clients: support ivi-application.xml for clients/simple-shm.c

Signed-off-by: Nobuhiko Tanibata <NOBUHIKO_TANIBATA@xddp.denso.co.jp>
Reviewed-by: Pekka Paalanen <pekka.paalanen@collabora.co.uk>
dev
Nobuhiko Tanibata 10 years ago committed by Pekka Paalanen
parent 45d4cbf15f
commit fba4ea3627
  1. 4
      Makefile.am
  2. 42
      clients/simple-shm.c

@ -400,7 +400,9 @@ nodist_weston_simple_shm_SOURCES = \
protocol/xdg-shell-protocol.c \ protocol/xdg-shell-protocol.c \
protocol/xdg-shell-client-protocol.h \ protocol/xdg-shell-client-protocol.h \
protocol/fullscreen-shell-protocol.c \ 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_CFLAGS = $(AM_CFLAGS) $(SIMPLE_CLIENT_CFLAGS)
weston_simple_shm_LDADD = $(SIMPLE_CLIENT_LIBS) libshared.la weston_simple_shm_LDADD = $(SIMPLE_CLIENT_LIBS) libshared.la

@ -37,6 +37,10 @@
#include "xdg-shell-client-protocol.h" #include "xdg-shell-client-protocol.h"
#include "fullscreen-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 display {
struct wl_display *display; struct wl_display *display;
struct wl_registry *registry; struct wl_registry *registry;
@ -45,6 +49,7 @@ struct display {
struct _wl_fullscreen_shell *fshell; struct _wl_fullscreen_shell *fshell;
struct wl_shm *shm; struct wl_shm *shm;
uint32_t formats; uint32_t formats;
struct ivi_application *ivi_application;
}; };
struct buffer { struct buffer {
@ -58,6 +63,7 @@ struct window {
int width, height; int width, height;
struct wl_surface *surface; struct wl_surface *surface;
struct xdg_surface *xdg_surface; struct xdg_surface *xdg_surface;
struct ivi_surface *ivi_surface;
struct buffer buffers[2]; struct buffer buffers[2];
struct buffer *prev_buffer; struct buffer *prev_buffer;
struct wl_callback *callback; struct wl_callback *callback;
@ -134,6 +140,17 @@ static const struct xdg_surface_listener xdg_surface_listener = {
handle_delete, 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 * static struct window *
create_window(struct display *display, int width, int height) 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_listener, window);
xdg_surface_set_title(window->xdg_surface, "simple-shm"); xdg_surface_set_title(window->xdg_surface, "simple-shm");
} else if (display->fshell) { } else if (display->fshell) {
_wl_fullscreen_shell_present_surface(display->fshell, _wl_fullscreen_shell_present_surface(display->fshell,
window->surface, window->surface,
_WL_FULLSCREEN_SHELL_PRESENT_METHOD_DEFAULT, _WL_FULLSCREEN_SHELL_PRESENT_METHOD_DEFAULT,
NULL); 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 { } else {
assert(0); assert(0);
} }
@ -350,6 +381,11 @@ registry_handle_global(void *data, struct wl_registry *registry,
id, &wl_shm_interface, 1); id, &wl_shm_interface, 1);
wl_shm_add_listener(d->shm, &shm_listener, d); 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 static void
@ -491,6 +527,12 @@ main(int argc, char **argv)
ret = wl_display_dispatch(display->display); ret = wl_display_dispatch(display->display);
fprintf(stderr, "simple-shm exiting\n"); 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_window(window);
destroy_display(display); destroy_display(display);

Loading…
Cancel
Save