diff options
| author | Markus Engel <markus.engel@tum.de> | 2013-08-02 20:25:14 +0000 |
|---|---|---|
| committer | Markus Engel <markus.engel@tum.de> | 2013-08-02 20:25:14 +0000 |
| commit | 5488905e7f4659c0fed7c1841b768cbaf26e3cb1 (patch) | |
| tree | 14f112d40162e0c5884cf8db2cd039bb51828d26 /src/desktop.cpp | |
| parent | Fixed more mismatched-tags; replaced GObject-properties in SPGuide (diff) | |
| download | inkscape-5488905e7f4659c0fed7c1841b768cbaf26e3cb1.tar.gz inkscape-5488905e7f4659c0fed7c1841b768cbaf26e3cb1.zip | |
reordered SPDesktop::set_event_context2; fixed last mismatched-tags
(bzr r11608.1.116)
Diffstat (limited to 'src/desktop.cpp')
| -rw-r--r-- | src/desktop.cpp | 22 |
1 files changed, 14 insertions, 8 deletions
diff --git a/src/desktop.cpp b/src/desktop.cpp index a8de8ee50..f602f30d1 100644 --- a/src/desktop.cpp +++ b/src/desktop.cpp @@ -673,20 +673,26 @@ SPDesktop::change_document (SPDocument *theDocument) #include "tool-factory.h" void SPDesktop::set_event_context2(const std::string& toolName) { - if (event_context) { - event_context->deactivate(); - event_context->finish(); - delete event_context; + SPEventContext* ec_old = event_context; + + if (ec_old) { + ec_old->deactivate(); } - event_context = ToolFactory::instance().createObject(toolName); + SPEventContext* ec_new = ToolFactory::instance().createObject(toolName); + ec_new->desktop = this; + ec_new->message_context = new Inkscape::MessageContext(this->messageStack()); + ec_new->setup(); - event_context->desktop = this; - event_context->message_context = new Inkscape::MessageContext(this->messageStack()); + event_context = ec_new; - event_context->setup(); + if (ec_old) { + ec_old->finish(); + delete ec_old; + } sp_event_context_activate(event_context); + _event_context_changed_signal.emit(this, event_context); } |
