summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorLászló Németh <nemeth@numbertext.org>2020-11-20 14:29:22 +0100
committerLászló Németh <nemeth@numbertext.org>2020-11-20 22:16:53 +0100
commit37fb6b5faa56c68c5d4dc61ee2eaafc828bf9939 (patch)
tree6d9509e4b5f5b70a08b31639064b20aeeed2868e
parentae8bc80952fafc791ce8bbddd99c99626a93989c (diff)
tdf#137684 sw ChangesInMargin: fix Undo of characters
Undo of tracked deletions in the same position was reversed to avoid changing the ranges of the remaining hidden redlines. Now the ranges are corrected after the Undo (at least for the multiple characters deleted by pressing Delete). Clean-up of commit fe1fc9615511994ac128e52f9ad1cda4e86188f5 (tdf#137684 sw ChangesInMargin: fix crash on Undo of characters). Change-Id: If10bba5232d7b5084a2770efd9df229ae7509eb3 Reviewed-on: https://gerrit.libreoffice.org/c/core/+/106266 Tested-by: Jenkins Reviewed-by: László Németh <nemeth@numbertext.org>
-rw-r--r--sw/qa/extras/uiwriter/uiwriter2.cxx3
-rw-r--r--sw/source/core/undo/unredln.cxx26
2 files changed, 20 insertions, 9 deletions
diff --git a/sw/qa/extras/uiwriter/uiwriter2.cxx b/sw/qa/extras/uiwriter/uiwriter2.cxx
index a14a16a49edb..48a6aa3fdc99 100644
--- a/sw/qa/extras/uiwriter/uiwriter2.cxx
+++ b/sw/qa/extras/uiwriter/uiwriter2.cxx
@@ -1917,8 +1917,7 @@ CPPUNIT_TEST_FIXTURE(SwUiWriterTest2, testTdf137684)
{
dispatchCommand(mxComponent, ".uno:Undo", {});
}
- // TODO: fix order of the characters after Undo
- CPPUNIT_ASSERT(getParagraph(1)->getString().startsWith(" noitpyrcnE"));
+ CPPUNIT_ASSERT(getParagraph(1)->getString().startsWith("Encryption "));
// switch off "Show changes in margin" mode
dispatchCommand(mxComponent, ".uno:ShowChangesInMargin", {});
diff --git a/sw/source/core/undo/unredln.cxx b/sw/source/core/undo/unredln.cxx
index 1d48861a4432..564eb781f3ed 100644
--- a/sw/source/core/undo/unredln.cxx
+++ b/sw/source/core/undo/unredln.cxx
@@ -93,23 +93,35 @@ void SwUndoRedline::UndoImpl(::sw::UndoRedoContext & rContext)
// fix PaM for deletions shown in margin
SwRedlineTable::size_type nCurRedlinePos;
const SwRangeRedline * pRedline =
- rDoc.getIDocumentRedlineAccess().GetRedline( *rPam.End(), &nCurRedlinePos );
+ rDoc.getIDocumentRedlineAccess().GetRedline( *rPam.GetPoint(), &nCurRedlinePos );
if ( pRedline && !pRedline->IsVisible() )
{
const SwRedlineTable& rTable = rDoc.getIDocumentRedlineAccess().GetRedlineTable();
- // skip older redlines in the same position
- while ( nCurRedlinePos + 1 < rTable.size() &&
- *pRedline->GetPoint() == *rTable[nCurRedlinePos + 1]->GetPoint() )
+ // count invisible (DELETE) redlines in the same position
+ SwRedlineTable::size_type nPos = nCurRedlinePos + 1;
+ while ( nPos < rTable.size() && !rTable[nPos]->IsVisible() &&
+ *pRedline->GetPoint() == *rTable[nPos]->GetPoint() )
{
- ++nCurRedlinePos;
+ ++nPos;
}
SwRangeRedline * pHiddenRedline( rTable[nCurRedlinePos] );
pHiddenRedline->Show(0, rTable.GetPos(pHiddenRedline), /*bForced=*/true);
pHiddenRedline->Show(1, rTable.GetPos(pHiddenRedline), /*bForced=*/true);
rPam = *pHiddenRedline;
- }
- UndoRedlineImpl(rDoc, rPam);
+ SwContentNode *pNd = rPam.GetContentNode();
+ const sal_Int32 nStart = rPam.Start()->nContent.GetIndex();
+ UndoRedlineImpl(rDoc, rPam);
+
+ // restore redline ranges to the start of the hidden deletion
+ // TODO fix the other cases
+ for (SwRedlineTable::size_type nIdx = nCurRedlinePos; nIdx + 1 < nPos; ++nIdx) {
+ SwRangeRedline * pHiddenRedline2( rTable[nIdx] );
+ pHiddenRedline2->GetPoint()->nContent.Assign(pNd, nStart);
+ }
+ }
+ else
+ UndoRedlineImpl(rDoc, rPam);
if( mpRedlSaveData )
{