summaryrefslogtreecommitdiff
path: root/sw/source
diff options
context:
space:
mode:
authorMichael Stahl <mstahl@redhat.com>2015-06-01 15:05:48 +0200
committerMichael Stahl <mstahl@redhat.com>2015-06-01 15:50:39 +0200
commit38e5251a82669d25928291712508651158b027b5 (patch)
tree1e8b3170a781bee266a3a642203b416d40edd7c4 /sw/source
parent5dc453ac9027828c6a2319126b620d8d9e6c08ba (diff)
sw: SwTxtNode::CutImpl(): destination must be in same SwDoc
Change-Id: I541dad26125bcd98e9c74016ecd03cd7f8bc71e6
Diffstat (limited to 'sw/source')
-rw-r--r--sw/source/core/txtnode/ndtxt.cxx24
1 files changed, 5 insertions, 19 deletions
diff --git a/sw/source/core/txtnode/ndtxt.cxx b/sw/source/core/txtnode/ndtxt.cxx
index 976e5c323ea3..b7b1c7145d27 100644
--- a/sw/source/core/txtnode/ndtxt.cxx
+++ b/sw/source/core/txtnode/ndtxt.cxx
@@ -2034,15 +2034,7 @@ void SwTextNode::CutImpl( SwTextNode * const pDest, const SwIndex & rDestStart,
{
assert(pDest); // Cut requires a destination
- // nicht im Dokument verschieben ?
- if( GetDoc() != pDest->GetDoc() )
- {
- OSL_FAIL("mst: entering dead and bitrotted code; fasten your seatbelts!");
- assert(false);
- CopyText( pDest, rDestStart, rStart, nLen);
- EraseText(rStart, nLen);
- return;
- }
+ assert(GetDoc() == pDest->GetDoc()); // must be same document
if( !nLen )
{
@@ -2193,14 +2185,8 @@ void SwTextNode::CutImpl( SwTextNode * const pDest, const SwIndex & rDestStart,
CHECK_SWPHINTS(pDest);
const sal_Int32 nEnd = rStart.GetIndex() + nLen;
- SwDoc* const pOtherDoc = (pDest->GetDoc() != GetDoc())
- ? pDest->GetDoc() : 0;
- bool const bUndoNodes = !pOtherDoc
- && GetDoc()->GetIDocumentUndoRedo().IsUndoNodes(GetNodes());
-
- OSL_ENSURE(!pOtherDoc,
- "mst: entering dead and bitrotted code; fasten your seatbelts!");
- assert(!pOtherDoc);
+ bool const bUndoNodes =
+ GetDoc()->GetIDocumentUndoRedo().IsUndoNodes(GetNodes());
// harte Absatz umspannende Attribute kopieren
if( HasSwAttrSet() )
@@ -2261,7 +2247,7 @@ void SwTextNode::CutImpl( SwTextNode * const pDest, const SwIndex & rDestStart,
{
// der Anfang liegt vollstaendig im Bereich
if( !pEndIdx || *pEndIdx < nEnd ||
- (!pOtherDoc && !bUndoNodes && RES_TXTATR_REFMARK == nWhich)
+ (!bUndoNodes && RES_TXTATR_REFMARK == nWhich)
|| pHt->HasDummyChar() )
{
// do not delete note and later add it -> sidebar flickering
@@ -2312,7 +2298,7 @@ void SwTextNode::CutImpl( SwTextNode * const pDest, const SwIndex & rDestStart,
| SetAttrMode::IS_COPY) );
if (bSuccess)
{
- lcl_CopyHint( nWhich, pHt, pNewHt, pOtherDoc, pDest );
+ lcl_CopyHint( nWhich, pHt, pNewHt, nullptr, pDest );
}
}
++nAttrCnt;