mirror of
				https://codeberg.org/dwl/dwl.git
				synced 2025-11-03 09:01:45 -05:00 
			
		
		
		
	refactor focusclient
This commit is contained in:
		
							parent
							
								
									7856cdc1bf
								
							
						
					
					
						commit
						ef7a37649c
					
				
					 1 changed files with 12 additions and 7 deletions
				
			
		
							
								
								
									
										19
									
								
								dwl.c
									
										
									
									
									
								
							
							
						
						
									
										19
									
								
								dwl.c
									
										
									
									
									
								
							| 
						 | 
					@ -673,6 +673,16 @@ focusclient(Client *old, Client *c, int lift)
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
	struct wlr_keyboard *kb = wlr_seat_get_keyboard(seat);
 | 
						struct wlr_keyboard *kb = wlr_seat_get_keyboard(seat);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						/* Raise client in stacking order if requested */
 | 
				
			||||||
 | 
						if (c && lift) {
 | 
				
			||||||
 | 
							wl_list_remove(&c->slink);
 | 
				
			||||||
 | 
							wl_list_insert(&stack, &c->slink);
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						/* Nothing else to do? */
 | 
				
			||||||
 | 
						if (c == old)
 | 
				
			||||||
 | 
							return;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	/* Deactivate old client if focus is changing */
 | 
						/* Deactivate old client if focus is changing */
 | 
				
			||||||
	if (c != old && old) {
 | 
						if (c != old && old) {
 | 
				
			||||||
		if (old->type != XDGShell)
 | 
							if (old->type != XDGShell)
 | 
				
			||||||
| 
						 | 
					@ -692,15 +702,10 @@ focusclient(Client *old, Client *c, int lift)
 | 
				
			||||||
	wlr_seat_keyboard_notify_enter(seat, WLR_SURFACE(c),
 | 
						wlr_seat_keyboard_notify_enter(seat, WLR_SURFACE(c),
 | 
				
			||||||
			kb->keycodes, kb->num_keycodes, &kb->modifiers);
 | 
								kb->keycodes, kb->num_keycodes, &kb->modifiers);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	/* Select client's monitor, move it to the top of the focus stack, and
 | 
						/* Put the new client atop the focus stack and select its monitor */
 | 
				
			||||||
	 * raise it in the stacking order if requested. */
 | 
					 | 
				
			||||||
	selmon = c->mon;
 | 
					 | 
				
			||||||
	wl_list_remove(&c->flink);
 | 
						wl_list_remove(&c->flink);
 | 
				
			||||||
	wl_list_insert(&fstack, &c->flink);
 | 
						wl_list_insert(&fstack, &c->flink);
 | 
				
			||||||
	if (lift) {
 | 
						selmon = c->mon;
 | 
				
			||||||
		wl_list_remove(&c->slink);
 | 
					 | 
				
			||||||
		wl_list_insert(&stack, &c->slink);
 | 
					 | 
				
			||||||
	}
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
	/* Activate the new client */
 | 
						/* Activate the new client */
 | 
				
			||||||
	if (c->type != XDGShell)
 | 
						if (c->type != XDGShell)
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue