summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--svl/source/undo/undo.cxx10
1 files changed, 7 insertions, 3 deletions
diff --git a/svl/source/undo/undo.cxx b/svl/source/undo/undo.cxx
index e27bf00e5ba4..e9166758cd17 100644
--- a/svl/source/undo/undo.cxx
+++ b/svl/source/undo/undo.cxx
@@ -635,10 +635,14 @@ bool SfxUndoManager::ImplAddUndoAction_NoNotify( SfxUndoAction *pAction, bool bT
// merge, if required
SfxUndoAction* pMergeWithAction = m_pData->pActUndoArray->nCurUndoAction ?
m_pData->pActUndoArray->aUndoActions[m_pData->pActUndoArray->nCurUndoAction-1].pAction : NULL;
- if ( bTryMerge && ( !pMergeWithAction || !pMergeWithAction->Merge( pAction ) ) )
+ if ( bTryMerge && pMergeWithAction )
{
- i_guard.markForDeletion( pAction );
- return false;
+ bool bMerged = pMergeWithAction->Merge( pAction );
+ if ( bMerged )
+ {
+ i_guard.markForDeletion( pAction );
+ return false;
+ }
}
// clear redo stack, if requested