diff options
author | David Tardon <dtardon@redhat.com> | 2016-09-08 16:27:25 +0200 |
---|---|---|
committer | David Tardon <dtardon@redhat.com> | 2016-09-09 07:30:30 +0200 |
commit | 0f9a81c8f58c1a9e771d7ff90abe3c20e8283f94 (patch) | |
tree | 89199dea3269ef95bc97013fd77b726b896eafbe | |
parent | 6678ff2e84f134a670259b48a7ba1721fccdaeb6 (diff) |
remove manual memory management
Change-Id: I07960df50645fb77b24eaad4a60f93b715cbb6a9
-rw-r--r-- | xmloff/source/style/xmlstyle.cxx | 37 |
1 files changed, 10 insertions, 27 deletions
diff --git a/xmloff/source/style/xmlstyle.cxx b/xmloff/source/style/xmlstyle.cxx index 885cabd0f634..a77496a83e2e 100644 --- a/xmloff/source/style/xmlstyle.cxx +++ b/xmloff/source/style/xmlstyle.cxx @@ -207,27 +207,26 @@ class SvXMLStyleIndex_Impl { OUString sName; sal_uInt16 nFamily; - const SvXMLStyleContext *pStyle; + const uno::Reference<SvXMLStyleContext> mxStyle; public: SvXMLStyleIndex_Impl( sal_uInt16 nFam, const OUString& rName ) : sName( rName ), - nFamily( nFam ), - pStyle ( nullptr ) + nFamily( nFam ) { } - SvXMLStyleIndex_Impl( const SvXMLStyleContext *pStl ) : - sName( pStl->GetName() ), - nFamily( pStl->GetFamily() ), - pStyle ( pStl ) + SvXMLStyleIndex_Impl( const uno::Reference<SvXMLStyleContext> &rStl ) : + sName( rStl->GetName() ), + nFamily( rStl->GetFamily() ), + mxStyle ( rStl ) { } const OUString& GetName() const { return sName; } sal_uInt16 GetFamily() const { return nFamily; } - const SvXMLStyleContext *GetStyle() const { return pStyle; } + const SvXMLStyleContext *GetStyle() const { return mxStyle.get(); } }; struct SvXMLStyleIndexCmp_Impl @@ -249,7 +248,7 @@ struct SvXMLStyleIndexCmp_Impl class SvXMLStylesContext_Impl { - typedef std::vector<SvXMLStyleContext*> StylesType; + typedef std::vector<uno::Reference<SvXMLStyleContext>> StylesType; typedef std::set<SvXMLStyleIndex_Impl, SvXMLStyleIndexCmp_Impl> IndicesType; StylesType aStyles; @@ -264,13 +263,12 @@ class SvXMLStylesContext_Impl public: explicit SvXMLStylesContext_Impl( bool bAuto ); - ~SvXMLStylesContext_Impl(); size_t GetStyleCount() const { return aStyles.size(); } SvXMLStyleContext *GetStyle( size_t i ) { - return i < aStyles.size() ? aStyles[ i ] : nullptr; + return i < aStyles.size() ? aStyles[ i ].get() : nullptr; } inline void AddStyle( SvXMLStyleContext *pStyle ); @@ -289,19 +287,9 @@ SvXMLStylesContext_Impl::SvXMLStylesContext_Impl( bool bAuto ) : #endif {} -SvXMLStylesContext_Impl::~SvXMLStylesContext_Impl() -{ - for (SvXMLStyleContext* pStyle : aStyles) - { - pStyle->ReleaseRef(); - } - aStyles.clear(); -} - inline void SvXMLStylesContext_Impl::AddStyle( SvXMLStyleContext *pStyle ) { aStyles.push_back( pStyle ); - pStyle->AddFirstRef(); FlushIndex(); } @@ -309,11 +297,6 @@ inline void SvXMLStylesContext_Impl::AddStyle( SvXMLStyleContext *pStyle ) void SvXMLStylesContext_Impl::Clear() { FlushIndex(); - - for (SvXMLStyleContext* pStyle : aStyles) - { - pStyle->ReleaseRef(); - } aStyles.clear(); } @@ -345,7 +328,7 @@ const SvXMLStyleContext *SvXMLStylesContext_Impl::FindStyleChildContext( sal_uIn { for( size_t i = 0; !pStyle && i < aStyles.size(); i++ ) { - const SvXMLStyleContext *pS = aStyles[ i ]; + const SvXMLStyleContext *pS = aStyles[ i ].get(); if( pS->GetFamily() == nFamily && pS->GetName() == rName ) pStyle = pS; |