summary refs log tree commit diff
path: root/group.c
Commit message (Collapse)AuthorAgeFilesLines
* Add group-last command that shows only the previously active group; ok okanop2022-01-271-0/+3
|
* Unrelated style fixes, consistency changes and sorting, appropriateokan2020-02-271-24/+22
| | | | | dosage/removal of wrappers, simplification of name queue, client cycle joins other kb/mb bound functions.
* zip extra linesokan2019-03-071-5/+1
|
* gc clientq inside groups, instead use the better maintained one per-screenokan2019-03-071-19/+28
|
* shuffle deck chairs: rename group actions to match intent for clarityokan2019-03-071-17/+17
|
* Tie group number and name together during config.okan2019-03-011-7/+2
|
* Move the group index (desktop number) check to the only 2 callers that requireokan2019-02-281-12/+0
| | | | checking due to ewmh.
* Ensure we don't action on the last group when the requested one is not found.okan2019-02-281-19/+17
|
* Selectively hide and show clients based on state; merge client_unhide() andokan2019-02-281-3/+5
| | | | client_show().
* Add 'group-close-[n]' action to close all windows within specified group.okan2019-02-251-0/+17
| | | | heavily based on a diff from Nam Nguyen.
* If the requested group number is invalid, bail but don't kill cwm.okan2018-01-231-3/+3
|
* Merge group_toggle_membership_leave into the buttonrelease event and only dookan2017-12-291-8/+1
| | | | border work for a group/ungroup action.
* Fix group hidden state when a client wants to be on all desktops on start;okan2017-02-101-1/+1
| | | | reported by Vadim Vygonets with diff, but another approach was taken.
* Sprinkle __func__ in appropriate error messages.okan2016-10-241-3/+3
|
* Refactor callbacks to take a void * so as to not try and generalize intookan2016-10-181-11/+11
| | | | | | | | client_ctx in keypress and buttonpress event handlers; pass appropriate *ctx's based on context. While here, limit some globals, replace defines with appropriate variables and fix some naming.
* Turn CALMWM_NGROUPS define into variable, ngroups.okan2016-10-041-4/+4
|
* Simplify group_holds_only_hidden(); from Vadim Vygonets.okan2016-09-021-10/+3
|
* Start cleaning up name vs function differences; replace magic numbers.okan2015-11-101-1/+1
|
* Mechanical change: group->gcokan2015-08-271-6/+6
|
* Re-add lost chunk in group_cycle from r1.113.okan2015-08-271-0/+3
|
* Further simplify _NET_WM_DESKTOP handling using new group_assign().okan2015-08-251-6/+3
|
* oops; remove left over debug printokan2015-08-251-2/+0
|
* Allowing sending a valid 'nogroup' (0) group_ctx to group_assign()okan2015-08-251-5/+6
| | | | | | (since we init all groups), though assigning the client's group to NULL for 'sticky'; use this simplification in a few places (others to follow).
* Split out sticky mode checks and the restoring of a client's group andokan2015-08-251-32/+45
| | | | | _NET_WM_DESKTOP from the config-based auto-grouping; no (intentional) behavior changes. Needed for further work in cleaning up this area.
* Move CLIENT_STICKY logic from client hide/unhide to group hide/unhide;okan2015-08-231-4/+8
| | | | | rationale being that clients should be able to hide/unhide independently of group switching.
* Bring group and client cycle closer together.okan2015-08-211-20/+34
|
* replace assert usageokan2015-06-281-3/+2
|
* Introduce a xreallocarray and convert a few xcalloc instances that dookan2015-03-281-1/+1
| | | | not require zero'ing.
* Switch to limits.h; replace MAXPATHLEN and MAXHOSTNAMELEN with PATH_MAXokan2015-01-191-1/+2
| | | | | | and HOST_NAME_MAX+1, respectively. ok doug@
* make group_init work like other *_init'sokan2014-10-081-14/+13
|
* these have nothing to do with 'sticky', but rather group membership; rename.okan2014-09-271-5/+2
|
* Pass just the group to group_setactive instead of the screen and anokan2014-09-271-12/+8
| | | | index which then needed to be found in a queue.
* Update _NET_CURRENT_DESKTOP with the screen's group_active->num.okan2014-09-231-3/+3
|
* Move stuff that doesn't belong in group_init; while here, explicitlyokan2014-09-231-11/+2
| | | | initialize hideall and cycling.
* Use a similarly named check as sticky for hidden check in a group.okan2014-09-171-9/+5
|
* Introduce a check to see if a group holds only 'sticky' clients and useokan2014-09-171-1/+14
| | | | | | | | this check to decide if a group is virtually empty. Rationale: if a group contains *only* 'sticky' clients, it should be skipped while cycling through groups. Apply similar logic to the group menu. Based on an idea from phessler@, who also tested another version.
* name the group client queue appropriately, like other queuesokan2014-09-081-10/+10
|
* Now that a group knows its screen, only pass down the group_ctx.okan2014-09-081-16/+16
|
* Add screen_ctx to group_ctx, and populate on init.okan2014-09-071-0/+1
|
* Get rid of a redundant array of groups per screen; we already have aokan2014-09-071-8/+22
| | | | link to the group queue for each screen.
* Rework group names: stash the group name inside the group_ctx as opposedokan2014-09-061-52/+2
| | | | | | to having to manage an array outside in screen_ctx for group names and shortcuts. Simplifies (and moves bits for) reading, and constructing data for, EWMH's _NET_DESKTOP_NAMES.
* Merge group_menu into mousefunc_menu_group.okan2014-09-011-36/+3
|
* Since the flatting out of sc->group_names is only for settingokan2014-08-251-24/+2
| | | | | NET_DESKTOP_NAMES, merge the helper into xu_ewmh_net_desktop_names, where we actually set the property.
* Implement _NET_WM_STATE_STICKY, bound to CM-s by default; allows anyokan2014-08-251-0/+2
| | | | | | | 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.
* gc->hidden has never consistently kept track of a group's state;okan2014-08-241-29/+18
| | | | | | | | | | 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.
* Fix nogroup regression, where nogroup became an actual group - theokan2014-08-221-12/+11
| | | | | | | | | | 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.
* Purely mechanical; unify 'num', 'no' and 'shortcut'.okan2014-08-201-19/+19
|
* Split off group window restacking.okan2014-08-201-4/+15
|
* fix a misleading comment and function nameokan2014-08-201-5/+5
|
* Pull highstack from group_ctx (and useless calculations of); in the oneokan2014-08-191-16/+9
| | | | | place that we use highstack, replace that usage with a local variable (for now until stacking is done properly).