diff options
| author | Devin J. Pohly <djpohly@gmail.com> | 2022-02-15 14:16:20 -0600 | 
|---|---|---|
| committer | Devin J. Pohly <djpohly@gmail.com> | 2022-02-15 14:16:20 -0600 | 
| commit | 52a33a2f1ec91c11d0fca92342b40b874d110652 (patch) | |
| tree | b7a603b54f868383b0ce9dd57be7251ff3289a02 | |
| parent | Merge branch 'scenegraph3' of github:djpohly/dwl into scenegraph3 (diff) | |
| parent | Merge pull request #164 from Sevz17/change-border-color (diff) | |
| download | dwl-52a33a2f1ec91c11d0fca92342b40b874d110652.tar.gz dwl-52a33a2f1ec91c11d0fca92342b40b874d110652.tar.bz2 dwl-52a33a2f1ec91c11d0fca92342b40b874d110652.tar.xz dwl-52a33a2f1ec91c11d0fca92342b40b874d110652.tar.zst dwl-52a33a2f1ec91c11d0fca92342b40b874d110652.zip | |
Merge branch 'scenegraph3' of github:djpohly/dwl into scenegraph3
Diffstat (limited to '')
| -rw-r--r-- | dwl.c | 16 | 
1 files changed, 16 insertions, 0 deletions
| @@ -1064,6 +1064,8 @@ focusclient(Client *c, int lift)  {  	struct wlr_surface *old = seat->keyboard_state.focused_surface;  	struct wlr_keyboard *kb; +	Client *w; +	int i;  	/* Raise client in stacking order if requested */  	if (c && lift) { @@ -1081,6 +1083,9 @@ focusclient(Client *c, int lift)  		wl_list_insert(&fstack, &c->flink);  		selmon = c->mon;  		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 */ @@ -1100,6 +1105,16 @@ focusclient(Client *c, int lift)  						))  				return;  		} 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);  		}  	} @@ -1305,6 +1320,7 @@ mapnotify(struct wl_listener *listener, void *data)  	for (i = 0; i < 4; i++) {  		c->border[i] = wlr_scene_rect_create(c->scene, 0, 0, bordercolor);  		c->border[i]->node.data = c; +		wlr_scene_rect_set_color(c->border[i], bordercolor);  	}  	if (client_is_unmanaged(c)) { | 
