diff options
Diffstat (limited to 'sfx2')
-rw-r--r-- | sfx2/source/view/viewimp.hxx | 6 | ||||
-rw-r--r-- | sfx2/source/view/viewsh.cxx | 34 |
2 files changed, 17 insertions, 23 deletions
diff --git a/sfx2/source/view/viewimp.hxx b/sfx2/source/view/viewimp.hxx index edd5495a33ef..3d77c18bc55a 100644 --- a/sfx2/source/view/viewimp.hxx +++ b/sfx2/source/view/viewimp.hxx @@ -29,8 +29,6 @@ #ifndef SFX_VIEWIMP_HXX #define SFX_VIEWIMP_HXX -// include --------------------------------------------------------------- - #include <basic/sbxobj.hxx> #include <sfx2/viewsh.hxx> #include <sfx2/viewfrm.hxx> // SvBorder @@ -43,13 +41,11 @@ #include <vcl/print.hxx> #include <queue> -// forward --------------------------------------------------------------- - class SfxOfficeDispatch; class SfxBaseController; typedef SfxShell* SfxShellPtr_Impl; -SV_DECL_PTRARR( SfxShellArr_Impl, SfxShellPtr_Impl, 4, 4 ) +typedef std::vector<SfxShellPtr_Impl> SfxShellArr_Impl; class SfxClipboardChangeListener; diff --git a/sfx2/source/view/viewsh.cxx b/sfx2/source/view/viewsh.cxx index 2c6bc1284420..c1bf06720f1a 100644 --- a/sfx2/source/view/viewsh.cxx +++ b/sfx2/source/view/viewsh.cxx @@ -1480,7 +1480,7 @@ sal_Bool SfxViewShell::HasSelection( sal_Bool ) const void SfxViewShell::AddSubShell( SfxShell& rShell ) { - pImp->aArr.Insert( &rShell, pImp->aArr.Count() ); + pImp->aArr.push_back(&rShell); SfxDispatcher *pDisp = pFrame->GetDispatcher(); if ( pDisp->IsActive(*this) ) { @@ -1494,25 +1494,24 @@ void SfxViewShell::RemoveSubShell( SfxShell* pShell ) SfxDispatcher *pDisp = pFrame->GetDispatcher(); if ( !pShell ) { - sal_uInt16 nCount = pImp->aArr.Count(); + size_t nCount = pImp->aArr.size(); if ( pDisp->IsActive(*this) ) { - for ( sal_uInt16 n=nCount; n>0; n-- ) - pDisp->Pop( *pImp->aArr[n-1] ); + for(size_t n = nCount; n > 0; --n) + pDisp->Pop(*pImp->aArr[n - 1]); pDisp->Flush(); } - - pImp->aArr.Remove(0, nCount); + pImp->aArr.clear(); } else { - sal_uInt16 nPos = pImp->aArr.GetPos( pShell ); - if ( nPos != 0xFFFF ) + SfxShellArr_Impl::iterator i = std::find(pImp->aArr.begin(), pImp->aArr.end(), pShell); + if(i != pImp->aArr.end()) { - pImp->aArr.Remove( nPos ); - if ( pDisp->IsActive(*this) ) + pImp->aArr.erase(i); + if(pDisp->IsActive(*this)) { - pDisp->RemoveShell_Impl( *pShell ); + pDisp->RemoveShell_Impl(*pShell); pDisp->Flush(); } } @@ -1521,22 +1520,21 @@ void SfxViewShell::RemoveSubShell( SfxShell* pShell ) SfxShell* SfxViewShell::GetSubShell( sal_uInt16 nNo ) { - sal_uInt16 nCount = pImp->aArr.Count(); - if ( nNo<nCount ) - return pImp->aArr[nCount-nNo-1]; + sal_uInt16 nCount = pImp->aArr.size(); + if(nNo < nCount) + return pImp->aArr[nCount - nNo - 1]; return NULL; } void SfxViewShell::PushSubShells_Impl( sal_Bool bPush ) { - sal_uInt16 nCount = pImp->aArr.Count(); SfxDispatcher *pDisp = pFrame->GetDispatcher(); if ( bPush ) { - for ( sal_uInt16 n=0; n<nCount; n++ ) - pDisp->Push( *pImp->aArr[n] ); + for(SfxShellArr_Impl::const_iterator i = pImp->aArr.begin(); i != pImp->aArr.end(); ++i) + pDisp->Push(**i); } - else if ( nCount ) + else if(!pImp->aArr.empty()) { SfxShell& rPopUntil = *pImp->aArr[0]; if ( pDisp->GetShellLevel( rPopUntil ) != USHRT_MAX ) |