summaryrefslogtreecommitdiff
path: root/xmlscript
diff options
context:
space:
mode:
authorNoel Grandin <noel.grandin@collabora.co.uk>2018-09-04 12:30:32 +0200
committerNoel Grandin <noel.grandin@collabora.co.uk>2018-09-05 09:31:40 +0200
commit7a11e702569ab89eb7722c883ecc3cbbe1a19a65 (patch)
treeca681a90dd7204642c296a1b3773ffe650455694 /xmlscript
parentd02587d79d38997cf74bb0add7dfdf32f26c1fe1 (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')
-rw-r--r--xmlscript/source/xml_helper/xml_impctx.cxx73
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();
}