diff options
author | Tony Crisci <tony@dubstepdish.com> | 2018-01-15 07:53:32 -0500 |
---|---|---|
committer | GitHub <noreply@github.com> | 2018-01-15 07:53:32 -0500 |
commit | c690420501a35ee83bf6afeb52139b3da2c455c2 (patch) | |
tree | 2631df62e96140109d2c563cdd160824e37af95a /xwayland | |
parent | 38887a09dc24c662f5f2530d225d89d5fd73f32b (diff) | |
parent | 65b28b3823f42ba04629defbde136e04619c63a9 (diff) | |
download | wlroots-c690420501a35ee83bf6afeb52139b3da2c455c2.tar.xz |
Merge pull request #562 from emersion/xwayland-fullscreen-render-children
xwayland: render children window in fullscreen
Diffstat (limited to 'xwayland')
-rw-r--r-- | xwayland/xwm.c | 10 |
1 files changed, 10 insertions, 0 deletions
diff --git a/xwayland/xwm.c b/xwayland/xwm.c index 53aac6a4..dc349ab2 100644 --- a/xwayland/xwm.c +++ b/xwayland/xwm.c @@ -96,6 +96,8 @@ static struct wlr_xwayland_surface *wlr_xwayland_surface_create( surface->height = height; surface->override_redirect = override_redirect; wl_list_insert(&xwm->surfaces, &surface->link); + wl_list_init(&surface->children); + wl_list_init(&surface->parent_link); wl_signal_init(&surface->events.destroy); wl_signal_init(&surface->events.request_configure); wl_signal_init(&surface->events.request_move); @@ -215,6 +217,7 @@ static void wlr_xwayland_surface_destroy( } wl_list_remove(&xsurface->link); + wl_list_remove(&xsurface->parent_link); if (xsurface->surface_id) { wl_list_remove(&xsurface->unpaired_link); @@ -305,6 +308,13 @@ static void read_surface_parent(struct wlr_xwm *xwm, xsurface->parent = NULL; } + wl_list_remove(&xsurface->parent_link); + if (xsurface->parent != NULL) { + wl_list_insert(&xsurface->parent->children, &xsurface->parent_link); + } else { + wl_list_init(&xsurface->parent_link); + } + wlr_log(L_DEBUG, "XCB_ATOM_WM_TRANSIENT_FOR: %p", xid); wl_signal_emit(&xsurface->events.set_parent, xsurface); } |