summary refs log tree commit diff
path: root/client.c
Commit message (Collapse)AuthorAgeFilesLines
* cvsimportokan2015-11-121-3/+5
|\ | | | | | | | | | | | | | | | | | | | | | | | | * refs/heads/master: more client vs screen context differences If a client sets hints, honor them for kb resize requests, just like we do for mouse based resize requests. Move kb pointer movement out of the kbfunc_client_moveresize since it's got nothing to do with clients, thus doing flags work causes lots of waste and almost useless jumpy pointer movements; while here, split out move and resize since they share almost no code, just like mouse client move/resize; factor out amount and factor. Still wonder why this is here, but it works now. pledge "stdio rpath proc exec" cwm before main event loop, after init/setup - mostly for menu building. Partial revert of replacing screen_area() with region_find(); until a fix for a regression is found; this bug has been around for a long time it seems, but this change exposed it. Likely need to track clients in to and out of regions. Use position on root to figure out region. Start cleaning up name vs function differences; replace magic numbers. Clean up unused defines. Extend region to include both view and work areas; switch to region_find() which no longer needs to recalculate gap each time a client (or menu) is created or altered. If no RandR, fall back to display dimensions while building regions instead of during execution.
| * If a client sets hints, honor them for kb resize requests, just like weokan2015-11-121-0/+2
| | | | | | | | | | | | do for mouse based resize requests. Based on a patch from Vadim Vygonets.
| * Partial revert of replacing screen_area() with region_find(); until aokan2015-11-111-48/+46
| | | | | | | | | | | | fix for a regression is found; this bug has been around for a long time it seems, but this change exposed it. Likely need to track clients in to and out of regions.
| * Start cleaning up name vs function differences; replace magic numbers.okan2015-11-101-3/+3
| |
| * Extend region to include both view and work areas; switch tookan2015-11-091-46/+48
| | | | | | | | | | | | | | region_find() which no longer needs to recalculate gap each time a client (or menu) is created or altered. If no RandR, fall back to display dimensions while building regions instead of during execution.
* | cvsimportokan2015-09-231-0/+10
|\| | | | | | | | | | | * refs/heads/master: Only when mapping clients from an initial wm start or restart, query the pointer and if it matches the child window, activate it; new clients will not need to make this roundtrip to the server. On execwm, we should properly release resources before exec'ing into a new window manager; so allow CWM_EXEC_WM to assign new wm to wm_argv and pass through cwm_status (now EXECWM) so that x_teardown() gets called before exec'ing the new window manager. Removes the need for a separate x_restart() now, using new wm_argv; and consolidates errno for execvp.
| * Only when mapping clients from an initial wm start or restart, query theokan2015-09-231-0/+10
| | | | | | | | | | | | | | pointer and if it matches the child window, activate it; new clients will not need to make this roundtrip to the server. Based on a patch from Preben Guldberg.
* | cvsimportokan2015-08-281-35/+49
|\| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | * 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-7/+7
| |
| * Add consistent checks against NULL.okan2015-08-271-4/+5
| |
| * Move client cycle grab/ungrab into a more relevant place; while here,okan2015-08-271-0/+4
| | | | | | | | update comments about why we need to grab/ungrab the keyboard.
| * Split out sticky mode checks and the restoring of a client's group andokan2015-08-251-3/+11
| | | | | | | | | | _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), butokan2015-08-241-0/+2
| | | | | | | | bottom-to-top order, as per spec (notified Thomas as well).
| * Don't allow freeze operations on fullscreen (consistent with whatokan2015-08-241-0/+3
| | | | | | | | fullscreen does).
| * Move CLIENT_STICKY logic from client hide/unhide to group hide/unhide;okan2015-08-231-6/+0
| | | | | | | | | | rationale being that clients should be able to hide/unhide independently of group switching.
| * Fix whitespace.okan2015-08-211-2/+2
| |
| * Add client freeze extension to _NET_WM_STATE Atom, allowing flag tookan2015-08-211-0/+2
| | | | | | | | persist. As usual with new Atoms, requires X restart.
| * _NET_WM_STATE_STICKY implies only sticky at the group/desktop level, notokan2015-08-211-3/+3
| | | | | | | | position and size; based on discussion with a few.
| * Bring group and client cycle closer together.okan2015-08-211-11/+11
| |
* | cvsimportokan2015-07-121-4/+4
|\|
| * styleokan2015-07-011-4/+4
| |
* | cvsimportChristian Neukirchen2015-07-011-76/+76
|\|
| * Re-implement XClientMessage handling so that we can feed screen_find andokan2015-06-301-1/+2
| | | | | | | | | | | | | | | | client_find valid resources as needed, relieving the need for screen_find to ungracefully handle invalid root windows. Removes a long standing XXX. Should theoretically allow XClientMessage handling on more than one X screen. Alter callers of screen_find to handle failures.
| * move client_find downokan2015-06-281-15/+15
| |
| * replace assert usageokan2015-06-281-3/+2
| |
| * Mechanical change from xinerama to region backed areas.okan2015-06-261-57/+57
| |
* | cvsimportokan2015-06-091-2/+5
|\|
| * stash window dimensionsokan2015-06-081-0/+3
| |
| * fill in mwm definesokan2015-05-201-2/+2
| |
* | cvsimportokan2015-03-291-0/+1
|\|
| * plug a leakokan2015-03-291-0/+1
| |
* | 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
| |