diff options
-rw-r--r-- | sc/inc/rangenam.hxx | 8 | ||||
-rw-r--r-- | sc/source/core/tool/rangenam.cxx | 119 | ||||
-rw-r--r-- | sc/source/core/tool/tokenstringcontext.cxx | 5 |
3 files changed, 77 insertions, 55 deletions
diff --git a/sc/inc/rangenam.hxx b/sc/inc/rangenam.hxx index 812af42c5744..426329a1818f 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 faf482d71fcc..0b0f50be64a0 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 4517975aeaef..856830c28ff6 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())); } |