mirror of
https://github.com/brl/mutter.git
synced 2024-11-21 07:30:42 -05:00
wayland: Add support for stable xdg-shell
This commit adds support for xdg_shell (the stable version). This was done by first copying the old xdg-shell unstable v6 implementation into a separate .c .h file pair (including various symbol renaming) then porting the old xdg-shell unstable v6 implementation to the new stable version. https://gitlab.gnome.org/GNOME/mutter/merge_requests/5 https://bugzilla.gnome.org/show_bug.cgi?id=791938
This commit is contained in:
parent
514c7028f4
commit
d714a94d97
2
.gitignore
vendored
2
.gitignore
vendored
@ -98,6 +98,8 @@ src/keyboard-shortcuts-inhibit-unstable-v*-protocol.c
|
||||
src/keyboard-shortcuts-inhibit-unstable-v*-server-protocol.h
|
||||
src/linux-dmabuf-unstable-v*-protocol.c
|
||||
src/linux-dmabuf-unstable-v*-server-protocol.h
|
||||
src/xdg-shell-protocol.c
|
||||
src/xdg-shell-server-protocol.h
|
||||
src/meta/meta-version.h
|
||||
src/libmutter-*.pc
|
||||
doc/reference/*.args
|
||||
|
@ -68,6 +68,8 @@ mutter_built_sources += \
|
||||
gtk-shell-server-protocol.h \
|
||||
gtk-primary-selection-protocol.c \
|
||||
gtk-primary-selection-server-protocol.h \
|
||||
xdg-shell-protocol.c \
|
||||
xdg-shell-server-protocol.h \
|
||||
xdg-shell-unstable-v6-protocol.c \
|
||||
xdg-shell-unstable-v6-server-protocol.h \
|
||||
relative-pointer-unstable-v1-protocol.c \
|
||||
@ -454,6 +456,8 @@ libmutter_@LIBMUTTER_API_VERSION@_la_SOURCES += \
|
||||
wayland/meta-window-xwayland.h \
|
||||
wayland/meta-wayland-xdg-shell.c \
|
||||
wayland/meta-wayland-xdg-shell.h \
|
||||
wayland/meta-wayland-legacy-xdg-shell.c \
|
||||
wayland/meta-wayland-legacy-xdg-shell.h \
|
||||
wayland/meta-wayland-wl-shell.c \
|
||||
wayland/meta-wayland-wl-shell.h \
|
||||
wayland/meta-wayland-gtk-shell.c \
|
||||
@ -742,7 +746,7 @@ backends/native/meta-default-modes.h: backends/native/gen-default-modes.py Makef
|
||||
.SECONDEXPANSION:
|
||||
|
||||
define protostability
|
||||
$(shell echo $1 | sed 's/.*\(\<unstable\>\|\<stable\>\).*/\1/')
|
||||
$(if $(findstring unstable,$1),unstable,stable)
|
||||
endef
|
||||
|
||||
define protoname
|
||||
|
1982
src/wayland/meta-wayland-legacy-xdg-shell.c
Normal file
1982
src/wayland/meta-wayland-legacy-xdg-shell.c
Normal file
File diff suppressed because it is too large
Load Diff
53
src/wayland/meta-wayland-legacy-xdg-shell.h
Normal file
53
src/wayland/meta-wayland-legacy-xdg-shell.h
Normal file
@ -0,0 +1,53 @@
|
||||
/*
|
||||
* Copyright (C) 2013-2015 Red Hat, Inc.
|
||||
*
|
||||
* This program is free software; you can redistribute it and/or
|
||||
* modify it under the terms of the GNU General Public License as
|
||||
* published by the Free Software Foundation; either version 2 of the
|
||||
* License, or (at your option) any later version.
|
||||
*
|
||||
* This program is distributed in the hope that it will be useful, but
|
||||
* WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||||
* General Public License for more details.
|
||||
*
|
||||
* You should have received a copy of the GNU General Public License
|
||||
* along with this program; if not, write to the Free Software
|
||||
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA
|
||||
* 02111-1307, USA.
|
||||
*/
|
||||
|
||||
#ifndef META_WAYLAND_LEGACY_XDG_SHELL_H
|
||||
#define META_WAYLAND_LEGACY_XDG_SHELL_H
|
||||
|
||||
#include "wayland/meta-wayland-surface.h"
|
||||
#include "wayland/meta-wayland-shell-surface.h"
|
||||
|
||||
#define META_TYPE_WAYLAND_ZXDG_SURFACE_V6 (meta_wayland_zxdg_surface_v6_get_type ())
|
||||
G_DECLARE_DERIVABLE_TYPE (MetaWaylandZxdgSurfaceV6,
|
||||
meta_wayland_zxdg_surface_v6,
|
||||
META, WAYLAND_ZXDG_SURFACE_V6,
|
||||
MetaWaylandShellSurface)
|
||||
|
||||
struct _MetaWaylandZxdgSurfaceV6Class
|
||||
{
|
||||
MetaWaylandShellSurfaceClass parent_class;
|
||||
|
||||
void (*shell_client_destroyed) (MetaWaylandZxdgSurfaceV6 *xdg_surface);
|
||||
};
|
||||
|
||||
#define META_TYPE_WAYLAND_ZXDG_TOPLEVEL_V6 (meta_wayland_zxdg_toplevel_v6_get_type ())
|
||||
G_DECLARE_FINAL_TYPE (MetaWaylandZxdgToplevelV6,
|
||||
meta_wayland_zxdg_toplevel_v6,
|
||||
META, WAYLAND_ZXDG_TOPLEVEL_V6,
|
||||
MetaWaylandZxdgSurfaceV6);
|
||||
|
||||
#define META_TYPE_WAYLAND_ZXDG_POPUP_V6 (meta_wayland_zxdg_popup_v6_get_type ())
|
||||
G_DECLARE_FINAL_TYPE (MetaWaylandZxdgPopupV6,
|
||||
meta_wayland_zxdg_popup_v6,
|
||||
META, WAYLAND_ZXDG_POPUP_V6,
|
||||
MetaWaylandZxdgSurfaceV6);
|
||||
|
||||
void meta_wayland_legacy_xdg_shell_init (MetaWaylandCompositor *compositor);
|
||||
|
||||
#endif /* META_WAYLAND_LEGACY_XDG_SHELL_H */
|
@ -43,6 +43,7 @@
|
||||
#include "meta-wayland-data-device.h"
|
||||
#include "meta-wayland-outputs.h"
|
||||
#include "meta-wayland-xdg-shell.h"
|
||||
#include "meta-wayland-legacy-xdg-shell.h"
|
||||
#include "meta-wayland-wl-shell.h"
|
||||
#include "meta-wayland-gtk-shell.h"
|
||||
|
||||
@ -1199,6 +1200,21 @@ window_position_changed (MetaWindow *window,
|
||||
meta_wayland_surface_update_outputs_recursively (surface);
|
||||
}
|
||||
|
||||
void
|
||||
meta_wayland_surface_create_surface_actor (MetaWaylandSurface *surface)
|
||||
{
|
||||
MetaSurfaceActor *surface_actor;
|
||||
|
||||
surface_actor = meta_surface_actor_wayland_new (surface);
|
||||
surface->surface_actor = g_object_ref_sink (surface_actor);
|
||||
}
|
||||
|
||||
void
|
||||
meta_wayland_surface_clear_surface_actor (MetaWaylandSurface *surface)
|
||||
{
|
||||
g_clear_object (&surface->surface_actor);
|
||||
}
|
||||
|
||||
MetaWaylandSurface *
|
||||
meta_wayland_surface_create (MetaWaylandCompositor *compositor,
|
||||
struct wl_client *client,
|
||||
@ -1269,6 +1285,7 @@ void
|
||||
meta_wayland_shell_init (MetaWaylandCompositor *compositor)
|
||||
{
|
||||
meta_wayland_xdg_shell_init (compositor);
|
||||
meta_wayland_legacy_xdg_shell_init (compositor);
|
||||
meta_wayland_wl_shell_init (compositor);
|
||||
meta_wayland_gtk_shell_init (compositor);
|
||||
}
|
||||
|
@ -231,6 +231,10 @@ void meta_wayland_surface_unref_buffer_use_count (MetaWaylandSurf
|
||||
void meta_wayland_surface_set_window (MetaWaylandSurface *surface,
|
||||
MetaWindow *window);
|
||||
|
||||
void meta_wayland_surface_create_surface_actor (MetaWaylandSurface *surface);
|
||||
|
||||
void meta_wayland_surface_clear_surface_actor (MetaWaylandSurface *surface);
|
||||
|
||||
void meta_wayland_surface_configure_notify (MetaWaylandSurface *surface,
|
||||
int new_x,
|
||||
int new_y,
|
||||
|
@ -37,7 +37,8 @@
|
||||
/* Global/master objects (version exported by wl_registry and negotiated through bind) */
|
||||
#define META_WL_COMPOSITOR_VERSION 4
|
||||
#define META_WL_DATA_DEVICE_MANAGER_VERSION 3
|
||||
#define META_XDG_SHELL_VERSION 1
|
||||
#define META_XDG_WM_BASE_VERSION 1
|
||||
#define META_ZXDG_SHELL_V6_VERSION 1
|
||||
#define META_WL_SHELL_VERSION 1
|
||||
#define META_WL_SEAT_VERSION 5
|
||||
#define META_WL_OUTPUT_VERSION 2
|
||||
|
@ -32,6 +32,7 @@
|
||||
#include "wayland/meta-wayland-private.h"
|
||||
#include "wayland/meta-wayland-versions.h"
|
||||
#include "wayland/meta-wayland-xdg-shell.h"
|
||||
#include "wayland/meta-wayland-legacy-xdg-shell.h"
|
||||
|
||||
#include "xdg-foreign-unstable-v1-server-protocol.h"
|
||||
|
||||
@ -145,6 +146,7 @@ xdg_exporter_export (struct wl_client *client,
|
||||
|
||||
if (!surface->role ||
|
||||
!META_IS_WAYLAND_XDG_SURFACE (surface->role) ||
|
||||
!META_IS_WAYLAND_ZXDG_SURFACE_V6 (surface->role) ||
|
||||
!surface->window)
|
||||
{
|
||||
wl_resource_post_error (resource,
|
||||
@ -254,6 +256,9 @@ is_valid_child (MetaWaylandSurface *surface)
|
||||
if (!META_IS_WAYLAND_XDG_SURFACE (surface->role))
|
||||
return FALSE;
|
||||
|
||||
if (!META_IS_WAYLAND_ZXDG_SURFACE_V6 (surface->role))
|
||||
return FALSE;
|
||||
|
||||
if (!surface->window)
|
||||
return FALSE;
|
||||
|
||||
@ -376,7 +381,9 @@ xdg_importer_import (struct wl_client *client,
|
||||
xdg_imported_destructor);
|
||||
|
||||
exported = g_hash_table_lookup (foreign->exported_surfaces, handle);
|
||||
if (!exported || !META_IS_WAYLAND_XDG_SURFACE (exported->surface->role))
|
||||
if (!exported ||
|
||||
(!META_IS_WAYLAND_XDG_SURFACE (exported->surface->role) &&
|
||||
!META_IS_WAYLAND_ZXDG_SURFACE_V6 (exported->surface->role)))
|
||||
{
|
||||
zxdg_imported_v1_send_destroyed (resource);
|
||||
return;
|
||||
|
File diff suppressed because it is too large
Load Diff
@ -33,6 +33,7 @@ struct _MetaWaylandXdgSurfaceClass
|
||||
MetaWaylandShellSurfaceClass parent_class;
|
||||
|
||||
void (*shell_client_destroyed) (MetaWaylandXdgSurface *xdg_surface);
|
||||
void (*reset) (MetaWaylandXdgSurface *xdg_surface);
|
||||
};
|
||||
|
||||
#define META_TYPE_WAYLAND_XDG_TOPLEVEL (meta_wayland_xdg_toplevel_get_type ())
|
||||
|
Loading…
Reference in New Issue
Block a user