summaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
authorMenTaLguY <mental@rydia.net>2006-04-29 20:17:41 +0000
committermental <mental@users.sourceforge.net>2006-04-29 20:17:41 +0000
commit8bb1647f12c3d8f62716cb546a57f854a7cf8e3d (patch)
tree0b13bf3edf9ee66169927bbed3c8efc9a0aac508 /src
parentsimplify the SimpleEvent API more (diff)
downloadinkscape-8bb1647f12c3d8f62716cb546a57f854a7cf8e3d.tar.gz
inkscape-8bb1647f12c3d8f62716cb546a57f854a7cf8e3d.zip
add finalizer logging
(bzr r633)
Diffstat (limited to 'src')
-rw-r--r--src/Makefile_insert2
-rw-r--r--src/gc-finalized.cpp64
-rw-r--r--src/gc-finalized.h4
3 files changed, 66 insertions, 4 deletions
diff --git a/src/Makefile_insert b/src/Makefile_insert
index 00c3be726..18f6b7b03 100644
--- a/src/Makefile_insert
+++ b/src/Makefile_insert
@@ -230,7 +230,7 @@ libinkpost_a_SOURCES = \
gc-alloc.h \
gc-anchored.h gc-anchored.cpp \
gc-core.h \
- gc-finalized.h \
+ gc-finalized.h gc-finalized.cpp \
gc-managed.h \
gc-soft-ptr.h \
gc.cpp \
diff --git a/src/gc-finalized.cpp b/src/gc-finalized.cpp
new file mode 100644
index 000000000..5b9aa3c80
--- /dev/null
+++ b/src/gc-finalized.cpp
@@ -0,0 +1,64 @@
+/*
+ * Inkscape::GC::Finalized - mixin for GC-managed objects with non-trivial
+ * destructors
+ *
+ * Copyright 2006 MenTaLguY <mental@rydia.net>
+ *
+ * This program is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU General Public License
+ * as published by the Free Software Foundation; either version 2
+ * of the License, or (at your option) any later version.
+ *
+ * See the file COPYING for details.
+ *
+ */
+
+#include <typeinfo>
+#include "debug/simple-event.h"
+#include "debug/event-tracker.h"
+#include "util/format.h"
+#include "util/share.h"
+#include "gc-finalized.h"
+
+namespace Inkscape {
+
+namespace GC {
+
+namespace {
+
+// workaround for g++ 4.0.2
+typedef Debug::SimpleEvent<Debug::Event::FINALIZERS> BaseEvent;
+
+class FinalizerEvent : public BaseEvent {
+public:
+ FinalizerEvent(Finalized *object)
+ : BaseEvent(Util::share_static_string("gc-finalizer"))
+ {
+ _addProperty("base", Util::format("%p", Core::base(object)));
+ _addProperty("pointer", Util::format("%p", object));
+ _addProperty("class", Util::share_static_string(typeid(*object).name()));
+ }
+};
+
+}
+
+void Finalized::_invoke_dtor(void *base, void *offset) {
+ Finalized *object=_unoffset(base, offset);
+ Debug::EventTracker<FinalizerEvent> tracker(object);
+ object->~Finalized();
+}
+
+}
+
+}
+
+/*
+ Local Variables:
+ mode:c++
+ c-file-style:"stroustrup"
+ c-file-offsets:((innamespace . 0)(inline-open . 0)(case-label . +))
+ indent-tabs-mode:nil
+ fill-column:99
+ End:
+*/
+// vim: filetype=cpp:expandtab:shiftwidth=4:tabstop=8:softtabstop=4:encoding=utf-8:textwidth=99 :
diff --git a/src/gc-finalized.h b/src/gc-finalized.h
index 046816b60..738d37692 100644
--- a/src/gc-finalized.h
+++ b/src/gc-finalized.h
@@ -114,9 +114,7 @@ public:
private:
/// invoke the destructor for an object given a base and offset pair
- static void _invoke_dtor(void *base, void *offset) {
- _unoffset(base, offset)->~Finalized();
- }
+ static void _invoke_dtor(void *base, void *offset);
/// turn 'this' pointer into an offset-from-base-address (stored as void *)
static void *_offset(void *base, Finalized *self) {