[Libreoffice-commits] core.git: writerfilter/source
Miklos Vajna
vmiklos at collabora.co.uk
Fri Sep 29 08:39:06 UTC 2017
writerfilter/source/ooxml/OOXMLPropertySet.cxx | 18 +++++++++++++-----
1 file changed, 13 insertions(+), 5 deletions(-)
New commits:
commit a3c2cce616c3a072ed7f7f8133b88db165ccbc5c
Author: Miklos Vajna <vmiklos at collabora.co.uk>
Date: Fri Sep 29 10:37:38 2017 +0200
Revert "writerfilter: convert loops to range-based-for"
This reverts commit 25cd067a82742210793e39708cc1de9ff84692a7, as it
broke CppunitTest_sw_ooxmlexport4. The comment above the change suggests
that perhaps the usage of indexes was intentional to avoid the usage of
invalidated iterators.
diff --git a/writerfilter/source/ooxml/OOXMLPropertySet.cxx b/writerfilter/source/ooxml/OOXMLPropertySet.cxx
index d4b7d1284af7..bd80f8dc5112 100644
--- a/writerfilter/source/ooxml/OOXMLPropertySet.cxx
+++ b/writerfilter/source/ooxml/OOXMLPropertySet.cxx
@@ -329,8 +329,8 @@ OOXMLValue * OOXMLInputStreamValue::clone() const
*/
OOXMLPropertySet::OOXMLPropertySet()
- : maType("OOXMLPropertySet")
{
+ maType = "OOXMLPropertySet";
}
OOXMLPropertySet::~OOXMLPropertySet()
@@ -343,8 +343,10 @@ void OOXMLPropertySet::resolve(Properties & rHandler)
// be appended to mProperties. I don't think it can cause elements
// to be deleted. But let's check with < here just to be safe that
// the indexing below works.
- for (OOXMLProperty::Pointer_t & pProp : mProperties)
+ for (size_t nIt = 0; nIt < mProperties.size(); ++nIt)
{
+ OOXMLProperty::Pointer_t pProp = mProperties[nIt];
+
if (pProp.get() != nullptr)
pProp->resolve(rHandler);
}
@@ -745,17 +747,23 @@ OOXMLTable::~OOXMLTable()
void OOXMLTable::resolve(Table & rTable)
{
+ Table * pTable = &rTable;
+
int nPos = 0;
- for (const ValuePointer_t & it : mPropertySets)
+ PropertySets_t::iterator it = mPropertySets.begin();
+ PropertySets_t::iterator itEnd = mPropertySets.end();
+
+ while (it != itEnd)
{
writerfilter::Reference<Properties>::Pointer_t pProperties
- (it->getProperties());
+ ((*it)->getProperties());
if (pProperties.get() != nullptr)
- rTable.entry(nPos, pProperties);
+ pTable->entry(nPos, pProperties);
++nPos;
+ ++it;
}
}
More information about the Libreoffice-commits
mailing list