aboutsummaryrefslogtreecommitdiffstats
path: root/calmwm.h (follow)
Commit message (Collapse)AuthorAgeLines
...
* Calculate client nameqlen in client_setname(), the only place it'sokan2016-10-04-3/+2
| | | | needed/used.
* Turn CALMWM_NGROUPS define into variable, ngroups.okan2016-10-04-2/+2
|
* Start simplifying menu code; and in turn, remove a cursor no longerokan2016-10-03-4/+3
| | | | needed.
* Defaults are split between defines and conf_init(); normalize these, asokan2016-10-03-12/+7
| | | | well as give 'sticky' groups its own variable.
* remove unused protookan2016-09-30-2/+1
|
* Use instinsic X11 functions for key/btn/ptr grab/ungrab/regrab requests;okan2016-09-30-8/+1
| | | | | 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-30-1/+3
| | | | | | | 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-29-3/+5
|
* Inline Xft draw and extents wrappers; too much abstraction.okan2016-09-28-4/+1
|
* Continue merging kb and mouse functions: foldokan2016-09-22-5/+1
| | | | | | 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-20-1/+2
|
* During init, query screen for _NET_ACTIVE_WINDOW and set that client asokan2016-09-16-2/+3
| | | | | | | | 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-12-8/+6
|
* Move kb pointer movement out of the kbfunc_client_moveresize since it'sokan2015-11-12-12/+11
| | | | | | | | 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-11-2/+7
| | | | | | 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-10-25/+24
|
* Clean up unused defines.okan2015-11-09-4/+1
|
* Extend region to include both view and work areas; switch tookan2015-11-09-6/+4
| | | | | | | 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-16-2/+4
| | | | | | | 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-27-2/+2
|
* Split out sticky mode checks and the restoring of a client's group andokan2015-08-25-2/+4
| | | | | _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-24-1/+3
| | | | bottom-to-top order, as per spec (notified Thomas as well).
* Sort _NET_WM_STATE Atoms like the spec.okan2015-08-24-2/+2
|
* Add Xkb modifier to ignore mask; from Alexander Polakov.okan2015-08-21-2/+2
|
* Fix whitespace.okan2015-08-21-7/+7
|
* Add client freeze extension to _NET_WM_STATE Atom, allowing flag tookan2015-08-21-2/+3
| | | | persist. As usual with new Atoms, requires X restart.
* introduce 'groupsearch' for group menu search; matches on either groupokan2015-07-12-1/+3
| | | | number/shortcut and/or name.
* Introduce a callback for cmd menu printing, special-casing 'lock' andokan2015-06-30-1/+2
| | | | 'term'.
* Mechanical change from xinerama to region backed areas.okan2015-06-26-3/+2
|
* collect 'gap' applicationsokan2015-06-26-1/+2
|
* Replace screen region info gathering with XRandR equivalent of Xineramaokan2015-06-26-2/+1
| | | | | 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-09-2/+2
|
* stash window dimensionsokan2015-06-08-1/+5
|
* add a flag to indicate a menu list instead of overloading 'prompt'okan2015-06-05-1/+2
|
* merge kbd and mouse grouptoggleokan2015-05-21-3/+1
|
* fill in mwm definesokan2015-05-20-4/+20
|
* Make window name and window class separate parameters to conf_autogroup.kspillner2015-05-17-2/+3
| | | | | | No functional change, but will be used shortly. ok okan@
* Introduce a xreallocarray and convert a few xcalloc instances that dookan2015-03-28-1/+2
| | | | not require zero'ing.
* Simplify key/mb binding moving argtype into flags and dropping anotherokan2015-03-26-2/+2
| | | | | 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-19-3/+3
| | | | | | and HOST_NAME_MAX+1, respectively. ok doug@
* make group_init work like other *_init'sokan2014-10-08-3/+3
|
* these have nothing to do with 'sticky', but rather group membership; rename.okan2014-09-27-3/+3
|
* Update _NET_CURRENT_DESKTOP with the screen's group_active->num.okan2014-09-23-2/+2
|
* Move stuff that doesn't belong in group_init; while here, explicitlyokan2014-09-23-5/+5
| | | | initialize hideall and cycling.
* these client actions are just toggles; less confusing with better namesokan2014-09-17-17/+19
|
* Use a similarly named check as sticky for hidden check in a group.okan2014-09-17-2/+2
|
* Implement EWMH _NET_WM_STATE_HIDDEN.okan2014-09-17-2/+4
|
* Introduce a check to see if a group holds only 'sticky' clients and useokan2014-09-17-2/+2
| | | | | | | | 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.
* fold in 'active' into 'flags'okan2014-09-10-2/+2
|
* name the group client queue appropriately, like other queuesokan2014-09-08-2/+2
|