clients: support ivi-application.xml for clients/simple-shm.c
authorNobuhiko Tanibata <NOBUHIKO_TANIBATA@xddp.denso.co.jp>
Wed, 15 Oct 2014 03:09:35 +0000 (12:09 +0900)
committerJan Ekström <jan.ekstrom@intel.com>
Thu, 4 Dec 2014 11:34:17 +0000 (13:34 +0200)
Signed-off-by: Nobuhiko Tanibata <NOBUHIKO_TANIBATA@xddp.denso.co.jp>
Reviewed-by: Pekka Paalanen <pekka.paalanen@collabora.co.uk>
Makefile.am
clients/simple-shm.c

index 927889b..6c5321f 100644 (file)
@@ -410,7 +410,9 @@ nodist_weston_simple_shm_SOURCES =          \
        protocol/xdg-shell-protocol.c           \
        protocol/xdg-shell-client-protocol.h    \
        protocol/fullscreen-shell-protocol.c    \
-       protocol/fullscreen-shell-client-protocol.h
+       protocol/fullscreen-shell-client-protocol.h     \
+       protocol/ivi-application-protocol.c             \
+       protocol/ivi-application-client-protocol.h
 weston_simple_shm_CFLAGS = $(AM_CFLAGS) $(SIMPLE_CLIENT_CFLAGS)
 weston_simple_shm_LDADD = $(SIMPLE_CLIENT_LIBS) libshared.la
 
index c1cb386..e6025aa 100644 (file)
 #include "xdg-shell-client-protocol.h"
 #include "fullscreen-shell-client-protocol.h"
 
+#include <sys/types.h>
+#include "ivi-application-client-protocol.h"
+#define IVI_SURFACE_ID 9000
+
 struct display {
        struct wl_display *display;
        struct wl_registry *registry;
@@ -45,6 +49,7 @@ struct display {
        struct _wl_fullscreen_shell *fshell;
        struct wl_shm *shm;
        uint32_t formats;
+       struct ivi_application *ivi_application;
 };
 
 struct buffer {
@@ -58,6 +63,7 @@ struct window {
        int width, height;
        struct wl_surface *surface;
        struct xdg_surface *xdg_surface;
+       struct ivi_surface *ivi_surface;
        struct buffer buffers[2];
        struct buffer *prev_buffer;
        struct wl_callback *callback;
@@ -134,6 +140,17 @@ static const struct xdg_surface_listener xdg_surface_listener = {
        handle_delete,
 };
 
+static void
+handle_ivi_surface_configure(void *data, struct ivi_surface *ivi_surface,
+                            int32_t width, int32_t height)
+{
+       /* Simple-shm is resizable */
+}
+
+static const struct ivi_surface_listener ivi_surface_listener = {
+       handle_ivi_surface_configure,
+};
+
 static struct window *
 create_window(struct display *display, int width, int height)
 {
@@ -160,11 +177,25 @@ create_window(struct display *display, int width, int height)
                                         &xdg_surface_listener, window);
 
                xdg_surface_set_title(window->xdg_surface, "simple-shm");
+
        } else if (display->fshell) {
                _wl_fullscreen_shell_present_surface(display->fshell,
                                                     window->surface,
                                                     _WL_FULLSCREEN_SHELL_PRESENT_METHOD_DEFAULT,
                                                     NULL);
+       } else if (display->ivi_application ) {
+               uint32_t id_ivisurf = IVI_SURFACE_ID + (uint32_t)getpid();
+               window->ivi_surface =
+                       ivi_application_surface_create(display->ivi_application,
+                                                      id_ivisurf, window->surface);
+               if (window->ivi_surface == NULL) {
+                       fprintf(stderr, "Failed to create ivi_client_surface\n");
+                       abort();
+               }
+
+               ivi_surface_add_listener(window->ivi_surface,
+                                        &ivi_surface_listener, window);
+
        } else {
                assert(0);
        }
@@ -350,6 +381,11 @@ registry_handle_global(void *data, struct wl_registry *registry,
                                          id, &wl_shm_interface, 1);
                wl_shm_add_listener(d->shm, &shm_listener, d);
        }
+       else if (strcmp(interface, "ivi_application") == 0) {
+               d->ivi_application =
+                       wl_registry_bind(registry, id,
+                                        &ivi_application_interface, 1);
+       }
 }
 
 static void
@@ -451,6 +487,12 @@ main(int argc, char **argv)
                ret = wl_display_dispatch(display->display);
 
        fprintf(stderr, "simple-shm exiting\n");
+
+       if (window->display->ivi_application) {
+               ivi_surface_destroy(window->ivi_surface);
+               ivi_application_destroy(window->display->ivi_application);
+       }
+
        destroy_window(window);
        destroy_display(display);