diff options
author | Thorsten Behrens <Thorsten.Behrens@CIB.de> | 2017-05-10 00:47:42 +0200 |
---|---|---|
committer | Thorsten Behrens <Thorsten.Behrens@CIB.de> | 2017-05-10 16:24:17 +0200 |
commit | 0a5d6ac82fa0feb6ffeec529b67d85d9646e5e59 (patch) | |
tree | d16b3e873f2926b6d8408fdacc6bb2f1d6054895 /xmlsecurity | |
parent | 09b76cc3b35429c5ca4351f6e79742a0ea2befac (diff) |
xmlsecurity: slightly more modern c++
Change-Id: I680bd57a492fe04dc98f2f61ff292e44e544a483
Reviewed-on: https://gerrit.libreoffice.org/37451
Tested-by: Jenkins <ci@libreoffice.org>
Reviewed-by: Thorsten Behrens <Thorsten.Behrens@CIB.de>
Diffstat (limited to 'xmlsecurity')
-rw-r--r-- | xmlsecurity/inc/framework/saxeventkeeperimpl.hxx | 6 | ||||
-rw-r--r-- | xmlsecurity/source/framework/saxeventkeeperimpl.cxx | 63 |
2 files changed, 29 insertions, 40 deletions
diff --git a/xmlsecurity/inc/framework/saxeventkeeperimpl.hxx b/xmlsecurity/inc/framework/saxeventkeeperimpl.hxx index 7b03800fbefb..160102b2cbb0 100644 --- a/xmlsecurity/inc/framework/saxeventkeeperimpl.hxx +++ b/xmlsecurity/inc/framework/saxeventkeeperimpl.hxx @@ -38,6 +38,7 @@ class ElementMark; class ElementCollector; #include <vector> +#include <memory> class XSECFW_DLLPUBLIC SAXEventKeeperImpl : public cppu::WeakImplHelper < @@ -114,7 +115,7 @@ private: /* * maintains a collection of all ElementMarks. */ - std::vector< const ElementMark* > m_vElementMarkBuffers; + std::vector<std::unique_ptr<const ElementMark>> m_vElementMarkBuffers; /* * maintains a list of new ElementCollectors that will be created @@ -214,6 +215,9 @@ public: SAXEventKeeperImpl(); virtual ~SAXEventKeeperImpl() override; + SAXEventKeeperImpl(const SAXEventKeeperImpl&) = delete; + SAXEventKeeperImpl& operator=(const SAXEventKeeperImpl&) = delete; + /* XSAXEventKeeper */ virtual sal_Int32 SAL_CALL addElementCollector( ) override; virtual void SAL_CALL removeElementCollector( sal_Int32 id ) override; diff --git a/xmlsecurity/source/framework/saxeventkeeperimpl.cxx b/xmlsecurity/source/framework/saxeventkeeperimpl.cxx index 0aa849fcb8da..e744285ef028 100644 --- a/xmlsecurity/source/framework/saxeventkeeperimpl.cxx +++ b/xmlsecurity/source/framework/saxeventkeeperimpl.cxx @@ -69,13 +69,6 @@ SAXEventKeeperImpl::~SAXEventKeeperImpl() */ m_vNewElementCollectors.clear(); m_pNewBlocker = nullptr; - - std::vector< const ElementMark* >::const_iterator ii = m_vElementMarkBuffers.begin(); - for( ; ii != m_vElementMarkBuffers.end(); ++ii ) - { - delete (*ii); - } - m_vElementMarkBuffers.clear(); } void SAXEventKeeperImpl::setCurrentBufferNode(BufferNode* pBufferNode) @@ -182,9 +175,8 @@ BufferNode* SAXEventKeeperImpl::addNewElementMarkBuffers() if (!m_vNewElementCollectors.empty()) { - std::vector< const ElementCollector* >::const_iterator ii = m_vNewElementCollectors.begin(); - - for( ; ii != m_vNewElementCollectors.end(); ++ii ) + for( auto ii = m_vNewElementCollectors.begin(); + ii != m_vNewElementCollectors.end(); ++ii ) { pBufferNode->addElementCollector(*ii); } @@ -219,13 +211,11 @@ ElementMark* SAXEventKeeperImpl::findElementMarkBuffer(sal_Int32 nId) const { ElementMark* pElementMark = nullptr; - std::vector< const ElementMark* >::const_iterator ii = m_vElementMarkBuffers.begin(); - - for( ; ii != m_vElementMarkBuffers.end(); ++ii ) + for( auto&& ii : m_vElementMarkBuffers ) { - if ( nId == (*ii)->getBufferId()) + if ( nId == ii->getBufferId()) { - pElementMark = const_cast<ElementMark*>(*ii); + pElementMark = const_cast<ElementMark*>(ii.get()); break; } } @@ -249,19 +239,18 @@ void SAXEventKeeperImpl::removeElementMarkBuffer(sal_Int32 nId) * nId - the Id of the ElementMark to be removed. ******************************************************************************/ { - std::vector< const ElementMark* >::iterator ii = m_vElementMarkBuffers.begin(); - - for( ; ii != m_vElementMarkBuffers.end(); ++ii ) + for( auto ii = m_vElementMarkBuffers.begin(); + ii != m_vElementMarkBuffers.end(); ++ii ) { if ( nId == (*ii)->getBufferId()) { /* * checks whether this ElementMark still in the new ElementCollect array */ - std::vector< const ElementCollector* >::iterator jj = m_vNewElementCollectors.begin(); - for( ; jj != m_vNewElementCollectors.end(); ++jj ) + for( auto jj = m_vNewElementCollectors.begin(); + jj != m_vNewElementCollectors.end(); ++jj ) { - if ((*ii) == (*jj)) + if (ii->get() == (*jj)) { m_vNewElementCollectors.erase(jj); break; @@ -271,16 +260,11 @@ void SAXEventKeeperImpl::removeElementMarkBuffer(sal_Int32 nId) /* * checks whether this ElementMark is the new Blocker */ - if ((*ii) == m_pNewBlocker) + if (ii->get() == m_pNewBlocker) { m_pNewBlocker = nullptr; } - /* - * destroy the ElementMark - */ - delete (*ii); - m_vElementMarkBuffers.erase( ii ); break; } @@ -353,8 +337,8 @@ OUString SAXEventKeeperImpl::printBufferNode( rc += "\n"; std::vector< const BufferNode* >* vChildren = pBufferNode->getChildren(); - std::vector< const BufferNode* >::const_iterator jj = vChildren->begin(); - for( ; jj != vChildren->end(); ++jj ) + for( auto jj = vChildren->begin(); + jj != vChildren->end(); ++jj ) { rc += printBufferNode(const_cast<BufferNode *>(*jj), nIndent+4); } @@ -387,10 +371,9 @@ cssu::Sequence< cssu::Reference< cssxw::XXMLElementWrapper > > cssu::Sequence < cssu::Reference< cssxw::XXMLElementWrapper > > aChildrenCollection ( vChildren->size()); - std::vector< const BufferNode* >::const_iterator ii = vChildren->begin(); - sal_Int32 nIndex = 0; - for( ; ii != vChildren->end(); ++ii ) + for( auto ii = vChildren->begin(); + ii != vChildren->end(); ++ii ) { aChildrenCollection[nIndex] = (*ii)->getXMLElement(); nIndex++; @@ -531,8 +514,8 @@ void SAXEventKeeperImpl::smashBufferNode( pParent->removeChild(pBufferNode); pBufferNode->setParent(nullptr); - std::vector< const BufferNode * >::const_iterator ii = vChildren->begin(); - for( ; ii != vChildren->end(); ++ii ) + for( auto ii = vChildren->begin(); + ii != vChildren->end(); ++ii ) { const_cast<BufferNode *>(*ii)->setParent(pParent); pParent->addChild(*ii, nIndex); @@ -632,7 +615,7 @@ void SAXEventKeeperImpl::releaseElementMarkBuffer() m_bIsReleasing = true; while (!m_vReleasedElementMarkBuffers.empty()) { - std::vector< sal_Int32 >::iterator pId = m_vReleasedElementMarkBuffers.begin(); + auto pId = m_vReleasedElementMarkBuffers.begin(); sal_Int32 nId = *pId; m_vReleasedElementMarkBuffers.erase( pId ); @@ -820,7 +803,8 @@ sal_Int32 SAXEventKeeperImpl::createElementCollector( bModifyElement, xReferenceResolvedListener); - m_vElementMarkBuffers.push_back( pElementCollector ); + m_vElementMarkBuffers.push_back( + std::unique_ptr<const ElementMark>(pElementCollector)); /* * All the new EC to initial EC array. @@ -850,7 +834,8 @@ sal_Int32 SAXEventKeeperImpl::createBlocker() OSL_ASSERT(m_pNewBlocker == nullptr); m_pNewBlocker = new ElementMark(cssxc::sax::ConstOfSecurityId::UNDEFINEDSECURITYID, nId); - m_vElementMarkBuffers.push_back( m_pNewBlocker ); + m_vElementMarkBuffers.push_back( + std::unique_ptr<const ElementMark>(m_pNewBlocker)); return nId; } @@ -913,7 +898,7 @@ void SAL_CALL SAXEventKeeperImpl::setElement( BufferNode* pBufferNode = pElementMark->getBufferNode(); if (pBufferNode != nullptr) { - bool bIsCurrent = m_xXMLDocument->isCurrent(pBufferNode->getXMLElement()); + const bool bIsCurrent = m_xXMLDocument->isCurrent(pBufferNode->getXMLElement()); pBufferNode->setXMLElement(aElement); if (bIsCurrent) @@ -1072,7 +1057,7 @@ void SAL_CALL SAXEventKeeperImpl::startElement( void SAL_CALL SAXEventKeeperImpl::endElement( const OUString& aName ) { - bool bIsCurrent = m_xXMLDocument->isCurrent(m_pCurrentBufferNode->getXMLElement()); + const bool bIsCurrent = m_xXMLDocument->isCurrent(m_pCurrentBufferNode->getXMLElement()); /* * If there is a following handler and no blocking now, then |