summary refs log tree commit diff
path: root/calmwm.h
Commit message (Collapse)AuthorAgeFilesLines
* 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).
* Sort _NET_WM_STATE Atoms like the spec.okan2015-08-241-1/+1
|
* Add Xkb modifier to ignore mask; from Alexander Polakov.okan2015-08-211-1/+1
|
* Fix whitespace.okan2015-08-211-6/+6
|
* Add client freeze extension to _NET_WM_STATE Atom, allowing flag tookan2015-08-211-1/+2
| | | | persist. As usual with new Atoms, requires X restart.
* introduce 'groupsearch' for group menu search; matches on either groupokan2015-07-121-0/+2
| | | | number/shortcut and/or name.
* Introduce a callback for cmd menu printing, special-casing 'lock' andokan2015-06-301-0/+1
| | | | 'term'.
* Mechanical change from xinerama to region backed areas.okan2015-06-261-2/+1
|
* collect 'gap' applicationsokan2015-06-261-0/+1
|
* Replace screen region info gathering with XRandR equivalent of Xineramaokan2015-06-261-1/+0
| | | | | queries (currently act on XRandR events anyway). Fall-back mode without XRandR is still what X provides. This removes -lXinerama.
* typo in comment; from jsteinha [at] iutbayonne.univ-pau.frokan2015-06-091-1/+1
|
* stash window dimensionsokan2015-06-081-0/+4
|
* add a flag to indicate a menu list instead of overloading 'prompt'okan2015-06-051-0/+1
|
* merge kbd and mouse grouptoggleokan2015-05-211-2/+0
|
* fill in mwm definesokan2015-05-201-3/+19
|
* Make window name and window class separate parameters to conf_autogroup.kspillner2015-05-171-1/+2
| | | | | | No functional change, but will be used shortly. ok okan@
* Introduce a xreallocarray and convert a few xcalloc instances that dookan2015-03-281-0/+1
| | | | not require zero'ing.
* Simplify key/mb binding moving argtype into flags and dropping anotherokan2015-03-261-1/+1
| | | | | variable; removes the need to zero out struct binding, leaving a simple malloc.
* Switch to limits.h; replace MAXPATHLEN and MAXHOSTNAMELEN with PATH_MAXokan2015-01-191-2/+2
| | | | | | and HOST_NAME_MAX+1, respectively. ok doug@
* make group_init work like other *_init'sokan2014-10-081-2/+2
|
* these have nothing to do with 'sticky', but rather group membership; rename.okan2014-09-271-2/+2
|
* Update _NET_CURRENT_DESKTOP with the screen's group_active->num.okan2014-09-231-1/+1
|
* Move stuff that doesn't belong in group_init; while here, explicitlyokan2014-09-231-4/+4
| | | | initialize hideall and cycling.
* these client actions are just toggles; less confusing with better namesokan2014-09-171-16/+18
|
* Use a similarly named check as sticky for hidden check in a group.okan2014-09-171-1/+1
|
* Implement EWMH _NET_WM_STATE_HIDDEN.okan2014-09-171-1/+3
|
* Introduce a check to see if a group holds only 'sticky' clients and useokan2014-09-171-1/+1
| | | | | | | | this check to decide if a group is virtually empty. Rationale: if a group contains *only* 'sticky' clients, it should be skipped while cycling through groups. Apply similar logic to the group menu. Based on an idea from phessler@, who also tested another version.