summary refs log tree commit diff
path: root/calmwm.h
Commit message (Collapse)AuthorAgeFilesLines
* cvsimportokan2015-11-121-49/+45
|\ | | | | | | | | | | | | | | | | | | | | | | | | * refs/heads/master: more client vs screen context differences If a client sets hints, honor them for kb resize requests, just like we do for mouse based resize requests. Move kb pointer movement out of the kbfunc_client_moveresize since it's 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. pledge "stdio rpath proc exec" cwm before main event loop, after init/setup - mostly for menu building. Partial revert of replacing screen_area() with region_find(); until a 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. Use position on root to figure out region. Start cleaning up name vs function differences; replace magic numbers. Clean up unused defines. Extend region to include both view and work areas; switch to 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.
| * 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.
* | cvsimportokan2015-09-231-1/+3
|\| | | | | | | | | | | * refs/heads/master: Only when mapping clients from an initial wm start or restart, query the pointer and if it matches the child window, activate it; new clients will not need to make this roundtrip to the server. On execwm, we should properly release resources before exec'ing into a 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.
| * 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.
* | cvsimportokan2015-08-281-9/+14
|\| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | * refs/heads/master: (21 commits) Lost fix from r1.112; add comment. Mechanical change: group->gc Add consistent checks against NULL. Move client cycle grab/ungrab into a more relevant place; while here, update comments about why we need to grab/ungrab the keyboard. Re-add lost chunk in group_cycle from r1.113. Further simplify _NET_WM_DESKTOP handling using new group_assign(). oops; remove left over debug print Allowing sending a valid 'nogroup' (0) group_ctx to group_assign() (since we init all groups), though assigning the client's group to NULL for 'sticky'; use this simplification in a few places (others to follow). Split out sticky mode checks and the restoring of a client's group and _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), but bottom-to-top order, as per spec (notified Thomas as well). Don't allow freeze operations on fullscreen (consistent with what fullscreen does). Sort _NET_WM_STATE Atoms like the spec. Move CLIENT_STICKY logic from client hide/unhide to group hide/unhide; rationale being that clients should be able to hide/unhide independently of group switching. Add Xkb modifier to ignore mask; from Alexander Polakov. Fix whitespace. Add client freeze extension to _NET_WM_STATE Atom, allowing flag to persist. As usual with new Atoms, requires X restart. _NET_WM_STATE_STICKY implies only sticky at the group/desktop level, not position and size; based on discussion with a few. Instead of special casing the 'term' and 'lock' commands, go back to keeping them hidden; showing them has apparently caused confusion/angst. Leave command list order from .cwmrc alone; remove sort. Bring group and client cycle closer together. ...
| * 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.
* | cvsimportokan2015-07-121-0/+2
|\|
| * introduce 'groupsearch' for group menu search; matches on either groupokan2015-07-121-0/+2
| | | | | | | | number/shortcut and/or name.
* | cvsimportChristian Neukirchen2015-07-011-3/+3
|\|
| * 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.
* | cvsimportokan2015-06-091-6/+26
|\|
| * 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@
* | add reallocarray.cChristian Neukirchen2015-03-291-0/+2
| |
* | cvsimportokan2015-03-291-1/+2
|\|
| * 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.
* | cvsimportChristian Neukirchen2015-01-221-2/+2
|\|
| * Switch to limits.h; replace MAXPATHLEN and MAXHOSTNAMELEN with PATH_MAXokan2015-01-191-2/+2
| | | | | | | | | | | | and HOST_NAME_MAX+1, respectively. ok doug@
* | cvsimportokan2014-10-081-2/+2
|\|
| * make group_init work like other *_init'sokan2014-10-081-2/+2
| |
* | cvsimportokan2014-09-271-7/+7
|\|
| * 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.
* | cvsimportokan2014-09-181-30/+31
|\|
| * 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.
| * fold in 'active' into 'flags'okan2014-09-101-1/+1
| |
| * name the group client queue appropriately, like other queuesokan2014-09-081-1/+1
| |