[mutter/gnome-3-34] wayland/data-device: Fix crash with offer from X11 client
- From: Robert Mader <rmader src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [mutter/gnome-3-34] wayland/data-device: Fix crash with offer from X11 client
- Date: Sun, 23 Feb 2020 17:33:24 +0000 (UTC)
commit 2709a4ffb19878cdaf5d001a7be5e717c17bf607
Author: Olivier Fourdan <ofourdan redhat com>
Date: Thu Feb 20 10:25:46 2020 +0100
wayland/data-device: Fix crash with offer from X11 client
If a data offer comes from an X11 client, the Wayland resource would be
NULL, causing a crash in `data_offer_choose_action()` trying to get the
resource version.
So instead of doing the version check in `data_offer_choose_action()`,
do it early when creating the data source.
Closes: https://gitlab.gnome.org/GNOME/mutter/issues/1057
https://gitlab.gnome.org/GNOME/mutter/merge_requests/1073
(cherry picked from commit f9326cfa3d5f0fd9f63f561d6dfbb92a8f6fb34a)
src/wayland/meta-wayland-data-device.c | 20 ++++++++++----------
1 file changed, 10 insertions(+), 10 deletions(-)
---
diff --git a/src/wayland/meta-wayland-data-device.c b/src/wayland/meta-wayland-data-device.c
index 144751fa8..b289bc9bf 100644
--- a/src/wayland/meta-wayland-data-device.c
+++ b/src/wayland/meta-wayland-data-device.c
@@ -143,16 +143,8 @@ data_offer_choose_action (MetaWaylandDataOffer *offer)
WL_DATA_OFFER_ACTION_SINCE_VERSION)
return WL_DATA_DEVICE_MANAGER_DND_ACTION_COPY;
- if (wl_resource_get_version (meta_wayland_data_source_get_resource (source)) <
- WL_DATA_SOURCE_ACTION_SINCE_VERSION)
- {
- actions = user_action = WL_DATA_DEVICE_MANAGER_DND_ACTION_COPY;
- }
- else
- {
- actions = meta_wayland_data_source_get_actions (source);
- user_action = meta_wayland_data_source_get_user_action (source);
- }
+ actions = meta_wayland_data_source_get_actions (source);
+ user_action = meta_wayland_data_source_get_user_action (source);
available_actions = actions & offer->dnd_actions;
@@ -2187,11 +2179,19 @@ meta_wayland_data_source_new (struct wl_resource *resource)
{
MetaWaylandDataSource *source =
g_object_new (META_TYPE_WAYLAND_DATA_SOURCE, NULL);
+ MetaWaylandDataSourcePrivate *priv =
+ meta_wayland_data_source_get_instance_private (source);
meta_wayland_data_source_set_resource (source, resource);
wl_resource_set_implementation (resource, &data_source_interface,
source, destroy_data_source);
+ if (wl_resource_get_version (resource) < WL_DATA_SOURCE_ACTION_SINCE_VERSION)
+ {
+ priv->dnd_actions = priv->user_dnd_action =
+ WL_DATA_DEVICE_MANAGER_DND_ACTION_COPY;
+ }
+
return source;
}
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]