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