Commit message (Collapse) | Author | Age | Lines | |
---|---|---|---|---|
* | Refactor callbacks to take a void * so as to not try and generalize into | okan | 2016-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 proto | okan | 2016-10-12 | -2/+1 |
| | ||||
* | Rename 2 kbfunc to match closer to what they do | okan | 2016-10-06 | -11/+11 |
| | ||||
* | Add an argument to the callbacks to pass the xevent context, button or | okan | 2016-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 all | okan | 2016-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. | okan | 2016-10-05 | -7/+7 |
| | ||||
* | Add CM-a for 'nogroup' (CM-0 stays for now); update manpage to reflect. | okan | 2016-10-05 | -4/+5 |
| | ||||
* | Stash wmname into conf. | okan | 2016-10-05 | -6/+8 |
| | ||||
* | When removing xrandr regions, ensure clients are within the bounds of | okan | 2016-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's | okan | 2016-10-04 | -11/+12 |
| | | | | needed/used. | |||
* | Turn CALMWM_NGROUPS define into variable, ngroups. | okan | 2016-10-04 | -23/+25 |
| | ||||
* | Start simplifying menu code; and in turn, remove a cursor no longer | okan | 2016-10-03 | -30/+25 |
| | | | | needed. | |||
* | Defaults are split between defines and conf_init(); normalize these, as | okan | 2016-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 it | okan | 2016-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 ptr | okan | 2016-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 proto | okan | 2016-09-30 | -2/+1 |
| | ||||
* | Set the initial ptr position during client init, instead of waiting | okan | 2016-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; | okan | 2016-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 va | okan | 2016-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* | okan | 2016-09-30 | -3/+3 |
| | | | | window. | |||
* | no need to unmap menu window again | okan | 2016-09-29 | -3/+2 |
| | ||||
* | Mechanical change: move screen menu bits to their own struct. | okan | 2016-09-29 | -35/+37 |
| | ||||
* | Inline Xft draw and extents wrappers; too much abstraction. | okan | 2016-09-28 | -36/+35 |
| | ||||
* | Do not call sweep_draw() too early: don't yet have w/h dimensions; plus | okan | 2016-09-28 | -2/+1 |
| | | | | | we will get a MotionNotify event right away anyway, setting required parameters. | |||
* | Continue merging kb and mouse functions: fold | okan | 2016-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 Purcell | okan | 2016-09-20 | -1/+4 |
| | ||||
* | de-static client_inbound() | okan | 2016-09-20 | -4/+4 |
| | ||||
* | remove debug that accidentally snuck in | okan | 2016-09-20 | -2/+2 |
| | ||||
* | Get rid of curcc, instead cycle through the queue; removes the need for | okan | 2016-09-20 | -23/+15 |
| | | | | client_none(). | |||
* | During init, query screen for _NET_ACTIVE_WINDOW and set that client as | okan | 2016-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; fallout | okan | 2016-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 flag | okan | 2016-09-14 | -14/+17 |
| | | | | instead of relying on curcc. | |||
* | init label | okan | 2016-09-13 | -1/+2 |
| | ||||
* | Limit mouse resize to hints within the client; matches kbd resize | okan | 2016-09-13 | -8/+3 |
| | | | | behaviour. | |||
* | Switch to just malloc since we need initialize most everything anyway. | okan | 2016-09-12 | -6/+8 |
| | ||||
* | change 'sticky' to 'stick' to toggle client stickiness (seems the | okan | 2016-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. | okan | 2016-09-02 | -11/+4 |
| | ||||
* | Simplify toggling flags; from Vadim Vygonets. | okan | 2016-09-02 | -16/+4 |
| | ||||
* | Do not draw borders on ignored clients when returning from fullscreen; | okan | 2016-09-01 | -2/+3 |
| | | | | from Vadim Vygonets. | |||
* | Remove redundant minimum client size adjustment (minw and minh are | okan | 2016-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. | okan | 2016-08-28 | -1/+2 |
| | | | | ok beck phessler | |||
* | add a column to previous commit for consitency. | matthieu | 2016-08-13 | -2/+2 |
| | ||||
* | conf_screen: report the fontname that can't be opened in case of failure. | matthieu | 2016-08-13 | -2/+2 |
| | | | | ok dcoppa@ | |||
* | If supplied format to menuq_add() is NULL, fill text with an empty | okan | 2016-04-28 | -2/+5 |
| | | | | string; found by Christian Neukirchen. | |||
* | Fix a typo from r1.201; fixes window_grouptoggle binding. | okan | 2015-11-17 | -2/+2 |
| | ||||
* | If a client does not set increment values, use 'moveamount' as a way to | okan | 2015-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. | okan | 2015-11-17 | -17/+8 |
| | ||||
* | more client vs screen context differences | okan | 2015-11-12 | -36/+34 |
| | ||||
* | If a client sets hints, honor them for kb resize requests, just like we | okan | 2015-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's | okan | 2015-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. |