Commit message (Collapse) | Author | Age | Files | Lines | |
---|---|---|---|---|---|
* | Allow cwm(1) to cycle through windows of the same window class as the HEAD master | okan | 2023-07-20 | 1 | -1/+3 |
| | | | | | | | active window; default key binding to M-grave, respectively Alt-Tilde, like other window managers have as well. from Simon Dassow | ||||
* | cycling fix: when no client is active, warp pointer to last active; | okan | 2022-02-27 | 1 | -1/+10 |
| | | | | from Walter Alejandro Iglesias. | ||||
* | whitespace | okan | 2022-02-26 | 1 | -1/+1 |
| | |||||
* | Add group-last command that shows only the previously active group; ok okan | op | 2022-01-27 | 1 | -0/+8 |
| | |||||
* | Simplify conditional construct. | tim | 2020-03-20 | 1 | -5/+2 |
| | | | | OK okan@ | ||||
* | No need to lookup current client early; move to right before it is | okan | 2020-03-20 | 1 | -3/+1 |
| | | | | needed. | ||||
* | Unrelated style fixes, consistency changes and sorting, appropriate | okan | 2020-02-27 | 1 | -13/+55 |
| | | | | | dosage/removal of wrappers, simplification of name queue, client cycle joins other kb/mb bound functions. | ||||
* | Ensure the pointer stays within client bounds after a window 'snap' (to edge). | okan | 2020-01-21 | 1 | -0/+1 |
| | | | | reported by Stefan Hagen. | ||||
* | Because cwm warps the pointer during a client move (to stay within the client), | okan | 2019-08-13 | 1 | -0/+2 |
| | | | | | | | | | there's a window of time where an expose or enternotify event will get generated for a lower client; use a hammer and drain events after keyboard move/resize, until such a time that cwm doesn't warp the pointer. Behavior noticed by kn. ok kn@ | ||||
* | Teach client_current() to use a screen to find the current client instead of | okan | 2019-03-07 | 1 | -1/+1 |
| | | | | | iterating over all (fallback if no screen provided for now). Initially convert trivial uses of client_current(). | ||||
* | shuffle deck chairs: rename group actions to match intent for clarity | okan | 2019-03-07 | 1 | -9/+9 |
| | |||||
* | Separate out the menu window from the client resize/move geom window; in each | okan | 2019-03-04 | 1 | -10/+9 |
| | | | | case, create and destroy on-demand. Isolate more menu specific code. | ||||
* | Add 'group-close-[n]' action to close all windows within specified group. | okan | 2019-02-25 | 1 | -0/+6 |
| | | | | heavily based on a diff from Nam Nguyen. | ||||
* | Rename internal functions to delinate between client remove, delete and xproto | okan | 2019-02-22 | 1 | -2/+2 |
| | | | | | delete; 'window-close' is now the proper action, but 'window-delete' as an alias will remain until more interesting changes require breaking configs. | ||||
* | fix missing includes | okan | 2019-02-13 | 1 | -0/+1 |
| | |||||
* | Convert menu-exec-wm from an abritrary exec menu, into a config-based menu from | okan | 2017-12-29 | 1 | -28/+30 |
| | | | | | | | | which one may configure (wm <name> <path_and_args>) (and choose) specific window managers to replace the running one. 'wm cwm cwm' is included by default. No objections and seems sensible to sthen. | ||||
* | As done for buttonrelease, work specific un-cycling and un-highlighting actions | okan | 2017-12-29 | 1 | -2/+9 |
| | | | | | | | | | into the keyrelease event, only performing what's actually needed for each; should result in much fewer events against keyreleases. No intended behaviour change. Additionally, like we do for group membership, grab the keyboard only when required for cycling. | ||||
* | Merge group_toggle_membership_leave into the buttonrelease event and only do | okan | 2017-12-29 | 1 | -1/+1 |
| | | | | border work for a group/ungroup action. | ||||
* | add helper function client_show to bring together like actions for unhide/raise | okan | 2017-12-29 | 1 | -4/+1 |
| | |||||
* | Use a variable to keep track of flags for menu_filter(). | okan | 2017-12-19 | 1 | -13/+21 |
| | |||||
* | Unconditionally show prompt on menus, regardless of invocation. | okan | 2017-12-11 | 1 | -5/+3 |
| | |||||
* | Original idea from Dimitris Papastamos to move windows to corners a while ago; | okan | 2017-12-07 | 1 | -0/+36 |
| | | | | | | | | | re-proposed by Julien Steinhauser with an updated diff. Apparently this was in the original calmnwm. However, expand the original idea and let clients 'snap' to edges instead, neatly allowing key bindings that snap to adjacent edges (i.e. corners) as well. No default bindings assigned. | ||||
* | give command and group menus their own match callbacks | okan | 2017-12-07 | 1 | -5/+4 |
| | |||||
* | spacing | okan | 2017-12-07 | 1 | -3/+2 |
| | |||||
* | Revert r1.109 (Switch to XWindowEvent() pulling out events that match the mask | okan | 2017-11-30 | 1 | -2/+2 |
| | | | | | | | *and* window.) of mousefunc.c. When a client destroys itself while we are moving or resizing it, XWindowEvent() blocks. Found the hard way by Anton Lazarov, and Lea°hNeukirchen found the right bit to revert - thanks! Reverting since the reason to switch from XMaskEvent was unclear. | ||||
* | remove extra parentheses | okan | 2017-07-14 | 1 | -2/+2 |
| | |||||
* | Pull over the remaining re-implemented window move/resize functions and create | okan | 2017-07-14 | 1 | -2/+139 |
| | | | | | a wrapper so that the key and mouse based move/resize callbacks can be unified. This has already been done with other window operations and menus. | ||||
* | rename one function, matching others, to help upcoming change | okan | 2017-07-12 | 1 | -1/+1 |
| | |||||
* | Replace fgetln(3) with POSIX getline(3); inspired by brynet and Ingo. | okan | 2017-07-10 | 1 | -11/+10 |
| | | | | feedback and ok brynet@ | ||||
* | Alter callbacks to take a struct instead of a growing number of arguments; | okan | 2017-05-09 | 1 | -50/+49 |
| | | | | greatly simplifies upcoming work. | ||||
* | Clean up, unify and accurately calculate edge distance with client move/resize | okan | 2017-05-01 | 1 | -43/+21 |
| | | | | | | actions, so as to not lose windows off the edge. inspired by diffs (and feedback) from Vadim Vygonets. | ||||
* | Ensure client stays inbound on key-based resize; based on logic existing in | okan | 2017-01-05 | 1 | -0/+4 |
| | | | | key-based client move; from Vadim Vygonets. | ||||
* | Add search_print_text(), a default callback for mi->print in menu_filter(). ↵ | okan | 2016-12-06 | 1 | -3/+3 |
| | | | | | | While here, normalize the remaining search_print_* argument paramters. | ||||
* | Consistent use of menuq_add for ssh menu. | okan | 2016-12-06 | 1 | -1/+1 |
| | |||||
* | Tame the number of 'exec' and 'path' search_match wrappers. No functional | okan | 2016-12-01 | 1 | -1/+1 |
| | | | | | 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 | 1 | -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' for | okan | 2016-12-01 | 1 | -1/+2 |
| | | | | | | | | 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) | ||||
* | Use an additional check with lstat(2) when d_type is unknown. | okan | 2016-11-15 | 1 | -3/+10 |
| | | | | from James McDonald via portable. | ||||
* | revert previous; upcoming changes will hopefully deal with these more | okan | 2016-11-15 | 1 | -22/+0 |
| | | | | naturally. | ||||
* | Add a wrapper based upon xevent handlers around client move/resize for key and | okan | 2016-11-15 | 1 | -0/+22 |
| | | | | mouse bindings. | ||||
* | Make it clear these are flags. | okan | 2016-10-24 | 1 | -6/+6 |
| | |||||
* | Sprinkle __func__ in appropriate error messages. | okan | 2016-10-24 | 1 | -3/+3 |
| | |||||
* | Refactor callbacks to take a void * so as to not try and generalize into | okan | 2016-10-18 | 1 | -166/+170 |
| | | | | | | | | 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. | ||||
* | Rename 2 kbfunc to match closer to what they do | okan | 2016-10-06 | 1 | -2/+2 |
| | |||||
* | Add an argument to the callbacks to pass the xevent context, button or | okan | 2016-10-06 | 1 | -35/+35 |
| | | | | | | | 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. | ||||
* | For both kb and mouse move, it is possible to grab a client and move it | okan | 2016-10-03 | 1 | -1/+13 |
| | | | | | 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 | 1 | -0/+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. | ||||
* | Continue merging kb and mouse functions: fold | okan | 2016-09-22 | 1 | -7/+22 |
| | | | | | | 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. | ||||
* | If a client does not set increment values, use 'moveamount' as a way to | okan | 2015-11-17 | 1 | -7/+9 |
| | | | | | | scale keyboard based resizes; extend kbfunc_amount(). Behaviour noted by, tested by, and ok sthen@ | ||||
* | more client vs screen context differences | okan | 2015-11-12 | 1 | -4/+4 |
| |