From 8f85595371de1848c9eb85492f04eb0e2bfc9cf5 Mon Sep 17 00:00:00 2001 From: Caolán McNamara Date: Sat, 19 Dec 2015 15:05:00 +0000 Subject: coverity#1343637 Double free and coverity#1343638 Double free coverity#1343639 Double free coverity#1343640 Double free coverity#1343641 Double free Change-Id: I8ce42f03d40fe514f73b3a7eabdb4f323b2239e6 --- xmloff/source/core/xmlictxt.cxx | 18 +++++++----------- xmloff/source/transform/TransformerContext.cxx | 9 +++------ xmloff/source/transform/TransformerContext.hxx | 8 ++++---- 3 files changed, 14 insertions(+), 21 deletions(-) (limited to 'xmloff') diff --git a/xmloff/source/core/xmlictxt.cxx b/xmloff/source/core/xmlictxt.cxx index ff7e4399c911..9629143ae44b 100644 --- a/xmloff/source/core/xmlictxt.cxx +++ b/xmloff/source/core/xmlictxt.cxx @@ -23,31 +23,27 @@ #include #include #include -#include #include #include using namespace ::com::sun::star; SvXMLImportContext::SvXMLImportContext( SvXMLImport& rImp, sal_uInt16 nPrfx, - const OUString& rLName ) : - mrImport( rImp ), - mnPrefix( nPrfx ), - maLocalName( rLName ), - mpRewindMap( nullptr ) + const OUString& rLName ) + : mrImport(rImp) + , mnPrefix(nPrfx) + , maLocalName(rLName) { } -SvXMLImportContext::SvXMLImportContext( SvXMLImport& rImp ) : - mrImport( rImp ), - mnPrefix ( 0 ), - mpRewindMap( nullptr ) +SvXMLImportContext::SvXMLImportContext( SvXMLImport& rImp ) + : mrImport(rImp) + , mnPrefix(0) { } SvXMLImportContext::~SvXMLImportContext() { - delete mpRewindMap; } SvXMLImportContext *SvXMLImportContext::CreateChildContext( sal_uInt16 nPrefix, diff --git a/xmloff/source/transform/TransformerContext.cxx b/xmloff/source/transform/TransformerContext.cxx index 72adbe6b519f..71b2b44a1171 100644 --- a/xmloff/source/transform/TransformerContext.cxx +++ b/xmloff/source/transform/TransformerContext.cxx @@ -22,7 +22,6 @@ #include #include #include -#include #include "TransformerBase.hxx" @@ -47,16 +46,14 @@ bool XMLTransformerContext::HasNamespace( sal_uInt16 nPrefix ) const } XMLTransformerContext::XMLTransformerContext( XMLTransformerBase& rImp, - const OUString& rQName ) : - m_rTransformer( rImp ), - m_aQName( rQName ), - m_pRewindMap( nullptr ) + const OUString& rQName ) + : m_rTransformer(rImp) + , m_aQName(rQName) { } XMLTransformerContext::~XMLTransformerContext() { - delete m_pRewindMap; } rtl::Reference XMLTransformerContext::CreateChildContext( sal_uInt16 nPrefix, diff --git a/xmloff/source/transform/TransformerContext.hxx b/xmloff/source/transform/TransformerContext.hxx index e51443336b81..5d27b3cf63f6 100644 --- a/xmloff/source/transform/TransformerContext.hxx +++ b/xmloff/source/transform/TransformerContext.hxx @@ -24,6 +24,7 @@ #include #include #include +#include #include class SvXMLNamespaceMap; @@ -37,11 +38,10 @@ class XMLTransformerContext : public ::salhelper::SimpleReferenceObject OUString m_aQName; - SvXMLNamespaceMap *m_pRewindMap; + std::unique_ptr m_xRewindMap; - SvXMLNamespaceMap *TakeRewindMap() - { auto p = m_pRewindMap; m_pRewindMap = nullptr; return p; } - void PutRewindMap( SvXMLNamespaceMap *p ) { m_pRewindMap = p; } + SvXMLNamespaceMap *TakeRewindMap() { return m_xRewindMap.release(); } + void PutRewindMap( SvXMLNamespaceMap *p ) { m_xRewindMap.reset(p); } protected: -- cgit