diff options
author | Michael Stahl <mstahl@redhat.com> | 2013-02-19 00:02:37 +0100 |
---|---|---|
committer | Michael Stahl <mstahl@redhat.com> | 2013-02-19 00:11:22 +0100 |
commit | 7ff650a6fe405c98d182c6cabbb46217b56bb0c6 (patch) | |
tree | ddeddf45ec70bce30c940eeba68fcee6eef3226f /ucb | |
parent | 21e2c2f16408328f78f418dd9dc086ef2a2a8f19 (diff) |
coverity#983214 Resource leak
... and some more general cleanup by using boost stuff.
Change-Id: I90b2f429f864c39cda70d42d061da14c0faba8e5
Diffstat (limited to 'ucb')
-rw-r--r-- | ucb/source/ucp/webdav-neon/webdavdatasupplier.cxx | 52 | ||||
-rw-r--r-- | ucb/source/ucp/webdav-neon/webdavdatasupplier.hxx | 7 |
2 files changed, 24 insertions, 35 deletions
diff --git a/ucb/source/ucp/webdav-neon/webdavdatasupplier.cxx b/ucb/source/ucp/webdav-neon/webdavdatasupplier.cxx index ef466898eee0..c33be5174602 100644 --- a/ucb/source/ucp/webdav-neon/webdavdatasupplier.cxx +++ b/ucb/source/ucp/webdav-neon/webdavdatasupplier.cxx @@ -32,6 +32,8 @@ ************************************************************************** *************************************************************************/ +#include <boost/ptr_container/ptr_vector.hpp> +#include <boost/shared_ptr.hpp> #include <osl/diagnose.h> #include <com/sun/star/ucb/OpenMode.hpp> #include <ucbhelper/contentidentifier.hxx> @@ -60,10 +62,11 @@ struct ResultListEntry uno::Reference< ucb::XContentIdentifier > xId; uno::Reference< ucb::XContent > xContent; uno::Reference< sdbc::XRow > xRow; - const ContentProperties* pData; + boost::shared_ptr<ContentProperties> const pData; - ResultListEntry( const ContentProperties* pEntry ) : pData( pEntry ) {}; - ~ResultListEntry() { delete pData; } + ResultListEntry(boost::shared_ptr<ContentProperties> const& pEntry) + : pData(pEntry) + {} }; //========================================================================= @@ -72,7 +75,7 @@ struct ResultListEntry // //========================================================================= -typedef std::vector< ResultListEntry* > ResultList; +typedef boost::ptr_vector<ResultListEntry> ResultList; //========================================================================= // @@ -96,22 +99,8 @@ struct DataSupplier_Impl sal_Int32 nOpenMode ) : m_xContent( rContent ), m_xContext( rxContext ), m_nOpenMode( nOpenMode ), m_bCountFinal( sal_False ), m_bThrowException( sal_False ) {} - ~DataSupplier_Impl(); }; -//========================================================================= -DataSupplier_Impl::~DataSupplier_Impl() -{ - ResultList::const_iterator it = m_aResults.begin(); - ResultList::const_iterator end = m_aResults.end(); - - while ( it != end ) - { - delete (*it); - ++it; - } -} - } //========================================================================= @@ -134,7 +123,6 @@ DataSupplier::DataSupplier( // virtual DataSupplier::~DataSupplier() { - delete m_pImpl; } //========================================================================= @@ -145,7 +133,7 @@ rtl::OUString DataSupplier::queryContentIdentifierString( sal_uInt32 nIndex ) if ( nIndex < m_pImpl->m_aResults.size() ) { - rtl::OUString aId = m_pImpl->m_aResults[ nIndex ]->aId; + rtl::OUString aId = m_pImpl->m_aResults[ nIndex ].aId; if ( !aId.isEmpty() ) { // Already cached. @@ -158,7 +146,7 @@ rtl::OUString DataSupplier::queryContentIdentifierString( sal_uInt32 nIndex ) rtl::OUString aId = m_pImpl->m_xContent->getResourceAccess().getURL(); const ContentProperties& props - = *( m_pImpl->m_aResults[ nIndex ]->pData ); + = *( m_pImpl->m_aResults[ nIndex ].pData ); if ( ( aId.lastIndexOf( '/' ) + 1 ) != aId.getLength() ) aId += rtl::OUString("/"); @@ -168,7 +156,7 @@ rtl::OUString DataSupplier::queryContentIdentifierString( sal_uInt32 nIndex ) if ( props.isTrailingSlash() ) aId += rtl::OUString("/"); - m_pImpl->m_aResults[ nIndex ]->aId = aId; + m_pImpl->m_aResults[ nIndex ].aId = aId; return aId; } return rtl::OUString(); @@ -184,7 +172,7 @@ DataSupplier::queryContentIdentifier( sal_uInt32 nIndex ) if ( nIndex < m_pImpl->m_aResults.size() ) { uno::Reference< ucb::XContentIdentifier > xId - = m_pImpl->m_aResults[ nIndex ]->xId; + = m_pImpl->m_aResults[ nIndex ].xId; if ( xId.is() ) { // Already cached. @@ -197,7 +185,7 @@ DataSupplier::queryContentIdentifier( sal_uInt32 nIndex ) { uno::Reference< ucb::XContentIdentifier > xId = new ::ucbhelper::ContentIdentifier( aId ); - m_pImpl->m_aResults[ nIndex ]->xId = xId; + m_pImpl->m_aResults[ nIndex ].xId = xId; return xId; } return uno::Reference< ucb::XContentIdentifier >(); @@ -213,7 +201,7 @@ DataSupplier::queryContent( sal_uInt32 nIndex ) if ( nIndex < m_pImpl->m_aResults.size() ) { uno::Reference< ucb::XContent > xContent - = m_pImpl->m_aResults[ nIndex ]->xContent; + = m_pImpl->m_aResults[ nIndex ].xContent; if ( xContent.is() ) { // Already cached. @@ -229,7 +217,7 @@ DataSupplier::queryContent( sal_uInt32 nIndex ) { uno::Reference< ucb::XContent > xContent = m_pImpl->m_xContent->getProvider()->queryContent( xId ); - m_pImpl->m_aResults[ nIndex ]->xContent = xContent; + m_pImpl->m_aResults[ nIndex ].xContent = xContent; return xContent; } @@ -298,7 +286,7 @@ uno::Reference< sdbc::XRow > DataSupplier::queryPropertyValues( if ( nIndex < m_pImpl->m_aResults.size() ) { - uno::Reference< sdbc::XRow > xRow = m_pImpl->m_aResults[ nIndex ]->xRow; + uno::Reference< sdbc::XRow > xRow = m_pImpl->m_aResults[ nIndex ].xRow; if ( xRow.is() ) { // Already cached. @@ -312,11 +300,11 @@ uno::Reference< sdbc::XRow > DataSupplier::queryPropertyValues( = Content::getPropertyValues( m_pImpl->m_xContext, getResultSet()->getProperties(), - *(m_pImpl->m_aResults[ nIndex ]->pData), + *(m_pImpl->m_aResults[ nIndex ].pData), rtl::Reference< ::ucbhelper::ContentProviderImplHelper >( m_pImpl->m_xContent->getProvider().get() ), queryContentIdentifierString( nIndex ) ); - m_pImpl->m_aResults[ nIndex ]->xRow = xRow; + m_pImpl->m_aResults[ nIndex ].xRow = xRow; return xRow; } @@ -330,7 +318,7 @@ void DataSupplier::releasePropertyValues( sal_uInt32 nIndex ) osl::Guard< osl::Mutex > aGuard( m_pImpl->m_aMutex ); if ( nIndex < m_pImpl->m_aResults.size() ) - m_pImpl->m_aResults[ nIndex ]->xRow = uno::Reference< sdbc::XRow >(); + m_pImpl->m_aResults[ nIndex ].xRow = uno::Reference< sdbc::XRow >(); } //========================================================================= @@ -444,8 +432,8 @@ sal_Bool DataSupplier::getData() } } - ContentProperties* pContentProperties - = new ContentProperties( rRes ); + boost::shared_ptr<ContentProperties> const + pContentProperties(new ContentProperties(rRes)); // Check resource against open mode. switch ( m_pImpl->m_nOpenMode ) diff --git a/ucb/source/ucp/webdav-neon/webdavdatasupplier.hxx b/ucb/source/ucp/webdav-neon/webdavdatasupplier.hxx index eb0f82c16629..5e97a71f03ec 100644 --- a/ucb/source/ucp/webdav-neon/webdavdatasupplier.hxx +++ b/ucb/source/ucp/webdav-neon/webdavdatasupplier.hxx @@ -26,10 +26,11 @@ * ************************************************************************/ -#ifndef _WEBDAV_UCP_DATASUPPLIER_HXX -#define _WEBDAV_UCP_DATASUPPLIER_HXX +#ifndef WEBDAV_UCP_DATASUPPLIER_HXX +#define WEBDAV_UCP_DATASUPPLIER_HXX #include <vector> +#include <boost/scoped_ptr.hpp> #include <rtl/ref.hxx> #include <ucbhelper/resultset.hxx> @@ -40,7 +41,7 @@ class Content; class DataSupplier : public ucbhelper::ResultSetDataSupplier { - DataSupplier_Impl* m_pImpl; + boost::scoped_ptr<DataSupplier_Impl> m_pImpl; private: sal_Bool getData(); |