summary refs log tree commit diff
path: root/calmwm.h
Commit message (Collapse)AuthorAgeFilesLines
* 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.
* fold in 'active' into 'flags'okan2014-09-101-1/+1
|
* name the group client queue appropriately, like other queuesokan2014-09-081-1/+1
|
* Remove duplicate client queue (mruq); instead, remove and take theokan2014-09-081-6/+3
| | | | | | 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-081-2/+2
|
* Add screen_ctx to group_ctx, and populate on init.okan2014-09-071-0/+1
|
* screen_fromroot -> screen_findokan2014-09-071-1/+1
|
* Get rid of a redundant array of groups per screen; we already have aokan2014-09-071-1/+0
| | | | link to the group queue for each screen.
* Move termpath and lockpath into cmdq; side effect is that 'lock' andokan2014-09-061-2/+0
| | | | 'term' now show up in the application menu.
* Rework group names: stash the group name inside the group_ctx as opposedokan2014-09-061-2/+1
| | | | | | 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-011-1/+3
|
* Since the flatting out of sc->group_names is only for settingokan2014-08-251-2/+1
| | | | | 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-251-1/+5
| | | | | | | 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-241-2/+0
| | | | | | | | | | 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-201-1/+1
|
* Pull highstack from group_ctx (and useless calculations of); in the oneokan2014-08-191-1/+0
| | | | | 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-181-1/+0
| | | | | | | 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-081-0/+1
|\ | | | | | | | | 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).
* | Introduce a region queue and replace screen's XineramaScreenInfo; weokan2014-02-031-2/+8
| | | | | | | | | | still use Xinerama to populate the regions per screen, but will switch at a more appropriate time.
* | Move redundant bits from screen_init (while dealing with existingokan2014-02-031-1/+1
| | | | | | | | | | | | clients) directly into client_init, performing the X roundtrip only once. With the previous change in maprequest, this moves decision making into one place for creating new clients.
* | No need to store screen colormap and visual; rather just use the Xokan2014-02-021-2/+0
| | | | | | | | macros in the one place they are needed.
* | The menu already limits entries with MENU_MAXENTRY, so don't botherokan2014-02-021-4/+3
| | | | | | | | holding a command name limit as well.
* | Switch ignoreq to winname struct since it's basically the same thing;okan2014-01-301-9/+3
| | | | | | | | removes limit on name matching.
* | Move cwm_status around to avoid header fu, and remove extraneous signalokan2014-01-301-9/+0
| | | | | | | | header from xevents.c; noticed by Christian Neukirchen.
* | Minimize trivial differences between a few kb and mb functions.okan2014-01-291-1/+1
| |
* | Merge keybinding and mousebinding queues into using the same mergedokan2014-01-291-15/+11
| | | | | | | | | | struct, binding; they were essentially the same accept for what was 'pressed', keysym or button.
* | Check command name/path for truncation and provide user feedback duringokan2014-01-291-1/+1
| | | | | | | | | | | | config parse (and use conf_cmd_add to populate defaults); based on a discussion with Tiago Cunha. While this looks ugly, there are likely some other changes here to come.
* | Check ignore windowname for truncation and provide user feedback duringokan2014-01-281-1/+1
| | | | | | | | config parse; based on a discussion with Tiago Cunha.
* | Somewhat streamline event loop/restart/quit handling; most notableokan2014-01-221-3/+7
| | | | | | | | | | | | | | | | change allows a restart to trigger proper teardown first, even though teardown is not (yet) complete. After some discussion with oga@nicotinebsd.org regarding a more complicated version/idea.
* | Sprinkle a few more const; from Tiago Cunha.okan2014-01-211-2/+2
| |
* | merge KBFLAG_NEEDCLIENT and MOUSEBIND_CTX_*; brings kbfunc and mousefuncokan2014-01-201-3/+2
| | | | | | | | bits even closer.
* | Use argument to pass down flags for mousefunc cyclegroup; removesokan2014-01-201-2/+0
| | | | | | | | rcyclegroup wrapper need - now similar to kbfunc.
* | constify and rename some confusing variables around cmdq.okan2014-01-201-6/+7
| |
* | - remove redundant range check for buttons in conf_bind_mouse.okan2014-01-201-2/+4
| | | | | | | | | | | | | | | | | | - make conf_bind_kbd return error on non-matches to match what conf_bind_mouse does. - rename some variables while here for clarity. - constify bind and cmd. from Tiago Cunha.
* | Add a function that adds an entry to a menuq, normalizing a common codeokan2014-01-201-0/+1
| | | | | | | | path; from Tiago Cunha.
* | use consistent typesokan2014-01-031-11/+11
| |
* | bring mousefunc closer to kbfuncokan2014-01-021-12/+19
| |
* | gc keycode in keybinding since we only deal with keysym nowokan2014-01-021-1/+0
| |
* | Implement support for EWMH's _NET_WM_STATE_FULLSCREEN hint.okan2013-12-161-2/+7
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Since we already have a form of 'maximize', we need to differentiate between 'maximize' and the new 'fullscreen' mode. The 'maximize' mode will continue to honor gap but now *retains* the border, matching the 'vert/horz maximize' behaviour. The new 'fullscreen' mode supports and follows the _NET_WM_STATE_FULLSCREEN hint, allowing the client perform additional window modifications; in this mode, cwm(1) will *ignore* gap, remove borders and freeze(move/resize) the client. Additionally, 'fullscreen' mode will remember various combinations of previous states. * default keybinding changes: CM-f 'fullscreen', CM-m 'maximize' (re-map as desired). Positive feedback from a few, testing and ok sthen@
* | Teach screen_find_xinerama() to apply gap only when told to do so;okan2013-12-131-1/+5
| | | | | | | | adjust callers. Needed for an upcoming feature.
* | Add support for XUrgency and matching _NET_WM_STATE_DEMANDS_ATTENTIONokan2013-12-131-1/+5
| | | | | | | | | | | | | | ewmh hint; urgencyborder is configurable. The urgency flag will stick, even while on a client in a non-viewable group, until the client receives focus (where the border is reset). Initial diff from Thomas Adam with some changes/enhancements from me.
* | ICCCM explicitly states that server time (CurrentTime) should *not* beokan2013-12-121-1/+2
| | | | | | | | | | | | | | | | | | | | | | used for focus events, but rather the timestamp of the generated event. Track the last event timestamp and send it down for a WM_TAKE_FOCUS ClientMessage. I suspect we should do this for clients that don't announce this Atom as well, though the raciness gets us into a bind. Solves focus order issue since WM_TAKE_FOCUS; fix verified by sthen@ ok sthen@