aboutsummaryrefslogtreecommitdiffstats
path: root/client.c (follow)
Commit message (Collapse)AuthorAgeLines
...
* re-use geom struct in client_ctx (saved)geometry.okan2012-07-13-52/+52
|
* convert xmax/ymax uses to view geometry.okan2012-07-13-8/+8
|
* fix missing atom (WM_PROTOCOLS) wrt new style handing; without this, theokan2012-07-04-2/+2
| | | | | | | window manager didn't know if a client supported CLIENT_PROTO_DELETE and thus used a hammer, XKillClient. behaviour reported by Tim van der Molen.
* re-implement atom handing; makes for a normalized and more consistentokan2012-07-03-34/+14
| | | | separation between cwm and ewmh. seen by a few.
* cycle through other common cycling modifiers; based on a diff fromokan2012-05-16-1/+13
| | | | | | Alexander Polakov. ok sthen@
* altpersist->cycling to be more clear that this is for cycling modokan2012-05-13-4/+4
| | | | | persistence; based on a diff from Alexander Polakov, in preparation for looping through other potential cycling modifiers.
* knf, some from a diff from Tiago Cunha.okan2012-05-13-8/+10
|
* add WM_TRANSIENT_FOR event support: moves dialogs, toolbars and such tookan2011-09-13-1/+18
| | | | | | | the group of the main application window; based on a diff from Alexander Polakov with CLIENT_IGNORE flag suggestion from oga@. ok oga@
* restore a comment and add another for clarity.okan2011-09-05-2/+6
|
* Make flavours of maximisation additive.oga2011-09-04-66/+94
| | | | | | | | | | i.e. horiz-max + vertmax = full maximisation. full - horiz = vertmax. etc. Martynas wrote something like this once, so I did okan, this version seems to finally deal with the corner cases. ok okan@.
* split off window hints from geometry so we don't need to carry them allokan2011-09-03-38/+38
| | | | around when dealing with {,h,v}max. same idea from oga.
* Add {r,}cycleingroup to cycle through clients belonging to the sameokan2011-09-03-5/+6
| | | | | | | group as the active client (as opposed to all unhidden clients); from Alexander Polakov, with a tiny tweak requested by oga. ok oga@
* correct spelling; from Alexander Polakov.okan2011-07-14-2/+2
|
* introduce a new config option to snap to the screen edge. 'snapdist'okan2011-06-24-1/+30
| | | | | | | | keyword taken from a diff from Sviatoslav Chagaev to do the same thing, but implemented in a completely way (based on some very old code from mk@). default set to 0, so no behavior change. ok oga@ (who would also like to take it further...)
* re-do various bits of {,h,v}max for simplicity and less flag handling.okan2011-06-24-28/+15
| | | | | | | as a bonus, flipping between various combinations of vmax+hmax provides a more predictable behavior. commitski oga@
* alter a few function returns and prototypes; found by lint.okan2011-06-24-14/+7
| | | | ok oga@
* tag and comment cleanup; ok oga@okan2011-05-11-1/+1
|
* introduce a new 'freeze' flag (CMS-f by default) which may be applied tookan2011-05-07-1/+19
| | | | | | | | | | | | | any window, after which all move/resize requests will be ignored, essentially freezing the window in place. there's a possibility to merge this with the 'ignore' concept, pending on how ignore+freeze should behave (really more ewmh stuff), but punting for now since ponies are on the line. requested and tested by thib at k2k11 with ponies, unicorns and rainbows. 'save the unicorns' todd@, ok oga@
* if virt/horz un-maximizing, restore only the un-maximized axisokan2011-03-22-1/+6
| | | | | | | | | coordinates; allows moving a client and not restoring the maximized axis coordinates. picked from a larger martynas diff from ages ago. ok oga@
* while this piece deals with client argv's in a seemingly inefficient wayokan2011-03-22-27/+1
| | | | | | | (noticed by Tim Peniket), since we don't ever do anything with cliarg, remove the hunk and cliarg completely. ok oga@
* remove XXX and move a configure event out of the event handler functions.okan2011-03-22-4/+4
| | | | | | reminded by a similiar diff from Thomas Pfaff. ok oga@
* if we are saving the pointer location for a specific client, make sureokan2011-02-13-1/+4
| | | | | | | | | | | that if it is not already inbounds, put it in the default location, which happens to be inbounds. behavior noticed by Thomas Pfaff while maximizing and un-maximizing a window, leaving the pointer behind and causing client_cycle() to be a bit lost. ok oga@
* replace XFetchName() with something more intelligent which attempts tookan2010-05-22-4/+5
| | | | | | | | use the appropriate netwm Atom first, as well as deal with utf8. slightly different incarnation tested by sthen@ and ajacoutot@ - thanks! ok oga@
* clean up a few xu_* functions to just accept what they need (Window).okan2010-04-11-4/+4
| | | | ok oga@
* Honour program-specified window position in size hints when placing windows.stsp2010-02-02-2/+2
| | | | | | Makes XMMS windows appear as expected. ok okan, oga
* - allow per-screen gap; not (yet) user configurable.okan2010-01-27-21/+21
| | | | | | - teach _NET_WORKAREA about gap. ok oga@
* pull all non-X11 headers from calmwm.h and place them only where theyokan2009-12-15-1/+10
| | | | | | are required. encourged to go all the way by oga@
* pull these headers only into files that need them.okan2009-12-15-1/+3
| | | | ok oga@
* merge the 2 common header files; specific includes to be pulled out asokan2009-12-15-2/+1
| | | | | | separate commits. ok oga@
* finish unfucking the screen_ctx handling.oga2009-12-10-4/+2
| | | | | | | | | | | | | remove screen_current() it was utterly bogus when nscreens > 1. pass a fake client_ctx in the case where there's no client and the kbfunc or mousefunc doesn't need a real one, it just contains the current screen, modify these functions so that they pass down the screen context to their callees. make groups per screen, it's the only way it makes sense in this regard. ok okan@.
* support _NET_CLIENT_LIST.oga2009-12-07-1/+24
| | | | | | | | the x property api doesn't let you remove one entry from an X property array, so client_remove is kinda expensive, but there's no real way around that.. ok okan@
* Implement _NET_ACTIVE_WINDOW. for now just the informational hint isoga2009-12-07-3/+20
| | | | | | | supported, the client message to change this will be supported when all informational hints are working. ok okan@
* style (whitespaces)tobias2009-11-28-4/+4
| | | | ok oga, okan
* With Xinerama enabled, the borders of a maximized window will show up onoga2009-09-25-3/+8
| | | | | | | | | all adjacent screens. This patch hides the borders while the window is maximized. From Bertrand Janin; thanks! ok okan@
* unroll the CCTOSC macro; from Thomas Pfaffokan2009-08-27-12/+12
| | | | ok oga@
* Instead of messing around everytime we do a resize, just clamp theoga2009-08-25-5/+6
| | | | | | resize increments to a minimum of one, and use it unconditionally. "you've convinced me, do it!" okan@
* unroll macro; ok oga@okan2009-08-25-4/+4
|
* Add a keybinding to allow horizontal maximisation of a window (CMS-enter).oga2009-08-24-4/+39
| | | | | | based on a diff by Thomas Pfaff; thanks! ok okan@
* bring together gathering, calculating and applying of size hints;okan2009-08-24-10/+92
| | | | | | additionally, respect aspect ratio hints. ok oga@
* Instead of having a function that just calls TAILQ_INIT on a global, useoga2009-08-24-7/+1
| | | | | | TAILQ_HEAD_INITIALIZER() and drop the function. ok okan@
* instead of checking for flags in the client context, then removing them.oga2009-08-24-3/+2
| | | | | | | | | | | e.g.: if (flags & flags_we_care_about) flags &= ~(flags_we_care_about); just whack the flags unconditionally, it's simpler. okan@ agrees.
* static local functions and data; almost identical diff from Thomas Pfaffokan2009-06-26-8/+14
| | | | ok oga@
* tidy up startup/init routinesokan2009-06-23-2/+2
| | | | ok oga@
* compact a bit by condensing a few if-else's; from Thomas Pfaffokan2009-06-20-11/+3
| | | | "go on then" oga@
* unroll XCALLOC/XMALLOC macros; since we use xcalloc/xmalloc all over theokan2009-06-20-3/+3
| | | | | | place anyway, this makes things a bit more consistent; from Thomas Pfaff ok oga@
* spacingokan2009-06-20-3/+1
|
* re-factor parts of mouse move/resize bit to shrink and make moreokan2009-06-17-6/+1
| | | | | | readable; no behavior change ok oga@
* re-order a bit for readability.okan2009-05-30-11/+8
| | | | "if it makes you happy" oga@
* nuke the leading underscore notation for local static functions - thereokan2009-05-18-4/+4
| | | | | | are far better ways to know. "go for it" oga@
* a long time coming - re-work the way we deal with colors: since we'reokan2009-05-17-9/+9
| | | | | | | | using Xft(3), use it to select the font color as well instead of trying to build one; properly allocate and free colors at-will, e.g. we now have configurable colors. feedback and ok's todd@ and oga@