X-Git-Url: https://git.danieliu.xyz/?a=blobdiff_plain;f=main.c;h=0a39c15da597fa1923d965635b67b1f8bce59425;hb=0f3acce0429bc5d2906eaf9279abc5565b189d33;hp=6ef9ea76af96b2be89254340b81f86dfbb4a74e5;hpb=e571de83e94c60ec3737e93145e6ffdce5de9c58;p=dwm.git diff --git a/main.c b/main.c index 6ef9ea7..0a39c15 100644 --- a/main.c +++ b/main.c @@ -196,6 +196,7 @@ main(int argc, char *argv[]) XSetErrorHandler(NULL); xerrorxlib = XSetErrorHandler(xerror); + XSync(dpy, False); /* init atoms */ wmatom[WMProtocols] = XInternAtom(dpy, "WM_PROTOCOLS", False); @@ -262,20 +263,12 @@ main(int argc, char *argv[]) if(readin) FD_SET(STDIN_FILENO, &rd); FD_SET(xfd, &rd); - - i = select(xfd + 1, &rd, 0, 0, 0); + i = select(xfd + 1, &rd, NULL, NULL, NULL); if(i == -1 && errno == EINTR) continue; if(i < 0) eprint("select failed\n"); else if(i > 0) { - if(FD_ISSET(xfd, &rd)) { - while(XPending(dpy)) { - XNextEvent(dpy, &ev); - if(handler[ev.type]) - (handler[ev.type])(&ev); /* call handler */ - } - } if(readin && FD_ISSET(STDIN_FILENO, &rd)) { readin = NULL != fgets(stext, sizeof(stext), stdin); if(readin) @@ -284,9 +277,15 @@ main(int argc, char *argv[]) strcpy(stext, "broken pipe"); drawstatus(); } + if(FD_ISSET(xfd, &rd)) { + while(XPending(dpy)) { + XNextEvent(dpy, &ev); + if(handler[ev.type]) + (handler[ev.type])(&ev); /* call handler */ + } + } } } - cleanup(); XCloseDisplay(dpy);