[Libreoffice-commits] core.git: 2 commits - sc/inc sc/source

Michael Stahl mstahl at redhat.com
Fri Nov 6 03:07:01 PST 2015


 sc/inc/rangenam.hxx                        |    8 -
 sc/source/core/tool/dbdata.cxx             |   13 ++-
 sc/source/core/tool/rangenam.cxx           |  119 +++++++++++++++++------------
 sc/source/core/tool/tokenstringcontext.cxx |    5 -
 4 files changed, 89 insertions(+), 56 deletions(-)

New commits:
commit ca551694bdce36dfaa795ffa8910ec86db979c56
Author: Michael Stahl <mstahl at redhat.com>
Date:   Thu Nov 5 23:27:17 2015 +0100

    sc: actually std::set::operator== does not use Compare parameter
    
    ... but operator== of the Key type, so this no longer compares the
    pointed-to objects.
    
    (regression from b5ae7dbc871df57686a603dfa99e8179a0e3a4b8)
    
    Change-Id: I5b0caa9abfa47362383776f7c1d44b73910f15ee

diff --git a/sc/source/core/tool/dbdata.cxx b/sc/source/core/tool/dbdata.cxx
index 2552d40..cdf0ff0 100644
--- a/sc/source/core/tool/dbdata.cxx
+++ b/sc/source/core/tool/dbdata.cxx
@@ -1169,7 +1169,18 @@ size_t ScDBCollection::NamedDBs::size() const
 
 bool ScDBCollection::NamedDBs::operator== (const NamedDBs& r) const
 {
-    return m_DBs == r.m_DBs;
+    if (m_DBs.size() != r.m_DBs.size())
+    {
+        return false;
+    }
+    for (auto iter1 = m_DBs.begin(), iter2 = r.m_DBs.begin(); iter1 != m_DBs.end(); ++iter1, ++iter2)
+    {
+        if (**iter1 != **iter2)
+        {
+            return false;
+        }
+    }
+    return true;
 }
 
 ScDBCollection::AnonDBs::iterator ScDBCollection::AnonDBs::begin()
commit df3ed9c8432359f6d539e2e4a1819dc68d885fdf
Author: Michael Stahl <mstahl at redhat.com>
Date:   Thu Nov 5 22:59:20 2015 +0100

    sc: replace boost::ptr_map with std::map<std::unique_ptr>
    
    Change-Id: Id4f24d8aa3db4e569f3eafa6d4ab32b0a95bf3c9

diff --git a/sc/inc/rangenam.hxx b/sc/inc/rangenam.hxx
index 812af42..426329a 100644
--- a/sc/inc/rangenam.hxx
+++ b/sc/inc/rangenam.hxx
@@ -26,9 +26,9 @@
 #include "scdllapi.h"
 #include "calcmacros.hxx"
 
+#include <memory>
 #include <map>
 #include <vector>
-#include <boost/ptr_container/ptr_map.hpp>
 
 class ScDocument;
 class ScTokenArray;
