aboutsummaryrefslogtreecommitdiffstats
path: root/calmwm.h (follow)
Commit message (Collapse)AuthorAgeLines
...
* 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
|
* Remove duplicate client queue (mruq); instead, remove and take theokan2014-09-08-7/+4
| | | | | | global Clientq and place it inside screen_ctx since every client belongs to a screen, then use the same per screen clientq to track stacking order (the sole reason for mruq).
* Now that a group knows its screen, only pass down the group_ctx.okan2014-09-08-3/+3
|
* Add screen_ctx to group_ctx, and populate on init.okan2014-09-07-1/+2
|
* screen_fromroot -> screen_findokan2014-09-07-2/+2
|
* Get rid of a redundant array of groups per screen; we already have aokan2014-09-07-2/+1
| | | | link to the group queue for each screen.
* Move termpath and lockpath into cmdq; side effect is that 'lock' andokan2014-09-06-3/+1
| | | | 'term' now show up in the application menu.
* Rework group names: stash the group name inside the group_ctx as opposedokan2014-09-06-3/+2
| | | | | | to having to manage an array outside in screen_ctx for group names and shortcuts. Simplifies (and moves bits for) reading, and constructing data for, EWMH's _NET_DESKTOP_NAMES.
* Merge group_menu into mousefunc_menu_group.okan2014-09-01-2/+4
|
* Since the flatting out of sc->group_names is only for settingokan2014-08-25-3/+2
| | | | | NET_DESKTOP_NAMES, merge the helper into xu_ewmh_net_desktop_names, where we actually set the property.
* Implement _NET_WM_STATE_STICKY, bound to CM-s by default; allows anyokan2014-08-25-2/+6
| | | | | | | client to 'stick' to all desktops (ewmh speak) or groups - this currently has the same affect as setting a client's group to 'nogroup', with the exception that the client can also be in a group, so when un-sticking, the client will go back to its original group/desktop.
* gc->hidden has never consistently kept track of a group's state;okan2014-08-24-3/+1
| | | | | | | | | | group_show() and group_hide() are not the only ways a group can change state - if all clients in a group are either hidden or unhidden, then that group's state should change, as well as the various EWMH ways. Instead of trying to keep track in a wide variety of places, simply query the clients in a group before needing to take action based on the group's state. Solves long standing confusion of when a group is hidden or not.
* Purely mechanical; unify 'num', 'no' and 'shortcut'.okan2014-08-20-2/+2
|
* Pull highstack from group_ctx (and useless calculations of); in the oneokan2014-08-19-2/+1
| | | | | place that we use highstack, replace that usage with a local variable (for now until stacking is done properly).
* Get rid of nhidden in group_ctx; it actually never reported correctlyokan2014-08-18-2/+1
| | | | | | | since nhidden wasn't incremented nor decremeted in all the right places, thus confusing matters. We don't need to carry a count around, so just use a local variable in the one place we need one to supply XRestackWindows().
* Make sure we cycle through existing client's group membership and setokan2014-02-08-1/+2
| | | | | the hidden state on the group; important to know group hidden state after a re-exec or restart of cwm (as easily seen in group menu).