use the focus stack to determine stacking order
Suddenly we have autoraise!
This commit is contained in:
		
							parent
							
								
									a5a7445dee
								
							
						
					
					
						commit
						e6bcf95e2e
					
				
							
								
								
									
										8
									
								
								dwl.c
									
									
									
									
									
								
							
							
						
						
									
										8
									
								
								dwl.c
									
									
									
									
									
								
							| @ -822,9 +822,9 @@ rendermon(struct wl_listener *listener, void *data) | ||||
| 	wlr_renderer_clear(drw, rootcolor); | ||||
| 
 | ||||
| 	/* Each subsequent window we render is rendered on top of the last. Because
 | ||||
| 	 * our client list is ordered front-to-back, we iterate over it backwards. */ | ||||
| 	 * our focus stack is ordered front-to-back, we iterate over it backwards. */ | ||||
| 	Client *c; | ||||
| 	wl_list_for_each_reverse(c, &clients, link) { | ||||
| 	wl_list_for_each_reverse(c, &fstack, flink) { | ||||
| 		/* Only render clients which are on this monitor. */ | ||||
| 		/* XXX consider checking wlr_output_layout_intersects, in case a
 | ||||
| 		 * window can be seen on multiple outputs */ | ||||
| @ -1241,9 +1241,9 @@ xytoclient(double x, double y, | ||||
| 		struct wlr_surface **surface, double *sx, double *sy) | ||||
| { | ||||
| 	/* This iterates over all of our surfaces and attempts to find one under the
 | ||||
| 	 * cursor. This relies on clients being ordered from top-to-bottom. */ | ||||
| 	 * cursor. This relies on fstack being ordered from top-to-bottom. */ | ||||
| 	Client *c; | ||||
| 	wl_list_for_each(c, &clients, link) { | ||||
| 	wl_list_for_each(c, &fstack, flink) { | ||||
| 		/* Skip clients that aren't visible */ | ||||
| 		if (!VISIBLEON(c, c->mon)) | ||||
| 			continue; | ||||
|  | ||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user