layout: Add a wrapper to print out the surface role
[src/agl-compositor.git] / src / ivi-compositor.h
index 75c5568..b506ce1 100644 (file)
 
 #include "agl-shell-server-protocol.h"
 
+struct ivi_compositor;
+
 struct desktop_client {
        struct wl_resource *resource;
+       struct ivi_compositor *ivi;
        struct wl_list link;    /* ivi_compositor::desktop_clients */
 };
 
@@ -66,9 +69,6 @@ struct ivi_compositor {
 
        struct wl_global *agl_shell;
        struct wl_global *agl_shell_desktop;
-       struct {
-               bool activate_apps_by_default;  /* switches once xdg top level has been 'created' */
-       } quirks;
 
        struct {
                struct wl_client *client;
@@ -86,6 +86,9 @@ struct ivi_compositor {
 
        struct wl_list pending_surfaces;
        struct wl_list popup_pending_apps;
+       struct wl_list fullscreen_pending_apps;
+       struct wl_list split_pending_apps;
+       struct wl_list remote_pending_apps;
 
        struct weston_layer hidden;
        struct weston_layer background;
@@ -125,8 +128,10 @@ struct ivi_output {
         * In output-coorrdinate space.
         */
        struct weston_geometry area;
+       struct weston_geometry area_saved;
 
        struct ivi_surface *active;
+       struct ivi_surface *previous_active;
 
        /* Temporary: only used during configuration */
        size_t add_len;
@@ -139,6 +144,10 @@ enum ivi_surface_role {
        IVI_SURFACE_ROLE_BACKGROUND,
        IVI_SURFACE_ROLE_PANEL,
        IVI_SURFACE_ROLE_POPUP,
+       IVI_SURFACE_ROLE_FULLSCREEN,
+       IVI_SURFACE_ROLE_SPLIT_V,
+       IVI_SURFACE_ROLE_SPLIT_H,
+       IVI_SURFACE_ROLE_REMOTE,
 };
 
 struct pending_popup {
@@ -149,6 +158,25 @@ struct pending_popup {
        struct wl_list link;    /** ivi_compositor::popup_pending_surfaces */
 };
 
+struct pending_fullscreen {
+       struct ivi_output *ioutput;
+       char *app_id;
+       struct wl_list link;    /** ivi_compositor::fullscreen_pending_apps */
+};
+
+struct pending_split {
+       struct ivi_output *ioutput;
+       char *app_id;
+       uint32_t orientation;
+       struct wl_list link;    /** ivi_compositor::split_pending_apps */
+};
+
+struct pending_remote {
+       struct ivi_output *ioutput;
+       char *app_id;
+       struct wl_list link;    /** ivi_compositor::remote_pending_apps */
+};
+
 struct ivi_desktop_surface {
        struct ivi_output *pending_output;
        struct ivi_output *last_output;
@@ -164,6 +192,19 @@ struct ivi_popup_surface {
        int y;
 };
 
+struct ivi_fullscreen_surface {
+       struct ivi_output *output;
+};
+
+struct ivi_split_surface {
+       struct ivi_output *output;
+       uint32_t orientation;
+};
+
+struct ivi_remote_surface {
+       struct ivi_output *output;
+};
+
 struct ivi_panel_surface {
        struct ivi_output *output;
        enum agl_shell_edge edge;
@@ -195,6 +236,9 @@ struct ivi_surface {
                struct ivi_background_surface bg;
                struct ivi_panel_surface panel;
                struct ivi_popup_surface popup;
+               struct ivi_fullscreen_surface fullscreen;
+               struct ivi_split_surface split;
+               struct ivi_remote_surface remote;
        };
 };
 
@@ -249,11 +293,8 @@ ivi_set_desktop_surface(struct ivi_surface *surface);
 /*
  * removes the pending popup one
  */
-bool
-ivi_check_pending_desktop_surface_popup(struct ivi_surface *surface);
-
 void
-ivi_set_desktop_surface_popup(struct ivi_surface *surface);
+ivi_check_pending_desktop_surface(struct ivi_surface *surface);
 
 void
 ivi_reflow_outputs(struct ivi_compositor *ivi);
@@ -269,6 +310,9 @@ ivi_layout_set_position(struct ivi_surface *surface,
                        int32_t x, int32_t y,
                        int32_t width, int32_t height);
 
+struct ivi_surface *
+ivi_find_app(struct ivi_compositor *ivi, const char *app_id);
+
 void
 ivi_layout_commit(struct ivi_compositor *ivi);
 
@@ -287,4 +331,29 @@ ivi_layout_panel_committed(struct ivi_surface *surface);
 void
 ivi_layout_popup_committed(struct ivi_surface *surface);
 
+void
+ivi_layout_fullscreen_committed(struct ivi_surface *surface);
+
+void
+ivi_layout_split_committed(struct ivi_surface *surface);
+
+void
+ivi_layout_deactivate(struct ivi_compositor *ivi, const char *app_id);
+
+void
+ivi_layout_desktop_resize(struct ivi_surface *surface,
+                         struct weston_geometry area);
+
+struct ivi_output *
+ivi_layout_get_output_from_surface(struct ivi_surface *surf);
+
+void
+insert_black_surface(struct ivi_output *output);
+
+void
+remove_black_surface(struct ivi_output *output);
+
+const char *
+ivi_layout_get_surface_role_name(struct ivi_surface *surf);
+
 #endif