implemented NET_ACTIVE_WINDOW support
authorAnselm R.Garbe <arg@10ksloc.org>
Tue, 8 Aug 2006 15:08:45 +0000 (17:08 +0200)
committerAnselm R.Garbe <arg@10ksloc.org>
Tue, 8 Aug 2006 15:08:45 +0000 (17:08 +0200)
client.c
dwm.h
event.c
main.c

index f92df83bb8a52b07cef20284d699c2bdafe84fa3..9b91ab65df2fdbaefcd907893f6e6cad926a4f94 100644 (file)
--- a/client.c
+++ b/client.c
@@ -58,6 +58,8 @@ focus(Client *c)
        drawtitle(c);
        XSetInputFocus(dpy, c->win, RevertToPointerRoot, CurrentTime);
        XSync(dpy, False);
+       XChangeProperty(dpy, root, netatom[NetActiveWindow], XA_WINDOW, 32,
+                       PropModeReplace, (unsigned char *)&c->win, 1);
        while(XCheckMaskEvent(dpy, EnterWindowMask, &ev));
 }
 
@@ -459,6 +461,9 @@ unmanage(Client *c)
        arrange(NULL);
        if(sel)
                focus(sel);
+       else
+               XChangeProperty(dpy, root, netatom[NetActiveWindow], XA_WINDOW, 32,
+                               PropModeReplace, (unsigned char *)NULL, 1);
 }
 
 void
diff --git a/dwm.h b/dwm.h
index 57d628abfc3e47638a9503883677ed180f59bed6..efef213d25547c9c7c688d7a5ca533e915ec5114 100644 (file)
--- a/dwm.h
+++ b/dwm.h
@@ -22,7 +22,7 @@ union Arg {
 };
 
 /* atoms */
-enum { NetSupported, NetWMName, NetLast };
+enum { NetSupported, NetWMName, NetActiveWindow, NetLast };
 enum { WMProtocols, WMDelete, WMLast };
 
 /* cursor */
diff --git a/event.c b/event.c
index 2e4f62ee74277de12b1babc8d2e2c9fe4aae0b3a..c3169aa7001c3434f214028d6371c38985f048c4 100644 (file)
--- a/event.c
+++ b/event.c
@@ -145,6 +145,18 @@ buttonpress(XEvent *e)
        }
 }
 
+static void
+clientmessage(XEvent *e)
+{
+       Client *c;
+       XClientMessageEvent *ev = &e->xclient;
+
+       if(ev->message_type == netatom[NetActiveWindow]) {
+               if((c = getclient(ev->window)) && c->tags[tsel])
+                       focus(c);
+       }
+}
+
 static void
 configurerequest(XEvent *e)
 {
@@ -339,6 +351,7 @@ unmapnotify(XEvent *e)
 
 void (*handler[LASTEvent]) (XEvent *) = {
        [ButtonPress] = buttonpress,
+       [ClientMessage] = clientmessage,
        [ConfigureRequest] = configurerequest,
        [DestroyNotify] = destroynotify,
        [EnterNotify] = enternotify,
diff --git a/main.c b/main.c
index 5efe59976ba83b1747ff85a9044c14e98cf8e97f..ded47614f73539b42d736be85d8ab0eec202e301 100644 (file)
--- a/main.c
+++ b/main.c
@@ -201,6 +201,7 @@ main(int argc, char *argv[])
        wmatom[WMDelete] = XInternAtom(dpy, "WM_DELETE_WINDOW", False);
        netatom[NetSupported] = XInternAtom(dpy, "_NET_SUPPORTED", False);
        netatom[NetWMName] = XInternAtom(dpy, "_NET_WM_NAME", False);
+       netatom[NetActiveWindow] = XInternAtom(dpy, "_NET_ACTIVE_WINDOW", False);
        XChangeProperty(dpy, root, netatom[NetSupported], XA_ATOM, 32,
                        PropModeReplace, (unsigned char *) netatom, NetLast);