diff options
author | Jochen Nitschke <j.nitschke+logerrit@ok.de> | 2016-09-05 12:08:51 +0200 |
---|---|---|
committer | Noel Grandin <noelgrandin@gmail.com> | 2016-09-06 11:42:23 +0000 |
commit | cb970f2d3d4241ce209b84518ac798598fd0dc39 (patch) | |
tree | 413d85f0069c71a05962cd11e02c85c23bf730bf | |
parent | d2143eacaf8b9799a1abd9bf1ce54df9bf73d29a (diff) |
use range based loops in SfxItemPool
access arrays with []
try to clear up Delete()
Change-Id: Ifcb741f56d263cf79c751aa6e32b410e6c22e6ef
Reviewed-on: https://gerrit.libreoffice.org/28673
Tested-by: Jenkins <ci@libreoffice.org>
Reviewed-by: Noel Grandin <noelgrandin@gmail.com>
-rw-r--r-- | svl/source/inc/poolio.hxx | 5 | ||||
-rw-r--r-- | svl/source/items/itempool.cxx | 97 | ||||
-rw-r--r-- | svl/source/items/poolio.cxx | 30 |
3 files changed, 60 insertions, 72 deletions
diff --git a/svl/source/inc/poolio.hxx b/svl/source/inc/poolio.hxx index c33a494076b6..627fd6ba62ab 100644 --- a/svl/source/inc/poolio.hxx +++ b/svl/source/inc/poolio.hxx @@ -146,9 +146,8 @@ struct SfxItemPool_Impl void DeleteItems() { - std::vector<SfxPoolItemArray_Impl*>::iterator itr = maPoolItems.begin(), itrEnd = maPoolItems.end(); - for (; itr != itrEnd; ++itr) - delete *itr; + for (auto pPoolItemArray : maPoolItems) + delete pPoolItemArray; maPoolItems.clear(); maPoolDefaults.clear(); diff --git a/svl/source/items/itempool.cxx b/svl/source/items/itempool.cxx index d67c56dd4fb7..40fde3da9dae 100644 --- a/svl/source/items/itempool.cxx +++ b/svl/source/items/itempool.cxx @@ -333,10 +333,10 @@ void SfxItemPool::ReleaseDefaults for ( sal_uInt16 n = 0; n < nCount; ++n ) { - assert(IsStaticDefaultItem(*(pDefaults+n))); - (*( pDefaults + n ))->SetRefCount( 0 ); + assert(IsStaticDefaultItem(pDefaults[n])); + pDefaults[n]->SetRefCount(0); if ( bDelete ) - { delete *( pDefaults + n ); *(pDefaults + n) = nullptr; } + { delete pDefaults[n] ; pDefaults[n]= nullptr; } } if ( bDelete ) @@ -401,16 +401,14 @@ void SfxItemPool::SetSecondaryPool( SfxItemPool *pPool ) // Detached Pools must be empty bool bOK = bHasSetItems; - for ( sal_uInt16 n = 0; - bOK && n <= pImpl->mpSecondary->pImpl->mnEnd - pImpl->mpSecondary->pImpl->mnStart; - ++n ) + for (auto const& rSecArrayPtr : pImpl->mpSecondary->pImpl->maPoolItems) { - SfxPoolItemArray_Impl* pItemArr = pImpl->mpSecondary->pImpl->maPoolItems[n]; - if ( pItemArr ) + if (!bOK) + break; + if (rSecArrayPtr) { - SfxPoolItemArrayBase_Impl::const_iterator ppHtArr = pItemArr->begin(); - for( size_t i = pItemArr->size(); i; ++ppHtArr, --i ) - if ( !(*ppHtArr) ) + for (auto const& rItemPtr : *rSecArrayPtr) + if (!rItemPtr) { OSL_FAIL( "old secondary pool must be empty" ); bOK = false; @@ -492,74 +490,70 @@ void SfxItemPool::Delete() pImpl->aBC.Broadcast( SfxSimpleHint( SFX_HINT_DYING ) ); // Iterate through twice: first for the SetItems. - // We separate this into two loops (for clarity's sake) - std::vector<SfxPoolItemArray_Impl*>::iterator itrItemArr = pImpl->maPoolItems.begin(); - auto itDefaultItem = pImpl->maPoolDefaults.begin(); - SfxPoolItem** ppStaticDefaultItem = pImpl->ppStaticDefaults; - sal_uInt16 nArrCnt; - - // Collect the SetItems first if (pImpl->ppStaticDefaults != nullptr) { - for ( nArrCnt = GetSize_Impl(); - nArrCnt; - --nArrCnt, ++itrItemArr, ++itDefaultItem, ++ppStaticDefaultItem) + for (size_t n = 0; n < GetSize_Impl(); ++n) { // *ppStaticDefaultItem could've already been deleted in a class derived // from SfxItemPool // This causes chaos in Itempool! - if ( *ppStaticDefaultItem && dynamic_cast< const SfxSetItem* >(*ppStaticDefaultItem) != nullptr ) + const SfxPoolItem* pStaticDefaultItem = pImpl->ppStaticDefaults[n]; + if (pStaticDefaultItem && dynamic_cast<const SfxSetItem*>(pStaticDefaultItem) != nullptr) { - if ( *itrItemArr ) + // SfxSetItem found, remove PoolItems (and defaults) with same ID + auto& rArrayPtr = pImpl->maPoolItems[n]; + if (rArrayPtr) { - SfxPoolItemArrayBase_Impl::const_iterator ppHtArr = (*itrItemArr)->begin(); - for ( size_t n = (*itrItemArr)->size(); n; --n, ++ppHtArr ) - if (*ppHtArr) + for (auto& rItemPtr : *rArrayPtr) + if (rItemPtr) { #ifdef DBG_UTIL - ReleaseRef( **ppHtArr, (*ppHtArr)->GetRefCount() ); + ReleaseRef(*rItemPtr, rItemPtr->GetRefCount()); #endif - delete *ppHtArr; + delete rItemPtr; } - DELETEZ( *itrItemArr ); + rArrayPtr->clear(); + // let pImpl->DeleteItems() delete item arrays in maPoolItems } - if (*itDefaultItem) + auto& rItemPtr = pImpl->maPoolDefaults[n]; + if (rItemPtr) { #ifdef DBG_UTIL - SetRefCount(**itDefaultItem, 0); + SetRefCount(*rItemPtr, 0); #endif - DELETEZ(*itDefaultItem); + delete rItemPtr; + rItemPtr = nullptr; } } } } - itrItemArr = pImpl->maPoolItems.begin(); - itDefaultItem = pImpl->maPoolDefaults.begin(); - - // Now for the easy Items - for ( nArrCnt = GetSize_Impl(); - nArrCnt; - --nArrCnt, ++itrItemArr, ++itDefaultItem) + // now remove remaining PoolItems (and defaults) who didn't have SetItems + for (auto& rArrayPtr : pImpl->maPoolItems) { - if ( *itrItemArr ) + if (rArrayPtr) { - SfxPoolItemArrayBase_Impl::const_iterator ppHtArr = (*itrItemArr)->begin(); - for ( size_t n = (*itrItemArr)->size(); n; --n, ++ppHtArr ) - if (*ppHtArr) + for (auto& rItemPtr : *rArrayPtr) + if (rItemPtr) { #ifdef DBG_UTIL - ReleaseRef( **ppHtArr, (*ppHtArr)->GetRefCount() ); + ReleaseRef(*rItemPtr, rItemPtr->GetRefCount()); #endif - delete *ppHtArr; + delete rItemPtr; } - DELETEZ( *itrItemArr ); + rArrayPtr->clear(); + // let pImpl->DeleteItems() delete item arrays in maPoolItems } - if (*itDefaultItem) + } + // default items + for (auto rItemPtr : pImpl->maPoolDefaults) + { + if (rItemPtr) { #ifdef DBG_UTIL - SetRefCount(**itDefaultItem, 0); + SetRefCount(*rItemPtr, 0); #endif - DELETEZ(*itDefaultItem); + delete rItemPtr; + rItemPtr = nullptr; } } @@ -666,7 +660,7 @@ const SfxPoolItem& SfxItemPool::Put( const SfxPoolItem& rItem, sal_uInt16 nWhich it = pItemArr->maPtrToIndex.find(const_cast<SfxPoolItem *>(&rItem)); // 1. search for an identical pointer in the pool - if (it != pItemArr->maPtrToIndex.end()) + if (it != pItemArr->maPtrToIndex.cend()) { AddRef(rItem); return rItem; @@ -674,8 +668,7 @@ const SfxPoolItem& SfxItemPool::Put( const SfxPoolItem& rItem, sal_uInt16 nWhich } // 2. search for an item with matching attributes. - SfxPoolItemArrayBase_Impl::iterator itr = pItemArr->begin(); - for (; itr != pItemArr->end(); ++itr) + for (auto itr = pItemArr->begin(); itr != pItemArr->end(); ++itr) { if (*itr) { diff --git a/svl/source/items/poolio.cxx b/svl/source/items/poolio.cxx index 1fbf5ce3b0dc..0fa426399d4e 100644 --- a/svl/source/items/poolio.cxx +++ b/svl/source/items/poolio.cxx @@ -309,23 +309,22 @@ void SfxItemPool::LoadCompleted() if ( pImpl->nInitRefCount > 1 ) { // Iterate over all Which values - std::vector<SfxPoolItemArray_Impl*>::const_iterator itrItemArr = pImpl->maPoolItems.begin(); - for( sal_uInt16 nArrCnt = GetSize_Impl(); nArrCnt; --nArrCnt, ++itrItemArr ) + for (auto& rPoolItemArrayPtr : pImpl->maPoolItems) { // Is there an item with the Which value present at all? - if ( *itrItemArr ) + if (rPoolItemArrayPtr) { // Iterate over all items with this WhichId - SfxPoolItemArrayBase_Impl::iterator ppHtArr = (*itrItemArr)->begin(); - for( size_t n = (*itrItemArr)->size(); n; --n, ++ppHtArr ) + for (auto& rItemPtr : *rPoolItemArrayPtr) { - if (*ppHtArr) + if (rItemPtr) { - if ( !ReleaseRef( **ppHtArr ) ) - DELETEZ( *ppHtArr ); + if (!ReleaseRef(*rItemPtr)) + DELETEZ(rItemPtr); } } - (*itrItemArr)->ReHash(); + // don't clear array, fill free list and clear pointer map + rPoolItemArrayPtr->ReHash(); } } @@ -467,19 +466,16 @@ SvStream &SfxItemPool::Load(SvStream &rStream) { // Iterate over all Which values - std::vector<SfxPoolItemArray_Impl*>::const_iterator itrItemArr = pImpl->maPoolItems.begin(); - for( size_t nArrCnt = GetSize_Impl(); nArrCnt; --nArrCnt, ++itrItemArr ) + for(auto const& rArrayPtr : pImpl->maPoolItems) { // Is there an Item with that Which value present at all? - if ( *itrItemArr ) + if (rArrayPtr) { - SfxPoolItemArrayBase_Impl::const_iterator ppHtArr = (*itrItemArr)->begin(); - for( size_t n = (*itrItemArr)->size(); n; --n, ++ppHtArr ) - if (*ppHtArr) + for (auto const& rItemPtr : *rArrayPtr) + if (rItemPtr) { SAL_INFO( "svl", "loading non-empty ItemPool" ); - - AddRef( **ppHtArr ); + AddRef(*rItemPtr); } } } |