aboutsummaryrefslogtreecommitdiffstats
path: root/group.c (unfollow)
Commit message (Collapse)AuthorLines
2014-08-22Fix nogroup regression, where nogroup became an actual group - theokan-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-20Purely mechanical; unify 'num', 'no' and 'shortcut'.okan-20/+20
2014-08-20Split off group window restacking.okan-5/+16
2014-08-20fix a misleading comment and function nameokan-6/+6
2014-08-19Pull highstack from group_ctx (and useless calculations of); in the oneokan-17/+10
place that we use highstack, replace that usage with a local variable (for now until stacking is done properly).
2014-08-18Get rid of nhidden in group_ctx; it actually never reported correctlyokan-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-08Make sure we cycle through existing client's group membership and setokan-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-08Replace a few hand rolled loops with like tailq loops.okan-17/+13
2014-02-07If _NET_WM_DESKTOP is set to -1 during client creation, place the client intookan-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-24correct arguments and drop the cast.okan-2/+2
sanity check by oga@nicotinebsd
2014-01-20Add a function that adds an entry to a menuq, normalizing a common codeokan-10/+3
path; from Tiago Cunha.
2013-12-11Stash Class and WM Hints in client_ctxokan-4/+4
2013-10-17a few err->errx since we don't have error messages here; from Tiago Cunhaokan-4/+4
2013-10-03unify type; no changeokan-2/+2
2013-07-15simplify atom handling; allows us to limit to one round-trip to serverokan-4/+4
for gathering Atoms.
2013-07-09since the root and event window are the same in the case of a buttonokan-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-08replace a few (x)malloc with (x)calloc to prevent potential integerokan-3/+3
overflows; from Tiago Cunha
2013-05-06remove group in client_delete directly.okan-12/+1
2013-04-30type fixokan-3/+2
2013-04-17add conf_ignore and move group_make_autogroup to conf_autogroup to match.okan-22/+1
2013-04-08reverse logic to make it like the othersokan-9/+5
2013-04-08consistencyokan-1/+2
2013-04-05zap stray whitespaceokan-2/+2
2013-01-13put back r1.68 which allows an empty group to be sticky; behaviorokan-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-10set the initial group to '1', missed by recent off-by-one groupokan-2/+2
numbering re-work; discovered the hard way by sthen@. ok sthen@
2013-01-01after we toggle a group hidden, it makes no sense to set it as activeokan-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-01make num of groups no longer off-by-one; from Alexander Polakovokan-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-17replace client highlight with a client flagokan-7/+5
2012-12-17create and use menuq_clear() helper; from Tiago Cunhaokan-5/+2
2012-11-29specific last match for autogroup; few iterations with Kent Spillner.okan-7/+9
2012-11-09sortokan-2/+2
2012-11-08fix some warnings; inspired by a diff from Thordur Bjornsson.okan-3/+3
2012-11-07get rid of the xfree() wrapper around free(); from Tiago Cunha.okan-4/+4
2012-09-09replace with xu_getprop wrapper used everywhere else.okan-13/+7
2012-07-08remove a redundant assignment and another one up.okan-3/+2
2012-07-03re-implement atom handing; makes for a normalized and more consistentokan-39/+18
separation between cwm and ewmh. seen by a few.
2012-05-16get rid of more stray lines/spacesokan-3/+3
2012-05-16fix commentokan-3/+4
2011-12-29check if we're in the group already, else multiple calls tookan-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-12use xfree instead of free since strings is allocated with xmalloc; fromokan-2/+2
dhill ok oga@
2011-09-19move client to group (movetogroup) and hide client only if group isokan-2/+6
already hidden (suggested behavior from Alexander Polakov). ok sthen oga
2011-09-13repair groupcycle (broke after cycle-in-group support added more flags);okan-6/+6
found by and fix from Thomas Pfaff. ok oga@
2011-07-25We are inconsistent when it comes to function returns, so just go allokan-4/+4
the way with the cwm specific parts. ok oga@
2011-05-11tag and comment cleanup; ok oga@okan-1/+1
2011-02-13we 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-25spacing nitsokan-1/+2
2010-09-25more clear variable name so than name/class shouldn't be confused again.okan-5/+5
ok oga@
2010-07-30revert -r1.45 of group.c (log was: fix window name and class to matchokan-3/+4
cwmrc(5)). instead, fix cwmrc(5) to match the old behavior which also happens to match the example config, of which many have based their configs; this also nicely matches the output of xprop(1). clean-up of variable names as a separate commit. suggested by sthen (and something we should have done initially). discussed with and ok oga@
2010-06-28fix window name and class to match cwmrc(5); from Holger Mikolon - thanks!okan-4/+3
ok oga@
2010-04-11clean up a few xu_* functions to just accept what they need (Window).okan-2/+2
ok oga@