remove wl_shell
This has been deprecated long enough, I think it's time to say goodbye. Signed-off-by: Derek Foreman <derek.foreman@collabora.com>
This commit is contained in:
parent
5ba7ae2937
commit
e6b8f5a5e4
@ -234,10 +234,6 @@ weston_desktop_xdg_wm_base_create(struct weston_desktop *desktop,
|
||||
struct wl_global *
|
||||
weston_desktop_xdg_shell_v6_create(struct weston_desktop *desktop,
|
||||
struct wl_display *display);
|
||||
struct wl_global *
|
||||
weston_desktop_wl_shell_create(struct weston_desktop *desktop,
|
||||
struct wl_display *display);
|
||||
|
||||
void
|
||||
weston_desktop_xwayland_init(struct weston_desktop *desktop);
|
||||
void
|
||||
|
@ -42,7 +42,6 @@ struct weston_desktop {
|
||||
void *user_data;
|
||||
struct wl_global *xdg_wm_base; /* Stable protocol xdg_shell replaces xdg_shell_unstable_v6 */
|
||||
struct wl_global *xdg_shell_v6; /* Unstable xdg_shell_unstable_v6 protocol. */
|
||||
struct wl_global *wl_shell;
|
||||
};
|
||||
|
||||
void
|
||||
@ -77,22 +76,6 @@ weston_desktop_create(struct weston_compositor *compositor,
|
||||
return NULL;
|
||||
}
|
||||
|
||||
#ifdef HAVE_DEPRECATED_WL_SHELL
|
||||
weston_log("Warning: support for deprecated wl_shell interface is "
|
||||
"enabled. Please migrate legacy clients to xdg-shell.\n");
|
||||
desktop->wl_shell =
|
||||
weston_desktop_wl_shell_create(desktop, display);
|
||||
if (desktop->wl_shell == NULL) {
|
||||
weston_desktop_destroy(desktop);
|
||||
return NULL;
|
||||
}
|
||||
#else
|
||||
weston_log("Note: support for the deprecated wl_shell interface is "
|
||||
"disabled. If a legacy client still needs it, it can be "
|
||||
"re-enabled by passing -Ddeprecated-wl-shell=true to Meson "
|
||||
"when building Weston.\n");
|
||||
#endif
|
||||
|
||||
weston_desktop_xwayland_init(desktop);
|
||||
|
||||
return desktop;
|
||||
@ -106,8 +89,6 @@ weston_desktop_destroy(struct weston_desktop *desktop)
|
||||
|
||||
weston_desktop_xwayland_fini(desktop);
|
||||
|
||||
if (desktop->wl_shell != NULL)
|
||||
wl_global_destroy(desktop->wl_shell);
|
||||
if (desktop->xdg_shell_v6 != NULL)
|
||||
wl_global_destroy(desktop->xdg_shell_v6);
|
||||
if (desktop->xdg_wm_base != NULL)
|
||||
|
@ -4,7 +4,6 @@ srcs_libdesktop = [
|
||||
'seat.c',
|
||||
'surface.c',
|
||||
'xwayland.c',
|
||||
'wl-shell.c',
|
||||
'xdg-shell.c',
|
||||
'xdg-shell-v6.c',
|
||||
xdg_shell_unstable_v6_server_protocol_h,
|
||||
|
@ -1,497 +0,0 @@
|
||||
/*
|
||||
* Copyright © 2010-2012 Intel Corporation
|
||||
* Copyright © 2011-2012 Collabora, Ltd.
|
||||
* Copyright © 2013 Raspberry Pi Foundation
|
||||
* Copyright © 2016 Quentin "Sardem FF7" Glidic
|
||||
*
|
||||
* Permission is hereby granted, free of charge, to any person obtaining a
|
||||
* copy of this software and associated documentation files (the "Software"),
|
||||
* to deal in the Software without restriction, including without limitation
|
||||
* the rights to use, copy, modify, merge, publish, distribute, sublicense,
|
||||
* and/or sell copies of the Software, and to permit persons to whom the
|
||||
* Software is furnished to do so, subject to the following conditions:
|
||||
*
|
||||
* The above copyright notice and this permission notice (including the next
|
||||
* paragraph) shall be included in all copies or substantial portions of the
|
||||
* Software.
|
||||
*
|
||||
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
||||
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
|
||||
* THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
||||
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
|
||||
* FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
|
||||
* DEALINGS IN THE SOFTWARE.
|
||||
*/
|
||||
|
||||
#include "config.h"
|
||||
|
||||
#include <assert.h>
|
||||
|
||||
#include <wayland-server.h>
|
||||
|
||||
#include <libweston/libweston.h>
|
||||
#include <libweston/zalloc.h>
|
||||
|
||||
#include <libweston-desktop/libweston-desktop.h>
|
||||
#include "internal.h"
|
||||
|
||||
#define WD_WL_SHELL_PROTOCOL_VERSION 1
|
||||
|
||||
enum weston_desktop_wl_shell_surface_state {
|
||||
NONE,
|
||||
TOPLEVEL,
|
||||
MAXIMIZED,
|
||||
FULLSCREEN,
|
||||
TRANSIENT,
|
||||
POPUP,
|
||||
};
|
||||
|
||||
struct weston_desktop_wl_shell_surface {
|
||||
struct wl_resource *resource;
|
||||
struct weston_desktop *desktop;
|
||||
struct wl_display *display;
|
||||
struct weston_desktop_surface *surface;
|
||||
struct weston_desktop_surface *parent;
|
||||
bool added;
|
||||
struct weston_desktop_seat *popup_seat;
|
||||
enum weston_desktop_wl_shell_surface_state state;
|
||||
struct wl_listener wl_surface_resource_destroy_listener;
|
||||
};
|
||||
|
||||
static void
|
||||
weston_desktop_wl_shell_surface_set_size(struct weston_desktop_surface *dsurface,
|
||||
void *user_data,
|
||||
int32_t width, int32_t height)
|
||||
{
|
||||
struct weston_desktop_wl_shell_surface *surface = user_data;
|
||||
struct weston_surface *wsurface =
|
||||
weston_desktop_surface_get_surface(surface->surface);
|
||||
|
||||
if ((wsurface->width == width && wsurface->height == height) ||
|
||||
(width == 0 && height == 0))
|
||||
return;
|
||||
|
||||
wl_shell_surface_send_configure(surface->resource,
|
||||
WL_SHELL_SURFACE_RESIZE_NONE,
|
||||
width, height);
|
||||
}
|
||||
|
||||
static void
|
||||
weston_desktop_wl_shell_surface_maybe_ungrab(struct weston_desktop_wl_shell_surface *surface)
|
||||
{
|
||||
if (surface->state != POPUP ||
|
||||
!weston_desktop_surface_get_grab(surface->surface))
|
||||
return;
|
||||
|
||||
weston_desktop_surface_popup_ungrab(surface->surface,
|
||||
surface->popup_seat);
|
||||
surface->popup_seat = NULL;
|
||||
}
|
||||
|
||||
static void
|
||||
weston_desktop_wl_shell_surface_committed(struct weston_desktop_surface *dsurface,
|
||||
void *user_data,
|
||||
int32_t sx, int32_t sy)
|
||||
{
|
||||
struct weston_desktop_wl_shell_surface *surface = user_data;
|
||||
struct weston_surface *wsurface =
|
||||
weston_desktop_surface_get_surface(dsurface);
|
||||
|
||||
if (wsurface->buffer_ref.buffer == NULL)
|
||||
weston_desktop_wl_shell_surface_maybe_ungrab(surface);
|
||||
|
||||
if (surface->added)
|
||||
weston_desktop_api_committed(surface->desktop, surface->surface,
|
||||
sx, sy);
|
||||
}
|
||||
|
||||
static void
|
||||
weston_desktop_wl_shell_surface_ping(struct weston_desktop_surface *dsurface,
|
||||
uint32_t serial, void *user_data)
|
||||
{
|
||||
struct weston_desktop_wl_shell_surface *surface = user_data;
|
||||
|
||||
wl_shell_surface_send_ping(surface->resource, serial);
|
||||
}
|
||||
|
||||
static void
|
||||
weston_desktop_wl_shell_surface_close(struct weston_desktop_surface *dsurface,
|
||||
void *user_data)
|
||||
{
|
||||
struct weston_desktop_wl_shell_surface *surface = user_data;
|
||||
|
||||
if (surface->state == POPUP)
|
||||
wl_shell_surface_send_popup_done(surface->resource);
|
||||
}
|
||||
|
||||
static bool
|
||||
weston_desktop_wl_shell_surface_get_maximized(struct weston_desktop_surface *dsurface,
|
||||
void *user_data)
|
||||
{
|
||||
struct weston_desktop_wl_shell_surface *surface = user_data;
|
||||
|
||||
return surface->state == MAXIMIZED;
|
||||
}
|
||||
|
||||
static bool
|
||||
weston_desktop_wl_shell_surface_get_fullscreen(struct weston_desktop_surface *dsurface,
|
||||
void *user_data)
|
||||
{
|
||||
struct weston_desktop_wl_shell_surface *surface = user_data;
|
||||
|
||||
return surface->state == FULLSCREEN;
|
||||
}
|
||||
|
||||
static void
|
||||
weston_desktop_wl_shell_change_state(struct weston_desktop_wl_shell_surface *surface,
|
||||
enum weston_desktop_wl_shell_surface_state state,
|
||||
struct weston_desktop_surface *parent,
|
||||
int32_t x, int32_t y)
|
||||
{
|
||||
bool to_add = (parent == NULL);
|
||||
|
||||
assert(state != NONE);
|
||||
|
||||
if (to_add && surface->added) {
|
||||
surface->state = state;
|
||||
return;
|
||||
}
|
||||
|
||||
if (surface->state != state) {
|
||||
if (surface->state == POPUP)
|
||||
weston_desktop_wl_shell_surface_maybe_ungrab(surface);
|
||||
|
||||
if (to_add) {
|
||||
weston_desktop_surface_unset_relative_to(surface->surface);
|
||||
weston_desktop_api_surface_added(surface->desktop,
|
||||
surface->surface);
|
||||
} else if (surface->added) {
|
||||
weston_desktop_api_surface_removed(surface->desktop,
|
||||
surface->surface);
|
||||
}
|
||||
|
||||
surface->state = state;
|
||||
surface->added = to_add;
|
||||
}
|
||||
|
||||
if (parent != NULL)
|
||||
weston_desktop_surface_set_relative_to(surface->surface, parent,
|
||||
x, y, false);
|
||||
}
|
||||
|
||||
static void
|
||||
weston_desktop_wl_shell_surface_destroy(struct weston_desktop_surface *dsurface,
|
||||
void *user_data)
|
||||
{
|
||||
struct weston_desktop_wl_shell_surface *surface = user_data;
|
||||
|
||||
wl_list_remove(&surface->wl_surface_resource_destroy_listener.link);
|
||||
|
||||
weston_desktop_wl_shell_surface_maybe_ungrab(surface);
|
||||
weston_desktop_surface_unset_relative_to(surface->surface);
|
||||
if (surface->added)
|
||||
weston_desktop_api_surface_removed(surface->desktop,
|
||||
surface->surface);
|
||||
|
||||
free(surface);
|
||||
}
|
||||
|
||||
static void
|
||||
weston_desktop_wl_shell_surface_protocol_pong(struct wl_client *wl_client,
|
||||
struct wl_resource *resource,
|
||||
uint32_t serial)
|
||||
{
|
||||
struct weston_desktop_surface *surface = wl_resource_get_user_data(resource);
|
||||
|
||||
weston_desktop_client_pong(weston_desktop_surface_get_client(surface), serial);
|
||||
}
|
||||
|
||||
static void
|
||||
weston_desktop_wl_shell_surface_protocol_move(struct wl_client *wl_client,
|
||||
struct wl_resource *resource,
|
||||
struct wl_resource *seat_resource,
|
||||
uint32_t serial)
|
||||
{
|
||||
struct weston_desktop_surface *dsurface =
|
||||
wl_resource_get_user_data(resource);
|
||||
struct weston_seat *seat =
|
||||
wl_resource_get_user_data(seat_resource);
|
||||
struct weston_desktop_wl_shell_surface *surface =
|
||||
weston_desktop_surface_get_implementation_data(dsurface);
|
||||
|
||||
if (seat == NULL)
|
||||
return;
|
||||
|
||||
weston_desktop_api_move(surface->desktop, dsurface, seat, serial);
|
||||
}
|
||||
|
||||
static void
|
||||
weston_desktop_wl_shell_surface_protocol_resize(struct wl_client *wl_client,
|
||||
struct wl_resource *resource,
|
||||
struct wl_resource *seat_resource,
|
||||
uint32_t serial,
|
||||
enum wl_shell_surface_resize edges)
|
||||
{
|
||||
struct weston_desktop_surface *dsurface =
|
||||
wl_resource_get_user_data(resource);
|
||||
struct weston_seat *seat = wl_resource_get_user_data(seat_resource);
|
||||
struct weston_desktop_wl_shell_surface *surface =
|
||||
weston_desktop_surface_get_implementation_data(dsurface);
|
||||
enum weston_desktop_surface_edge surf_edges =
|
||||
(enum weston_desktop_surface_edge) edges;
|
||||
|
||||
if (seat == NULL)
|
||||
return;
|
||||
|
||||
weston_desktop_api_resize(surface->desktop, dsurface, seat, serial, surf_edges);
|
||||
}
|
||||
|
||||
static void
|
||||
weston_desktop_wl_shell_surface_protocol_set_toplevel(struct wl_client *wl_client,
|
||||
struct wl_resource *resource)
|
||||
{
|
||||
struct weston_desktop_surface *dsurface =
|
||||
wl_resource_get_user_data(resource);
|
||||
struct weston_desktop_wl_shell_surface *surface =
|
||||
weston_desktop_surface_get_implementation_data(dsurface);
|
||||
|
||||
weston_desktop_wl_shell_change_state(surface, TOPLEVEL, NULL, 0, 0);
|
||||
if (surface->parent == NULL)
|
||||
return;
|
||||
surface->parent = NULL;
|
||||
weston_desktop_api_set_parent(surface->desktop, surface->surface, NULL);
|
||||
}
|
||||
|
||||
static void
|
||||
weston_desktop_wl_shell_surface_protocol_set_transient(struct wl_client *wl_client,
|
||||
struct wl_resource *resource,
|
||||
struct wl_resource *parent_resource,
|
||||
int32_t x, int32_t y,
|
||||
enum wl_shell_surface_transient flags)
|
||||
{
|
||||
struct weston_desktop_surface *dsurface =
|
||||
wl_resource_get_user_data(resource);
|
||||
struct weston_surface *wparent =
|
||||
wl_resource_get_user_data(parent_resource);
|
||||
struct weston_desktop_surface *parent;
|
||||
struct weston_desktop_wl_shell_surface *surface =
|
||||
weston_desktop_surface_get_implementation_data(dsurface);
|
||||
|
||||
if (!weston_surface_is_desktop_surface(wparent))
|
||||
return;
|
||||
|
||||
parent = weston_surface_get_desktop_surface(wparent);
|
||||
if (flags & WL_SHELL_SURFACE_TRANSIENT_INACTIVE) {
|
||||
weston_desktop_wl_shell_change_state(surface, TRANSIENT, parent,
|
||||
x, y);
|
||||
} else {
|
||||
weston_desktop_wl_shell_change_state(surface, TOPLEVEL, NULL,
|
||||
0, 0);
|
||||
surface->parent = parent;
|
||||
weston_desktop_api_set_parent(surface->desktop,
|
||||
surface->surface, parent);
|
||||
}
|
||||
}
|
||||
|
||||
static void
|
||||
weston_desktop_wl_shell_surface_protocol_set_fullscreen(struct wl_client *wl_client,
|
||||
struct wl_resource *resource,
|
||||
enum wl_shell_surface_fullscreen_method method,
|
||||
uint32_t framerate,
|
||||
struct wl_resource *output_resource)
|
||||
{
|
||||
struct weston_desktop_surface *dsurface =
|
||||
wl_resource_get_user_data(resource);
|
||||
struct weston_desktop_wl_shell_surface *surface =
|
||||
weston_desktop_surface_get_implementation_data(dsurface);
|
||||
struct weston_output *output = NULL;
|
||||
|
||||
if (output_resource != NULL)
|
||||
output = weston_head_from_resource(output_resource)->output;
|
||||
|
||||
weston_desktop_wl_shell_change_state(surface, FULLSCREEN, NULL, 0, 0);
|
||||
weston_desktop_api_fullscreen_requested(surface->desktop, dsurface,
|
||||
true, output);
|
||||
}
|
||||
|
||||
static void
|
||||
weston_desktop_wl_shell_surface_protocol_set_popup(struct wl_client *wl_client,
|
||||
struct wl_resource *resource,
|
||||
struct wl_resource *seat_resource,
|
||||
uint32_t serial,
|
||||
struct wl_resource *parent_resource,
|
||||
int32_t x, int32_t y,
|
||||
enum wl_shell_surface_transient flags)
|
||||
{
|
||||
struct weston_desktop_surface *dsurface =
|
||||
wl_resource_get_user_data(resource);
|
||||
struct weston_seat *wseat = wl_resource_get_user_data(seat_resource);
|
||||
struct weston_desktop_seat *seat = weston_desktop_seat_from_seat(wseat);
|
||||
struct weston_surface *parent =
|
||||
wl_resource_get_user_data(parent_resource);
|
||||
struct weston_desktop_surface *parent_surface;
|
||||
struct weston_desktop_wl_shell_surface *surface =
|
||||
weston_desktop_surface_get_implementation_data(dsurface);
|
||||
|
||||
/* Check that if we have a valid wseat we also got a valid desktop seat */
|
||||
if (wseat != NULL && seat == NULL) {
|
||||
wl_client_post_no_memory(wl_client);
|
||||
return;
|
||||
}
|
||||
|
||||
if (!weston_surface_is_desktop_surface(parent))
|
||||
return;
|
||||
|
||||
parent_surface = weston_surface_get_desktop_surface(parent);
|
||||
|
||||
weston_desktop_wl_shell_change_state(surface, POPUP,
|
||||
parent_surface, x, y);
|
||||
weston_desktop_surface_popup_grab(surface->surface, seat, serial);
|
||||
surface->popup_seat = seat;
|
||||
}
|
||||
|
||||
static void
|
||||
weston_desktop_wl_shell_surface_protocol_set_maximized(struct wl_client *wl_client,
|
||||
struct wl_resource *resource,
|
||||
struct wl_resource *output_resource)
|
||||
{
|
||||
struct weston_desktop_surface *dsurface =
|
||||
wl_resource_get_user_data(resource);
|
||||
struct weston_desktop_wl_shell_surface *surface =
|
||||
weston_desktop_surface_get_implementation_data(dsurface);
|
||||
|
||||
weston_desktop_wl_shell_change_state(surface, MAXIMIZED, NULL, 0, 0);
|
||||
weston_desktop_api_maximized_requested(surface->desktop, dsurface, true);
|
||||
}
|
||||
|
||||
static void
|
||||
weston_desktop_wl_shell_surface_protocol_set_title(struct wl_client *wl_client,
|
||||
struct wl_resource *resource,
|
||||
const char *title)
|
||||
{
|
||||
struct weston_desktop_surface *surface =
|
||||
wl_resource_get_user_data(resource);
|
||||
|
||||
weston_desktop_surface_set_title(surface, title);
|
||||
}
|
||||
|
||||
static void
|
||||
weston_desktop_wl_shell_surface_protocol_set_class(struct wl_client *wl_client,
|
||||
struct wl_resource *resource,
|
||||
const char *class_)
|
||||
{
|
||||
struct weston_desktop_surface *surface =
|
||||
wl_resource_get_user_data(resource);
|
||||
|
||||
weston_desktop_surface_set_app_id(surface, class_);
|
||||
}
|
||||
|
||||
|
||||
static const struct wl_shell_surface_interface weston_desktop_wl_shell_surface_implementation = {
|
||||
.pong = weston_desktop_wl_shell_surface_protocol_pong,
|
||||
.move = weston_desktop_wl_shell_surface_protocol_move,
|
||||
.resize = weston_desktop_wl_shell_surface_protocol_resize,
|
||||
.set_toplevel = weston_desktop_wl_shell_surface_protocol_set_toplevel,
|
||||
.set_transient = weston_desktop_wl_shell_surface_protocol_set_transient,
|
||||
.set_fullscreen = weston_desktop_wl_shell_surface_protocol_set_fullscreen,
|
||||
.set_popup = weston_desktop_wl_shell_surface_protocol_set_popup,
|
||||
.set_maximized = weston_desktop_wl_shell_surface_protocol_set_maximized,
|
||||
.set_title = weston_desktop_wl_shell_surface_protocol_set_title,
|
||||
.set_class = weston_desktop_wl_shell_surface_protocol_set_class,
|
||||
};
|
||||
|
||||
static const struct weston_desktop_surface_implementation weston_desktop_wl_shell_surface_internal_implementation = {
|
||||
.set_size = weston_desktop_wl_shell_surface_set_size,
|
||||
.committed = weston_desktop_wl_shell_surface_committed,
|
||||
.ping = weston_desktop_wl_shell_surface_ping,
|
||||
.close = weston_desktop_wl_shell_surface_close,
|
||||
|
||||
.get_maximized = weston_desktop_wl_shell_surface_get_maximized,
|
||||
.get_fullscreen = weston_desktop_wl_shell_surface_get_fullscreen,
|
||||
|
||||
.destroy = weston_desktop_wl_shell_surface_destroy,
|
||||
};
|
||||
|
||||
static void
|
||||
wl_surface_resource_destroyed(struct wl_listener *listener,
|
||||
void *data)
|
||||
{
|
||||
struct weston_desktop_wl_shell_surface *surface =
|
||||
wl_container_of(listener, surface,
|
||||
wl_surface_resource_destroy_listener);
|
||||
|
||||
/* the wl_shell_surface spec says that wl_shell_surfaces are to be
|
||||
* destroyed automatically when the wl_surface is destroyed. */
|
||||
weston_desktop_surface_destroy(surface->surface);
|
||||
}
|
||||
|
||||
static void
|
||||
weston_desktop_wl_shell_protocol_get_shell_surface(struct wl_client *wl_client,
|
||||
struct wl_resource *resource,
|
||||
uint32_t id,
|
||||
struct wl_resource *surface_resource)
|
||||
{
|
||||
struct weston_desktop_client *client = wl_resource_get_user_data(resource);
|
||||
struct weston_surface *wsurface = wl_resource_get_user_data(surface_resource);
|
||||
struct weston_desktop_wl_shell_surface *surface;
|
||||
|
||||
|
||||
if (weston_surface_set_role(wsurface, "wl_shell_surface", resource, WL_SHELL_ERROR_ROLE) < 0)
|
||||
return;
|
||||
|
||||
surface = zalloc(sizeof(struct weston_desktop_wl_shell_surface));
|
||||
if (surface == NULL) {
|
||||
wl_client_post_no_memory(wl_client);
|
||||
return;
|
||||
}
|
||||
|
||||
surface->desktop = weston_desktop_client_get_desktop(client);
|
||||
surface->display = weston_desktop_get_display(surface->desktop);
|
||||
|
||||
surface->surface =
|
||||
weston_desktop_surface_create(surface->desktop, client, wsurface,
|
||||
&weston_desktop_wl_shell_surface_internal_implementation,
|
||||
surface);
|
||||
if (surface->surface == NULL) {
|
||||
free(surface);
|
||||
return;
|
||||
}
|
||||
|
||||
surface->wl_surface_resource_destroy_listener.notify =
|
||||
wl_surface_resource_destroyed;
|
||||
wl_resource_add_destroy_listener(wsurface->resource,
|
||||
&surface->wl_surface_resource_destroy_listener);
|
||||
|
||||
surface->resource =
|
||||
weston_desktop_surface_add_resource(surface->surface,
|
||||
&wl_shell_surface_interface,
|
||||
&weston_desktop_wl_shell_surface_implementation,
|
||||
id, NULL);
|
||||
}
|
||||
|
||||
|
||||
static const struct wl_shell_interface weston_desktop_wl_shell_implementation = {
|
||||
.get_shell_surface = weston_desktop_wl_shell_protocol_get_shell_surface,
|
||||
};
|
||||
|
||||
static void
|
||||
weston_desktop_wl_shell_bind(struct wl_client *client, void *data,
|
||||
uint32_t version, uint32_t id)
|
||||
{
|
||||
struct weston_desktop *desktop = data;
|
||||
|
||||
weston_desktop_client_create(desktop, client, NULL, &wl_shell_interface,
|
||||
&weston_desktop_wl_shell_implementation,
|
||||
version, id);
|
||||
}
|
||||
|
||||
struct wl_global *
|
||||
weston_desktop_wl_shell_create(struct weston_desktop *desktop,
|
||||
struct wl_display *display)
|
||||
{
|
||||
return wl_global_create(display,
|
||||
&wl_shell_interface,
|
||||
WD_WL_SHELL_PROTOCOL_VERSION, desktop,
|
||||
weston_desktop_wl_shell_bind);
|
||||
}
|
@ -143,12 +143,6 @@ if dep_xkbcommon.version().version_compare('>= 0.5.0')
|
||||
config_h.set('HAVE_XKBCOMMON_COMPOSE', '1')
|
||||
endif
|
||||
|
||||
if get_option('deprecated-wl-shell')
|
||||
warning('Support for the deprecated wl_shell interface is enabled.')
|
||||
warning('This feature will be removed in a future version.')
|
||||
config_h.set('HAVE_DEPRECATED_WL_SHELL', '1')
|
||||
endif
|
||||
|
||||
dep_wayland_server = dependency('wayland-server', version: '>= 1.20.0')
|
||||
dep_wayland_client = dependency('wayland-client', version: '>= 1.20.0')
|
||||
dep_pixman = dependency('pixman-1', version: '>= 0.25.2')
|
||||
|
@ -131,13 +131,6 @@ option(
|
||||
description: 'Weston desktop shell: default helper client selection'
|
||||
)
|
||||
|
||||
option(
|
||||
'deprecated-wl-shell',
|
||||
type: 'boolean',
|
||||
value: false,
|
||||
description: 'Enable the deprecated wl_shell protocol'
|
||||
)
|
||||
|
||||
option(
|
||||
'color-management-lcms',
|
||||
type: 'boolean',
|
||||
|
Loading…
Reference in New Issue
Block a user