Updated fullscreen shell to current protocol level.

This commit is contained in:
Armin Novak 2019-01-22 13:09:59 +01:00
parent 7f158b97be
commit 0ef64f8a84
5 changed files with 84 additions and 54 deletions

View File

@ -31,14 +31,14 @@ macro(generate_protocol_file PROTO)
COMMAND ${WAYLAND_SCANNER} client-header < ${CMAKE_SOURCE_DIR}/uwac/protocols/${PROTO}.xml > ${CMAKE_CURRENT_BINARY_DIR}/${PROTO}-client-protocol.h COMMAND ${WAYLAND_SCANNER} client-header < ${CMAKE_SOURCE_DIR}/uwac/protocols/${PROTO}.xml > ${CMAKE_CURRENT_BINARY_DIR}/${PROTO}-client-protocol.h
DEPENDS ${CMAKE_SOURCE_DIR}/uwac/protocols/${PROTO}.xml DEPENDS ${CMAKE_SOURCE_DIR}/uwac/protocols/${PROTO}.xml
) )
list(APPEND GENERATED_SOURCES ${CMAKE_CURRENT_BINARY_DIR}/${PROTO}-client-protocol.h) list(APPEND GENERATED_SOURCES ${CMAKE_CURRENT_BINARY_DIR}/${PROTO}-client-protocol.h)
list(APPEND GENERATED_SOURCES ${CMAKE_CURRENT_BINARY_DIR}/${PROTO}-protocol.c) list(APPEND GENERATED_SOURCES ${CMAKE_CURRENT_BINARY_DIR}/${PROTO}-protocol.c)
endmacro() endmacro()
generate_protocol_file(xdg-shell) generate_protocol_file(xdg-shell)
generate_protocol_file(ivi-application) generate_protocol_file(ivi-application)
generate_protocol_file(fullscreen-shell) generate_protocol_file(fullscreen-shell-unstable-v1)
if(FREEBSD) if(FREEBSD)
include_directories(${EPOLLSHIM_INCLUDE_DIR}) include_directories(${EPOLLSHIM_INCLUDE_DIR})

View File

