aboutsummaryrefslogtreecommitdiffstats
Commit message (Collapse)AuthorAgeLines
...
* Refactor callbacks to take a void * so as to not try and generalize intookan2016-10-18-514/+517
| | | | | | | | 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.
* remove another unused protookan2016-10-12-2/+1
|
* Rename 2 kbfunc to match closer to what they dookan2016-10-06-11/+11
|
* Add an argument to the callbacks to pass the xevent context, button orokan2016-10-06-92/+87
| | | | | | | key press. This allows to remove a few hacks to duplicate functions only for behaviour changes; now differing behaviours are pushed down to the callback. Also will allow for previously unavailable actions to be bind-able down the road.
* 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.
* More accurate to say 'toggle', rather than 'select', for group[n]/nogroup.okan2016-10-05-7/+7
|
* Add CM-a for 'nogroup' (CM-0 stays for now); update manpage to reflect.okan2016-10-05-4/+5
|
* Stash wmname into conf.okan2016-10-05-6/+8
|
* When removing xrandr regions, ensure clients are within the bounds ofokan2016-10-04-3/+28
| | | | | | the screen; adapted from an ancient diff from Sviatoslav Chagaev. Things in this area will likely change, but put this in so it works now and serves as a reminder.
* Calculate client nameqlen in client_setname(), the only place it'sokan2016-10-04-11/+12
| | | | needed/used.
* Turn CALMWM_NGROUPS define into variable, ngroups.okan2016-10-04-23/+25
|
* Start simplifying menu code; and in turn, remove a cursor no longerokan2016-10-03-30/+25
| | | | needed.
* Defaults are split between defines and conf_init(); normalize these, asokan2016-10-03-24/+17
| | | | well as give 'sticky' groups its own variable.
* For both kb and mouse move, it is possible to grab a client and move itokan2016-10-03-7/+29
| | | | | completely off the screen/region; instead, if the pointer is outside of the client bounds, warp the pointer to the closest edge before moving.
* client_ptrwarp should not deal with unhiding or raising clients (non ptrokan2016-10-03-8/+10
| | | | | 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.
* remove unused protookan2016-09-30-2/+1
|
* 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.
* Use instinsic X11 functions for key/btn/ptr grab/ungrab/regrab requests;okan2016-09-30-90/+50
| | | | | the one line wrappers provided no value and limited altering calls where needed; additionally, most of them had but one caller.
* Replace mousefunc_sweep_draw() with a generic menu_windraw() using vaokan2016-09-30-29/+43
| | | | | | | lists; use it appropriately for both window dimension and position in the respective mousefunc calls. ok bryent@
* Switch to XWindowEvent() pulling out events that match the mask *and*okan2016-09-30-3/+3
| | | | window.
* no need to unmap menu window againokan2016-09-29-3/+2
|
* Mechanical change: move screen menu bits to their own struct.okan2016-09-29-35/+37
|
* Inline Xft draw and extents wrappers; too much abstraction.okan2016-09-28-36/+35
|
* Do not call sweep_draw() too early: don't yet have w/h dimensions; plusokan2016-09-28-2/+1
| | | | | we will get a MotionNotify event right away anyway, setting required parameters.
* Continue merging kb and mouse functions: foldokan2016-09-22-95/+32
| | | | | | mousefunc_menu_{client,cmd,group} into the respective kbfunc_menu_{client,cmd,group} functions; simply pass a flag down from config denoting mouse action behaviour.
* Allow ctrl-[ for abort (esc); from Benjamin Scher Purcellokan2016-09-20-1/+4
|
* de-static client_inbound()okan2016-09-20-4/+4
|
* remove debug that accidentally snuck inokan2016-09-20-2/+2
|
* Get rid of curcc, instead cycle through the queue; removes the need forokan2016-09-20-23/+15
| | | | client_none().
* During init, query screen for _NET_ACTIVE_WINDOW and set that client asokan2016-09-16-14/+32
| | | | | | | | 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-14/+17
| | | | instead of relying on curcc.
* init labelokan2016-09-13-1/+2
|
* Limit mouse resize to hints within the client; matches kbd resizeokan2016-09-13-8/+3
| | | | behaviour.
* Switch to just malloc since we need initialize most everything anyway.okan2016-09-12-6/+8
|
* change 'sticky' to 'stick' to toggle client stickiness (seems theokan2016-09-12-6/+6
| | | | | default binding worked for everyone for a long time!); conflict with group sticky found by Ali Farzanrad - thanks!
* Simplify group_holds_only_hidden(); from Vadim Vygonets.okan2016-09-02-11/+4
|
* 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.
* Enable the use of numpad Enter key on menus; from Henrique N. Lengler.okan2016-08-28-1/+2
| | | | ok beck phessler
* add a column to previous commit for consitency.matthieu2016-08-13-2/+2
|
* conf_screen: report the fontname that can't be opened in case of failure.matthieu2016-08-13-2/+2
| | | | ok dcoppa@
* If supplied format to menuq_add() is NULL, fill text with an emptyokan2016-04-28-2/+5
| | | | string; found by Christian Neukirchen.
* Fix a typo from r1.201; fixes window_grouptoggle binding.okan2015-11-17-2/+2
|
* If a client does not set increment values, use 'moveamount' as a way tookan2015-11-17-8/+10
| | | | | | scale keyboard based resizes; extend kbfunc_amount(). Behaviour noted by, tested by, and ok sthen@
* Inline the only use of mousefunc_sweep_calc.okan2015-11-17-17/+8
|
* more client vs screen context differencesokan2015-11-12-36/+34
|
* If a client sets hints, honor them for kb resize requests, just like weokan2015-11-12-6/+8
| | | | | | do for mouse based resize requests. Based on a patch from Vadim Vygonets.
* Move kb pointer movement out of the kbfunc_client_moveresize since it'sokan2015-11-12-137/+153
| | | | | | | | 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.