summaryrefslogtreecommitdiff
path: root/sw
diff options
context:
space:
mode:
authorMichael Stahl <mstahl@redhat.com>2015-05-05 23:30:00 +0200
committerMichael Stahl <mstahl@redhat.com>2015-05-06 00:10:17 +0200
commit6a37faafa545ccf0b242d4f3b179dcbe710a2814 (patch)
treeafaf7ab7b229aa6e9d41d8aaf640018a382e3375 /sw
parentc4cf85766453982f1aa94a7f2cb22af19ed100be (diff)
sw: make SplitRedline() a little more readable
Change-Id: Icd99c8d98ae4c5cd6c6552a929c28ad0f096c214
Diffstat (limited to 'sw')
-rw-r--r--sw/source/core/doc/DocumentRedlineManager.cxx40
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;