summaryrefslogtreecommitdiffstats
path: root/src/desktop.cpp
diff options
context:
space:
mode:
authorMarkus Engel <markus.engel@tum.de>2013-08-02 20:25:14 +0000
committerMarkus Engel <markus.engel@tum.de>2013-08-02 20:25:14 +0000
commit5488905e7f4659c0fed7c1841b768cbaf26e3cb1 (patch)
tree14f112d40162e0c5884cf8db2cd039bb51828d26 /src/desktop.cpp
parentFixed more mismatched-tags; replaced GObject-properties in SPGuide (diff)
downloadinkscape-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.cpp22
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);
}