diff options
author | Thorsten Behrens <tbehrens@suse.com> | 2012-01-09 18:04:58 +0100 |
---|---|---|
committer | Thorsten Behrens <tbehrens@suse.com> | 2012-01-09 18:37:52 +0100 |
commit | c85142eb63c61de68aa7dbb10b2bcb8b48b870f9 (patch) | |
tree | 1463febf22a6bb33cdc974d7a886551265cfc7a1 | |
parent | 540963d879296ef81f883305057e63465b2ff586 (diff) |
Fix more incorrect iterator re-use.
Follow-up fix for 540963d879296ef81f883305057e63465b2ff586
std::algos use iterator arguments by value, and may change them.
-rw-r--r-- | canvas/source/tools/spriteredrawmanager.cxx | 16 | ||||
-rw-r--r-- | slideshow/source/engine/animationnodes/basecontainernode.cxx | 3 | ||||
-rw-r--r-- | slideshow/source/engine/eventmultiplexer.cxx | 4 | ||||
-rw-r--r-- | slideshow/source/engine/tools.cxx | 2 |
4 files changed, 11 insertions, 14 deletions
diff --git a/canvas/source/tools/spriteredrawmanager.cxx b/canvas/source/tools/spriteredrawmanager.cxx index 25accbe47278..2af5b34e6f8c 100644 --- a/canvas/source/tools/spriteredrawmanager.cxx +++ b/canvas/source/tools/spriteredrawmanager.cxx @@ -412,16 +412,11 @@ namespace canvas if( nNumSprites > 3 || nNumSprites < 1 ) return false; - const SpriteConnectedRanges::ComponentListType::const_iterator aBegin( - rUpdateArea.maComponentList.begin() ); - const SpriteConnectedRanges::ComponentListType::const_iterator aEnd( - rUpdateArea.maComponentList.end() ); - // now, calc the _true_ update area, by merging all sprite's // true update areas into one rectangle - ::basegfx::B2DRange aTrueArea( aBegin->second.getUpdateArea() ); - ::std::for_each( aBegin, - aEnd, + ::basegfx::B2DRange aTrueArea( rUpdateArea.maComponentList.begin()->second.getUpdateArea() ); + ::std::for_each( rUpdateArea.maComponentList.begin(), + rUpdateArea.maComponentList.end(), ::boost::bind( (void (basegfx::B2DRange::*)(const basegfx::B2DRange&))( &basegfx::B2DRange::expand), aTrueArea, @@ -429,9 +424,12 @@ namespace canvas ::boost::bind( ::o3tl::select2nd<AreaComponent>(), _1 ) ) ) ); + const SpriteConnectedRanges::ComponentListType::const_iterator aEnd( + rUpdateArea.maComponentList.end() ); + // and check whether _any_ of the sprites tells that its area // update will not be opaque. - return (::std::find_if( aBegin, + return (::std::find_if( rUpdateArea.maComponentList.begin(), aEnd, ::boost::bind( &SpriteRedrawManager::isAreaUpdateNotOpaque, this, diff --git a/slideshow/source/engine/animationnodes/basecontainernode.cxx b/slideshow/source/engine/animationnodes/basecontainernode.cxx index bf00001cc19d..fd816544f0c7 100644 --- a/slideshow/source/engine/animationnodes/basecontainernode.cxx +++ b/slideshow/source/engine/animationnodes/basecontainernode.cxx @@ -113,10 +113,9 @@ void BaseContainerNode::appendChildNode( AnimationNodeSharedPtr const& pNode ) bool BaseContainerNode::isChildNode( AnimationNodeSharedPtr const& pNode ) const { // find given notifier in child vector - VectorOfNodes::const_iterator const iBegin( maChildren.begin() ); VectorOfNodes::const_iterator const iEnd( maChildren.end() ); VectorOfNodes::const_iterator const iFind( - std::find( iBegin, iEnd, pNode ) ); + std::find( maChildren.begin(), iEnd, pNode ) ); return (iFind != iEnd); } diff --git a/slideshow/source/engine/eventmultiplexer.cxx b/slideshow/source/engine/eventmultiplexer.cxx index 8bb0f08d7857..d162718e9742 100644 --- a/slideshow/source/engine/eventmultiplexer.cxx +++ b/slideshow/source/engine/eventmultiplexer.cxx @@ -617,10 +617,10 @@ bool EventMultiplexerImpl::notifyMouseHandlers( // find corresponding view (to map mouse position into user // coordinate space) UnoViewVector::const_iterator aIter; - const UnoViewVector::const_iterator aBegin( mrViewContainer.begin() ); const UnoViewVector::const_iterator aEnd ( mrViewContainer.end() ); if( (aIter=::std::find_if( - aBegin, aEnd, + mrViewContainer.begin(), + aEnd, boost::bind( std::equal_to< uno::Reference< presentation::XSlideShowView > >(), boost::cref( xView ), diff --git a/slideshow/source/engine/tools.cxx b/slideshow/source/engine/tools.cxx index e36f4ee47d44..7dabb90b060e 100644 --- a/slideshow/source/engine/tools.cxx +++ b/slideshow/source/engine/tools.cxx @@ -472,7 +472,7 @@ namespace slideshow pArray + nLen, NamedValueComparator( rSearchKey ) ); - if( pFound == pArray + nLen ) + if( pFound == rSequence.getConstArray() + nLen ) return false; return true; |