diff options
author | emersion <contact@emersion.fr> | 2018-01-28 21:17:44 +0100 |
---|---|---|
committer | emersion <contact@emersion.fr> | 2018-01-28 21:48:05 +0100 |
commit | 5bbff20b8d593ad55efa4b31ea520519d6d988c9 (patch) | |
tree | 12afecb38738a67baef07dfe2374d6bd10cf2822 | |
parent | f0b3a71fbc72eeccf44bc6a6f6c39a80af918463 (diff) |
Fix assertion failed in data_source_notify_finish
-rw-r--r-- | types/wlr_data_device.c | 7 |
1 files changed, 5 insertions, 2 deletions
diff --git a/types/wlr_data_device.c b/types/wlr_data_device.c index 5a6bc198..c359be79 100644 --- a/types/wlr_data_device.c +++ b/types/wlr_data_device.c @@ -173,16 +173,19 @@ static void data_offer_resource_destroy(struct wl_resource *resource) { goto out; } - offer->source->offer = NULL; - // If the drag destination has version < 3, wl_data_offer.finish // won't be called, so do this here as a safety net, because // we still want the version >= 3 drag source to be happy. if (wl_resource_get_version(offer->resource) < WL_DATA_OFFER_ACTION_SINCE_VERSION) { data_source_notify_finish(offer->source); + offer->source->offer = NULL; } else if (offer->source->dnd_finish) { + // source->cancel can free the source + offer->source->offer = NULL; offer->source->cancel(offer->source); + } else { + offer->source->offer = NULL; } out: |