diff --git a/Makefile.am b/Makefile.am index 26e94fa8..dc8e35bc 100644 --- a/Makefile.am +++ b/Makefile.am @@ -400,7 +400,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 diff --git a/clients/simple-shm.c b/clients/simple-shm.c index a2c5f36a..f810bbee 100644 --- a/clients/simple-shm.c +++ b/clients/simple-shm.c @@ -37,6 +37,10 @@ #include "xdg-shell-client-protocol.h" #include "fullscreen-shell-client-protocol.h" +#include +#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 @@ -491,6 +527,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);