diff options
author | Noel Grandin <noel.grandin@collabora.co.uk> | 2018-09-04 12:30:32 +0200 |
---|---|---|
committer | Noel Grandin <noel.grandin@collabora.co.uk> | 2018-09-05 09:31:40 +0200 |
commit | 7a11e702569ab89eb7722c883ecc3cbbe1a19a65 (patch) | |
tree | ca681a90dd7204642c296a1b3773ffe650455694 /xmlscript/source | |
parent | d02587d79d38997cf74bb0add7dfdf32f26c1fe1 (diff) |
loplugin:useuniqueptr in DocumentHandlerImpl
Change-Id: I722f9a25040ab4ddd8a5d3e5b402c22e5cc3f454
Reviewed-on: https://gerrit.libreoffice.org/60002
Tested-by: Jenkins
Reviewed-by: Noel Grandin <noel.grandin@collabora.co.uk>
Diffstat (limited to 'xmlscript/source')
-rw-r--r-- | xmlscript/source/xml_helper/xml_impctx.cxx | 73 |
1 files changed, 36 insertions, 37 deletions
diff --git a/xmlscript/source/xml_helper/xml_impctx.cxx b/xmlscript/source/xml_helper/xml_impctx.cxx index 0ad0d17b8467..9c1df5f7cd92 100644 --- a/xmlscript/source/xml_helper/xml_impctx.cxx +++ b/xmlscript/source/xml_helper/xml_impctx.cxx @@ -112,7 +112,7 @@ class DocumentHandlerImpl : sal_Int32 m_nLastPrefix_lookup; OUString m_aLastPrefix_lookup; - std::vector< ElementEntry * > m_elements; + std::vector< ElementEntry > m_elements; sal_Int32 m_nSkipElements; std::unique_ptr<Mutex> m_pMutex; @@ -195,7 +195,7 @@ DocumentHandlerImpl::getCurrentElement() const if (m_elements.empty()) return Reference< xml::input::XElement >(); else - return m_elements.back()->m_xElement; + return m_elements.back().m_xElement; } inline sal_Int32 DocumentHandlerImpl::getUidByURI( OUString const & rURI ) @@ -426,7 +426,7 @@ void DocumentHandlerImpl::startElement( Reference< xml::input::XAttributes > xAttributes; sal_Int32 nUid; OUString aLocalName; - ::std::unique_ptr< ElementEntry > elementEntry( new ElementEntry ); + ElementEntry elementEntry; { // guard start: MGuard aGuard( m_pMutex ); @@ -442,7 +442,7 @@ void DocumentHandlerImpl::startElement( // save all namespace ids std::unique_ptr<sal_Int32[]> pUids(new sal_Int32[ nAttribs ]); - OUString * pPrefixes = new OUString[ nAttribs ]; + std::unique_ptr<OUString[]> pPrefixes(new OUString[ nAttribs ]); std::unique_ptr<OUString[]> pLocalNames(new OUString[ nAttribs ]); std::unique_ptr<OUString[]> pQNames(new OUString[ nAttribs ]); @@ -465,7 +465,7 @@ void DocumentHandlerImpl::startElement( pushPrefix( aDefNamespacePrefix, xAttribs->getValueByIndex( nPos ) ); - elementEntry->m_prefixes.push_back( aDefNamespacePrefix ); + elementEntry.m_prefixes.push_back( aDefNamespacePrefix ); pUids[ nPos ] = UID_UNKNOWN; pPrefixes[ nPos ] = g_sXMLNS; pLocalNames[ nPos ] = aDefNamespacePrefix; @@ -474,7 +474,7 @@ void DocumentHandlerImpl::startElement( { OUString aPrefix( rQAttributeName.copy( 6 ) ); pushPrefix( aPrefix, xAttribs->getValueByIndex( nPos ) ); - elementEntry->m_prefixes.push_back( aPrefix ); + elementEntry.m_prefixes.push_back( aPrefix ); pUids[ nPos ] = UID_UNKNOWN; pPrefixes[ nPos ] = g_sXMLNS; pLocalNames[ nPos ] = aPrefix; @@ -507,7 +507,7 @@ void DocumentHandlerImpl::startElement( pUids[ nPos ] = getUidByPrefix( pPrefixes[ nPos ] ); } } - delete[] pPrefixes; + pPrefixes.reset(); // ownership of arrays belongs to attribute list xAttributes = static_cast< xml::input::XAttributes * >( new ExtendedAttributes( @@ -518,33 +518,33 @@ void DocumentHandlerImpl::startElement( // create new child context and append to list if (! m_elements.empty()) - xCurrentElement = m_elements.back()->m_xElement; + xCurrentElement = m_elements.back().m_xElement; } // :guard end if (xCurrentElement.is()) { - elementEntry->m_xElement = + elementEntry.m_xElement = xCurrentElement->startChildElement( nUid, aLocalName, xAttributes ); } else { - elementEntry->m_xElement = + elementEntry.m_xElement = m_xRoot->startRootElement( nUid, aLocalName, xAttributes ); } { MGuard aGuard( m_pMutex ); - if (elementEntry->m_xElement.is()) + if (elementEntry.m_xElement.is()) { - m_elements.push_back( elementEntry.release() ); + m_elements.push_back( std::move(elementEntry) ); } else { ++m_nSkipElements; // pop prefixes - for (sal_Int32 nPos = elementEntry->m_prefixes.size(); nPos--;) - popPrefix(elementEntry->m_prefixes[nPos]); + for (sal_Int32 nPos = elementEntry.m_prefixes.size(); nPos--;) + popPrefix(elementEntry.m_prefixes[nPos]); SAL_INFO("xmlscript.xmlhelper", " no context given on createChildElement() => ignoring element \"" << rQElementName << "\" ..."); } @@ -556,34 +556,33 @@ void DocumentHandlerImpl::endElement( { Reference< xml::input::XElement > xCurrentElement; { - MGuard aGuard( m_pMutex ); - if (m_nSkipElements) - { - --m_nSkipElements; - SAL_INFO("xmlscript.xmlhelper", "### received endElement() for \"" << rQElementName << "\"."); - return; - } + MGuard aGuard( m_pMutex ); + if (m_nSkipElements) + { + --m_nSkipElements; + SAL_INFO("xmlscript.xmlhelper", "### received endElement() for \"" << rQElementName << "\"."); + return; + } - // popping context - SAL_WARN_IF( m_elements.empty(), "xmlscript.xmlhelper", "m_elements is empty" ); - ElementEntry * pEntry = m_elements.back(); - xCurrentElement = pEntry->m_xElement; + // popping context + SAL_WARN_IF( m_elements.empty(), "xmlscript.xmlhelper", "m_elements is empty" ); + ElementEntry& rEntry = m_elements.back(); + xCurrentElement = rEntry.m_xElement; #if OSL_DEBUG_LEVEL > 0 - sal_Int32 nUid; - OUString aLocalName; - getElementName( rQElementName, &nUid, &aLocalName ); - SAL_WARN_IF( xCurrentElement->getLocalName() != aLocalName, "xmlscript.xmlhelper", "xCurrentElement->getLocalName() != aLocalName" ); - SAL_WARN_IF( xCurrentElement->getUid() != nUid, "xmlscript.xmlhelper", "xCurrentElement->getUid() != nUid" ); + sal_Int32 nUid; + OUString aLocalName; + getElementName( rQElementName, &nUid, &aLocalName ); + SAL_WARN_IF( xCurrentElement->getLocalName() != aLocalName, "xmlscript.xmlhelper", "xCurrentElement->getLocalName() != aLocalName" ); + SAL_WARN_IF( xCurrentElement->getUid() != nUid, "xmlscript.xmlhelper", "xCurrentElement->getUid() != nUid" ); #endif - // pop prefixes - for ( sal_Int32 nPos = pEntry->m_prefixes.size(); nPos--; ) - { - popPrefix( pEntry->m_prefixes[ nPos ] ); - } - m_elements.pop_back(); - delete pEntry; + // pop prefixes + for ( sal_Int32 nPos = rEntry.m_prefixes.size(); nPos--; ) + { + popPrefix( rEntry.m_prefixes[ nPos ] ); + } + m_elements.pop_back(); } xCurrentElement->endElement(); } |