From 3ca66ea9f38670e1c491e8a2063c2867afb12d39 Mon Sep 17 00:00:00 2001 From: Noel Grandin Date: Sat, 2 Jun 2012 12:23:29 +0200 Subject: Convert SV_DECL_PTRARR(TextViews) to std::vector Change-Id: Icd79dec8c77fc13cf82c66a2d64ca2325eaa66ab --- svtools/inc/svtools/texteng.hxx | 3 ++- svtools/source/edit/texteng.cxx | 55 +++++++++++++++++++---------------------- 2 files changed, 28 insertions(+), 30 deletions(-) (limited to 'svtools') diff --git a/svtools/inc/svtools/texteng.hxx b/svtools/inc/svtools/texteng.hxx index ab897b26bb57..b20a01bdb9d7 100644 --- a/svtools/inc/svtools/texteng.hxx +++ b/svtools/inc/svtools/texteng.hxx @@ -34,7 +34,6 @@ class TextDoc; class TextView; class TextPaM; class TextSelection; -class TextViews; class TEParaPortions; class TextAttrib; class TextCharAttrib; @@ -80,6 +79,8 @@ class LocaleDataWrapper; enum TxtAlign { TXTALIGN_LEFT, TXTALIGN_CENTER, TXTALIGN_RIGHT }; +typedef std::vector TextViews; + class SVT_DLLPUBLIC TextEngine : public SfxBroadcaster { friend class TextView; diff --git a/svtools/source/edit/texteng.cxx b/svtools/source/edit/texteng.cxx index fa62f3f1049b..9fc4de968f96 100644 --- a/svtools/source/edit/texteng.cxx +++ b/svtools/source/edit/texteng.cxx @@ -70,9 +70,6 @@ using namespace ::com::sun::star; using namespace ::com::sun::star::uno; using namespace ::rtl; -typedef TextView* TextViewPtr; -SV_DECL_PTRARR( TextViews, TextViewPtr, 0 ) - // ------------------------------------------------------------------------- // (-) class TextEngine @@ -140,7 +137,7 @@ TextEngine::~TextEngine() void TextEngine::InsertView( TextView* pTextView ) { - mpViews->Insert( pTextView, mpViews->Count() ); + mpViews->push_back( pTextView ); pTextView->SetSelection( TextSelection() ); if ( !GetActiveView() ) @@ -149,11 +146,11 @@ void TextEngine::InsertView( TextView* pTextView ) void TextEngine::RemoveView( TextView* pTextView ) { - sal_uInt16 nPos = mpViews->GetPos( pTextView ); - if( nPos != USHRT_MAX ) + TextViews::iterator it = std::find( mpViews->begin(), mpViews->end(), pTextView ); + if( it != mpViews->end() ) { pTextView->HideCursor(); - mpViews->Remove( nPos, 1 ); + mpViews->erase( it ); if ( pTextView == GetActiveView() ) SetActiveView( 0 ); } @@ -161,12 +158,12 @@ void TextEngine::RemoveView( TextView* pTextView ) sal_uInt16 TextEngine::GetViewCount() const { - return mpViews->Count(); + return mpViews->size(); } TextView* TextEngine::GetView( sal_uInt16 nView ) const { - return mpViews->GetObject( nView ); + return (*mpViews)[ nView ]; } TextView* TextEngine::GetActiveView() const @@ -227,9 +224,9 @@ void TextEngine::SetFont( const Font& rFont ) FormatFullDoc(); UpdateViews(); - for ( sal_uInt16 nView = mpViews->Count(); nView; ) + for ( sal_uInt16 nView = mpViews->size(); nView; ) { - TextView* pView = mpViews->GetObject( --nView ); + TextView* pView = (*mpViews)[ --nView ]; pView->GetWindow()->SetInputContext( InputContext( GetFont(), !pView->IsReadOnly() ? INPUTCONTEXT_TEXT|INPUTCONTEXT_EXTTEXTINPUT : 0 ) ); } } @@ -450,9 +447,9 @@ void TextEngine::ImpRemoveText() TextPaM aStartPaM( 0, 0 ); TextSelection aEmptySel( aStartPaM, aStartPaM ); - for ( sal_uInt16 nView = 0; nView < mpViews->Count(); nView++ ) + for ( sal_uInt16 nView = 0; nView < mpViews->size(); nView++ ) { - TextView* pView = mpViews->GetObject( nView ); + TextView* pView = (*mpViews)[ nView ]; pView->ImpSetSelection( aEmptySel ); } ResetUndo(); @@ -473,9 +470,9 @@ void TextEngine::SetText( const XubString& rText ) if ( rText.Len() ) aPaM = ImpInsertText( aEmptySel, rText ); - for ( sal_uInt16 nView = 0; nView < mpViews->Count(); nView++ ) + for ( sal_uInt16 nView = 0; nView < mpViews->size(); nView++ ) { - TextView* pView = mpViews->GetObject( nView ); + TextView* pView = (*mpViews)[ nView ]; pView->ImpSetSelection( aEmptySel ); // Wenn kein Text, dann auch Kein Format&Update @@ -1530,9 +1527,9 @@ void TextEngine::UpdateViews( TextView* pCurView ) DBG_ASSERT( IsFormatted(), "UpdateViews: Doc nicht formatiert!" ); - for ( sal_uInt16 nView = 0; nView < mpViews->Count(); nView++ ) + for ( sal_uInt16 nView = 0; nView < mpViews->size(); nView++ ) { - TextView* pView = mpViews->GetObject( nView ); + TextView* pView = (*mpViews)[ nView ]; pView->HideCursor(); Rectangle aClipRec( maInvalidRec ); @@ -2812,11 +2809,11 @@ void TextEngine::ImpParagraphInserted( sal_uLong nPara ) { // Die aktive View braucht nicht angepasst werden, aber bei allen // passiven muss die Selektion angepasst werden: - if ( mpViews->Count() > 1 ) + if ( mpViews->size() > 1 ) { - for ( sal_uInt16 nView = mpViews->Count(); nView; ) + for ( sal_uInt16 nView = mpViews->size(); nView; ) { - TextView* pView = mpViews->GetObject( --nView ); + TextView* pView = (*mpViews)[ --nView ]; if ( pView != GetActiveView() ) { for ( int n = 0; n <= 1; n++ ) @@ -2833,11 +2830,11 @@ void TextEngine::ImpParagraphInserted( sal_uLong nPara ) void TextEngine::ImpParagraphRemoved( sal_uLong nPara ) { - if ( mpViews->Count() > 1 ) + if ( mpViews->size() > 1 ) { - for ( sal_uInt16 nView = mpViews->Count(); nView; ) + for ( sal_uInt16 nView = mpViews->size(); nView; ) { - TextView* pView = mpViews->GetObject( --nView ); + TextView* pView = (*mpViews)[ --nView ]; if ( pView != GetActiveView() ) { sal_uLong nParas = mpDoc->GetNodes().Count(); @@ -2861,11 +2858,11 @@ void TextEngine::ImpParagraphRemoved( sal_uLong nPara ) void TextEngine::ImpCharsRemoved( sal_uLong nPara, sal_uInt16 nPos, sal_uInt16 nChars ) { - if ( mpViews->Count() > 1 ) + if ( mpViews->size() > 1 ) { - for ( sal_uInt16 nView = mpViews->Count(); nView; ) + for ( sal_uInt16 nView = mpViews->size(); nView; ) { - TextView* pView = mpViews->GetObject( --nView ); + TextView* pView = (*mpViews)[ --nView ]; if ( pView != GetActiveView() ) { sal_uInt16 nEnd = nPos+nChars; @@ -2888,11 +2885,11 @@ void TextEngine::ImpCharsRemoved( sal_uLong nPara, sal_uInt16 nPos, sal_uInt16 n void TextEngine::ImpCharsInserted( sal_uLong nPara, sal_uInt16 nPos, sal_uInt16 nChars ) { - if ( mpViews->Count() > 1 ) + if ( mpViews->size() > 1 ) { - for ( sal_uInt16 nView = mpViews->Count(); nView; ) + for ( sal_uInt16 nView = mpViews->size(); nView; ) { - TextView* pView = mpViews->GetObject( --nView ); + TextView* pView = (*mpViews)[ --nView ]; if ( pView != GetActiveView() ) { for ( int n = 0; n <= 1; n++ ) -- cgit