summaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
authorNicolas Dufour <nicoduf@yahoo.fr>2013-03-19 07:01:10 +0000
committerJazzyNico <nicoduf@yahoo.fr>2013-03-19 07:01:10 +0000
commit4002d292bbb499304af30bc060ce0200481062b8 (patch)
treef43e785df061301652b89800183647bd56bbac55 /src
parentDrop remaining unused functions (diff)
downloadinkscape-4002d292bbb499304af30bc060ce0200481062b8.tar.gz
inkscape-4002d292bbb499304af30bc060ce0200481062b8.zip
Partial fix for Bug #1071082 (Undo History doesn't work if open before file is opened) by vaifrax.
(bzr r12225)
Diffstat (limited to 'src')
-rw-r--r--src/desktop.cpp7
-rw-r--r--src/event-log.cpp13
2 files changed, 19 insertions, 1 deletions
diff --git a/src/desktop.cpp b/src/desktop.cpp
index c7a763ae1..d74e8fdad 100644
--- a/src/desktop.cpp
+++ b/src/desktop.cpp
@@ -1582,6 +1582,13 @@ SPDesktop::setDocument (SPDocument *doc)
_layer_hierarchy->connectChanged(sigc::bind(sigc::ptr_fun(_layer_hierarchy_changed), this));
_layer_hierarchy->setTop(doc->getRoot());
+ // remove old EventLog if it exists (see also: bug #1071082)
+ if (event_log) {
+ doc->removeUndoObserver(*event_log);
+ delete event_log;
+ event_log = 0;
+ }
+
/* setup EventLog */
event_log = new Inkscape::EventLog(doc);
doc->addUndoObserver(*event_log);
diff --git a/src/event-log.cpp b/src/event-log.cpp
index e2528ce0b..9304f68c5 100644
--- a/src/event-log.cpp
+++ b/src/event-log.cpp
@@ -38,7 +38,18 @@ EventLog::EventLog(SPDocument* document) :
curr_row[_columns.type] = SP_VERB_FILE_NEW;
}
-EventLog::~EventLog() { }
+EventLog::~EventLog() {
+ // avoid crash by clearing entries here (see bug #1071082)
+ if (_connected) {
+ (*_callback_connections)[CALLB_SELECTION_CHANGE].block();
+ (*_callback_connections)[CALLB_EXPAND].block();
+
+ _event_list_store->clear();
+
+ (*_callback_connections)[CALLB_EXPAND].block(false);
+ (*_callback_connections)[CALLB_SELECTION_CHANGE].block(false);
+ }
+}
void
EventLog::notifyUndoEvent(Event* log)