diff options
| author | MenTaLguY <mental@rydia.net> | 2006-04-29 20:17:41 +0000 |
|---|---|---|
| committer | mental <mental@users.sourceforge.net> | 2006-04-29 20:17:41 +0000 |
| commit | 8bb1647f12c3d8f62716cb546a57f854a7cf8e3d (patch) | |
| tree | 0b13bf3edf9ee66169927bbed3c8efc9a0aac508 /src | |
| parent | simplify the SimpleEvent API more (diff) | |
| download | inkscape-8bb1647f12c3d8f62716cb546a57f854a7cf8e3d.tar.gz inkscape-8bb1647f12c3d8f62716cb546a57f854a7cf8e3d.zip | |
add finalizer logging
(bzr r633)
Diffstat (limited to 'src')
| -rw-r--r-- | src/Makefile_insert | 2 | ||||
| -rw-r--r-- | src/gc-finalized.cpp | 64 | ||||
| -rw-r--r-- | src/gc-finalized.h | 4 |
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) { |
