summaryrefslogtreecommitdiff
path: root/UnoControls
diff options
context:
space:
mode:
Diffstat (limited to 'UnoControls')
-rw-r--r--UnoControls/source/controls/progressmonitor.cxx63
-rw-r--r--UnoControls/source/inc/progressmonitor.hxx11
2 files changed, 35 insertions, 39 deletions
diff --git a/UnoControls/source/controls/progressmonitor.cxx b/UnoControls/source/controls/progressmonitor.cxx
index 3d9e058e9c85..ca206b1f44c4 100644
--- a/UnoControls/source/controls/progressmonitor.cxx
+++ b/UnoControls/source/controls/progressmonitor.cxx
@@ -60,6 +60,9 @@ using namespace ::com::sun::star::uno ;
using namespace ::com::sun::star::lang ;
using namespace ::com::sun::star::awt ;
+using ::std::vector;
+
+
namespace unocontrols{
//____________________________________________________________________________________________________________
@@ -119,10 +122,6 @@ ProgressMonitor::ProgressMonitor( const Reference< XMultiServiceFactory >& xFact
m_xText_Bottom->setText ( OUString(RTL_CONSTASCII_USTRINGPARAM( PROGRESSMONITOR_DEFAULT_TEXT )) ) ;
--m_refCount ;
-
- // Initialize info lists for fixedtext's
- m_pTextlist_Top = new IMPL_Textlist ;
- m_pTextlist_Bottom = new IMPL_Textlist ;
}
ProgressMonitor::~ProgressMonitor()
@@ -275,11 +274,11 @@ void SAL_CALL ProgressMonitor::addText(
// ... and insert it in right list.
if ( bbeforeProgress == sal_True )
{
- m_pTextlist_Top->Insert ( pTextItem, LIST_APPEND ) ;
+ maTextlist_Top.push_back( pTextItem );
}
else
{
- m_pTextlist_Bottom->Insert ( pTextItem, LIST_APPEND ) ;
+ maTextlist_Bottom.push_back( pTextItem );
}
}
@@ -309,11 +308,15 @@ void SAL_CALL ProgressMonitor::removeText ( const OUString& rTopic, sal_Bool bbe
// ... delete item from right list ...
if ( bbeforeProgress == sal_True )
{
- m_pTextlist_Top->Remove ( pSearchItem ) ;
+ vector< IMPL_TextlistItem* >::iterator itr = maTextlist_Top.begin();
+ while ( (itr < maTextlist_Top.end()) && (*itr != pSearchItem) ) ++itr;
+ maTextlist_Top.erase(itr);
}
else
{
- m_pTextlist_Bottom->Remove ( pSearchItem ) ;
+ vector< IMPL_TextlistItem* >::iterator itr = maTextlist_Bottom.begin();
+ while ( (itr < maTextlist_Bottom.end()) && (*itr != pSearchItem) ) ++itr;
+ maTextlist_Bottom.erase(itr);
}
delete pSearchItem ;
@@ -893,9 +896,9 @@ void ProgressMonitor::impl_rebuildFixedText ()
// Collect all topics from list and format text.
// "\n" MUST BE at the end of line!!! => Else ... topic and his text are not in the same line!!!
- for ( sal_uInt32 n=0; n<m_pTextlist_Top->Count(); ++n )
+ for ( size_t n = 0; n < maTextlist_Top.size(); ++n )
{
- IMPL_TextlistItem* pSearchItem = m_pTextlist_Top->GetObject (n) ;
+ IMPL_TextlistItem* pSearchItem = maTextlist_Top[ n ];
aCollectString += pSearchItem->sTopic ;
aCollectString += OUString(RTL_CONSTASCII_USTRINGPARAM("\n")) ;
}
@@ -911,9 +914,9 @@ void ProgressMonitor::impl_rebuildFixedText ()
// Collect all topics from list and format text.
// "\n" MUST BE at the end of line!!! => Else ... topic and his text are not in the same line!!!
- for ( sal_uInt32 n=0; n<m_pTextlist_Top->Count(); ++n )
+ for ( size_t n = 0; n < maTextlist_Top.size(); ++n )
{
- IMPL_TextlistItem* pSearchItem = m_pTextlist_Top->GetObject (n) ;
+ IMPL_TextlistItem* pSearchItem = maTextlist_Top[ n ];
aCollectString += pSearchItem->sText ;
aCollectString += OUString(RTL_CONSTASCII_USTRINGPARAM("\n")) ;
}
@@ -931,9 +934,9 @@ void ProgressMonitor::impl_rebuildFixedText ()
// Collect all topics from list and format text.
// "\n" MUST BE at the end of line!!! => Else ... topic and his text are not in the same line!!!
- for ( sal_uInt32 n=0; n<m_pTextlist_Bottom->Count(); ++n )
+ for ( size_t n = 0; n < maTextlist_Bottom.size(); ++n )
{
- IMPL_TextlistItem* pSearchItem = m_pTextlist_Bottom->GetObject (n) ;
+ IMPL_TextlistItem* pSearchItem = maTextlist_Bottom[ n ];
aCollectString += pSearchItem->sTopic ;
aCollectString += OUString(RTL_CONSTASCII_USTRINGPARAM("\n")) ;
}
@@ -949,9 +952,9 @@ void ProgressMonitor::impl_rebuildFixedText ()
// Collect all topics from list and format text.
// "\n" MUST BE at the end of line!!! => Else ... topic and his text are not in the same line!!!
- for ( sal_uInt32 n=0; n<m_pTextlist_Bottom->Count(); ++n )
+ for ( size_t n = 0; n < maTextlist_Bottom.size(); ++n )
{
- IMPL_TextlistItem* pSearchItem = m_pTextlist_Bottom->GetObject (n) ;
+ IMPL_TextlistItem* pSearchItem = maTextlist_Bottom[ n ];
aCollectString += pSearchItem->sText ;
aCollectString += OUString(RTL_CONSTASCII_USTRINGPARAM("\n")) ;
}
@@ -972,23 +975,19 @@ void ProgressMonitor::impl_cleanMemory ()
// Delete all of lists.
- sal_uInt32 nPosition ;
-
- for ( nPosition = 0; nPosition < m_pTextlist_Top->Count () ; ++nPosition )
+ for ( size_t nPosition = 0; nPosition < maTextlist_Top.size() ; ++nPosition )
{
- IMPL_TextlistItem* pSearchItem = m_pTextlist_Top->GetObject ( nPosition ) ;
+ IMPL_TextlistItem* pSearchItem = maTextlist_Top[ nPosition ];
delete pSearchItem ;
}
- m_pTextlist_Top->Clear () ;
- delete m_pTextlist_Top ;
+ maTextlist_Top.clear();
- for ( nPosition = 0; nPosition < m_pTextlist_Bottom->Count () ; ++nPosition )
+ for ( size_t nPosition = 0; nPosition < maTextlist_Bottom.size() ; ++nPosition )
{
- IMPL_TextlistItem* pSearchItem = m_pTextlist_Bottom->GetObject ( nPosition ) ;
+ IMPL_TextlistItem* pSearchItem = maTextlist_Bottom[ nPosition ];
delete pSearchItem ;
}
- m_pTextlist_Bottom->Clear () ;
- delete m_pTextlist_Bottom ;
+ maTextlist_Bottom.clear();
}
//____________________________________________________________________________________________________________
@@ -998,30 +997,30 @@ void ProgressMonitor::impl_cleanMemory ()
IMPL_TextlistItem* ProgressMonitor::impl_searchTopic ( const OUString& rTopic, sal_Bool bbeforeProgress )
{
// Get right textlist for following operations.
- IMPL_Textlist* pTextList ;
+ ::std::vector< IMPL_TextlistItem* >* pTextList ;
// Ready for multithreading
ClearableMutexGuard aGuard ( m_aMutex ) ;
if ( bbeforeProgress == sal_True )
{
- pTextList = m_pTextlist_Top ;
+ pTextList = &maTextlist_Top ;
}
else
{
- pTextList = m_pTextlist_Bottom ;
+ pTextList = &maTextlist_Bottom ;
}
// Switch off guard.
aGuard.clear () ;
// Search the topic in textlist.
- sal_uInt32 nPosition = 0 ;
- sal_uInt32 nCount = pTextList->Count () ;
+ size_t nPosition = 0;
+ size_t nCount = pTextList->size();
for ( nPosition = 0; nPosition < nCount ; ++nPosition )
{
- IMPL_TextlistItem* pSearchItem = pTextList->GetObject ( nPosition ) ;
+ IMPL_TextlistItem* pSearchItem = pTextList->at( nPosition );
if ( pSearchItem->sTopic == rTopic )
{
diff --git a/UnoControls/source/inc/progressmonitor.hxx b/UnoControls/source/inc/progressmonitor.hxx
index 08353d11f4a0..6d829249449f 100644
--- a/UnoControls/source/inc/progressmonitor.hxx
+++ b/UnoControls/source/inc/progressmonitor.hxx
@@ -72,6 +72,8 @@
#include <com/sun/star/awt/XLayoutConstrains.hpp>
#include <com/sun/star/awt/XProgressBar.hpp>
+#include <vector>
+
//____________________________________________________________________________________________________________
// includes of my own project
//____________________________________________________________________________________________________________
@@ -121,10 +123,6 @@ struct IMPL_TextlistItem
::rtl::OUString sText ; /// Right site of textline in dialog
};
-/// Define a list-class for struct IMPL_TextlistItem
-class IMPL_Textlist ;
-DECLARE_LIST( IMPL_Textlist, IMPL_TextlistItem* )
-
//____________________________________________________________________________________________________________
// class declaration
//____________________________________________________________________________________________________________
@@ -781,12 +779,11 @@ private:
//____________________________________________________________________________________________________________
private:
-
- IMPL_Textlist* m_pTextlist_Top ; // Elements before progress
+ ::std::vector < IMPL_TextlistItem* > maTextlist_Top; // Elements before progress
CSS_UNO::Reference< CSS_AWT::XFixedText > m_xTopic_Top ; // (used, if parameter "beforeProgress"=sal_True in "addText, updateText, removeText")
CSS_UNO::Reference< CSS_AWT::XFixedText > m_xText_Top ;
- IMPL_Textlist* m_pTextlist_Bottom ; // Elements below of progress
+ ::std::vector < IMPL_TextlistItem* > maTextlist_Bottom; // Elements below of progress
CSS_UNO::Reference< CSS_AWT::XFixedText > m_xTopic_Bottom ; // (used, if parameter "beforeProgress"=sal_False in "addText, updateText, removeText")
CSS_UNO::Reference< CSS_AWT::XFixedText > m_xText_Bottom ;