diff options
author | Owain Ainsworth <oga@cvs.openbsd.org> | 2009-12-07 22:22:00 +0000 |
---|---|---|
committer | Owain Ainsworth <oga@cvs.openbsd.org> | 2009-12-07 22:22:00 +0000 |
commit | c292d9c54c266dce273998b869f9987f1e3474a8 (patch) | |
tree | 8ec537b1eff92f367ae8829e003d9959c96f1db6 | |
parent | 638ccb831275de783d2b12a36bc54e176350a19b (diff) |
Implement _NET_ACTIVE_WINDOW. for now just the informational hint is
supported, the client message to change this will be supported when all
informational hints are working.
ok okan@
-rw-r--r-- | app/cwm/calmwm.h | 5 | ||||
-rw-r--r-- | app/cwm/client.c | 23 | ||||
-rw-r--r-- | app/cwm/xutil.c | 3 |
3 files changed, 25 insertions, 6 deletions
diff --git a/app/cwm/calmwm.h b/app/cwm/calmwm.h index 4f3fcf9a8..b533103a9 100644 --- a/app/cwm/calmwm.h +++ b/app/cwm/calmwm.h @@ -15,7 +15,7 @@ * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. * - * $Id: calmwm.h,v 1.99 2009/12/07 21:20:52 okan Exp $ + * $Id: calmwm.h,v 1.100 2009/12/07 22:21:59 oga Exp $ */ #ifndef _CALMWM_H_ @@ -526,7 +526,8 @@ extern struct conf Conf; #define _NET_SUPPORTED cwm_atoms[7] #define _NET_SUPPORTING_WM_CHECK cwm_atoms[8] #define _NET_WM_NAME cwm_atoms[9] -#define CWM_NO_ATOMS 10 +#define _NET_ACTIVE_WINDOW cwm_atoms[10] +#define CWM_NO_ATOMS 11 #define CWM_NETWM_START 7 extern Atom cwm_atoms[CWM_NO_ATOMS]; diff --git a/app/cwm/client.c b/app/cwm/client.c index 8531b9e3b..16f5fd56d 100644 --- a/app/cwm/client.c +++ b/app/cwm/client.c @@ -15,7 +15,7 @@ * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. * - * $Id: client.c,v 1.66 2009/11/28 17:52:12 tobias Exp $ + * $Id: client.c,v 1.67 2009/12/07 22:21:59 oga Exp $ */ #include "headers.h" @@ -23,6 +23,7 @@ static struct client_ctx *client_mrunext(struct client_ctx *); static struct client_ctx *client_mruprev(struct client_ctx *); +static void client_none(struct screen_ctx *); static void client_placecalc(struct client_ctx *); static void client_update(struct client_ctx *); static void client_gethints(struct client_ctx *); @@ -142,7 +143,7 @@ client_delete(struct client_ctx *cc) TAILQ_REMOVE(&Clientq, cc, entry); if (_curcc == cc) - _curcc = NULL; + client_none(sc); XFree(cc->size); @@ -202,12 +203,28 @@ client_setactive(struct client_ctx *cc, int fg) if (fg && _curcc != cc) { client_setactive(NULL, 0); _curcc = cc; + XChangeProperty(X_Dpy, sc->rootwin, _NET_ACTIVE_WINDOW, + XA_WINDOW, 32, PropModeReplace, + (unsigned char *)&cc->win, 1); } cc->active = fg; client_draw_border(cc); } +/* + * set when there is no active client + */ +static void +client_none(struct screen_ctx *sc) +{ + Window none = None; + + XChangeProperty(X_Dpy, sc->rootwin, _NET_ACTIVE_WINDOW, + XA_WINDOW, 32, PropModeReplace, (unsigned char *)&none, 1); + _curcc = NULL; +} + struct client_ctx * client_current(void) { @@ -399,7 +416,7 @@ client_hide(struct client_ctx *cc) xu_setstate(cc, IconicState); if (cc == _curcc) - _curcc = NULL; + client_none(cc->sc); } void diff --git a/app/cwm/xutil.c b/app/cwm/xutil.c index 5bea7c3e3..a2ba9b9bf 100644 --- a/app/cwm/xutil.c +++ b/app/cwm/xutil.c @@ -15,7 +15,7 @@ * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. * - * $Id: xutil.c,v 1.18 2009/12/07 21:20:52 okan Exp $ + * $Id: xutil.c,v 1.19 2009/12/07 22:21:59 oga Exp $ */ #include "headers.h" @@ -181,6 +181,7 @@ char *atoms[CWM_NO_ATOMS] = { "_NET_SUPPORTED", "_NET_SUPPORTING_WM_CHECK", "_NET_WM_NAME", + "_NET_ACTIVE_WINDOW", }; void |