added an creatnotify event handler
authorAnselm R. Garbe <arg@suckless.org>
Mon, 4 Jun 2007 09:50:48 +0000 (11:50 +0200)
committerAnselm R. Garbe <arg@suckless.org>
Mon, 4 Jun 2007 09:50:48 +0000 (11:50 +0200)
client.c
dwm.h
event.c
layout.c

index 06bc9d88feb773e790c60f87a9326de15863ce68..68d10a7333402f402fc317221f55120a4f4f9dd8 100644 (file)
--- a/client.c
+++ b/client.c
@@ -96,6 +96,14 @@ attach(Client *c) {
        clients = c;
 }
 
+void
+ban(Client *c) {
+       if (c->isbanned)
+               return;
+       XMoveWindow(dpy, c->win, c->x + 2 * sw, c->y);
+       c->isbanned = True;
+}
+
 void
 configure(Client *c) {
        XConfigureEvent ce;
@@ -298,6 +306,37 @@ togglefloating(const char *arg) {
        lt->arrange();
 }
 
+void
+unban(Client *c) {
+       if (!c->isbanned)
+               return;
+       XMoveWindow(dpy, c->win, c->x, c->y);
+       c->isbanned = False;
+}
+
+void
+unmanage(Client *c) {
+       XWindowChanges wc;
+
+       wc.border_width = c->oldborder;
+       /* The server grab construct avoids race conditions. */
+       XGrabServer(dpy);
+       XSetErrorHandler(xerrordummy);
+       XConfigureWindow(dpy, c->win, CWBorderWidth, &wc); /* restore border */
+       detach(c);
+       detachstack(c);
+       if(sel == c)
+               focus(NULL);
+       XUngrabButton(dpy, AnyButton, AnyModifier, c->win);
+       setclientstate(c, WithdrawnState);
+       free(c->tags);
+       free(c);
+       XSync(dpy, False);
+       XSetErrorHandler(xerror);
+       XUngrabServer(dpy);
+       lt->arrange();
+}
+
 void
 updatesizehints(Client *c) {
        long msize;
@@ -376,26 +415,3 @@ updatetitle(Client *c) {
        c->name[sizeof c->name - 1] = '\0';
        XFree(name.value);
 }
-
-void
-unmanage(Client *c) {
-       XWindowChanges wc;
-
-       wc.border_width = c->oldborder;
-       /* The server grab construct avoids race conditions. */
-       XGrabServer(dpy);
-       XSetErrorHandler(xerrordummy);
-       XConfigureWindow(dpy, c->win, CWBorderWidth, &wc); /* restore border */
-       detach(c);
-       detachstack(c);
-       if(sel == c)
-               focus(NULL);
-       XUngrabButton(dpy, AnyButton, AnyModifier, c->win);
-       setclientstate(c, WithdrawnState);
-       free(c->tags);
-       free(c);
-       XSync(dpy, False);
-       XSetErrorHandler(xerror);
-       XUngrabServer(dpy);
-       lt->arrange();
-}
diff --git a/dwm.h b/dwm.h
index bd190c6df034844337af55c140216379213f4267..999f02796e455b0a61be0491c9b9da3b9b5adb8a 100644 (file)
--- a/dwm.h
+++ b/dwm.h
@@ -96,6 +96,7 @@ extern Window root, barwin;
 
 /* client.c */
 void attach(Client *c);                        /* attaches c to global client list */
+void ban(Client *c);                   /* bans c */
 void configure(Client *c);             /* send synthetic configure event */
 void detach(Client *c);                        /* detaches c from global client list */
 void focus(Client *c);                 /* focus c if visible && !NULL, or focus top visible */
@@ -104,9 +105,10 @@ void manage(Window w, XWindowAttributes *wa);      /* manage new client */
 void resize(Client *c, int x, int y,
                int w, int h, Bool sizehints);  /* resize with given coordinates c*/
 void togglefloating(const char *arg);  /* toggles sel between floating/tiled state */
+void unban(Client *c);                 /* unbans c */
+void unmanage(Client *c);              /* destroy c */
 void updatesizehints(Client *c);       /* update the size hint variables of c */
 void updatetitle(Client *c);           /* update the name of c */
-void unmanage(Client *c);              /* destroy c */
 
 /* draw.c */
 void drawstatus(void);                 /* draw the bar */
diff --git a/event.c b/event.c
index ad4e271e328dbd975c4a43e4fcf93a8cc0289409..949812fe49814392f418e3575ffa1133961b9e96 100644 (file)
--- a/event.c
+++ b/event.c
@@ -224,6 +224,19 @@ configurenotify(XEvent *e) {
        }
 }
 
+static void
+createnotify(XEvent *e) {
+       static XWindowAttributes wa;
+       XCreateWindowEvent *ev = &e->xcreatewindow;
+
+       if(!XGetWindowAttributes(dpy, ev->window, &wa))
+               return;
+       if(wa.override_redirect)
+               return;
+       if(!getclient(ev->window) && (wa.map_state == IsViewable))
+               manage(ev->window, &wa);
+}
+
 static void
 destroynotify(XEvent *e) {
        Client *c;
@@ -350,6 +363,7 @@ void (*handler[LASTEvent]) (XEvent *) = {
        [ButtonPress] = buttonpress,
        [ConfigureRequest] = configurerequest,
        [ConfigureNotify] = configurenotify,
+       [CreateNotify] = createnotify,
        [DestroyNotify] = destroynotify,
        [EnterNotify] = enternotify,
        [LeaveNotify] = leavenotify,
index 0706c624a4d35edf601b09689913db32120ce492..acf0a8e7e49c75ea9be112048597933496fdcb16 100644 (file)
--- a/layout.c
+++ b/layout.c
@@ -11,22 +11,6 @@ static unsigned int nlayouts = 0;
 static unsigned int masterw = MASTERWIDTH;
 static unsigned int nmaster = NMASTER;
 
-static void
-ban(Client *c) {
-       if (c->isbanned)
-               return;
-       XMoveWindow(dpy, c->win, c->x + 2 * sw, c->y);
-       c->isbanned = True;
-}
-
-static void
-unban(Client *c) {
-       if (!c->isbanned)
-               return;
-       XMoveWindow(dpy, c->win, c->x, c->y);
-       c->isbanned = False;
-}
-
 static void
 tile(void) {
        unsigned int i, n, nx, ny, nw, nh, mw, mh, tw, th;