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>
This commit is contained in:
committed by
Pekka Paalanen
parent
45d4cbf15f
commit
fba4ea3627
+3
-1
@@ -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);
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user