@@ -170,8 +170,8 @@ class ScRangeName
 {
 private:
     typedef std::vector<ScRangeData*> IndexDataType;
-    typedef ::boost::ptr_map<OUString, ScRangeData> DataType;
-    DataType maData;
+    typedef ::std::map<OUString, std::unique_ptr<ScRangeData>> DataType;
+    DataType m_Data;
     IndexDataType maIndexToData;
 
 public:
@@ -208,7 +208,7 @@ public:
     bool empty() const;
 
     /** Insert object into set.
-        @ATTENTION: The underlying ::boost::ptr_map_adapter::insert(p) takes
+        @ATTENTION: The underlying ::std::map<std::unique_ptr>::insert(p) takes
         ownership of p and if it can't insert it deletes the object! So, if
         this insert here returns false the object where p pointed to is gone!
      */
diff --git a/sc/source/core/tool/rangenam.cxx b/sc/source/core/tool/rangenam.cxx
index faf482d..0b0f50b 100644
--- a/sc/source/core/tool/rangenam.cxx
+++ b/sc/source/core/tool/rangenam.cxx
@@ -23,6 +23,7 @@
 #include <unotools/transliterationwrapper.hxx>
 #include <com/sun/star/sheet/NamedRangeFlag.hpp>
 #include <osl/diagnose.h>
+#include <o3tl/make_unique.hxx>
 
 #include "token.hxx"
 #include "tokenarray.hxx"
@@ -667,7 +668,7 @@ class MatchByRange : public unary_function<ScRangeData, bool>
     const ScRange& mrRange;
 public:
     explicit MatchByRange(const ScRange& rRange) : mrRange(rRange) {}
-    bool operator() ( boost::ptr_container_detail::ref_pair<OUString, const ScRangeData* const> const& r) const
+    bool operator() (std::pair<OUString const, std::unique_ptr<ScRangeData>> const& r) const
     {
         return r.second->IsRangeAtBlock(mrRange);
     }
@@ -677,42 +678,43 @@ public:
 
 ScRangeName::ScRangeName() {}
 
-ScRangeName::ScRangeName(const ScRangeName& r) :
-    maData(r.maData)
+ScRangeName::ScRangeName(const ScRangeName& r)
 {
-    // boost::ptr_map clones and deletes, so each collection needs its own
-    // index to data.
+    for (auto const& it : r.m_Data)
+    {
+        m_Data.insert(std::make_pair(it.first, o3tl::make_unique<ScRangeData>(*it.second)));
+    }
+    // std::map was cloned, so each collection needs its own index to data.
     maIndexToData.resize( r.maIndexToData.size(), NULL);
-    DataType::const_iterator itr = maData.begin(), itrEnd = maData.end();
-    for (; itr != itrEnd; ++itr)
+    for (auto const& itr : m_Data)
     {
-        size_t nPos = itr->second->GetIndex() - 1;
+        size_t nPos = itr.second->GetIndex() - 1;
         if (nPos >= maIndexToData.size())
         {
             OSL_FAIL( "ScRangeName copy-ctor: maIndexToData size doesn't fit");
             maIndexToData.resize(nPos+1, NULL);
         }
-        maIndexToData[nPos] = const_cast<ScRangeData*>(itr->second);
+        maIndexToData[nPos] = const_cast<ScRangeData*>(itr.second.get());
     }
 }
 
 const ScRangeData* ScRangeName::findByRange(const ScRange& rRange) const
 {
     DataType::const_iterator itr = std::find_if(
-        maData.begin(), maData.end(), MatchByRange(rRange));
-    return itr == maData.end() ? NULL : itr->second;
+        m_Data.begin(), m_Data.end(), MatchByRange(rRange));
+    return itr == m_Data.end() ? nullptr : itr->second.get();
 }
 
 ScRangeData* ScRangeName::findByUpperName(const OUString& rName)
 {
-    DataType::iterator itr = maData.find(rName);
-    return itr == maData.end() ? NULL : itr->second;
+    DataType::iterator itr = m_Data.find(rName);
+    return itr == m_Data.end() ? nullptr : itr->second.get();
 }
 
 const ScRangeData* ScRangeName::findByUpperName(const OUString& rName) const
 {
-    DataType::const_iterator itr = maData.find(rName);
-    return itr == maData.end() ? NULL : itr->second;
+    DataType::const_iterator itr = m_Data.find(rName);
+    return itr == m_Data.end() ? nullptr : itr->second.get();
 }
 
 ScRangeData* ScRangeName::findByIndex(sal_uInt16 i) const
@@ -727,81 +729,88 @@ ScRangeData* ScRangeName::findByIndex(sal_uInt16 i) const
 
 void ScRangeName::UpdateReference(sc::RefUpdateContext& rCxt, SCTAB nLocalTab )
 {
-    DataType::iterator itr = maData.begin(), itrEnd = maData.end();
-    for (; itr != itrEnd; ++itr)
-        itr->second->UpdateReference(rCxt, nLocalTab);
+    for (auto const& itr : m_Data)
+    {
+        itr.second->UpdateReference(rCxt, nLocalTab);
+    }
 }
 
 void ScRangeName::UpdateInsertTab( sc::RefUpdateInsertTabContext& rCxt, SCTAB nLocalTab )
 {
-    DataType::iterator itr = maData.begin(), itrEnd = maData.end();
-    for (; itr != itrEnd; ++itr)
-        itr->second->UpdateInsertTab(rCxt, nLocalTab);
+    for (auto const& itr : m_Data)
+    {
+        itr.second->UpdateInsertTab(rCxt, nLocalTab);
+    }
 }
 
 void ScRangeName::UpdateDeleteTab( sc::RefUpdateDeleteTabContext& rCxt, SCTAB nLocalTab )
 {
-    DataType::iterator itr = maData.begin(), itrEnd = maData.end();
-    for (; itr != itrEnd; ++itr)
-        itr->second->UpdateDeleteTab(rCxt, nLocalTab);
+    for (auto const& itr : m_Data)
+    {
+        itr.second->UpdateDeleteTab(rCxt, nLocalTab);
+    }
 }
 
 void ScRangeName::UpdateMoveTab( sc::RefUpdateMoveTabContext& rCxt, SCTAB nLocalTab )
 {
-    DataType::iterator itr = maData.begin(), itrEnd = maData.end();
-    for (; itr != itrEnd; ++itr)
-        itr->second->UpdateMoveTab(rCxt, nLocalTab);
+    for (auto const& itr : m_Data)
+    {
+        itr.second->UpdateMoveTab(rCxt, nLocalTab);
+    }
 }
 
 void ScRangeName::UpdateTranspose(const ScRange& rSource, const ScAddress& rDest)
 {
-    DataType::iterator itr = maData.begin(), itrEnd = maData.end();
-    for (; itr != itrEnd; ++itr)
-        itr->second->UpdateTranspose(rSource, rDest);
+    for (auto const& itr : m_Data)
+    {
+        itr.second->UpdateTranspose(rSource, rDest);
+    }
 }
 
 void ScRangeName::UpdateGrow(const ScRange& rArea, SCCOL nGrowX, SCROW nGrowY)
 {
-    DataType::iterator itr = maData.begin(), itrEnd = maData.end();
-    for (; itr != itrEnd; ++itr)
-        itr->second->UpdateGrow(rArea, nGrowX, nGrowY);
+    for (auto const& itr : m_Data)
+    {
+        itr.second->UpdateGrow(rArea, nGrowX, nGrowY);
+    }
 }
 
 void ScRangeName::CompileUnresolvedXML( sc::CompileFormulaContext& rCxt )
 {
-    DataType::iterator itr = maData.begin(), itrEnd = maData.end();
-    for (; itr != itrEnd; ++itr)
-        itr->second->CompileUnresolvedXML(rCxt);
+    for (auto const& itr : m_Data)
+    {
+        itr.second->CompileUnresolvedXML(rCxt);
+    }
 }
 
 ScRangeName::const_iterator ScRangeName::begin() const
 {
-    return maData.begin();
+    return m_Data.begin();
 }
 
 ScRangeName::const_iterator ScRangeName::end() const
 {
-    return maData.end();
+    return m_Data.end();
 }
 
 ScRangeName::iterator ScRangeName::begin()
 {
-    return maData.begin();
+    return m_Data.begin();
 }
 
 ScRangeName::iterator ScRangeName::end()
 {
-    return maData.end();
+    return m_Data.end();
 }
 
 size_t ScRangeName::size() const
 {
-    return maData.size();
+    return m_Data.size();
 }
 
 bool ScRangeName::empty() const
 {
-    return maData.empty();
+    return m_Data.empty();
 }
 
 bool ScRangeName::insert(ScRangeData* p)
