Commit message (Collapse) | Author | Age | Lines | |
---|---|---|---|---|
* | Add BSD compatibility functions and headers | Wynn Wolf Arbor | 2021-04-27 | -1/+1 |
| | | | | | | | | | Original file locations in the OpenBSD tree: - lib/libc/stdlib/reallocarray.c - lib/libc/stdlib/strtonum.c - lib/libc/string/strlcat.c - lib/libc/string/strlcpy.c - sys/sys/queue.h | |||
* | Unrelated style fixes, consistency changes and sorting, appropriate ↵ | okan | 2020-03-18 | -25/+23 |
| | | | | dosage/removal of wrappers, simplification of name queue, client cycle joins other kb/mb bound functions. | |||
* | zip extra lines | okan | 2019-03-07 | -6/+2 |
| | ||||
* | gc clientq inside groups, instead use the better maintained one per-screen | okan | 2019-03-07 | -20/+29 |
| | ||||
* | shuffle deck chairs: rename group actions to match intent for clarity | okan | 2019-03-07 | -18/+18 |
| | ||||
* | Tie group number and name together during config. | okan | 2019-03-01 | -8/+3 |
| | ||||
* | Move the group index (desktop number) check to the only 2 callers that require | okan | 2019-02-28 | -13/+1 |
| | | | | checking due to ewmh. | |||
* | Ensure we don't action on the last group when the requested one is not found. | okan | 2019-02-28 | -20/+18 |
| | ||||
* | Selectively hide and show clients based on state; merge client_unhide() and | okan | 2019-02-28 | -4/+6 |
| | | | | client_show(). | |||
* | Add 'group-close-[n]' action to close all windows within specified group. | okan | 2019-02-25 | -1/+18 |
| | | | | heavily based on a diff from Nam Nguyen. | |||
* | If the requested group number is invalid, bail but don't kill cwm. | okan | 2018-01-23 | -4/+4 |
| | ||||
* | Merge group_toggle_membership_leave into the buttonrelease event and only do | okan | 2017-12-29 | -9/+2 |
| | | | | border work for a group/ungroup action. | |||
* | Fix group hidden state when a client wants to be on all desktops on start; | okan | 2017-02-10 | -2/+2 |
| | | | | reported by Vadim Vygonets with diff, but another approach was taken. | |||
* | Sprinkle __func__ in appropriate error messages. | okan | 2016-10-24 | -4/+4 |
| | ||||
* | Refactor callbacks to take a void * so as to not try and generalize into | okan | 2016-10-18 | -12/+12 |
| | | | | | | | | 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. | okan | 2016-10-04 | -5/+5 |
| | ||||
* | Simplify group_holds_only_hidden(); from Vadim Vygonets. | okan | 2016-09-02 | -11/+4 |
| | ||||
* | Start cleaning up name vs function differences; replace magic numbers. | okan | 2015-11-10 | -2/+2 |
| | ||||
* | Mechanical change: group->gc | okan | 2015-08-27 | -7/+7 |
| | ||||
* | Re-add lost chunk in group_cycle from r1.113. | okan | 2015-08-27 | -1/+4 |
| | ||||
* | Further simplify _NET_WM_DESKTOP handling using new group_assign(). | okan | 2015-08-25 | -7/+4 |
| | ||||
* | oops; remove left over debug print | okan | 2015-08-25 | -3/+1 |
| | ||||
* | Allowing sending a valid 'nogroup' (0) group_ctx to group_assign() | okan | 2015-08-25 | -6/+7 |
| | | | | | | (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 and | okan | 2015-08-25 | -33/+46 |
| | | | | | _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; | okan | 2015-08-23 | -5/+9 |
| | | | | | rationale being that clients should be able to hide/unhide independently of group switching. | |||
* | Bring group and client cycle closer together. | okan | 2015-08-21 | -21/+35 |
| | ||||
* | replace assert usage | okan | 2015-06-28 | -4/+3 |
| | ||||
* | Introduce a xreallocarray and convert a few xcalloc instances that do | okan | 2015-03-28 | -2/+2 |
| | | | | not require zero'ing. | |||
* | Switch to limits.h; replace MAXPATHLEN and MAXHOSTNAMELEN with PATH_MAX | okan | 2015-01-19 | -2/+3 |
| | | | | | | and HOST_NAME_MAX+1, respectively. ok doug@ | |||
* | make group_init work like other *_init's | okan | 2014-10-08 | -15/+14 |
| | ||||
* | these have nothing to do with 'sticky', but rather group membership; rename. | okan | 2014-09-27 | -6/+3 |
| | ||||
* | Pass just the group to group_setactive instead of the screen and an | okan | 2014-09-27 | -13/+9 |
| | | | | index which then needed to be found in a queue. | |||
* | Update _NET_CURRENT_DESKTOP with the screen's group_active->num. | okan | 2014-09-23 | -4/+4 |
| | ||||
* | Move stuff that doesn't belong in group_init; while here, explicitly | okan | 2014-09-23 | -12/+3 |
| | | | | initialize hideall and cycling. | |||
* | Use a similarly named check as sticky for hidden check in a group. | okan | 2014-09-17 | -10/+6 |
| | ||||
* | Introduce a check to see if a group holds only 'sticky' clients and use | okan | 2014-09-17 | -2/+15 |
| | | | | | | | | 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 queues | okan | 2014-09-08 | -11/+11 |
| | ||||
* | Now that a group knows its screen, only pass down the group_ctx. | okan | 2014-09-08 | -17/+17 |
| | ||||
* | Add screen_ctx to group_ctx, and populate on init. | okan | 2014-09-07 | -1/+2 |
| | ||||
* | Get rid of a redundant array of groups per screen; we already have a | okan | 2014-09-07 | -9/+23 |
| | | | | link to the group queue for each screen. | |||
* | Rework group names: stash the group name inside the group_ctx as opposed | okan | 2014-09-06 | -53/+3 |
| | | | | | | 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. | okan | 2014-09-01 | -37/+4 |
| | ||||
* | Since the flatting out of sc->group_names is only for setting | okan | 2014-08-25 | -25/+3 |
| | | | | | 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 any | okan | 2014-08-25 | -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. | |||
* | gc->hidden has never consistently kept track of a group's state; | okan | 2014-08-24 | -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. | |||
* | Fix nogroup regression, where nogroup became an actual group - the | okan | 2014-08-22 | -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. | |||
* | Purely mechanical; unify 'num', 'no' and 'shortcut'. | okan | 2014-08-20 | -20/+20 |
| | ||||
* | Split off group window restacking. | okan | 2014-08-20 | -5/+16 |
| | ||||
* | fix a misleading comment and function name | okan | 2014-08-20 | -6/+6 |
| | ||||
* | Pull highstack from group_ctx (and useless calculations of); in the one | okan | 2014-08-19 | -17/+10 |
| | | | | | place that we use highstack, replace that usage with a local variable (for now until stacking is done properly). |