libweston-desktop/xdg_shell_v6: Add surface as needed
authorQuentin Glidic <sardemff7+git@sardemff7.net>
Sun, 11 Sep 2016 09:29:23 +0000 (11:29 +0200)
committerQuentin Glidic <sardemff7+git@sardemff7.net>
Mon, 12 Sep 2016 14:46:49 +0000 (16:46 +0200)
Signed-off-by: Quentin Glidic <sardemff7+git@sardemff7.net>
Reviewed-by: Jonas Ã…dahl <jadahl@gmail.com>
libweston-desktop/xdg-shell-v6.c

index 70e9132..fbf3e69 100644 (file)
@@ -284,6 +284,18 @@ static void
 weston_desktop_xdg_surface_schedule_configure(struct weston_desktop_xdg_surface *surface);
 
 static void
+weston_desktop_xdg_toplevel_ensure_added(struct weston_desktop_xdg_toplevel *toplevel)
+{
+       if (toplevel->added)
+               return;
+
+       weston_desktop_api_surface_added(toplevel->base.desktop,
+                                        toplevel->base.desktop_surface);
+       weston_desktop_xdg_surface_schedule_configure(&toplevel->base);
+       toplevel->added = true;
+}
+
+static void
 weston_desktop_xdg_toplevel_protocol_set_parent(struct wl_client *wl_client,
                                                struct wl_resource *resource,
                                                struct wl_resource *parent_resource)
@@ -296,6 +308,8 @@ weston_desktop_xdg_toplevel_protocol_set_parent(struct wl_client *wl_client,
 
        if (parent_resource != NULL)
                parent = wl_resource_get_user_data(parent_resource);
+
+       weston_desktop_xdg_toplevel_ensure_added(toplevel);
        weston_desktop_api_set_parent(toplevel->base.desktop, dsurface, parent);
 }
 
@@ -416,6 +430,7 @@ weston_desktop_xdg_toplevel_protocol_set_maximized(struct wl_client *wl_client,
        struct weston_desktop_xdg_toplevel *toplevel =
                weston_desktop_surface_get_implementation_data(dsurface);
 
+       weston_desktop_xdg_toplevel_ensure_added(toplevel);
        weston_desktop_api_maximized_requested(toplevel->base.desktop, dsurface, true);
 }
 
@@ -428,6 +443,7 @@ weston_desktop_xdg_toplevel_protocol_unset_maximized(struct wl_client *wl_client
        struct weston_desktop_xdg_toplevel *toplevel =
                weston_desktop_surface_get_implementation_data(dsurface);
 
+       weston_desktop_xdg_toplevel_ensure_added(toplevel);
        weston_desktop_api_maximized_requested(toplevel->base.desktop, dsurface, false);
 }
 
@@ -445,6 +461,7 @@ weston_desktop_xdg_toplevel_protocol_set_fullscreen(struct wl_client *wl_client,
        if (output_resource != NULL)
                output = wl_resource_get_user_data(output_resource);
 
+       weston_desktop_xdg_toplevel_ensure_added(toplevel);
        weston_desktop_api_fullscreen_requested(toplevel->base.desktop, dsurface,
                                                true, output);
 }
@@ -458,6 +475,7 @@ weston_desktop_xdg_toplevel_protocol_unset_fullscreen(struct wl_client *wl_clien
        struct weston_desktop_xdg_toplevel *toplevel =
                weston_desktop_surface_get_implementation_data(dsurface);
 
+       weston_desktop_xdg_toplevel_ensure_added(toplevel);
        weston_desktop_api_fullscreen_requested(toplevel->base.desktop, dsurface,
                                                false, NULL);
 }
@@ -471,6 +489,7 @@ weston_desktop_xdg_toplevel_protocol_set_minimized(struct wl_client *wl_client,
        struct weston_desktop_xdg_toplevel *toplevel =
                weston_desktop_surface_get_implementation_data(dsurface);
 
+       weston_desktop_xdg_toplevel_ensure_added(toplevel);
        weston_desktop_api_minimized_requested(toplevel->base.desktop, dsurface);
 }
 
@@ -584,10 +603,7 @@ weston_desktop_xdg_toplevel_committed(struct weston_desktop_xdg_toplevel *toplev
        bool reconfigure = false;
 
        if (!wsurface->buffer_ref.buffer && !toplevel->added) {
-               weston_desktop_api_surface_added(toplevel->base.desktop,
-                                                toplevel->base.desktop_surface);
-               weston_desktop_xdg_surface_schedule_configure(&toplevel->base);
-               toplevel->added = true;
+               weston_desktop_xdg_toplevel_ensure_added(toplevel);
                return;
        }
        if (!wsurface->buffer_ref.buffer)