aewl
changeset 63:f14858218641
searching for a better way to discard enter notifies
author | Anselm R. Garbe <garbeam@wmii.de> |
---|---|
date | Fri, 14 Jul 2006 13:03:53 +0200 (2006-07-14) |
parents | 0a4b066ce254 |
children | 46d44d185464 |
files | client.c dwm.h event.c util.c |
diffstat | 4 files changed, 12 insertions(+), 54 deletions(-) [+] |
line diff
1.1 --- a/client.c Fri Jul 14 12:11:24 2006 +0200 1.2 +++ b/client.c Fri Jul 14 13:03:53 2006 +0200 1.3 @@ -28,17 +28,19 @@ 1.4 void 1.5 zoom(Arg *arg) 1.6 { 1.7 - Client **l, *old; 1.8 + Client **l; 1.9 1.10 - if(!(old = sel)) 1.11 + if(!sel) 1.12 return; 1.13 1.14 + if(sel == next(clients)) 1.15 + sel = next(sel->next); 1.16 + 1.17 for(l = &clients; *l && *l != sel; l = &(*l)->next); 1.18 *l = sel->next; 1.19 1.20 - old->next = clients; /* pop */ 1.21 - clients = old; 1.22 - sel = old; 1.23 + sel->next = clients; /* pop */ 1.24 + clients = sel; 1.25 arrange(NULL); 1.26 focus(sel); 1.27 } 1.28 @@ -54,7 +56,6 @@ 1.29 sel->h = sh - 2 * sel->border - bh; 1.30 craise(sel); 1.31 resize(sel, False); 1.32 - discard_events(EnterWindowMask); 1.33 } 1.34 1.35 void 1.36 @@ -65,9 +66,6 @@ 1.37 tsel = arg->i; 1.38 arrange(NULL); 1.39 1.40 - if((c = next(clients))) 1.41 - focus(c); 1.42 - 1.43 for(c = clients; c; c = next(c->next)) 1.44 draw_client(c); 1.45 draw_bar(); 1.46 @@ -120,7 +118,6 @@ 1.47 focus(sel); 1.48 } 1.49 } 1.50 - discard_events(EnterWindowMask); 1.51 } 1.52 1.53 void 1.54 @@ -171,13 +168,12 @@ 1.55 else 1.56 ban_client(c); 1.57 } 1.58 - if(sel && !sel->tags[tsel]) { 1.59 + if(!sel || (sel && !sel->tags[tsel])) { 1.60 if((sel = next(clients))) { 1.61 craise(sel); 1.62 focus(sel); 1.63 } 1.64 } 1.65 - discard_events(EnterWindowMask); 1.66 } 1.67 1.68 void 1.69 @@ -323,14 +319,16 @@ 1.70 focus(Client *c) 1.71 { 1.72 Client *old = sel; 1.73 + XEvent ev; 1.74 1.75 + XFlush(dpy); 1.76 sel = c; 1.77 if(old && old != c) 1.78 draw_client(old); 1.79 draw_client(c); 1.80 XSetInputFocus(dpy, c->win, RevertToPointerRoot, CurrentTime); 1.81 XFlush(dpy); 1.82 - discard_events(EnterWindowMask); 1.83 + while(XCheckMaskEvent(dpy, EnterWindowMask, &ev)); 1.84 } 1.85 1.86 static void
2.1 --- a/dwm.h Fri Jul 14 12:11:24 2006 +0200 2.2 +++ b/dwm.h Fri Jul 14 13:03:53 2006 +0200 2.3 @@ -137,9 +137,6 @@ 2.4 extern unsigned int textw(char *text); 2.5 extern unsigned int texth(void); 2.6 2.7 -/* event.c */ 2.8 -extern void discard_events(long even_mask); 2.9 - 2.10 /* dev.c */ 2.11 extern void update_keys(void); 2.12 extern void keypress(XEvent *e); 2.13 @@ -155,8 +152,5 @@ 2.14 /* util.c */ 2.15 extern void error(const char *errstr, ...); 2.16 extern void *emallocz(unsigned int size); 2.17 -extern void *emalloc(unsigned int size); 2.18 -extern void *erealloc(void *ptr, unsigned int size); 2.19 -extern char *estrdup(const char *str); 2.20 extern void spawn(Arg *arg); 2.21 extern void swap(void **p1, void **p2);
3.1 --- a/event.c Fri Jul 14 12:11:24 2006 +0200 3.2 +++ b/event.c Fri Jul 14 13:03:53 2006 +0200 3.3 @@ -4,6 +4,7 @@ 3.4 */ 3.5 3.6 #include <fcntl.h> 3.7 +#include <stdio.h> 3.8 #include <stdlib.h> 3.9 #include <string.h> 3.10 #include <X11/keysym.h> 3.11 @@ -37,13 +38,6 @@ 3.12 [UnmapNotify] = unmapnotify 3.13 }; 3.14 3.15 -void 3.16 -discard_events(long even_mask) 3.17 -{ 3.18 - XEvent ev; 3.19 - while(XCheckMaskEvent(dpy, even_mask, &ev)); 3.20 -} 3.21 - 3.22 static void 3.23 buttonpress(XEvent *e) 3.24 {
4.1 --- a/util.c Fri Jul 14 12:11:24 2006 +0200 4.2 +++ b/util.c Fri Jul 14 13:03:53 2006 +0200 4.3 @@ -6,7 +6,6 @@ 4.4 #include <stdarg.h> 4.5 #include <stdio.h> 4.6 #include <stdlib.h> 4.7 -#include <string.h> 4.8 #include <sys/types.h> 4.9 #include <sys/wait.h> 4.10 #include <unistd.h> 4.11 @@ -39,33 +38,6 @@ 4.12 return res; 4.13 } 4.14 4.15 -void * 4.16 -emalloc(unsigned int size) 4.17 -{ 4.18 - void *res = malloc(size); 4.19 - if(!res) 4.20 - bad_malloc(size); 4.21 - return res; 4.22 -} 4.23 - 4.24 -void * 4.25 -erealloc(void *ptr, unsigned int size) 4.26 -{ 4.27 - void *res = realloc(ptr, size); 4.28 - if(!res) 4.29 - bad_malloc(size); 4.30 - return res; 4.31 -} 4.32 - 4.33 -char * 4.34 -estrdup(const char *str) 4.35 -{ 4.36 - char *res = strdup(str); 4.37 - if(!res) 4.38 - bad_malloc(strlen(str)); 4.39 - return res; 4.40 -} 4.41 - 4.42 void 4.43 swap(void **p1, void **p2) 4.44 {