From 21c0c41e515d342ef49689da9e43f22d83373125 Mon Sep 17 00:00:00 2001 From: Emmanuele Bassi Date: Thu, 1 May 2008 09:28:41 +0000 Subject: [PATCH] 2008-05-01 Emmanuele Bassi * clutter/clutter-behaviour.c: (clutter_behaviour_remove_all): Disconnect the ::destroy handler when removing all actors, to match the behaviour of clutter_behaviour_remove(). --- ChangeLog | 23 +++++++++++++++-------- clutter/clutter-behaviour.c | 3 +++ 2 files changed, 18 insertions(+), 8 deletions(-) diff --git a/ChangeLog b/ChangeLog index 61aaba705..0190dfe5a 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,10 +1,17 @@ +2008-05-01 Emmanuele Bassi + + * clutter/clutter-behaviour.c: + (clutter_behaviour_remove_all): Disconnect the ::destroy + handler when removing all actors, to match the behaviour + of clutter_behaviour_remove(). + 2008-05-01 Matthew Allum * clutter/glx/clutter-glx-texture-pixmap.c: * tests/test-pixmap.c: - Fix up texture-pixmap, now works. - Thanks to Neil for spotting we were actually using - wrong texture type in fbconfig (COGL change). + Fix up texture-pixmap, now works. + Thanks to Neil for spotting we were actually using + wrong texture type in fbconfig (COGL change). 2008-04-30 Øyvind Kolås @@ -70,12 +77,12 @@ * clutter/x11/Makefile.am: * clutter/x11/clutter-x11-texture-pixmap.c: * tests/test-pixmap.c: - Commit newer x11 texture pixmap stuff (optionally using SHM). - Also seemingly still broken overhauled glx-texture-pixmap - (code by Robert and myself) + Commit newer x11 texture pixmap stuff (optionally using SHM). + Also seemingly still broken overhauled glx-texture-pixmap + (code by Robert and myself) * configure.ac: - Minor formatting change. + Minor formatting change. 2008-04-29 Neil Roberts @@ -761,7 +768,7 @@ * clutter/clutter-actor.c: Remove uneeded stage private member. Add show-on-set-parent prop and make so by default Actors are - now automatically shown when reparented (#791) + now automatically shown when reparented (#791) * clutter/eglx/clutter-backend-egl.c: * clutter/cogl/gles/cogl.c: diff --git a/clutter/clutter-behaviour.c b/clutter/clutter-behaviour.c index c5d267c38..11da23d35 100644 --- a/clutter/clutter-behaviour.c +++ b/clutter/clutter-behaviour.c @@ -652,6 +652,9 @@ clutter_behaviour_remove_all (ClutterBehaviour *behave) ClutterActor *actor = l->data; g_signal_emit (behave, behave_signals[REMOVED], 0, actor); + g_signal_handlers_disconnect_by_func (actor, + G_CALLBACK (remove_actor_on_destroy), + behave); g_object_unref (actor); }