make sure we do not create a double fullscreen_bg
and also make sure we do not destroy it if it does not exist Fixes: #274
This commit is contained in:
parent
8cdb997126
commit
b04c73be3d
13
dwl.c
13
dwl.c
@ -1879,14 +1879,19 @@ setfullscreen(Client *c, int fullscreen)
|
||||
*
|
||||
* For brevity we set a black background for all clients
|
||||
*/
|
||||
c->fullscreen_bg = wlr_scene_rect_create(c->scene,
|
||||
c->geom.width, c->geom.height, fullscreen_bg);
|
||||
wlr_scene_node_lower_to_bottom(&c->fullscreen_bg->node);
|
||||
if (!c->fullscreen_bg) {
|
||||
c->fullscreen_bg = wlr_scene_rect_create(c->scene,
|
||||
c->geom.width, c->geom.height, fullscreen_bg);
|
||||
wlr_scene_node_lower_to_bottom(&c->fullscreen_bg->node);
|
||||
}
|
||||
} else {
|
||||
/* restore previous size instead of arrange for floating windows since
|
||||
* client positions are set by the user and cannot be recalculated */
|
||||
resize(c, c->prev, 0);
|
||||
wlr_scene_node_destroy(&c->fullscreen_bg->node);
|
||||
if (c->fullscreen_bg) {
|
||||
wlr_scene_node_destroy(&c->fullscreen_bg->node);
|
||||
c->fullscreen_bg = NULL;
|
||||
}
|
||||
}
|
||||
arrange(c->mon);
|
||||
printstatus();
|
||||
|
Loading…
Reference in New Issue
Block a user