diff options
| author | Jabier Arraiza Cenoz <jabier.arraiza@marker.es> | 2016-10-10 14:06:22 +0000 |
|---|---|---|
| committer | jabiertxof <info@marker.es> | 2016-10-10 14:06:22 +0000 |
| commit | b949d0bdb9f751a94fd71f8bab7610d9a6a11a90 (patch) | |
| tree | 34ed87d81aa9286ceb66ea1ba56efa4b2f6ad757 /src/document-undo.cpp | |
| parent | Update to trunk (diff) | |
| download | inkscape-b949d0bdb9f751a94fd71f8bab7610d9a6a11a90.tar.gz inkscape-b949d0bdb9f751a94fd71f8bab7610d9a6a11a90.zip | |
Fix some canvas item problems and refresh items on rotate
(bzr r15142.1.10)
Diffstat (limited to 'src/document-undo.cpp')
| -rw-r--r-- | src/document-undo.cpp | 51 |
1 files changed, 25 insertions, 26 deletions
diff --git a/src/document-undo.cpp b/src/document-undo.cpp index 023843fcc..ae90c916e 100644 --- a/src/document-undo.cpp +++ b/src/document-undo.cpp @@ -240,53 +240,52 @@ static void perform_document_update(SPDocument &doc) { gboolean Inkscape::DocumentUndo::undo(SPDocument *doc) { - using Inkscape::Debug::EventTracker; - using Inkscape::Debug::SimpleEvent; + using Inkscape::Debug::EventTracker; + using Inkscape::Debug::SimpleEvent; - gboolean ret; + gboolean ret; - EventTracker<SimpleEvent<Inkscape::Debug::Event::DOCUMENT> > tracker("undo"); + EventTracker<SimpleEvent<Inkscape::Debug::Event::DOCUMENT> > tracker("undo"); - g_assert (doc != NULL); - g_assert (doc->priv != NULL); - g_assert (doc->priv->sensitive); + g_assert (doc != NULL); + g_assert (doc->priv != NULL); + g_assert (doc->priv->sensitive); - doc->priv->sensitive = FALSE; + doc->priv->sensitive = FALSE; doc->priv->seeking = true; - doc->actionkey.clear(); + doc->actionkey.clear(); - finish_incomplete_transaction(*doc); + finish_incomplete_transaction(*doc); - if (! doc->priv->undo.empty()) { - Inkscape::Event *log = doc->priv->undo.back(); - doc->priv->undo.pop_back(); - sp_repr_undo_log (log->event); - perform_document_update(*doc); + if (! doc->priv->undo.empty()) { + Inkscape::Event *log = doc->priv->undo.back(); + doc->priv->undo.pop_back(); + sp_repr_undo_log (log->event); + perform_document_update(*doc); - doc->priv->redo.push_back(log); + doc->priv->redo.push_back(log); doc->setModifiedSinceSave(); doc->priv->undoStackObservers.notifyUndoEvent(log); - ret = TRUE; - } else { - ret = FALSE; - } + ret = TRUE; + } else { + ret = FALSE; + } - sp_repr_begin_transaction (doc->rdoc); + sp_repr_begin_transaction (doc->rdoc); - doc->priv->sensitive = TRUE; + doc->priv->sensitive = TRUE; doc->priv->seeking = false; - if (ret) - INKSCAPE.external_change(); + if (ret) INKSCAPE.external_change(); + SPObject *updated = doc->getRoot(); if (updated) { updated->requestDisplayUpdate(SP_OBJECT_MODIFIED_FLAG); } - - return ret; + return ret; } gboolean Inkscape::DocumentUndo::redo(SPDocument *doc) |
