diff options
| author | Nicolas Dufour <nicoduf@yahoo.fr> | 2013-03-19 07:01:10 +0000 |
|---|---|---|
| committer | JazzyNico <nicoduf@yahoo.fr> | 2013-03-19 07:01:10 +0000 |
| commit | 4002d292bbb499304af30bc060ce0200481062b8 (patch) | |
| tree | f43e785df061301652b89800183647bd56bbac55 /src | |
| parent | Drop remaining unused functions (diff) | |
| download | inkscape-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.cpp | 7 | ||||
| -rw-r--r-- | src/event-log.cpp | 13 |
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) |