@@ -827,7 +836,8 @@ bool ScRangeName::insert(ScRangeData* p)
 
     OUString aName(p->GetUpperName());
     erase(aName); // ptr_map won't insert it if a duplicate name exists.
-    pair<DataType::iterator, bool> r = maData.insert(aName, p);
+    pair<DataType::iterator, bool> r =
+        m_Data.insert(std::make_pair(aName, std::unique_ptr<ScRangeData>(p)));
     if (r.second)
     {
         // Data inserted.  Store its index for mapping.
@@ -846,15 +856,15 @@ void ScRangeName::erase(const ScRangeData& r)
 
 void ScRangeName::erase(const OUString& rName)
 {
-    DataType::iterator itr = maData.find(rName);
-    if (itr != maData.end())
+    DataType::iterator itr = m_Data.find(rName);
+    if (itr != m_Data.end())
         erase(itr);
 }
 
 void ScRangeName::erase(const iterator& itr)
 {
     sal_uInt16 nIndex = itr->second->GetIndex();
-    maData.erase(itr);
+    m_Data.erase(itr);
     OSL_ENSURE( 0 < nIndex && nIndex <= maIndexToData.size(), "ScRangeName::erase: bad index");
     if (0 < nIndex && nIndex <= maIndexToData.size())
         maIndexToData[nIndex-1] = NULL;
@@ -862,13 +872,26 @@ void ScRangeName::erase(const iterator& itr)
 
 void ScRangeName::clear()
 {
-    maData.clear();
+    m_Data.clear();
     maIndexToData.clear();
 }
 
 bool ScRangeName::operator== (const ScRangeName& r) const
 {
-    return maData == r.maData;
+    if (m_Data.size() != r.m_Data.size())
+    {
+        return false;
+    }
+    for (auto iter1 = m_Data.begin(), iter2 = r.m_Data.begin();
+         iter1 != m_Data.end();
+         ++iter1, ++iter2)
+    {
+        if (!(iter1->first == iter2->first && *iter1->second == *iter2->second))
+        {
+            return false;
+        }
+    }
+    return true;
 }
 
 /* vim:set shiftwidth=4 softtabstop=4 expandtab: */
diff --git a/sc/source/core/tool/tokenstringcontext.cxx b/sc/source/core/tool/tokenstringcontext.cxx
index 4517975..856830c 100644
--- a/sc/source/core/tool/tokenstringcontext.cxx
+++ b/sc/source/core/tool/tokenstringcontext.cxx
@@ -21,10 +21,9 @@ namespace {
 
 void insertAllNames( TokenStringContext::IndexNameMapType& rMap, const ScRangeName& rNames )
 {
-    ScRangeName::const_iterator it = rNames.begin(), itEnd = rNames.end();
-    for (; it != itEnd; ++it)
+    for (auto const& it : rNames)
     {
-        const ScRangeData* pData = it->second;
+        const ScRangeData *const pData = it.second.get();
         rMap.insert(
             TokenStringContext::IndexNameMapType::value_type(pData->GetIndex(), pData->GetName()));
     }


More information about the Libreoffice-commits mailing list