[Libreoffice-commits] .: basic/source
August Sodora
augsod at kemper.freedesktop.org
Sun Nov 20 20:44:52 PST 2011
basic/source/comp/symtbl.cxx | 32 ++++++++++++++------------------
basic/source/inc/symtbl.hxx | 14 +++++++-------
2 files changed, 21 insertions(+), 25 deletions(-)
New commits:
commit ee3ad385fb3ca476e57e80d7b77c1e184e52e1d8
Author: August Sodora <augsod at gmail.com>
Date: Sun Nov 20 23:44:21 2011 -0500
Convert to boost::ptr_vector
diff --git a/basic/source/comp/symtbl.cxx b/basic/source/comp/symtbl.cxx
index 4e6e932..22b31ea 100644
--- a/basic/source/comp/symtbl.cxx
+++ b/basic/source/comp/symtbl.cxx
@@ -34,7 +34,6 @@
#include <string.h>
#include <ctype.h>
-SV_IMPL_PTRARR(SbiStrings,String*)
SV_IMPL_PTRARR(SbiSymbols,SbiSymDef*)
// All symbol names are laid down int the symbol-pool's stringpool, so that
@@ -57,30 +56,27 @@ SbiStringPool::SbiStringPool( SbiParser* p )
SbiStringPool::~SbiStringPool()
{}
-
-const String& SbiStringPool::Find( sal_uInt16 n ) const
+const rtl::OUString& SbiStringPool::Find( sal_uInt32 n ) const
{
- if( !n || n > aData.Count() )
- return aEmpty;
+ if( n == 0 || n > aData.size() )
+ return aEmpty; //hack, returning a reference to a simulation of null
else
- return *aData.GetObject( n-1 );
+ return aData[n - 1];
}
-
-
-short SbiStringPool::Add( const String& rVal, sal_Bool bNoCase )
+short SbiStringPool::Add( const rtl::OUString& rVal, sal_Bool bNoCase )
{
- sal_uInt16 n = aData.Count();
- for( sal_uInt16 i = 0; i < n; i++ )
+ sal_uInt32 n = aData.size();
+ for( sal_uInt32 i = 0; i < n; ++i )
{
- String* p = aData.GetObject( i );
- if( ( bNoCase && p->Equals( rVal ) )
- || ( !bNoCase && p->EqualsIgnoreCaseAscii( rVal ) ) )
+ rtl::OUString& p = aData[i];
+ if( ( bNoCase && p == rVal )
+ || ( !bNoCase && p.equalsIgnoreAsciiCase( rVal ) ) )
return i+1;
}
- const String* pNew = new String( rVal );
- aData.Insert( pNew, n++ );
- return (short) n;
+
+ aData.push_back(new rtl::OUString(rVal));
+ return (short) ++n;
}
short SbiStringPool::Add( double n, SbxDataType t )
@@ -94,7 +90,7 @@ short SbiStringPool::Add( double n, SbxDataType t )
case SbxDOUBLE: snprintf( buf, sizeof(buf), "%.16g", n ); break;
default: break;
}
- return Add( String::CreateFromAscii( buf ) );
+ return Add( rtl::OUString::createFromAscii( buf ) );
}
/***************************************************************************
diff --git a/basic/source/inc/symtbl.hxx b/basic/source/inc/symtbl.hxx
index 8e4540e..33da527 100644
--- a/basic/source/inc/symtbl.hxx
+++ b/basic/source/inc/symtbl.hxx
@@ -29,6 +29,8 @@
#ifndef _SYMTBL_HXX
#define _SYMTBL_HXX
+#include <boost/ptr_container/ptr_vector.hpp>
+
class SbiConstDef;
class SbiParser;
class SbiProcDef;
@@ -40,21 +42,19 @@ enum SbiSymScope { SbLOCAL, SbPARAM, SbPUBLIC, SbGLOBAL, SbRTL };
// The string-pool collects string entries and
// makes sure that they don't exist twice.
-SV_DECL_PTRARR_DEL(SbiStrings,String*,5,5)
-
class SbiStringPool {
- SbiStrings aData;
- String aEmpty; // for convenience
+ const rtl::OUString aEmpty;
+ boost::ptr_vector<rtl::OUString> aData;
SbiParser* pParser;
public:
SbiStringPool( SbiParser* );
~SbiStringPool();
- sal_uInt16 GetSize() const { return aData.Count(); }
+ sal_uInt32 GetSize() const { return aData.size(); }
// From 8.4.1999: default changed to sal_True because of #64236 -
// change it back to sal_False when the bug is cleanly removed.
- short Add( const String&, sal_Bool=sal_True );
+ short Add( const rtl::OUString&, sal_Bool=sal_True );
short Add( double, SbxDataType );
- const String& Find( sal_uInt16 ) const;
+ const rtl::OUString& Find( sal_uInt32 ) const;
SbiParser* GetParser() { return pParser; }
};
More information about the Libreoffice-commits
mailing list