summary refs log tree commit diff
Commit message (Collapse)AuthorAgeFilesLines
* these client actions are just toggles; less confusing with better namesokan2014-09-175-51/+53
|
* ewmh states _NET_WM_STATE_STICKY should not alter positionokan2014-09-173-6/+6
|
* Use a similarly named check as sticky for hidden check in a group.okan2014-09-173-12/+8
|
* don't toggle _WM_STATE_HIDDEN here yetokan2014-09-171-2/+2
|
* Implement EWMH _NET_WM_STATE_HIDDEN.okan2014-09-174-5/+27
|
* Introduce a check to see if a group holds only 'sticky' clients and useokan2014-09-173-3/+16
| | | | | | | | 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.
* use similiar style for client flagsokan2014-09-154-7/+7
|
* Remove incorrect cast in kbfunc_exec. In kbfunc_ssh, reverse logic onokan2014-09-111-4/+4
| | | | truncation check so it's obvious.
* fold in 'active' into 'flags'okan2014-09-102-6/+6
|
* move the check for an empty queue up during cycleokan2014-09-081-3/+1
|
* name the group client queue appropriately, like other queuesokan2014-09-084-17/+17
|
* more style nits and wrappingokan2014-09-081-4/+6
|
* since mruq has been folded in, rename mru-named functionsokan2014-09-081-6/+6
|
* Remove duplicate client queue (mruq); instead, remove and take theokan2014-09-087-28/+25
| | | | | | 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-083-19/+19
|
* Add screen_ctx to group_ctx, and populate on init.okan2014-09-072-0/+2
|
* more style nitsokan2014-09-078-67/+67
|
* screen_fromroot -> screen_findokan2014-09-074-8/+8
|
* Get rid of a redundant array of groups per screen; we already have aokan2014-09-072-9/+22
| | | | link to the group queue for each screen.
* Few style nits; extend 'path' to MAXPATHLEN.okan2014-09-061-10/+13
|
* generic sighandlerokan2014-09-061-10/+13
|
* style nitokan2014-09-061-2/+2
|
* Move termpath and lockpath into cmdq; side effect is that 'lock' andokan2014-09-063-24/+27
| | | | 'term' now show up in the application menu.
* Rework group names: stash the group name inside the group_ctx as opposedokan2014-09-065-64/+41
| | | | | | 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.
* bring menu bits closer togetherokan2014-09-021-3/+2
|
* add explicit paran and drop some empty lines bringing like functions closerokan2014-09-012-6/+2
|
* Merge group_menu into mousefunc_menu_group.okan2014-09-013-38/+31
|
* Since the flatting out of sc->group_names is only for settingokan2014-08-253-28/+21
| | | | | 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-258-3/+47
| | | | | | | 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.
* Continue effort to bring keyboard and mouse functions together; mergeokan2014-08-241-30/+20
| | | | name_to_kbfunc and name_to_mousefunc.
* gc->hidden has never consistently kept track of a group's state;okan2014-08-243-32/+18
| | | | | | | | | | 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.
* Fix nogroup regression, where nogroup became an actual group - theokan2014-08-224-15/+18
| | | | | | | | | | symantics between cwm groups and ewmh got in the way. Ensure a client that wants to be in nogroup stays in nogroup (thus stays in view), even when (re)reading NET_WM_DESKTOP. Paritially reverts patchset 644 (2014-02-07 13:09 PST) which deals with a NULL cc->group. All to be revisited when NET_WM_STATE_STICKY hits cwm. Reported by many; testing and ok phessler.
* Purely mechanical; unify 'num', 'no' and 'shortcut'.okan2014-08-208-31/+30
|
* Split off group window restacking.okan2014-08-201-4/+15
|
* whitespaceokan2014-08-201-1/+1
|
* fix a misleading comment and function nameokan2014-08-201-5/+5
|
* Remove unnecessary memset since reload was replaced with restart;okan2014-08-191-2/+0
| | | | from Kent Spillner.
* Pull highstack from group_ctx (and useless calculations of); in the oneokan2014-08-192-17/+9
| | | | | 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-182-8/+5
| | | | | | | 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().
* plug memleak (currently unused func); from Tiago Cunhaokan2014-04-211-0/+1
|
* Alignment fix; found the hard way on sparc64 by landry@ (and thanks toookan2014-02-271-1/+1
| | | | | | for fast access to a box!) ok deraadt@, matthieu@
* Make sure we cycle through existing client's group membership and setokan2014-02-083-0/+11
|\ | | | | | | | | 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).
| * Initial import of cwm-3. cwmbernd2007-04-270-0/+0
| | | | | | | | tested by sturm@, ok matthieu@
* | Replace a few hand rolled loops with like tailq loops.okan2014-02-081-16/+12
| |
* | all mapped clients now should have a group, so simplify some casesokan2014-02-073-7/+3
| |
* | If _NET_WM_DESKTOP is set to -1 during client creation, place the client intookan2014-02-071-28/+12
| | | | | | | | | | | | | | | | | | | | | | | | group 0 (nogroup); solves problem initially discovered by oga@nicotinebsd with tint2. A clientmessage *after* client creation already handles this case. Go further and assign every client to a group; in non-sticky mode, group 0 (nogroup) and sticky mode, the active group. In both cases, autogroup will override the group assignment. Removing a group from a client always places the client back into group 0 (nogroup). Autogroup can also assign a client to group 0 (nogroup) to keep a client always visible (unless of course one opts to hide all clients).
* | Some clients set the urgency flag even if they are the active client;okan2014-02-061-1/+2
| | | | | | | | | | prevent annoying behavior by only setting the cwm urgency flag if the client is not active; diff from Thomas Adam.
* | Introduce a region queue and replace screen's XineramaScreenInfo; weokan2014-02-032-24/+34
| | | | | | | | | | still use Xinerama to populate the regions per screen, but will switch at a more appropriate time.
* | make this XQueryTree like the otherokan2014-02-031-12/+10
| |
* | Move redundant bits from screen_init (while dealing with existingokan2014-02-034-15/+17
| | | | | | | | | | | | 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.