mirror of
				https://codeberg.org/dwl/dwl.git
				synced 2025-11-03 09:01:45 -05:00 
			
		
		
		
	change border color according to focus state
This commit is contained in:
		
							parent
							
								
									05ac420342
								
							
						
					
					
						commit
						894f2a3152
					
				
					 1 changed files with 16 additions and 0 deletions
				
			
		
							
								
								
									
										16
									
								
								dwl.c
									
										
									
									
									
								
							
							
						
						
									
										16
									
								
								dwl.c
									
										
									
									
									
								
							| 
						 | 
					@ -1064,6 +1064,8 @@ focusclient(Client *c, int lift)
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
	struct wlr_surface *old = seat->keyboard_state.focused_surface;
 | 
						struct wlr_surface *old = seat->keyboard_state.focused_surface;
 | 
				
			||||||
	struct wlr_keyboard *kb;
 | 
						struct wlr_keyboard *kb;
 | 
				
			||||||
 | 
						Client *w;
 | 
				
			||||||
 | 
						int i;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	/* Raise client in stacking order if requested */
 | 
						/* Raise client in stacking order if requested */
 | 
				
			||||||
	if (c && lift) {
 | 
						if (c && lift) {
 | 
				
			||||||
| 
						 | 
					@ -1081,6 +1083,9 @@ focusclient(Client *c, int lift)
 | 
				
			||||||
		wl_list_insert(&fstack, &c->flink);
 | 
							wl_list_insert(&fstack, &c->flink);
 | 
				
			||||||
		selmon = c->mon;
 | 
							selmon = c->mon;
 | 
				
			||||||
		c->isurgent = 0;
 | 
							c->isurgent = 0;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							for (i = 0; i < 4; i++)
 | 
				
			||||||
 | 
								wlr_scene_rect_set_color(c->border[i], focuscolor);
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	/* Deactivate old client if focus is changing */
 | 
						/* Deactivate old client if focus is changing */
 | 
				
			||||||
| 
						 | 
					@ -1100,6 +1105,16 @@ focusclient(Client *c, int lift)
 | 
				
			||||||
						))
 | 
											))
 | 
				
			||||||
				return;
 | 
									return;
 | 
				
			||||||
		} else {
 | 
							} else {
 | 
				
			||||||
 | 
					#ifdef XWAYLAND
 | 
				
			||||||
 | 
								if (wlr_surface_is_xwayland_surface(old))
 | 
				
			||||||
 | 
									w = wlr_xwayland_surface_from_wlr_surface(old)->data;
 | 
				
			||||||
 | 
								else
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
									w = wlr_xdg_surface_from_wlr_surface(old)->data;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
								for (i = 0; i < 4; i++)
 | 
				
			||||||
 | 
									wlr_scene_rect_set_color(w->border[i], bordercolor);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
			client_activate_surface(old, 0);
 | 
								client_activate_surface(old, 0);
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
| 
						 | 
					@ -1305,6 +1320,7 @@ mapnotify(struct wl_listener *listener, void *data)
 | 
				
			||||||
	for (i = 0; i < 4; i++) {
 | 
						for (i = 0; i < 4; i++) {
 | 
				
			||||||
		c->border[i] = wlr_scene_rect_create(c->scene, 0, 0, bordercolor);
 | 
							c->border[i] = wlr_scene_rect_create(c->scene, 0, 0, bordercolor);
 | 
				
			||||||
		c->border[i]->node.data = c;
 | 
							c->border[i]->node.data = c;
 | 
				
			||||||
 | 
							wlr_scene_rect_set_color(c->border[i], bordercolor);
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if (client_is_unmanaged(c)) {
 | 
						if (client_is_unmanaged(c)) {
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue