sw/inc/bparr.hxx | 3 +-- sw/source/core/docnode/nodes.cxx | 18 ++++-------------- 2 files changed, 5 insertions(+), 16 deletions(-)
New commits: commit ca16ec4346cec871163c0b9ff361c7ad8bc74c16 Author: Stephan Bergmann <sberg...@redhat.com> Date: Thu Aug 7 10:09:07 2014 +0200 Avoid illegal downcasts from BigPtrEntry to SwNode ...and while at it, remove the need for the TempBigPtrEntry derivation. Change-Id: Ic758f646578a90a28632b1368fed209eb84f9c1c diff --git a/sw/inc/bparr.hxx b/sw/inc/bparr.hxx index 3c5ea87..741534d 100644 --- a/sw/inc/bparr.hxx +++ b/sw/inc/bparr.hxx @@ -34,9 +34,8 @@ class BigPtrEntry BlockInfo* pBlock; sal_uInt16 nOffset; public: - virtual ~BigPtrEntry() {} -protected: BigPtrEntry() : pBlock(0), nOffset(0) {} + virtual ~BigPtrEntry() {} inline sal_uLong GetPos() const; inline BigPtrArray& GetArray() const; diff --git a/sw/source/core/docnode/nodes.cxx b/sw/source/core/docnode/nodes.cxx index 06375d9..8efb977 100644 --- a/sw/source/core/docnode/nodes.cxx +++ b/sw/source/core/docnode/nodes.cxx @@ -2213,16 +2213,6 @@ void SwNodes::ForEach( const SwNodeIndex& rStart, const SwNodeIndex& rEnd, ForEach( rStart.GetIndex(), rEnd.GetIndex(), fnForEach, pArgs ); } -namespace { - -//TODO: seems to be not/wrongly used -struct TempBigPtrEntry : public BigPtrEntry -{ - TempBigPtrEntry() {} -}; - -} - void SwNodes::RemoveNode( sal_uLong nDelPos, sal_uLong nSz, bool bDel ) { sal_uLong nEnd = nDelPos + nSz; @@ -2275,11 +2265,11 @@ void SwNodes::RemoveNode( sal_uLong nDelPos, sal_uLong nSz, bool bDel ) } } - std::vector<TempBigPtrEntry> aTempEntries; + std::vector<BigPtrEntry> aTempEntries; if( bDel ) { sal_uLong nCnt = nSz; - SwNode *pDel = (*this)[ nDelPos+nCnt-1 ], *pPrev = (*this)[ nDelPos+nCnt-2 ]; + BigPtrEntry *pDel = (*this)[ nDelPos+nCnt-1 ], *pPrev = (*this)[ nDelPos+nCnt-2 ]; // set temporary object // JP 24.08.98: this should actually be removed because one could @@ -2292,13 +2282,13 @@ void SwNodes::RemoveNode( sal_uLong nDelPos, sal_uLong nSz, bool bDel ) { delete pDel; pDel = pPrev; - sal_uLong nPrevNdIdx = pPrev->GetIndex(); + sal_uLong nPrevNdIdx = pPrev->GetPos(); BigPtrEntry* pTempEntry = &aTempEntries[nCnt]; BigPtrArray::Replace( nPrevNdIdx+1, pTempEntry ); if( nCnt ) pPrev = (*this)[ nPrevNdIdx - 1 ]; } - nDelPos = pDel->GetIndex() + 1; + nDelPos = pDel->GetPos() + 1; } BigPtrArray::Remove( nDelPos, nSz ); _______________________________________________ Libreoffice-commits mailing list libreoffice-comm...@lists.freedesktop.org http://lists.freedesktop.org/mailman/listinfo/libreoffice-commits