@ -103,23 +103,26 @@ struct wl_shm_listener shm_listener =
cb_shm_format cb_shm_format
}; };
static void xdg_shell_ping(void* data, struct xdg_shell* shell, uint32_t serial) static void xdg_shell_ping(void *data,
struct xdg_wm_base *xdg_wm_base,
uint32_t serial)
{ {
xdg_shell_pong(shell, serial); xdg_wm_base_pong(xdg_wm_base, serial);
} }
static const struct xdg_shell_listener xdg_shell_listener = static const struct xdg_wm_base_listener xdg_wm_base_listener =
{ {
xdg_shell_ping, xdg_shell_ping,
}; };
#ifdef BUILD_FULLSCREEN_SHELL #ifdef BUILD_FULLSCREEN_SHELL
static void fullscreen_capability(void* data, struct _wl_fullscreen_shell* _wl_fullscreen_shell, static void fullscreen_capability(void *data,
uint32_t capabilty) struct zwp_fullscreen_shell_v1 *zwp_fullscreen_shell_v1,
uint32_t capability)
{ {
} }
static const struct _wl_fullscreen_shell_listener fullscreen_shell_listener = static const struct zwp_fullscreen_shell_v1_listener fullscreen_shell_listener =
{ {
fullscreen_capability, fullscreen_capability,
}; };
@ -208,11 +211,10 @@ static void registry_handle_global(void* data, struct wl_registry* registry, uin
d->shell = wl_registry_bind(registry, id, &wl_shell_interface, min(TARGET_SHELL_INTERFACE, d->shell = wl_registry_bind(registry, id, &wl_shell_interface, min(TARGET_SHELL_INTERFACE,
version)); version));
} }
else if (strcmp(interface, "xdg_shell") == 0) else if (strcmp(interface, "xdg_wm_base") == 0)
{ {
d->xdg_shell = wl_registry_bind(registry, id, &xdg_shell_interface, 1); d->xdg_base = wl_registry_bind(registry, id, &xdg_wm_base_interface, 1);
xdg_shell_use_unstable_version(d->xdg_shell, TARGET_XDG_VERSION); xdg_wm_base_add_listener(d->xdg_base, &xdg_wm_base_listener, d);
xdg_shell_add_listener(d->xdg_shell, &xdg_shell_listener, d);
#if BUILD_IVI #if BUILD_IVI
} }
else if (strcmp(interface, "ivi_application") == 0) else if (strcmp(interface, "ivi_application") == 0)
@ -221,10 +223,10 @@ static void registry_handle_global(void* data, struct wl_registry* registry, uin
#endif #endif
#if BUILD_FULLSCREEN_SHELL #if BUILD_FULLSCREEN_SHELL
} }
else if (strcmp(interface, "_wl_fullscreen_shell") == 0) else if (strcmp(interface, "zwp_fullscreen_shell_v1") == 0)
{ {
d->fullscreen_shell = wl_registry_bind(registry, id, &_wl_fullscreen_shell_interface, 1); d->fullscreen_shell = wl_registry_bind(registry, id, &zwp_fullscreen_shell_v1_interface, 1);
_wl_fullscreen_shell_add_listener(d->fullscreen_shell, &fullscreen_shell_listener, d); zwp_fullscreen_shell_v1_add_listener(d->fullscreen_shell, &fullscreen_shell_listener, d);
#endif #endif
#if 0 #if 0
} }
@ -513,7 +515,7 @@ UwacReturnCode UwacCloseDisplay(UwacDisplay** pdisplay)
#ifdef BUILD_FULLSCREEN_SHELL #ifdef BUILD_FULLSCREEN_SHELL
if (display->fullscreen_shell) if (display->fullscreen_shell)
_wl_fullscreen_shell_destroy(display->fullscreen_shell); zwp_fullscreen_shell_v1_destroy(display->fullscreen_shell);
#endif #endif
#ifdef BUILD_IVI #ifdef BUILD_IVI
@ -523,8 +525,11 @@ UwacReturnCode UwacCloseDisplay(UwacDisplay** pdisplay)
#endif #endif
if (display->xdg_shell) if (display->xdg_toplevel)
xdg_shell_destroy(display->xdg_shell); xdg_toplevel_destroy(display->xdg_toplevel);
if (display->xdg_base)
xdg_wm_base_destroy(display->xdg_base);
if (display->shell) if (display->shell)
wl_shell_destroy(display->shell); wl_shell_destroy(display->shell);

View File

