Commit message (Collapse) | Author | Age | Lines | |
---|---|---|---|---|
* | Fold unbinding functions into one for each, key and mouse; plugs a leak when | okan | 2016-12-02 | -37/+11 |
| | | | | unbinding a mouse button bound to a command. | |||
* | use the correct type | okan | 2016-12-02 | -2/+2 |
| | ||||
* | Tame the number of 'exec' and 'path' search_match wrappers. No functional | okan | 2016-12-01 | -27/+13 |
| | | | | | change now, though more can likely go later, losing the (paritally complete or incomplete/broken) argument completion bits. | |||
* | Switch ssh menu to search_match_text; like group/window/cmd menus, use only a | okan | 2016-12-01 | -2/+2 |
| | | | | substring match. The previous matching is only intended for the exec menus. | |||
* | Change 'menu-window' to display all windows; then add 'menu-window-hidden' for | okan | 2016-12-01 | -10/+18 |
| | | | | | | | | the previous behaviour of 'menu-window'. 'menu-window' becomes the default binding; use 'bind-mouse "1" menu-window-hidden' to restore old behaviour for those who prefer. OK sthen@ (long long time ago on a different version) | |||
* | Normalize bind function names, based on a few categories: window, group, menu | okan | 2016-12-01 | -344/+390 |
| | | | | | | | | and pointer. Replace 'bind' and 'mousebind' options with 'bind-key' and 'bind-mouse', respectively, replace special 'unmap' keyword with 'unbind-key' and 'unbind-mouse', and additionally allow unbinding all with 'all' keyword. | |||
* | Use an additional check with lstat(2) when d_type is unknown. | okan | 2016-11-15 | -4/+11 |
| | | | | from James McDonald via portable. | |||
* | revert previous; upcoming changes will hopefully deal with these more | okan | 2016-11-15 | -29/+5 |
| | | | | naturally. | |||
* | Add a wrapper based upon xevent handlers around client move/resize for key and | okan | 2016-11-15 | -5/+29 |
| | | | | mouse bindings. | |||
* | Define callbacks, then default bindings. | okan | 2016-11-14 | -83/+85 |
| | ||||
* | Reorganize for upcoming changes. | okan | 2016-11-14 | -287/+256 |
| | ||||
* | Remove the (8) default bindings for pointer move since they conflict with | okan | 2016-11-14 | -16/+3 |
| | | | | | | | default bindings for emacs, which wins; the feature remains and can be bound to whatever users wish with cwmrc(5). from mpi@ | |||
* | Make it clear these are flags. | okan | 2016-10-24 | -14/+14 |
| | ||||
* | Remove duplicate check that strsubmatch() already does; while here, fix a | okan | 2016-10-24 | -3/+3 |
| | | | | comment. | |||
* | Sprinkle __func__ in appropriate error messages. | okan | 2016-10-24 | -15/+15 |
| | ||||
* | Get rid of 'matchname'; it's too surprising to have the menu change during | okan | 2016-10-24 | -14/+5 |
| | | | | | | client search as different potential str matches are cycled through. If there's interest, the only string that doesn't exist in the listing is the window's class - that can be added of course, but it makes the line too long imho. | |||
* | clean up search_match_client(); no behaviour change | okan | 2016-10-22 | -22/+10 |
| | ||||
* | 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 |
| |