[mutter/wip/tablet-protocol: 47/63] wayland: Add MetaWaylandSurface::destroy signal
- From: Carlos Garnacho <carlosg src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [mutter/wip/tablet-protocol: 47/63] wayland: Add MetaWaylandSurface::destroy signal
- Date: Tue, 1 Mar 2016 11:45:08 +0000 (UTC)
commit d1d4d9c24a94d09d782fbe4b878653535cfd1eef
Author: Carlos Garnacho <carlosg gnome org>
Date: Thu Oct 22 14:07:52 2015 +0200
wayland: Add MetaWaylandSurface::destroy signal
There's places where it would be convenient to add listeners to this,
so add the signal. The signal is only emitted once during destruction,
it is convenient for the places where we want notifications at a time
the object is still alive, as opposed to weak refs which notify after
the fact.
src/wayland/meta-wayland-surface.c | 32 ++++++++++++++++++++++++++++++++
src/wayland/meta-wayland-surface.h | 1 +
2 files changed, 33 insertions(+), 0 deletions(-)
---
diff --git a/src/wayland/meta-wayland-surface.c b/src/wayland/meta-wayland-surface.c
index cff4373..df13539 100644
--- a/src/wayland/meta-wayland-surface.c
+++ b/src/wayland/meta-wayland-surface.c
@@ -136,6 +136,13 @@ G_DEFINE_TYPE (MetaWaylandSurfaceRoleDND,
meta_wayland_surface_role_dnd,
META_TYPE_WAYLAND_SURFACE_ROLE);
+enum {
+ SURFACE_DESTROY,
+ N_SURFACE_SIGNALS
+};
+
+guint surface_signals[N_SURFACE_SIGNALS] = { 0 };
+
static void
meta_wayland_surface_role_assigned (MetaWaylandSurfaceRole *surface_role);
@@ -2610,6 +2617,20 @@ meta_wayland_surface_get_absolute_coordinates (MetaWaylandSurface *surface,
}
static void
+meta_wayland_surface_dispose (GObject *object)
+{
+ MetaWaylandSurface *surface = META_WAYLAND_SURFACE (object);
+
+ if (!surface->destroying)
+ {
+ g_signal_emit (object, surface_signals[SURFACE_DESTROY], 0);
+ surface->destroying = TRUE;
+ }
+
+ G_OBJECT_CLASS (meta_wayland_surface_parent_class)->dispose (object);
+}
+
+static void
meta_wayland_surface_init (MetaWaylandSurface *surface)
{
surface->pending = g_object_new (META_TYPE_WAYLAND_PENDING_STATE, NULL);
@@ -2618,6 +2639,17 @@ meta_wayland_surface_init (MetaWaylandSurface *surface)
static void
meta_wayland_surface_class_init (MetaWaylandSurfaceClass *klass)
{
+ GObjectClass *object_class = G_OBJECT_CLASS (klass);
+
+ object_class->dispose = meta_wayland_surface_dispose;
+
+ surface_signals[SURFACE_DESTROY] =
+ g_signal_new ("destroy",
+ G_TYPE_FROM_CLASS (object_class),
+ G_SIGNAL_RUN_LAST,
+ 0, NULL, NULL,
+ g_cclosure_marshal_VOID__VOID,
+ G_TYPE_NONE, 0);
}
static void
diff --git a/src/wayland/meta-wayland-surface.h b/src/wayland/meta-wayland-surface.h
index 4a2c244..32eff35 100644
--- a/src/wayland/meta-wayland-surface.h
+++ b/src/wayland/meta-wayland-surface.h
@@ -185,6 +185,7 @@ struct _MetaWaylandSurface
MetaWaylandSerial acked_configure_serial;
gboolean has_set_geometry;
gboolean is_modal;
+ gboolean destroying;
/* xdg_popup */
struct {
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]