summaryrefslogtreecommitdiff
path: root/basic/source
diff options
context:
space:
mode:
authorMichael Stahl <mstahl@redhat.com>2015-10-25 17:23:27 +0100
committerMichael Stahl <mstahl@redhat.com>2015-10-26 16:09:20 +0100
commit51eb04a158a89cc2260d40e844ac7b9eca0cee0a (patch)
tree066f8edef0c3d569a3b99854ba399134edf39a6e /basic/source
parent71f6aab077f30f8b0eb6c7458cb0646dea892148 (diff)
basic: replace boost::ptr_vector with std::vector<std::unique_ptr>
Change-Id: I98c4ac860fbdb55a61f9be0e9d2d5f29fb849e05
Diffstat (limited to 'basic/source')
-rw-r--r--basic/source/comp/symtbl.cxx32
-rw-r--r--basic/source/inc/symtbl.hxx7
2 files changed, 20 insertions, 19 deletions
diff --git a/basic/source/comp/symtbl.cxx b/basic/source/comp/symtbl.cxx
index db6b1505b3a5..a0390af65d1e 100644
--- a/basic/source/comp/symtbl.cxx
+++ b/basic/source/comp/symtbl.cxx
@@ -107,33 +107,33 @@ SbiSymDef* SbiSymPool::First()
SbiSymDef* SbiSymPool::Next()
{
- if( ++nCur >= aData.size() )
+ if (m_Data.size() <= ++nCur)
return NULL;
else
- return &aData[ nCur ];
+ return m_Data[ nCur ].get();
}
SbiSymDef* SbiSymPool::AddSym( const OUString& rName )
{
SbiSymDef* p = new SbiSymDef( rName );
- p->nPos = aData.size();
+ p->nPos = m_Data.size();
p->nId = rStrings.Add( rName );
p->nProcId = nProcId;
p->pIn = this;
- aData.insert( aData.begin() + p->nPos, p );
+ m_Data.insert( m_Data.begin() + p->nPos, std::unique_ptr<SbiSymDef>(p) );
return p;
}
SbiProcDef* SbiSymPool::AddProc( const OUString& rName )
{
SbiProcDef* p = new SbiProcDef( pParser, rName );
- p->nPos = aData.size();
+ p->nPos = m_Data.size();
p->nId = rStrings.Add( rName );
// procs are always local
p->nProcId = 0;
p->pIn = this;
- aData.insert( aData.begin() + p->nPos, p );
+ m_Data.insert( m_Data.begin() + p->nPos, std::unique_ptr<SbiProcDef>(p) );
return p;
}
@@ -152,7 +152,7 @@ void SbiSymPool::Add( SbiSymDef* pDef )
return;
}
- pDef->nPos = aData.size();
+ pDef->nPos = m_Data.size();
if( !pDef->nId )
{
// A unique name must be created in the string pool
@@ -172,17 +172,17 @@ void SbiSymPool::Add( SbiSymDef* pDef )
pDef->nProcId = nProcId;
}
pDef->pIn = this;
- aData.insert( aData.begin() + pDef->nPos, pDef );
+ m_Data.insert( m_Data.begin() + pDef->nPos, std::unique_ptr<SbiSymDef>(pDef) );
}
}
SbiSymDef* SbiSymPool::Find( const OUString& rName )
{
- sal_uInt16 nCount = aData.size();
+ sal_uInt16 nCount = m_Data.size();
for( sal_uInt16 i = 0; i < nCount; i++ )
{
- SbiSymDef &r = aData[ nCount - i - 1 ];
+ SbiSymDef &r = *m_Data[ nCount - i - 1 ];
if( ( !r.nProcId || ( r.nProcId == nProcId)) &&
( r.aName.equalsIgnoreAsciiCase(rName)))
{
@@ -204,13 +204,13 @@ SbiSymDef* SbiSymPool::Find( const OUString& rName )
SbiSymDef* SbiSymPool::Get( sal_uInt16 n )
{
- if( n >= aData.size() )
+ if (m_Data.size() <= n)
{
return NULL;
}
else
{
- return &aData[ n ];
+ return m_Data[ n ].get();
}
}
@@ -246,9 +246,9 @@ sal_uInt32 SbiSymPool::Reference( const OUString& rName )
void SbiSymPool::CheckRefs()
{
- for( size_t i = 0; i < aData.size(); i++ )
+ for (size_t i = 0; i < m_Data.size(); ++i)
{
- SbiSymDef &r = aData[ i ];
+ SbiSymDef &r = *m_Data[ i ];
if( !r.IsDefined() )
{
pParser->Error( ERRCODE_BASIC_UNDEF_LABEL, r.GetName() );
@@ -459,7 +459,9 @@ void SbiProcDef::Match( SbiProcDef* pOld )
nPos = pOld->nPos;
nId = pOld->nId;
pIn = pOld->pIn;
- pIn->aData.replace( nPos, this ).release();
+ std::unique_ptr<SbiSymDef> tmp(this);
+ std::swap(pIn->m_Data[nPos], tmp);
+ tmp.release();
}
delete pOld;
}
diff --git a/basic/source/inc/symtbl.hxx b/basic/source/inc/symtbl.hxx
index d9e279d7761b..2f75fa810763 100644
--- a/basic/source/inc/symtbl.hxx
+++ b/basic/source/inc/symtbl.hxx
@@ -20,8 +20,8 @@
#ifndef INCLUDED_BASIC_SOURCE_INC_SYMTBL_HXX
#define INCLUDED_BASIC_SOURCE_INC_SYMTBL_HXX
+#include <memory>
#include <vector>
-#include <boost/ptr_container/ptr_vector.hpp>
class SbiConstDef;
class SbiParser;
@@ -54,8 +54,7 @@ class SbiSymPool {
friend class SbiProcDef;
protected:
SbiStringPool& rStrings;
- boost::ptr_vector<SbiSymDef>
- aData;
+ std::vector<std::unique_ptr<SbiSymDef>> m_Data;
SbiSymPool* pParent;
SbiParser* pParser;
SbiSymScope eScope;
@@ -67,7 +66,7 @@ public:
void SetParent( SbiSymPool* p ) { pParent = p; }
void SetProcId( short n ) { nProcId = n; }
- sal_uInt16 GetSize() const { return aData.size(); }
+ sal_uInt16 GetSize() const { return m_Data.size(); }
SbiSymScope GetScope() const { return eScope; }
void SetScope( SbiSymScope s ) { eScope = s; }
SbiParser* GetParser() { return pParser; }