summary refs log tree commit diff
path: root/xutil.c
Commit message (Collapse)AuthorAgeFilesLines
* cvsimportokan2015-08-281-8/+37
|\ | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | * refs/heads/master: (21 commits) Lost fix from r1.112; add comment. Mechanical change: group->gc Add consistent checks against NULL. Move client cycle grab/ungrab into a more relevant place; while here, update comments about why we need to grab/ungrab the keyboard. Re-add lost chunk in group_cycle from r1.113. Further simplify _NET_WM_DESKTOP handling using new group_assign(). oops; remove left over debug print Allowing sending a valid 'nogroup' (0) group_ctx to group_assign() (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 _NET_WM_DESKTOP from the config-based auto-grouping; no (intentional) behavior changes. Needed for further work in cleaning up this area. Implement _NET_CLIENT_LIST_STACKING (from Thomas Admin), but bottom-to-top order, as per spec (notified Thomas as well). Don't allow freeze operations on fullscreen (consistent with what fullscreen does). Sort _NET_WM_STATE Atoms like the spec. Move CLIENT_STICKY logic from client hide/unhide to group hide/unhide; rationale being that clients should be able to hide/unhide independently of group switching. Add Xkb modifier to ignore mask; from Alexander Polakov. Fix whitespace. Add client freeze extension to _NET_WM_STATE Atom, allowing flag to persist. As usual with new Atoms, requires X restart. _NET_WM_STATE_STICKY implies only sticky at the group/desktop level, not position and size; based on discussion with a few. Instead of special casing the 'term' and 'lock' commands, go back to keeping them hidden; showing them has apparently caused confusion/angst. Leave command list order from .cwmrc alone; remove sort. Bring group and client cycle closer together. ...
| * Mechanical change: group->gcokan2015-08-271-2/+2
| |
| * Implement _NET_CLIENT_LIST_STACKING (from Thomas Admin), butokan2015-08-241-0/+21
| | | | | | | | bottom-to-top order, as per spec (notified Thomas as well).
| * Sort _NET_WM_STATE Atoms like the spec.okan2015-08-241-15/+15
| |
| * Add client freeze extension to _NET_WM_STATE Atom, allowing flag tookan2015-08-211-1/+9
| | | | | | | | persist. As usual with new Atoms, requires X restart.
* | cvsimportokan2015-03-291-4/+5
|\|
| * Introduce a xreallocarray and convert a few xcalloc instances that dookan2015-03-281-4/+4
| | | | | | | | not require zero'ing.
| * plug a leakokan2015-03-281-0/+1
| |
* | cvsimportChristian Neukirchen2015-01-221-1/+2
|\|
| * Switch to limits.h; replace MAXPATHLEN and MAXHOSTNAMELEN with PATH_MAXokan2015-01-191-1/+2
| | | | | | | | | | | | and HOST_NAME_MAX+1, respectively. ok doug@
* | cvsimportokan2014-09-271-2/+4
|\|
| * Update _NET_CURRENT_DESKTOP with the screen's group_active->num.okan2014-09-231-2/+4
| |
* | cvsimportokan2014-09-181-22/+30
|\|
| * these client actions are just toggles; less confusing with better namesokan2014-09-171-10/+10
| |
| * Implement EWMH _NET_WM_STATE_HIDDEN.okan2014-09-171-2/+10
| |
| * use similiar style for client flagsokan2014-09-151-1/+1
| |
| * Remove duplicate client queue (mruq); instead, remove and take theokan2014-09-081-2/+2
| | | | | | | | | | | | global Clientq and place it inside screen_ctx since every client belongs to a screen, then use the same per screen clientq to track stacking order (the sole reason for mruq).
| * more style nitsokan2014-09-071-9/+9
| |
* | cvsimportChristian Neukirchen2014-09-071-4/+59
|\|
| * Rework group names: stash the group name inside the group_ctx as opposedokan2014-09-061-8/+36
| | | | | | | | | | | | 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.
| * Since the flatting out of sc->group_names is only for settingokan2014-08-251-2/+18
| | | | | | | | | | 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/+8
| | | | | | | | | | | | | | 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.
| * Fix nogroup regression, where nogroup became an actual group - theokan2014-08-221-1/+4
| | | | | | | | | | | | | | | | | | | | 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-2/+2
| |
* | cvsimportokan2014-02-271-1/+1
|\|
| * Alignment fix; found the hard way on sparc64 by landry@ (and thanks toookan2014-02-271-1/+1
| | | | | | | | | | | | for fast access to a box!) ok deraadt@, matthieu@
* | cvsimportokan2014-02-081-5/+1
|\|
| * all mapped clients now should have a group, so simplify some casesokan2014-02-071-5/+1
| |
* | cvsimportokan2014-01-031-14/+14
|\|
| * use consistent typesokan2014-01-031-14/+14
| |
* | cvsimportokan2013-12-171-1/+1
|\|
| * replace with memsetokan2013-12-171-1/+1
| |
* | cvsimportokan2013-12-161-4/+14
|\|
| * Implement support for EWMH's _NET_WM_STATE_FULLSCREEN hint.okan2013-12-161-4/+14
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Since we already have a form of 'maximize', we need to differentiate between 'maximize' and the new 'fullscreen' mode. The 'maximize' mode will continue to honor gap but now *retains* the border, matching the 'vert/horz maximize' behaviour. The new 'fullscreen' mode supports and follows the _NET_WM_STATE_FULLSCREEN hint, allowing the client perform additional window modifications; in this mode, cwm(1) will *ignore* gap, remove borders and freeze(move/resize) the client. Additionally, 'fullscreen' mode will remember various combinations of previous states. * default keybinding changes: CM-f 'fullscreen', CM-m 'maximize' (re-map as desired). Positive feedback from a few, testing and ok sthen@
* | cvsimportokan2013-12-131-1/+9
|\|
| * Add support for XUrgency and matching _NET_WM_STATE_DEMANDS_ATTENTIONokan2013-12-131-1/+9
| | | | | | | | | | | | | | ewmh hint; urgencyborder is configurable. The urgency flag will stick, even while on a client in a non-viewable group, until the client receives focus (where the border is reset). Initial diff from Thomas Adam with some changes/enhancements from me.
* | cvsimportokan2013-12-111-27/+0
|\|
| * Remove extra work and simplify client state handling.okan2013-12-111-27/+0
| |
* | cvsimportokan2013-10-251-36/+39
|\|
| * shuffleokan2013-10-201-37/+37
| |
| * wrap key ungrab like btn ungrab, for it'll be used againokan2013-10-201-0/+6
| |
| * Using xu_btn_ungrab() buttons during client_leave doesn't work (errorokan2013-10-191-5/+2
| | | | | | | | | | | | | | BadValue) when the modifier is already AnyModifier . Instead alter xu_btn_ungrab() to ungrab AnyButton/AnyModifier and call it only when a client is coming into focus in client_setactive(), instead of iterating over ignore mods - matches how we handle key grabs.
* | cvsimportokan2013-10-071-3/+3
|\|
| * unify type; no changeokan2013-10-031-3/+3
| |
* | cvsimportokan2013-07-161-79/+31
|\|
| * we no longer need to construct an array for _NET_SUPPORTED.okan2013-07-161-7/+1
| |
| * collapse linesokan2013-07-151-2/+1
| |
| * simplify atom handling; allows us to limit to one round-trip to serverokan2013-07-151-72/+31
| | | | | | | | for gathering Atoms.
* | cvsimportokan2013-07-101-4/+4
|\|
| * type fixesokan2013-07-101-1/+1
| |