summary refs log tree commit diff
path: root/calmwm.h
Commit message (Collapse)AuthorAgeFilesLines
* Convert menu-exec-wm from an abritrary exec menu, into a config-based menu fromokan2017-12-291-4/+8
| | | | | | | | 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 actionsokan2017-12-291-1/+1
| | | | | | | | | 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 dookan2017-12-291-2/+1
| | | | border work for a group/ungroup action.
* add helper function client_show to bring together like actions for unhide/raiseokan2017-12-291-0/+1
|
* Add support for _NET_WM_STATE_SKIP_PAGER and _NET_WM_STATE_SKIP_TASKBAR; eerilyokan2017-12-191-1/+10
| | | | | | | close to cwm's 'ignore'. Roughly based on an initial diff from Walter Alejandro Iglesias, but with support for both Atoms and without cwm-based bindings.
* remove duplicate ExposureMaskokan2017-12-151-2/+2
|
* Unconditionally show prompt on menus, regardless of invocation.okan2017-12-111-2/+2
|
* Original idea from Dimitris Papastamos to move windows to corners a while ago;okan2017-12-071-0/+1
| | | | | | | | | 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 callbacksokan2017-12-071-0/+4
|
* stash dir into conf since it'll be of useokan2017-12-071-1/+1
|
* Pull over the remaining re-implemented window move/resize functions and createokan2017-07-141-3/+0
| | | | | 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 changeokan2017-07-121-1/+1
|
* Alter callbacks to take a struct instead of a growing number of arguments;okan2017-05-091-60/+50
| | | | greatly simplifies upcoming work.
* Clean up, unify and accurately calculate edge distance with client move/resizeokan2017-05-011-0/+1
| | | | | | actions, so as to not lose windows off the edge. inspired by diffs (and feedback) from Vadim Vygonets.
* Switch bwidth type; unfortunately X11 is inconsistent.okan2017-04-261-1/+1
|
* Add search_print_text(), a default callback for mi->print in menu_filter(). ↵okan2016-12-061-0/+1
| | | | | | While here, normalize the remaining search_print_* argument paramters.
* Tame the number of 'exec' and 'path' search_match wrappers. No functionalokan2016-12-011-3/+1
| | | | | change now, though more can likely go later, losing the (paritally complete or incomplete/broken) argument completion bits.
* Change 'menu-window' to display all windows; then add 'menu-window-hidden' forokan2016-12-011-0/+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)
* revert previous; upcoming changes will hopefully deal with these moreokan2016-11-151-2/+0
| | | | naturally.
* Add a wrapper based upon xevent handlers around client move/resize for key andokan2016-11-151-0/+2
| | | | mouse bindings.
* Define callbacks, then default bindings.okan2016-11-141-1/+1
|
* Get rid of 'matchname'; it's too surprising to have the menu change duringokan2016-10-241-1/+0
| | | | | | 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.
* Refactor callbacks to take a void * so as to not try and generalize intookan2016-10-181-120/+122
| | | | | | | | 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-061-3/+3
|
* Add an argument to the callbacks to pass the xevent context, button orokan2016-10-061-37/+37
| | | | | | | 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.
* Stash wmname into conf.okan2016-10-051-1/+1
|
* When removing xrandr regions, ensure clients are within the bounds ofokan2016-10-041-0/+1
| | | | | | 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-041-2/+1
| | | | needed/used.
* Turn CALMWM_NGROUPS define into variable, ngroups.okan2016-10-041-1/+1
|
* Start simplifying menu code; and in turn, remove a cursor no longerokan2016-10-031-3/+2
| | | | needed.
* Defaults are split between defines and conf_init(); normalize these, asokan2016-10-031-11/+6
| | | | well as give 'sticky' groups its own variable.
* remove unused protookan2016-09-301-1/+0
|
* Use instinsic X11 functions for key/btn/ptr grab/ungrab/regrab requests;okan2016-09-301-7/+0
| | | | | 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-301-0/+2
| | | | | | | lists; use it appropriately for both window dimension and position in the respective mousefunc calls. ok bryent@
* Mechanical change: move screen menu bits to their own struct.okan2016-09-291-2/+4
|
* Inline Xft draw and extents wrappers; too much abstraction.okan2016-09-281-3/+0
|
* Continue merging kb and mouse functions: foldokan2016-09-221-4/+0
| | | | | | 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.
* de-static client_inbound()okan2016-09-201-0/+1
|
* During init, query screen for _NET_ACTIVE_WINDOW and set that client asokan2016-09-161-1/+2
| | | | | | | | 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).
* more client vs screen context differencesokan2015-11-121-7/+5
|
* Move kb pointer movement out of the kbfunc_client_moveresize since it'sokan2015-11-121-11/+10
| | | | | | | | 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.
* Partial revert of replacing screen_area() with region_find(); until aokan2015-11-111-1/+6
| | | | | | fix for a regression is found; this bug has been around for a long time it seems, but this change exposed it. Likely need to track clients in to and out of regions.
* Start cleaning up name vs function differences; replace magic numbers.okan2015-11-101-24/+23
|
* Clean up unused defines.okan2015-11-091-3/+0
|
* Extend region to include both view and work areas; switch tookan2015-11-091-5/+3
| | | | | | | region_find() which no longer needs to recalculate gap each time a client (or menu) is created or altered. If no RandR, fall back to display dimensions while building regions instead of during execution.
* On execwm, we should properly release resources before exec'ing into aokan2015-09-161-1/+3
| | | | | | | new window manager; so allow CWM_EXEC_WM to assign new wm to wm_argv and pass through cwm_status (now EXECWM) so that x_teardown() gets called before exec'ing the new window manager. Removes the need for a separate x_restart() now, using new wm_argv; and consolidates errno for execvp.
* Mechanical change: group->gcokan2015-08-271-1/+1
|
* Split out sticky mode checks and the restoring of a client's group andokan2015-08-251-1/+3
| | | | | _NET_WM_DESKTOP from the config-based auto-grouping; no (intentional) behavior changes. Needed for further work in cleaning up this area.
* Implement _NET_CLIENT_LIST_STACKING (from Thomas Admin), butokan2015-08-241-0/+2
| | | | bottom-to-top order, as per spec (notified Thomas as well).