grabbuttons() and grabkeys() are now independent from prior numlockmask initialization
This commit is contained in:
		
							parent
							
								
									6411aa921b
								
							
						
					
					
						commit
						288cf78b18
					
				
							
								
								
									
										54
									
								
								dwm.c
									
									
									
									
									
								
							
							
						
						
									
										54
									
								
								dwm.c
									
									
									
									
									
								
							| @ -191,6 +191,7 @@ static void unmanage(Client *c); | |||||||
| static void unmapnotify(XEvent *e); | static void unmapnotify(XEvent *e); | ||||||
| static void updatebar(void); | static void updatebar(void); | ||||||
| static void updategeom(void); | static void updategeom(void); | ||||||
|  | static void updatenumlockmask(void); | ||||||
| static void updatesizehints(Client *c); | static void updatesizehints(Client *c); | ||||||
| static void updatetitle(Client *c); | static void updatetitle(Client *c); | ||||||
| static void updatewmhints(Client *c); | static void updatewmhints(Client *c); | ||||||
| @ -735,34 +736,27 @@ gettextprop(Window w, Atom atom, char *text, unsigned int size) { | |||||||
| 
 | 
 | ||||||
| void | void | ||||||
| grabbuttons(Client *c, Bool focused) { | grabbuttons(Client *c, Bool focused) { | ||||||
| 	unsigned int i, j; | 	updatenumlockmask(); | ||||||
| 	unsigned int modifiers[] = { 0, LockMask, numlockmask, numlockmask|LockMask }; | 	{ | ||||||
| 
 | 		unsigned int i, j; | ||||||
| 	XUngrabButton(dpy, AnyButton, AnyModifier, c->win); | 		unsigned int modifiers[] = { 0, LockMask, numlockmask, numlockmask|LockMask }; | ||||||
| 	if(focused) { | 		XUngrabButton(dpy, AnyButton, AnyModifier, c->win); | ||||||
| 		for(i = 0; i < LENGTH(buttons); i++) | 		if(focused) { | ||||||
| 			if(buttons[i].click == ClkClientWin) | 			for(i = 0; i < LENGTH(buttons); i++) | ||||||
| 				for(j = 0; j < LENGTH(modifiers); j++) | 				if(buttons[i].click == ClkClientWin) | ||||||
| 					XGrabButton(dpy, buttons[i].button, buttons[i].mask | modifiers[j], c->win, False, BUTTONMASK, GrabModeAsync, GrabModeSync, None, None); | 					for(j = 0; j < LENGTH(modifiers); j++) | ||||||
| 	} else | 						XGrabButton(dpy, buttons[i].button, buttons[i].mask | modifiers[j], c->win, False, BUTTONMASK, GrabModeAsync, GrabModeSync, None, None); | ||||||
| 		XGrabButton(dpy, AnyButton, AnyModifier, c->win, False, | 		} else | ||||||
| 		            BUTTONMASK, GrabModeAsync, GrabModeSync, None, None); | 			XGrabButton(dpy, AnyButton, AnyModifier, c->win, False, | ||||||
|  | 			            BUTTONMASK, GrabModeAsync, GrabModeSync, None, None); | ||||||
|  | 	} | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void | void | ||||||
| grabkeys(void) { | grabkeys(void) { | ||||||
| 	unsigned int i, j; | 	updatenumlockmask(); | ||||||
| 	XModifierKeymap *modmap; |  | ||||||
| 
 |  | ||||||
| 	/* update modifier map */ |  | ||||||
| 	modmap = XGetModifierMapping(dpy); |  | ||||||
| 	for(i = 0; i < 8; i++) |  | ||||||
| 		for(j = 0; j < modmap->max_keypermod; j++) |  | ||||||
| 			if(modmap->modifiermap[i * modmap->max_keypermod + j] == XKeysymToKeycode(dpy, XK_Num_Lock)) |  | ||||||
| 				numlockmask = (1 << i); |  | ||||||
| 	XFreeModifiermap(modmap); |  | ||||||
| 
 |  | ||||||
| 	{ /* grab keys */ | 	{ /* grab keys */ | ||||||
|  | 		unsigned int i, j; | ||||||
| 		unsigned int modifiers[] = { 0, LockMask, numlockmask, numlockmask|LockMask }; | 		unsigned int modifiers[] = { 0, LockMask, numlockmask, numlockmask|LockMask }; | ||||||
| 		KeyCode code; | 		KeyCode code; | ||||||
| 
 | 
 | ||||||
| @ -1575,6 +1569,20 @@ updategeom(void) { | |||||||
| 	by = showbar ? (topbar ? wy - bh : wy + wh) : -bh; | 	by = showbar ? (topbar ? wy - bh : wy + wh) : -bh; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | void | ||||||
|  | updatenumlockmask(void) { | ||||||
|  | 	unsigned int i, j; | ||||||
|  | 	XModifierKeymap *modmap; | ||||||
|  | 
 | ||||||
|  | 	numlockmask = 0; | ||||||
|  | 	modmap = XGetModifierMapping(dpy); | ||||||
|  | 	for(i = 0; i < 8; i++) | ||||||
|  | 		for(j = 0; j < modmap->max_keypermod; j++) | ||||||
|  | 			if(modmap->modifiermap[i * modmap->max_keypermod + j] == XKeysymToKeycode(dpy, XK_Num_Lock)) | ||||||
|  | 				numlockmask = (1 << i); | ||||||
|  | 	XFreeModifiermap(modmap); | ||||||
|  | } | ||||||
|  | 
 | ||||||
| void | void | ||||||
| updatesizehints(Client *c) { | updatesizehints(Client *c) { | ||||||
| 	long msize; | 	long msize; | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user
	 Anselm R Garbe
						Anselm R Garbe