@ -32,7 +32,7 @@
#include "ivi-application-client-protocol.h" #include "ivi-application-client-protocol.h"
#endif #endif
#ifdef BUILD_FULLSCREEN_SHELL #ifdef BUILD_FULLSCREEN_SHELL
#include "fullscreen-shell-client-protocol.h" #include "fullscreen-shell-unstable-v1-client-protocol.h"
#endif #endif
#ifdef HAVE_PIXMAN_REGION #ifdef HAVE_PIXMAN_REGION
@ -84,12 +84,13 @@ struct uwac_display {
struct wl_compositor *compositor; struct wl_compositor *compositor;
struct wl_subcompositor *subcompositor; struct wl_subcompositor *subcompositor;
struct wl_shell *shell; struct wl_shell *shell;
struct xdg_shell *xdg_shell; struct xdg_toplevel *xdg_toplevel;
struct xdg_wm_base *xdg_base;
#ifdef BUILD_IVI #ifdef BUILD_IVI
struct ivi_application *ivi_application; struct ivi_application *ivi_application;
#endif #endif
#ifdef BUILD_FULLSCREEN_SHELL #ifdef BUILD_FULLSCREEN_SHELL
struct _wl_fullscreen_shell *fullscreen_shell; struct zwp_fullscreen_shell_v1 *fullscreen_shell;
#endif #endif
struct wl_shm *shm; struct wl_shm *shm;
@ -210,6 +211,7 @@ struct uwac_window {
struct wl_surface *surface; struct wl_surface *surface;
struct wl_shell_surface *shell_surface; struct wl_shell_surface *shell_surface;
struct xdg_surface *xdg_surface; struct xdg_surface *xdg_surface;
struct xdg_toplevel *xdg_toplevel;
#ifdef BUILD_IVI #ifdef BUILD_IVI
struct ivi_surface *ivi_surface; struct ivi_surface *ivi_surface;
#endif #endif

View File

@ -82,32 +82,34 @@ void UwacWindowDestroyBuffers(UwacWindow* w)
int UwacWindowShmAllocBuffers(UwacWindow* w, int nbuffers, int allocSize, uint32_t width, int UwacWindowShmAllocBuffers(UwacWindow* w, int nbuffers, int allocSize, uint32_t width,
uint32_t height, enum wl_shm_format format); uint32_t height, enum wl_shm_format format);
static void xdg_handle_configure(void* data, struct xdg_surface* surface, static void xdg_handle_configure(void *data,
int32_t width, int32_t height, struct xdg_toplevel *xdg_toplevel,
struct wl_array* states, uint32_t serial) int32_t width,
int32_t height,
struct wl_array *states)
{ {
UwacWindow* window = (UwacWindow*)data; UwacWindow* window = (UwacWindow*)data;
UwacConfigureEvent* event; UwacConfigureEvent* event;
int ret, surfaceState; int ret, surfaceState;
enum xdg_surface_state* state; enum xdg_toplevel_state* state;
surfaceState = 0; surfaceState = 0;
wl_array_for_each(state, states) wl_array_for_each(state, states)
{ {
switch (*state) switch (*state)
{ {
case XDG_SURFACE_STATE_MAXIMIZED: case XDG_TOPLEVEL_STATE_MAXIMIZED:
surfaceState |= UWAC_WINDOW_MAXIMIZED; surfaceState |= UWAC_WINDOW_MAXIMIZED;
break; break;
case XDG_SURFACE_STATE_FULLSCREEN: case XDG_TOPLEVEL_STATE_FULLSCREEN:
surfaceState |= UWAC_WINDOW_FULLSCREEN; surfaceState |= UWAC_WINDOW_FULLSCREEN;
break; break;
case XDG_SURFACE_STATE_ACTIVATED: case XDG_TOPLEVEL_STATE_ACTIVATED:
surfaceState |= UWAC_WINDOW_ACTIVATED; surfaceState |= UWAC_WINDOW_ACTIVATED;
break; break;
case XDG_SURFACE_STATE_RESIZING: case XDG_TOPLEVEL_STATE_RESIZING:
surfaceState |= UWAC_WINDOW_RESIZING; surfaceState |= UWAC_WINDOW_RESIZING;
break; break;
@ -155,10 +157,11 @@ static void xdg_handle_configure(void* data, struct xdg_surface* surface,
} }
ack: ack:
xdg_surface_ack_configure(surface, serial); return;
} }
static void xdg_handle_close(void* data, struct xdg_surface* xdg_surface) static void xdg_handle_close(void *data,
struct xdg_toplevel *xdg_toplevel)
{ {
UwacCloseEvent* event; UwacCloseEvent* event;
UwacWindow* window = (UwacWindow*)data; UwacWindow* window = (UwacWindow*)data;
@ -174,12 +177,11 @@ static void xdg_handle_close(void* data, struct xdg_surface* xdg_surface)
event->window = window; event->window = window;
} }
static const struct xdg_surface_listener xdg_surface_listener = static const struct xdg_toplevel_listener xdg_toplevel_listener =
{ {
xdg_handle_configure, xdg_handle_configure,
xdg_handle_close, xdg_handle_close,
}; };
#if BUILD_IVI #if BUILD_IVI
static void ivi_handle_configure(void* data, struct ivi_surface* surface, static void ivi_handle_configure(void* data, struct ivi_surface* surface,
@ -428,9 +430,9 @@ UwacWindow* UwacCreateWindowShm(UwacDisplay* display, uint32_t width, uint32_t h
wl_surface_set_user_data(w->surface, w); wl_surface_set_user_data(w->surface, w);
if (display->xdg_shell) if (display->xdg_base)
{ {
w->xdg_surface = xdg_shell_get_xdg_surface(display->xdg_shell, w->surface); w->xdg_surface = xdg_wm_base_get_xdg_surface(display->xdg_base, w->surface);
if (!w->xdg_surface) if (!w->xdg_surface)
{ {
@ -438,8 +440,15 @@ UwacWindow* UwacCreateWindowShm(UwacDisplay* display, uint32_t width, uint32_t h
goto out_error_shell; goto out_error_shell;
} }
w->xdg_toplevel = xdg_surface_get_toplevel(w->xdg_surface);
if (!w->xdg_toplevel)
{
display->last_error = UWAC_ERROR_NOMEMORY;
goto out_error_shell;
}
assert(w->xdg_surface); assert(w->xdg_surface);
xdg_surface_add_listener(w->xdg_surface, &xdg_surface_listener, w); xdg_toplevel_add_listener(w->xdg_toplevel, &xdg_toplevel_listener, w);
#if BUILD_IVI #if BUILD_IVI
} }
else if (display->ivi_application) else if (display->ivi_application)
@ -452,8 +461,8 @@ UwacWindow* UwacCreateWindowShm(UwacDisplay* display, uint32_t width, uint32_t h
} }
else if (display->fullscreen_shell) else if (display->fullscreen_shell)
{ {
_wl_fullscreen_shell_present_surface(display->fullscreen_shell, w->surface, zwp_fullscreen_shell_v1_present_surface(display->fullscreen_shell, w->surface,
_WL_FULLSCREEN_SHELL_PRESENT_METHOD_CENTER, NULL); ZWP_FULLSCREEN_SHELL_V1_PRESENT_METHOD_CENTER, NULL);
#endif #endif
} }
else else
@ -672,15 +681,15 @@ UwacReturnCode UwacWindowGetGeometry(UwacWindow* window, UwacSize* geometry)
UwacReturnCode UwacWindowSetFullscreenState(UwacWindow* window, UwacOutput* output, UwacReturnCode UwacWindowSetFullscreenState(UwacWindow* window, UwacOutput* output,
bool isFullscreen) bool isFullscreen)
{ {
if (window->xdg_surface) if (window->xdg_toplevel)
{ {
if (isFullscreen) if (isFullscreen)
{ {
xdg_surface_set_fullscreen(window->xdg_surface, output ? output->output : NULL); xdg_toplevel_set_fullscreen(window->xdg_toplevel, output ? output->output : NULL);
} }
else else
{ {
xdg_surface_unset_fullscreen(window->xdg_surface); xdg_toplevel_unset_fullscreen(window->xdg_toplevel);
} }
} }
else if (window->shell_surface) else if (window->shell_surface)
@ -703,8 +712,8 @@ UwacReturnCode UwacWindowSetFullscreenState(UwacWindow* window, UwacOutput* outp
void UwacWindowSetTitle(UwacWindow* window, const char* name) void UwacWindowSetTitle(UwacWindow* window, const char* name)
{ {
if (window->xdg_surface) if (window->xdg_toplevel)
xdg_surface_set_title(window->xdg_surface, name); xdg_toplevel_set_title(window->xdg_toplevel, name);
else if (window->shell_surface) else if (window->shell_surface)
wl_shell_surface_set_title(window->shell_surface, name); wl_shell_surface_set_title(window->shell_surface, name);
} }

View File

@ -1,6 +1,8 @@
<protocol name="fullscreen_shell"> <?xml version="1.0" encoding="UTF-8"?>
<interface name="_wl_fullscreen_shell" version="1"> <protocol name="fullscreen_shell_unstable_v1">
<description summary="Displays a single surface per output">
<interface name="zwp_fullscreen_shell_v1" version="1">
<description summary="displays a single surface per output">
Displays a single surface per output. Displays a single surface per output.
This interface provides a mechanism for a single client to display This interface provides a mechanism for a single client to display
@ -14,7 +16,7 @@
details about scaling and mode switches. details about scaling and mode switches.
The client can have at most one surface per output at any time. The client can have at most one surface per output at any time.
Requesting a surface be presented on an output that already has a Requesting a surface to be presented on an output that already has a
surface replaces the previously presented surface. Presenting a null surface replaces the previously presented surface. Presenting a null
surface removes its content and effectively disables the output. surface removes its content and effectively disables the output.
Exactly what happens when an output is "disabled" is Exactly what happens when an output is "disabled" is
@ -25,11 +27,20 @@
until either the client removes it or the compositor destroys the until either the client removes it or the compositor destroys the
output. This way, the client can update the output's contents by output. This way, the client can update the output's contents by
simply attaching a new buffer. simply attaching a new buffer.
Warning! The protocol described in this file is experimental and
backward incompatible changes may be made. Backward compatible changes
may be added together with the corresponding interface version bump.
Backward incompatible changes are done by bumping the version number in
the protocol and interface names and resetting the interface version.
Once the protocol is to be declared stable, the 'z' prefix and the
version number in the protocol and interface names are removed and the
interface version number is reset.
</description> </description>
<request name="release" type="destructor"> <request name="release" type="destructor">
<description summary="release the wl_fullscreen_shell interface"> <description summary="release the wl_fullscreen_shell interface">
Release the binding from the wl_fullscreen_shell interface Release the binding from the wl_fullscreen_shell interface.
This destroys the server-side object and frees this binding. If This destroys the server-side object and frees this binding. If
the client binds to wl_fullscreen_shell multiple times, it may wish the client binds to wl_fullscreen_shell multiple times, it may wish
@ -43,7 +54,7 @@
are advertised one-at-a-time when the wl_fullscreen_shell interface is are advertised one-at-a-time when the wl_fullscreen_shell interface is
bound. See the wl_fullscreen_shell.capability event for more details. bound. See the wl_fullscreen_shell.capability event for more details.
ARBITRARY_MODE: ARBITRARY_MODES:
This is a hint to the client that indicates that the compositor is This is a hint to the client that indicates that the compositor is
capable of setting practically any mode on its outputs. If this capable of setting practically any mode on its outputs. If this
capability is provided, wl_fullscreen_shell.present_surface_for_mode capability is provided, wl_fullscreen_shell.present_surface_for_mode
@ -76,7 +87,7 @@
wl_display.sync request immediately after binding to ensure that they wl_display.sync request immediately after binding to ensure that they
receive all the capability events. receive all the capability events.
</description> </description>
<arg name="capabilty" type="uint"/> <arg name="capability" type="uint"/>
</event> </event>
<enum name="present_method"> <enum name="present_method">
@ -160,18 +171,18 @@
<arg name="surface" type="object" interface="wl_surface"/> <arg name="surface" type="object" interface="wl_surface"/>
<arg name="output" type="object" interface="wl_output"/> <arg name="output" type="object" interface="wl_output"/>
<arg name="framerate" type="int"/> <arg name="framerate" type="int"/>
<arg name="feedback" type="new_id" interface="_wl_fullscreen_shell_mode_feedback"/> <arg name="feedback" type="new_id" interface="zwp_fullscreen_shell_mode_feedback_v1"/>
</request> </request>
<enum name="error"> <enum name="error">
<description summary="wl_fullscreen_shell error values"> <description summary="wl_fullscreen_shell error values">
These errors can be emitted in response to wl_fullscreen_shell requests These errors can be emitted in response to wl_fullscreen_shell requests.
</description> </description>
<entry name="invalid_method" value="0" summary="present_method is not known"/> <entry name="invalid_method" value="0" summary="present_method is not known"/>
</enum> </enum>
</interface> </interface>
<interface name="_wl_fullscreen_shell_mode_feedback" version="1"> <interface name="zwp_fullscreen_shell_mode_feedback_v1" version="1">
<event name="mode_successful"> <event name="mode_successful">
<description summary="mode switch succeeded"> <description summary="mode switch succeeded">
This event indicates that the attempted mode switch operation was This event indicates that the attempted mode switch operation was
@ -182,16 +193,18 @@
wl_fullscreen_shell_mode_feedback object. wl_fullscreen_shell_mode_feedback object.
</description> </description>
</event> </event>
<event name="mode_failed"> <event name="mode_failed">
<description summary="mode switch failed"> <description summary="mode switch failed">
This event indicates that the attempted mode switch operation This event indicates that the attempted mode switch operation
failed. This may be because the requested output mode is not failed. This may be because the requested output mode is not
possible or it may mean that the compositor does not want to allow it. possible or it may mean that the compositor does not want to allow it.
Upon receiving this event, the client should destroy the Upon receiving this event, the client should destroy the
wl_fullscreen_shell_mode_feedback object. wl_fullscreen_shell_mode_feedback object.
</description> </description>
</event> </event>
<event name="present_cancelled"> <event name="present_cancelled">
<description summary="mode switch cancelled"> <description summary="mode switch cancelled">
This event indicates that the attempted mode switch operation was This event indicates that the attempted mode switch operation was
@ -203,4 +216,5 @@
</description> </description>
</event> </event>
</interface> </interface>
</protocol> </protocol>