summary refs log tree commit diff
Commit message (Collapse)AuthorAgeFilesLines
...
* | 'window-search' is spelled 'menu-window'; the former snuck in during theokan2016-12-061-1/+0
| | | | | | | | | | conversion('menu-window' already existed and was properlly documented); found the hard way by sthen@ while trying to convert.
* | Fold unbinding functions into one for each, key and mouse; plugs a leak whenokan2016-12-021-36/+10
| | | | | | | | unbinding a mouse button bound to a command.
* | use the correct typeokan2016-12-021-1/+1
| |
* | Tame the number of 'exec' and 'path' search_match wrappers. No functionalokan2016-12-014-23/+9
| | | | | | | | | | 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 aokan2016-12-011-1/+1
| | | | | | | | substring match. The previous matching is only intended for the exec menus.
* | Change 'menu-window' to display all windows; then add 'menu-window-hidden' forokan2016-12-015-4/+12
| | | | | | | | | | | | | | | | 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, menuokan2016-12-013-340/+386
| | | | | | | | | | | | | | | | 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.okan2016-11-151-3/+10
| | | | | | | | from James McDonald via portable.
* | revert previous; upcoming changes will hopefully deal with these moreokan2016-11-153-26/+2
| | | | | | | | naturally.
* | Add a wrapper based upon xevent handlers around client move/resize for key andokan2016-11-153-2/+26
| | | | | | | | mouse bindings.
* | Define callbacks, then default bindings.okan2016-11-143-80/+82
| |
* | Reorganize for upcoming changes.okan2016-11-141-286/+255
| |
* | Remove the (8) default bindings for pointer move since they conflict withokan2016-11-142-13/+0
| | | | | | | | | | | | | | 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.okan2016-10-243-11/+11
| |
* | Remove duplicate check that strsubmatch() already does; while here, fix aokan2016-10-241-2/+2
| | | | | | | | comment.
* | Sprinkle __func__ in appropriate error messages.okan2016-10-245-10/+10
| |
* | Get rid of 'matchname'; it's too surprising to have the menu change duringokan2016-10-242-12/+3
| | | | | | | | | | | | 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 changeokan2016-10-221-21/+9
| |
* | Refactor callbacks to take a void * so as to not try and generalize intookan2016-10-1810-505/+508
| | | | | | | | | | | | | | | | 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-121-1/+0
| |
* | Rename 2 kbfunc to match closer to what they dookan2016-10-063-8/+8
| |
* | Add an argument to the callbacks to pass the xevent context, button orokan2016-10-065-87/+82
| | | | | | | | | | | | | | 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-061-0/+4
| | | | | | | | | | 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-052-4/+4
| |
* | Add CM-a for 'nogroup' (CM-0 stays for now); update manpage to reflect.okan2016-10-052-1/+2
| |
* | Stash wmname into conf.okan2016-10-053-3/+5
| |
* | When removing xrandr regions, ensure clients are within the bounds ofokan2016-10-043-0/+25
| | | | | | | | | | | | 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-043-8/+9
| | | | | | | | needed/used.
* | Turn CALMWM_NGROUPS define into variable, ngroups.okan2016-10-045-18/+20
| |
* | Start simplifying menu code; and in turn, remove a cursor no longerokan2016-10-033-27/+22
| | | | | | | | needed.
* | Defaults are split between defines and conf_init(); normalize these, asokan2016-10-034-20/+13
| | | | | | | | 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-032-5/+27
| | | | | | | | | | 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-033-5/+7
| | | | | | | | | | 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-301-1/+0
| |
* | Set the initial ptr position during client init, instead of waitingokan2016-09-301-12/+7
| | | | | | | | | | 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-305-85/+45
| | | | | | | | | | 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-303-26/+40
| | | | | | | | | | | | | | 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-301-2/+2
| | | | | | | | window.
* | no need to unmap menu window againokan2016-09-291-2/+1
| |
* | Mechanical change: move screen menu bits to their own struct.okan2016-09-295-30/+32
| |
* | Inline Xft draw and extents wrappers; too much abstraction.okan2016-09-284-32/+31
| |
* | Do not call sweep_draw() too early: don't yet have w/h dimensions; plusokan2016-09-281-1/+0
| | | | | | | | | | we will get a MotionNotify event right away anyway, setting required parameters.
* | Continue merging kb and mouse functions: foldokan2016-09-224-91/+28
| | | | | | | | | | | | 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-201-0/+3
| |
* | de-static client_inbound()okan2016-09-202-2/+2
| |
* | remove debug that accidentally snuck inokan2016-09-201-1/+1
| |
* | Get rid of curcc, instead cycle through the queue; removes the need forokan2016-09-202-21/+13
| | | | | | | | client_none().
* | During init, query screen for _NET_ACTIVE_WINDOW and set that client asokan2016-09-165-9/+27
| | | | | | | | | | | | | | | | 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-141-0/+1
| | | | | | | | | | | | 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-143-11/+14
| | | | | | | | instead of relying on curcc.