diff options
author | Michael Stahl <mstahl@redhat.com> | 2015-05-05 23:30:00 +0200 |
---|---|---|
committer | Michael Stahl <mstahl@redhat.com> | 2015-05-06 00:10:17 +0200 |
commit | 6a37faafa545ccf0b242d4f3b179dcbe710a2814 (patch) | |
tree | afaf7ab7b229aa6e9d41d8aaf640018a382e3375 /sw | |
parent | c4cf85766453982f1aa94a7f2cb22af19ed100be (diff) |
sw: make SplitRedline() a little more readable
Change-Id: Icd99c8d98ae4c5cd6c6552a929c28ad0f096c214
Diffstat (limited to 'sw')
-rw-r--r-- | sw/source/core/doc/DocumentRedlineManager.cxx | 40 |
1 files changed, 19 insertions, 21 deletions
diff --git a/sw/source/core/doc/DocumentRedlineManager.cxx b/sw/source/core/doc/DocumentRedlineManager.cxx index eda520584d73..5659a96b40d0 100644 --- a/sw/source/core/doc/DocumentRedlineManager.cxx +++ b/sw/source/core/doc/DocumentRedlineManager.cxx @@ -1823,59 +1823,57 @@ bool DocumentRedlineManager::SplitRedline( const SwPaM& rRange ) { bool bChg = false; sal_uInt16 n = 0; - const SwPosition* pStt = rRange.Start(), - * pEnd = pStt == rRange.GetPoint() ? rRange.GetMark() - : rRange.GetPoint(); + const SwPosition* pStt = rRange.Start(); + const SwPosition* pEnd = rRange.End(); GetRedline( *pStt, &n ); - for( ; n < mpRedlineTbl->size() ; ++n ) + for ( ; n < mpRedlineTbl->size(); ++n) { - SwRangeRedline* pTmp = (*mpRedlineTbl)[ n ]; - SwPosition* pTStt = pTmp->Start(), - * pTEnd = pTStt == pTmp->GetPoint() ? pTmp->GetMark() - : pTmp->GetPoint(); - if( *pTStt <= *pStt && *pStt <= *pTEnd && - *pTStt <= *pEnd && *pEnd <= *pTEnd ) + SwRangeRedline * pRedline = (*mpRedlineTbl)[ n ]; + SwPosition *const pRedlineStart = pRedline->Start(); + SwPosition *const pRedlineEnd = pRedline->End(); + if (*pRedlineStart <= *pStt && *pStt <= *pRedlineEnd && + *pRedlineStart <= *pEnd && *pEnd <= *pRedlineEnd) { bChg = true; int nn = 0; - if( *pStt == *pTStt ) + if (*pStt == *pRedlineStart) nn += 1; - if( *pEnd == *pTEnd ) + if (*pEnd == *pRedlineEnd) nn += 2; SwRangeRedline* pNew = 0; switch( nn ) { case 0: - pNew = new SwRangeRedline( *pTmp ); - pTmp->SetEnd( *pStt, pTEnd ); + pNew = new SwRangeRedline( *pRedline ); + pRedline->SetEnd( *pStt, pRedlineEnd ); pNew->SetStart( *pEnd ); break; case 1: - *pTStt = *pEnd; + *pRedlineStart = *pEnd; break; case 2: - *pTEnd = *pStt; + *pRedlineEnd = *pStt; break; case 3: - pTmp->InvalidateRange(); + pRedline->InvalidateRange(); mpRedlineTbl->DeleteAndDestroy( n-- ); - pTmp = 0; + pRedline = nullptr; break; } - if( pTmp && !pTmp->HasValidRange() ) + if (pRedline && !pRedline->HasValidRange()) { // re-insert mpRedlineTbl->Remove( n ); - mpRedlineTbl->Insert( pTmp, n ); + mpRedlineTbl->Insert( pRedline, n ); } if( pNew ) mpRedlineTbl->Insert( pNew, n ); } - else if( *pEnd < *pTStt ) + else if (*pEnd < *pRedlineStart) break; } return bChg; |