desktop: Do not attempt to send terminate event
[src/agl-compositor.git] / src / ivi-compositor.h
index 5137d19..bc5cc68 100644 (file)
@@ -46,6 +46,11 @@ struct desktop_client {
        struct wl_list link;    /* ivi_compositor::desktop_clients */
 };
 
+enum agl_shell_bound_status {
+       BOUND_OK,
+       BOUND_FAILED,
+};
+
 struct ivi_compositor {
        struct weston_compositor *compositor;
        struct weston_config *config;
@@ -81,6 +86,7 @@ struct ivi_compositor {
                struct wl_client *client;
                struct wl_resource *resource;
                bool ready;
+               enum agl_shell_bound_status status;
        } shell_client;
 
        struct wl_list desktop_clients; /* desktop_client::link */
@@ -255,6 +261,8 @@ struct ivi_surface {
        struct ivi_compositor *ivi;
        struct weston_desktop_surface *dsurface;
        struct weston_view *view;
+       struct ivi_output *hidden_layer_output;
+       struct ivi_output *current_completed_output;
 
        struct wl_list link;
        int focus_count;
@@ -271,6 +279,7 @@ struct ivi_surface {
                NORMAL,
                RESIZING,
                FULLSCREEN,
+               HIDDEN,
        } state;
 
        enum ivi_surface_role role;
@@ -408,10 +417,13 @@ struct ivi_output *
 ivi_layout_get_output_from_surface(struct ivi_surface *surf);
 
 void
-insert_black_surface(struct ivi_output *output);
+insert_black_curtain(struct ivi_output *output);
 
 void
-remove_black_surface(struct ivi_output *output);
+remove_black_curtain(struct ivi_output *output);
+
+bool
+output_has_black_curtain(struct ivi_output *output);
 
 const char *
 ivi_layout_get_surface_role_name(struct ivi_surface *surf);