making enternotify less focus hungry
This commit is contained in:
		
							parent
							
								
									92fe06b501
								
							
						
					
					
						commit
						3a392b8558
					
				
					 2 changed files with 4 additions and 21 deletions
				
			
		
							
								
								
									
										21
									
								
								BUGS
									
										
									
									
									
								
							
							
						
						
									
										21
									
								
								BUGS
									
										
									
									
									
								
							|  | @ -8,27 +8,6 @@ reproducible with xrandr -s but not with --output and --mode, strange | |||
| 
 | ||||
| --- | ||||
| 
 | ||||
| > enternotify is handled even when the entered window is already focused | ||||
| > (eg moving the mouse to the bar and back, scrolling on the border..) | ||||
| > | ||||
| > focusing might be expensive for some clients (eg dim/light up) | ||||
| > | ||||
| > a possible solution is to modify enternotify: | ||||
| > | ||||
| > +       c = wintoclient(ev->window); | ||||
| >        if((m = wintomon(ev->window)) && m != selmon) { | ||||
| >                unfocus(selmon->sel); | ||||
| >                selmon = m; | ||||
| >        } | ||||
| > +       else if (c == selmon->sel || c == NULL) | ||||
| > +               return; | ||||
| 
 | ||||
| --- | ||||
| 
 | ||||
| dmenu appears on the monitor where the pointer is and not on selmon | ||||
| 
 | ||||
| --- | ||||
| 
 | ||||
| yet another corner case: | ||||
| open a terminal, focus another monitor, but without moving the mouse | ||||
| pointer there | ||||
|  |  | |||
							
								
								
									
										4
									
								
								dwm.c
									
										
									
									
									
								
							
							
						
						
									
										4
									
								
								dwm.c
									
										
									
									
									
								
							|  | @ -820,15 +820,19 @@ drawtext(const char *text, unsigned long col[ColLast], Bool invert) { | |||
| 
 | ||||
| void | ||||
| enternotify(XEvent *e) { | ||||
| 	Client *c; | ||||
| 	Monitor *m; | ||||
| 	XCrossingEvent *ev = &e->xcrossing; | ||||
| 
 | ||||
| 	if((ev->mode != NotifyNormal || ev->detail == NotifyInferior) && ev->window != root) | ||||
| 		return; | ||||
| 	c = wintoclient(ev->window); | ||||
| 	if((m = wintomon(ev->window)) && m != selmon) { | ||||
| 		unfocus(selmon->sel, True); | ||||
| 		selmon = m; | ||||
| 	} | ||||
| 	else if(c == selmon->sel || c == NULL) | ||||
| 		return; | ||||
| 	focus((wintoclient(ev->window))); | ||||
| } | ||||
| 
 | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue