aboutsummaryrefslogtreecommitdiffstats
path: root/client.c (follow)
Commit message (Collapse)AuthorAgeLines
* stray newlinesokan2016-12-06-2/+1
|
* Set dim.{x,y} during client_init and update on resize, instead ofokan2016-12-06-4/+5
| | | | (re)calculating only when applying hints.
* Refactor callbacks to take a void * so as to not try and generalize intookan2016-10-18-7/+7
| | | | | | | | 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.
* Check the ptr bounds in the new client during cycling, since not allokan2016-10-06-1/+5
| | | | | actions do ptrsave, such as restoring client geometry; adapted from a diff by Vadim Vygonets.
* Calculate client nameqlen in client_setname(), the only place it'sokan2016-10-04-7/+8
| | | | needed/used.
* Defaults are split between defines and conf_init(); normalize these, asokan2016-10-03-2/+2
| | | | well as give 'sticky' groups its own variable.
* client_ptrwarp should not deal with unhiding or raising clients (non ptrokan2016-10-03-6/+2
| | | | | requests); most callers do this already - deal with the few that do not. client_ptrwarp becomes a simple wrapper (setpos) but it will be expanded.
* Set the initial ptr position during client init, instead of waitingokan2016-09-30-13/+8
| | | | | until (maybe) a ptrwarp call. Likewise, explicitly ensure an inbounds ptr position (same as initial) when saving.
* de-static client_inbound()okan2016-09-20-3/+2
|
* Get rid of curcc, instead cycle through the queue; removes the need forokan2016-09-20-21/+13
| | | | client_none().
* During init, query screen for _NET_ACTIVE_WINDOW and set that client asokan2016-09-16-6/+6
| | | | | | | | active; while we already look at what's under the pointer, use this information first, then look under the pointer (saving that round-trip). This restores the active state to a client after restart even if the pointer is not above it (and of course the pointer is not above another client).
* Some clients fail to setup hints at all, so initalize for them; falloutokan2016-09-14-1/+2
| | | | | | from r1.218 switching to malloc - clearly missed this case. found the hard way by brynet@
* Fix-up a few simple uses of client_current(): check CLIENT_ACTIVE flagokan2016-09-14-7/+7
| | | | instead of relying on curcc.
* init labelokan2016-09-13-1/+2
|
* Switch to just malloc since we need initialize most everything anyway.okan2016-09-12-6/+8
|
* Simplify toggling flags; from Vadim Vygonets.okan2016-09-02-16/+4
|
* Do not draw borders on ignored clients when returning from fullscreen;okan2016-09-01-2/+3
| | | | from Vadim Vygonets.
* Remove redundant minimum client size adjustment (minw and minh areokan2016-09-01-4/+1
| | | | always positive since r1.214); from Vadim Vygonets.
* If a client sets hints, honor them for kb resize requests, just like weokan2015-11-12-1/+3
| | | | | | 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-11-49/+47
| | | | | | 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-10-4/+4
|
* Extend region to include both view and work areas; switch tookan2015-11-09-47/+49
| | | | | | | 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.
* Only when mapping clients from an initial wm start or restart, query theokan2015-09-23-1/+11
| | | | | | | 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.
* Mechanical change: group->gcokan2015-08-27-8/+8
|
* Add consistent checks against NULL.okan2015-08-27-5/+6
|
* Move client cycle grab/ungrab into a more relevant place; while here,okan2015-08-27-1/+5
| | | | 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-25-4/+12
| | | | | _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-24-1/+3
| | | | bottom-to-top order, as per spec (notified Thomas as well).
* Don't allow freeze operations on fullscreen (consistent with whatokan2015-08-24-1/+4
| | | | fullscreen does).
* Move CLIENT_STICKY logic from client hide/unhide to group hide/unhide;okan2015-08-23-7/+1
| | | | | rationale being that clients should be able to hide/unhide independently of group switching.
* Fix whitespace.okan2015-08-21-3/+3
|
* Add client freeze extension to _NET_WM_STATE Atom, allowing flag tookan2015-08-21-1/+3
| | | | persist. As usual with new Atoms, requires X restart.
* _NET_WM_STATE_STICKY implies only sticky at the group/desktop level, notokan2015-08-21-4/+4
| | | | position and size; based on discussion with a few.
* Bring group and client cycle closer together.okan2015-08-21-12/+12
|
* styleokan2015-07-01-5/+5
|
* Re-implement XClientMessage handling so that we can feed screen_find andokan2015-06-30-2/+3
| | | | | | | | 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-28-16/+16
|
* replace assert usageokan2015-06-28-4/+3
|
* Mechanical change from xinerama to region backed areas.okan2015-06-26-58/+58
|
* stash window dimensionsokan2015-06-08-1/+4
|
* fill in mwm definesokan2015-05-20-3/+3
|
* plug a leakokan2015-03-29-1/+2
|
* First restore net_wm_state(ewmh), then wm_state(iccc); prevents clientsokan2015-01-23-7/+6
| | | | | | | | 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.
* Switch to limits.h; replace MAXPATHLEN and MAXHOSTNAMELEN with PATH_MAXokan2015-01-19-2/+3
| | | | | | and HOST_NAME_MAX+1, respectively. ok doug@
* these have nothing to do with 'sticky', but rather group membership; rename.okan2014-09-27-2/+2
|
* these client actions are just toggles; less confusing with better namesokan2014-09-17-8/+8
|
* ewmh states _NET_WM_STATE_STICKY should not alter positionokan2014-09-17-4/+4
|
* don't toggle _WM_STATE_HIDDEN here yetokan2014-09-17-3/+3
|
* Implement EWMH _NET_WM_STATE_HIDDEN.okan2014-09-17-3/+14
|
* use similiar style for client flagsokan2014-09-15-5/+5
|