Commit message (Collapse) | Author | Lines | ||
---|---|---|---|---|
2014-09-01 | Merge group_menu into mousefunc_menu_group. | okan | -37/+4 | |
2014-08-25 | Since the flatting out of sc->group_names is only for setting | okan | -25/+3 | |
NET_DESKTOP_NAMES, merge the helper into xu_ewmh_net_desktop_names, where we actually set the property. | ||||
2014-08-25 | Implement _NET_WM_STATE_STICKY, bound to CM-s by default; allows any | okan | -1/+3 | |
client to 'stick' to all desktops (ewmh speak) or groups - this currently has the same affect as setting a client's group to 'nogroup', with the exception that the client can also be in a group, so when un-sticking, the client will go back to its original group/desktop. | ||||
2014-08-24 | gc->hidden has never consistently kept track of a group's state; | okan | -30/+19 | |
group_show() and group_hide() are not the only ways a group can change state - if all clients in a group are either hidden or unhidden, then that group's state should change, as well as the various EWMH ways. Instead of trying to keep track in a wide variety of places, simply query the clients in a group before needing to take action based on the group's state. Solves long standing confusion of when a group is hidden or not. | ||||
2014-08-22 | Fix nogroup regression, where nogroup became an actual group - the | okan | -13/+12 | |
symantics between cwm groups and ewmh got in the way. Ensure a client that wants to be in nogroup stays in nogroup (thus stays in view), even when (re)reading NET_WM_DESKTOP. Paritially reverts patchset 644 (2014-02-07 13:09 PST) which deals with a NULL cc->group. All to be revisited when NET_WM_STATE_STICKY hits cwm. Reported by many; testing and ok phessler. | ||||
2014-08-20 | Purely mechanical; unify 'num', 'no' and 'shortcut'. | okan | -20/+20 | |
2014-08-20 | Split off group window restacking. | okan | -5/+16 | |
2014-08-20 | fix a misleading comment and function name | okan | -6/+6 | |
2014-08-19 | Pull highstack from group_ctx (and useless calculations of); in the one | okan | -17/+10 | |
place that we use highstack, replace that usage with a local variable (for now until stacking is done properly). | ||||
2014-08-18 | Get rid of nhidden in group_ctx; it actually never reported correctly | okan | -8/+6 | |
since nhidden wasn't incremented nor decremeted in all the right places, thus confusing matters. We don't need to carry a count around, so just use a local variable in the one place we need one to supply XRestackWindows(). | ||||
2014-02-08 | Make sure we cycle through existing client's group membership and set | okan | -1/+10 | |
the hidden state on the group; important to know group hidden state after a re-exec or restart of cwm (as easily seen in group menu). | ||||
2014-02-08 | Replace a few hand rolled loops with like tailq loops. | okan | -17/+13 | |
2014-02-07 | If _NET_WM_DESKTOP is set to -1 during client creation, place the client into | okan | -29/+13 | |
group 0 (nogroup); solves problem initially discovered by oga@nicotinebsd with tint2. A clientmessage *after* client creation already handles this case. Go further and assign every client to a group; in non-sticky mode, group 0 (nogroup) and sticky mode, the active group. In both cases, autogroup will override the group assignment. Removing a group from a client always places the client back into group 0 (nogroup). Autogroup can also assign a client to group 0 (nogroup) to keep a client always visible (unless of course one opts to hide all clients). | ||||
2014-01-24 | correct arguments and drop the cast. | okan | -2/+2 | |
sanity check by oga@nicotinebsd | ||||
2014-01-20 | Add a function that adds an entry to a menuq, normalizing a common code | okan | -10/+3 | |
path; from Tiago Cunha. | ||||
2013-12-11 | Stash Class and WM Hints in client_ctx | okan | -4/+4 | |
2013-10-17 | a few err->errx since we don't have error messages here; from Tiago Cunha | okan | -4/+4 | |
2013-10-03 | unify type; no change | okan | -2/+2 | |
2013-07-15 | simplify atom handling; allows us to limit to one round-trip to server | okan | -4/+4 | |
for gathering Atoms. | ||||
2013-07-09 | since the root and event window are the same in the case of a button | okan | -5/+2 | |
event on the screen's root window, there's no need to pass down the entire XButtonEvent event, at least to group_menu(), the only callback which takes an argument at this point; instead use the already populated screen. | ||||
2013-07-08 | replace a few (x)malloc with (x)calloc to prevent potential integer | okan | -3/+3 | |
overflows; from Tiago Cunha | ||||
2013-05-06 | remove group in client_delete directly. | okan | -12/+1 | |
2013-04-30 | type fix | okan | -3/+2 | |
2013-04-17 | add conf_ignore and move group_make_autogroup to conf_autogroup to match. | okan | -22/+1 | |
2013-04-08 | reverse logic to make it like the others | okan | -9/+5 | |
2013-04-08 | consistency | okan | -1/+2 | |
2013-04-05 | zap stray whitespace | okan | -2/+2 | |
2013-01-13 | put back r1.68 which allows an empty group to be sticky; behavior | okan | -2/+6 | |
change noticed by Thomas Pfaff and diagnosis why we need to group_setactive in this case by Alexander Polakov. replace XXX with a useful comment. | ||||
2013-01-10 | set the initial group to '1', missed by recent off-by-one group | okan | -2/+2 | |
numbering re-work; discovered the hard way by sthen@. ok sthen@ | ||||
2013-01-01 | after we toggle a group hidden, it makes no sense to set it as active | okan | -6/+2 | |
(in sticky or non-stick mode), regardless of existing clients assigned to that group; oga marked this bit XXX in -r1.34 for it didn't seem make sense then either. pulled from a diff from from Alexander Polakov. | ||||
2013-01-01 | make num of groups no longer off-by-one; from Alexander Polakov | okan | -6/+6 | |
note that a re-exec of cwm will not rewrite the group number atom of *existing* clients, so they will remain off-by-one until each client has its atom updated, or of course a restart of X. | ||||
2012-12-17 | replace client highlight with a client flag | okan | -7/+5 | |
2012-12-17 | create and use menuq_clear() helper; from Tiago Cunha | okan | -5/+2 | |
2012-11-29 | specific last match for autogroup; few iterations with Kent Spillner. | okan | -7/+9 | |
2012-11-09 | sort | okan | -2/+2 | |
2012-11-08 | fix some warnings; inspired by a diff from Thordur Bjornsson. | okan | -3/+3 | |
2012-11-07 | get rid of the xfree() wrapper around free(); from Tiago Cunha. | okan | -4/+4 | |
2012-09-09 | replace with xu_getprop wrapper used everywhere else. | okan | -13/+7 | |
2012-07-08 | remove a redundant assignment and another one up. | okan | -3/+2 | |
2012-07-03 | re-implement atom handing; makes for a normalized and more consistent | okan | -39/+18 | |
separation between cwm and ewmh. seen by a few. | ||||
2012-05-16 | get rid of more stray lines/spaces | okan | -3/+3 | |
2012-05-16 | fix comment | okan | -3/+4 | |
2011-12-29 | check if we're in the group already, else multiple calls to | okan | -2/+4 | |
group_movetogroup() on one client will still increment nhidden if the group is hidden. found the hard way by Thomas Jeunet and fix from Alexander Polakov - thanks to both! ok oga@ | ||||
2011-10-12 | use xfree instead of free since strings is allocated with xmalloc; from | okan | -2/+2 | |
dhill ok oga@ | ||||
2011-09-19 | move client to group (movetogroup) and hide client only if group is | okan | -2/+6 | |
already hidden (suggested behavior from Alexander Polakov). ok sthen oga | ||||
2011-09-13 | repair groupcycle (broke after cycle-in-group support added more flags); | okan | -6/+6 | |
found by and fix from Thomas Pfaff. ok oga@ | ||||
2011-07-25 | We are inconsistent when it comes to function returns, so just go all | okan | -4/+4 | |
the way with the cwm specific parts. ok oga@ | ||||
2011-05-11 | tag and comment cleanup; ok oga@ | okan | -1/+1 | |
2011-02-13 | we lose track of highstack somewhere, so recompute it before we need it. | tedu | -1/+6 | |
fixes a crash reported by christian neukirchen. ok okan | ||||
2010-09-25 | spacing nits | okan | -1/+2 | |