summary refs log tree commit diff
path: root/client.c
Commit message (Collapse)AuthorAgeFilesLines
* cvsimportChristian Neukirchen2015-01-241-6/+5
|\
| * First restore net_wm_state(ewmh), then wm_state(iccc); prevents clientsokan2015-01-231-6/+5
| | | | | | | | | | | | | | | | from re-hiding on restart due to flag toggling (note that this is ripe for re-vamping). Behavior only observed on restarts. Problem found by, and initial patch from, Henri Kemppainen (thanks!), though ever so slightly different one applied.
* | 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-1/+1
|\|
| * these have nothing to do with 'sticky', but rather group membership; rename.okan2014-09-271-1/+1
| |
* | cvsimportokan2014-09-181-66/+78
|\|
| * these client actions are just toggles; less confusing with better namesokan2014-09-171-7/+7
| |
| * ewmh states _NET_WM_STATE_STICKY should not alter positionokan2014-09-171-3/+3
| |
| * don't toggle _WM_STATE_HIDDEN here yetokan2014-09-171-2/+2
| |
| * Implement EWMH _NET_WM_STATE_HIDDEN.okan2014-09-171-2/+13
| |
| * use similiar style for client flagsokan2014-09-151-4/+4
| |
| * fold in 'active' into 'flags'okan2014-09-101-5/+5
| |
| * move the check for an empty queue up during cycleokan2014-09-081-3/+1
| |
| * name the group client queue appropriately, like other queuesokan2014-09-081-5/+5
| |
| * more style nits and wrappingokan2014-09-081-4/+6
| |
| * since mruq has been folded in, rename mru-named functionsokan2014-09-081-6/+6
| |
| * Remove duplicate client queue (mruq); instead, remove and take theokan2014-09-081-16/+17
| | | | | | | | | | | | 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-17/+17
| |
| * screen_fromroot -> screen_findokan2014-09-071-1/+1
| |
* | cvsimportChristian Neukirchen2014-09-071-1/+18
|\|
| * Implement _NET_WM_STATE_STICKY, bound to CM-s by default; allows anyokan2014-08-251-0/+17
| | | | | | | | | | | | | | 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.
| * Purely mechanical; unify 'num', 'no' and 'shortcut'.okan2014-08-201-1/+1
| |
* | cvsimportokan2014-02-081-1/+2
|\|
| * Some clients set the urgency flag even if they are the active client;okan2014-02-061-1/+2
| | | | | | | | | | prevent annoying behavior by only setting the cwm urgency flag if the client is not active; diff from Thomas Adam.
* | cvsimportokan2014-02-031-2/+10
|\|
| * Move redundant bits from screen_init (while dealing with existingokan2014-02-031-2/+10
| | | | | | | | | | | | clients) directly into client_init, performing the X roundtrip only once. With the previous change in maprequest, this moves decision making into one place for creating new clients.
* | cvsimportokan2014-02-021-1/+4
|\|
| * Move redundant window attr fetch from maprequest directly intookan2014-02-021-1/+4
| | | | | | | | client_init and perform that X roundtrip only once.
* | cvsimportokan2014-01-281-1/+0
|\|
| * move some init up and shed some blank linesokan2014-01-271-1/+0
| |
* | cvsimportokan2014-01-031-5/+8
|\|
| * state is longokan2014-01-031-1/+1
| |
| * rename for clarityokan2014-01-021-4/+4
| |
| * When a client doesn't specify size hints, nothing prevents a resize tookan2014-01-021-0/+3
| | | | | | | | | | | | | | 0x0 - don't allow this situation during mouse resize (check already in place for kbd resize). Reported by brynet@
* | cvsimportokan2013-12-171-2/+2
|\|
| * replace with memsetokan2013-12-171-2/+2
| |
* | cvsimportokan2013-12-161-23/+37
|\|
| * Implement support for EWMH's _NET_WM_STATE_FULLSCREEN hint.okan2013-12-161-23/+37
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 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-6/+6
|\|
| * Teach screen_find_xinerama() to apply gap only when told to do so;okan2013-12-131-6/+6
| | | | | | | | adjust callers. Needed for an upcoming feature.
* | cvsimportokan2013-12-131-0/+15
|\|
| * we need the save-set when re-exec'ing so as to not lose State on our hidden ↵okan2013-12-131-0/+15
| | | | | | | | clients
* | cvsimportChristian Neukirchen2013-12-131-4/+7
|\|
| * ICCCM explicitly states that server time (CurrentTime) should *not* beokan2013-12-121-4/+7
| | | | | | | | | | | | | | | | | | | | | | used for focus events, but rather the timestamp of the generated event. Track the last event timestamp and send it down for a WM_TAKE_FOCUS ClientMessage. I suspect we should do this for clients that don't announce this Atom as well, though the raciness gets us into a bind. Solves focus order issue since WM_TAKE_FOCUS; fix verified by sthen@ ok sthen@
* | cvsimportokan2013-12-111-41/+59
|\|
| * we don't need to manage the save-set since we're not reparenting; left-over ↵okan2013-12-111-2/+0
| | | | | | | | from pwin
| * since we are drawing in unhide, no need to during client setupokan2013-12-111-1/+0
| |
| * apply mwm hints laterokan2013-12-111-3/+3
| |
| * Add client wrapper for XWMHints to support XA_WM_HINTS in PropertyNotifyokan2013-12-111-7/+11
| | | | | | | | events; based off a diff from Thomas Adam.