summaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
authorMenTaLguY <mental@rydia.net>2006-07-21 21:16:41 +0000
committermental <mental@users.sourceforge.net>2006-07-21 21:16:41 +0000
commit7cf31bfe46b387d8ef36d880e2e3c2f4275961b8 (patch)
treef3df5a9a0a49c70e2b576cdb1c251f12e3e71b50 /src
parentswitch to sigc++ signal for "release" (diff)
downloadinkscape-7cf31bfe46b387d8ef36d880e2e3c2f4275961b8.tar.gz
inkscape-7cf31bfe46b387d8ef36d880e2e3c2f4275961b8.zip
switch to sigc++ signals for "release"
(bzr r1451)
Diffstat (limited to 'src')
-rw-r--r--src/uri-references.cpp12
-rw-r--r--src/uri-references.h3
2 files changed, 9 insertions, 6 deletions
diff --git a/src/uri-references.cpp b/src/uri-references.cpp
index fff985139..793e10d98 100644
--- a/src/uri-references.cpp
+++ b/src/uri-references.cpp
@@ -17,6 +17,8 @@
#include "uri.h"
#include "uri-references.h"
+#include <sigc++/functors/mem_fun.h>
+
static gchar *uri_to_id(SPDocument *document, const gchar *uri);
namespace Inkscape {
@@ -97,12 +99,12 @@ void URIReference::_setObject(SPObject *obj) {
if (_obj) {
sp_object_href(_obj, _owner);
- g_signal_connect(G_OBJECT(_obj), "release", G_CALLBACK(&URIReference::_release), reinterpret_cast<gpointer>(this));
+ _release_connection = _obj->connectRelease(sigc::mem_fun(*this, &URIReference::_release));
}
_changed_signal.emit(old_obj, _obj);
if (old_obj) {
+ _release_connection.disconnect();
/* release the old object _after_ the signal emission */
- g_signal_handlers_disconnect_by_func(G_OBJECT(old_obj), (void *)&URIReference::_release, reinterpret_cast<gpointer>(this));
sp_object_hunref(old_obj, _owner);
}
}
@@ -111,9 +113,9 @@ void URIReference::_setObject(SPObject *obj) {
* it on its "release" signal, rather than later, when its ID is actually
* unregistered from the document.
*/
-void URIReference::_release(SPObject *obj, URIReference *reference) {
- g_assert( reference->_obj == obj );
- reference->_setObject(NULL);
+void URIReference::_release(SPObject *obj) {
+ g_assert( _obj == obj );
+ _setObject(NULL);
}
} /* namespace Inkscape */
diff --git a/src/uri-references.h b/src/uri-references.h
index 8d4bf7098..38f346987 100644
--- a/src/uri-references.h
+++ b/src/uri-references.h
@@ -119,13 +119,14 @@ protected:
private:
SPObject *_owner;
sigc::connection _connection;
+ sigc::connection _release_connection;
SPObject *_obj;
URI *_uri;
sigc::signal<void, SPObject *, SPObject *> _changed_signal;
void _setObject(SPObject *object);
- static void _release(SPObject *object, URIReference *reference);
+ void _release(SPObject *object);
void operator=(const URIReference &ref);
/* Private and definition-less to prevent accidental use. */