From af1c00c6428ec07d4e3d90b60772a600660a9651 Mon Sep 17 00:00:00 2001 From: Noel Grandin Date: Mon, 22 Jun 2015 13:59:49 +0200 Subject: move sorting code closer together to make it easier to understand. Also switch iteration to range-based for loops. Change-Id: I39a3f565f40458fd5598bb2e97fe71a0fec1c09c --- xmloff/source/draw/shapeimport.cxx | 165 +++++++++++++++++-------------------- 1 file changed, 77 insertions(+), 88 deletions(-) (limited to 'xmloff') diff --git a/xmloff/source/draw/shapeimport.cxx b/xmloff/source/draw/shapeimport.cxx index d7581a235716..c155b548a4d8 100644 --- a/xmloff/source/draw/shapeimport.cxx +++ b/xmloff/source/draw/shapeimport.cxx @@ -778,18 +778,18 @@ public: vector maZOrderList; vector maUnsortedList; - sal_Int32 mnCurrentZ; - ShapeSortContext* mpParentContext; - const OUString msZOrder; + sal_Int32 mnCurrentZ; + ShapeSortContext* mpParentContext; ShapeSortContext( uno::Reference< drawing::XShapes >& rShapes, ShapeSortContext* pParentContext = NULL ); + void popGroupAndSort(); +private: void moveShape( sal_Int32 nSourcePos, sal_Int32 nDestPos ); }; ShapeSortContext::ShapeSortContext( uno::Reference< drawing::XShapes >& rShapes, ShapeSortContext* pParentContext ) -: mxShapes( rShapes ), mnCurrentZ( 0 ), mpParentContext( pParentContext ), - msZOrder("ZOrder") +: mxShapes( rShapes ), mnCurrentZ( 0 ), mpParentContext( pParentContext ) { } @@ -799,127 +799,116 @@ void ShapeSortContext::moveShape( sal_Int32 nSourcePos, sal_Int32 nDestPos ) uno::Reference< beans::XPropertySet > xPropSet; aAny >>= xPropSet; - if( xPropSet.is() && xPropSet->getPropertySetInfo()->hasPropertyByName( msZOrder ) ) + if( xPropSet.is() && xPropSet->getPropertySetInfo()->hasPropertyByName( OUString("ZOrder") ) ) { aAny <<= nDestPos; - xPropSet->setPropertyValue( msZOrder, aAny ); + xPropSet->setPropertyValue( OUString("ZOrder"), aAny ); - vector::iterator aIter = maZOrderList.begin(); - vector::iterator aEnd = maZOrderList.end(); - - while( aIter != aEnd ) + for( ZOrderHint& rHint : maZOrderList ) { - if( (*aIter).nIs < nSourcePos ) + if( rHint.nIs < nSourcePos ) { - DBG_ASSERT( (*aIter).nIs >= nDestPos, "Shape sorting failed" ); - (*aIter).nIs++; + DBG_ASSERT(rHint.nIs >= nDestPos, "Shape sorting failed" ); + rHint.nIs++; } - ++aIter; } - aIter = maUnsortedList.begin(); - aEnd = maUnsortedList.end(); - - while( aIter != aEnd ) + for( ZOrderHint& rHint : maUnsortedList ) { - if( (*aIter).nIs < nSourcePos ) + if( rHint.nIs < nSourcePos ) { - DBG_ASSERT( (*aIter).nIs >= nDestPos, "shape sorting failed" ); - (*aIter).nIs++; + DBG_ASSERT( rHint.nIs >= nDestPos, "shape sorting failed" ); + rHint.nIs++; } - ++aIter; } } } -void XMLShapeImportHelper::pushGroupForSorting( uno::Reference< drawing::XShapes >& rShapes ) +// sort shapes +void ShapeSortContext::popGroupAndSort() { - mpImpl->mpSortContext = new ShapeSortContext( rShapes, mpImpl->mpSortContext ); -} - -void XMLShapeImportHelper::popGroupAndSort() -{ - DBG_ASSERT( mpImpl->mpSortContext, "No context to sort!" ); - if( mpImpl->mpSortContext == NULL ) + // only do something if we have shapes to sort + if( maZOrderList.empty() ) return; - try - { - vector& rZList = mpImpl->mpSortContext->maZOrderList; - vector& rUnsortedList = mpImpl->mpSortContext->maUnsortedList; - - // sort shapes - if( !rZList.empty() ) - { - // only do something if we have shapes to sort + // check if there are more shapes than inserted with ::shapeWithZIndexAdded() + // This can happen if there where already shapes on the page before import + // Since the writer may delete some of this shapes during import, we need + // to do this here and not in our c'tor anymore - // check if there are more shapes than inserted with ::shapeWithZIndexAdded() - // This can happen if there where already shapes on the page before import - // Since the writer may delete some of this shapes during import, we need - // to do this here and not in our c'tor anymore + // check if we have more shapes than we know of + sal_Int32 nCount = mxShapes->getCount(); - // check if we have more shapes than we know of - sal_Int32 nCount = mpImpl->mpSortContext->mxShapes->getCount(); + nCount -= maZOrderList.size(); + nCount -= maUnsortedList.size(); - nCount -= rZList.size(); - nCount -= rUnsortedList.size(); + if( nCount > 0 ) + { + // first update offsets of added shapes + for (ZOrderHint& rHint : maZOrderList) + rHint.nIs += nCount; + for (ZOrderHint& rHint : maUnsortedList) + rHint.nIs += nCount; - if( nCount > 0 ) - { - // first update offsets of added shapes - vector::iterator aIter( rZList.begin() ); - while( aIter != rZList.end() ) - (*aIter++).nIs += nCount; + // second add the already existing shapes in the unsorted list + ZOrderHint aNewHint; + do + { + nCount--; - aIter = rUnsortedList.begin(); - while( aIter != rUnsortedList.end() ) - (*aIter++).nIs += nCount; + aNewHint.nIs = nCount; + aNewHint.nShould = -1; - // second add the already existing shapes in the unsorted list - ZOrderHint aNewHint; + maUnsortedList.insert(maUnsortedList.begin(), aNewHint); + } + while( nCount ); + } - do - { - nCount--; + // sort z-ordered shapes by nShould field + std::sort(maZOrderList.begin(), maZOrderList.end()); - aNewHint.nIs = nCount; - aNewHint.nShould = -1; + // this is the current index, all shapes before that + // index are finished + sal_Int32 nIndex = 0; + for (ZOrderHint& rHint : maZOrderList) + { + while( nIndex < rHint.nShould && !maUnsortedList.empty() ) + { + ZOrderHint aGapHint( *maUnsortedList.begin() ); + maUnsortedList.erase(maUnsortedList.begin()); - rUnsortedList.insert(rUnsortedList.begin(), aNewHint); - } - while( nCount ); - } + moveShape( aGapHint.nIs, nIndex++ ); + } - // sort z ordered shapes - std::sort(rZList.begin(), rZList.end()); + if(rHint.nIs != nIndex ) + moveShape( rHint.nIs, nIndex ); - // this is the current index, all shapes before that - // index are finished - sal_Int32 nIndex = 0; - while( !rZList.empty() ) - { - while( nIndex < (*rZList.begin()).nShould && !rUnsortedList.empty() ) - { - ZOrderHint aGapHint( *rUnsortedList.begin() ); - rUnsortedList.erase(rUnsortedList.begin()); + nIndex++; + } + maZOrderList.clear(); +} - mpImpl->mpSortContext->moveShape( aGapHint.nIs, nIndex++ ); - } +void XMLShapeImportHelper::pushGroupForSorting( uno::Reference< drawing::XShapes >& rShapes ) +{ + mpImpl->mpSortContext = new ShapeSortContext( rShapes, mpImpl->mpSortContext ); +} - if( (*rZList.begin()).nIs != nIndex ) - mpImpl->mpSortContext->moveShape( (*rZList.begin()).nIs, nIndex ); +void XMLShapeImportHelper::popGroupAndSort() +{ + DBG_ASSERT( mpImpl->mpSortContext, "No context to sort!" ); + if( mpImpl->mpSortContext == NULL ) + return; - rZList.erase(rZList.begin()); - nIndex++; - } - } + try + { + mpImpl->mpSortContext->popGroupAndSort(); } catch( uno::Exception& ) { OSL_FAIL("exception while sorting shapes, sorting failed!"); } - // put parent on top and delete current context, were done + // put parent on top and delete current context, we are done ShapeSortContext* pContext = mpImpl->mpSortContext; mpImpl->mpSortContext = pContext->mpParentContext; delete pContext; -- cgit