we close stdin as well
authorAnselm R.Garbe <arg@10ksloc.org>
Wed, 16 Aug 2006 07:31:41 +0000 (09:31 +0200)
committerAnselm R.Garbe <arg@10ksloc.org>
Wed, 16 Aug 2006 07:31:41 +0000 (09:31 +0200)
main.c

diff --git a/main.c b/main.c
index 545efe9c422b0a05d36d2e4ec5c27fc25e29fed0..50fb9d72dcf631e9c8c2c4394b16a95ecd3f008f 100644 (file)
--- a/main.c
+++ b/main.c
 /* static */
 
 static int (*xerrorxlib)(Display *, XErrorEvent *);
-static Bool otherwm;
+static Bool otherwm, readin;
 
 static void
 cleanup()
 {
+       close(STDIN_FILENO);
        while(sel) {
                resize(sel, True, TopLeft);
                unmanage(sel);
@@ -146,7 +147,7 @@ sendevent(Window w, Atom a, long value)
 void
 quit(Arg *arg)
 {
-       running = False;
+       readin = running = False;
 }
 
 /*
@@ -176,7 +177,6 @@ main(int argc, char *argv[])
        int i, j, xfd;
        unsigned int mask;
        fd_set rd;
-       Bool readin = True;
        Window w;
        XModifierKeymap *modmap;
        XSetWindowAttributes wa;
@@ -279,6 +279,7 @@ main(int argc, char *argv[])
        /* main event loop, also reads status text from stdin */
        XSync(dpy, False);
        procevent();
+       readin = True;
        while(running) {
                FD_ZERO(&rd);
                if(readin)