diff options
-rw-r--r-- | sc/source/core/tool/scmatrix.cxx | 40 |
1 files changed, 24 insertions, 16 deletions
diff --git a/sc/source/core/tool/scmatrix.cxx b/sc/source/core/tool/scmatrix.cxx index 9fbbbbca80bd..2640bfb617fe 100644 --- a/sc/source/core/tool/scmatrix.cxx +++ b/sc/source/core/tool/scmatrix.cxx @@ -32,6 +32,7 @@ #include <math.h> #include <vector> +#include <limits> #include <mdds/multi_type_matrix.hpp> #include <mdds/multi_type_vector_types.hpp> @@ -942,11 +943,12 @@ public: } }; +const size_t ResultNotSet = std::numeric_limits<size_t>::max(); -template<typename vType> +template<typename _Type> class WalkAndMatchElements : std::unary_function<MatrixImplType::element_block_node_type, void> { - vType maMatchValue; + _Type maMatchValue; MatrixImplType::size_pair_type maSize; size_t mnCol1; size_t mnCol2; @@ -954,8 +956,13 @@ class WalkAndMatchElements : std::unary_function<MatrixImplType::element_block_n size_t mnIndex; public: - WalkAndMatchElements(vType aMatchValue, const MatrixImplType::size_pair_type& aSize, size_t nCol1, size_t nCol2) - : maMatchValue(aMatchValue), maSize(aSize), mnCol1(nCol1), mnCol2(nCol2), mnResult(SCSIZE_MAX), mnIndex(0) {} + WalkAndMatchElements(_Type aMatchValue, const MatrixImplType::size_pair_type& aSize, size_t nCol1, size_t nCol2) : + maMatchValue(aMatchValue), + maSize(aSize), + mnCol1(nCol1), + mnCol2(nCol2), + mnResult(ResultNotSet), + mnIndex(0) {} size_t getMatching() const { return mnResult; } @@ -964,12 +971,11 @@ public: void operator() (const MatrixImplType::element_block_node_type& node) { // early exit if match aleady found - if (mnResult != SCSIZE_MAX) + if (mnResult != ResultNotSet) return; // limit lookup to the requested columns - if (mnIndex >= ( mnCol1 * maSize.row ) && - mnIndex <= ( ( mnCol2 + 1 ) * maSize.row ) ) + if ((mnCol1 * maSize.row) <= mnIndex && mnIndex < ((mnCol2 + 1) * maSize.row)) { mnResult = compare(node); } @@ -979,14 +985,15 @@ public: }; template<> -size_t WalkAndMatchElements<double>::compare(const MatrixImplType::element_block_node_type& node) const { +size_t WalkAndMatchElements<double>::compare(const MatrixImplType::element_block_node_type& node) const +{ size_t nCount = 0; switch (node.type) { case mdds::mtm::element_numeric: { - mdds::mtv::numeric_element_block::const_iterator it = mdds::mtv::numeric_element_block::begin(*node.data); - mdds::mtv::numeric_element_block::const_iterator itEnd = mdds::mtv::numeric_element_block::end(*node.data); + MatrixImplType::numeric_block_type::const_iterator it = MatrixImplType::numeric_block_type::begin(*node.data); + MatrixImplType::numeric_block_type::const_iterator itEnd = MatrixImplType::numeric_block_type::end(*node.data); for (; it != itEnd; ++it, nCount++) { if (*it == maMatchValue) @@ -998,9 +1005,9 @@ size_t WalkAndMatchElements<double>::compare(const MatrixImplType::element_block } case mdds::mtm::element_boolean: { - mdds::mtv::boolean_element_block::const_iterator it = mdds::mtv::boolean_element_block::begin(*node.data); - mdds::mtv::boolean_element_block::const_iterator itEnd = mdds::mtv::boolean_element_block::end(*node.data); - for (; it != itEnd; ++it, nCount++) + MatrixImplType::boolean_block_type::const_iterator it = MatrixImplType::boolean_block_type::begin(*node.data); + MatrixImplType::boolean_block_type::const_iterator itEnd = MatrixImplType::boolean_block_type::end(*node.data); + for (; it != itEnd; ++it, ++nCount) { if (*it == maMatchValue) { @@ -1015,11 +1022,12 @@ size_t WalkAndMatchElements<double>::compare(const MatrixImplType::element_block default: ; } - return SCSIZE_MAX; + return ResultNotSet; } template<> -size_t WalkAndMatchElements<OUString>::compare(const MatrixImplType::element_block_node_type& node) const { +size_t WalkAndMatchElements<OUString>::compare(const MatrixImplType::element_block_node_type& node) const +{ size_t nCount = 0; switch (node.type) { @@ -1042,7 +1050,7 @@ size_t WalkAndMatchElements<OUString>::compare(const MatrixImplType::element_blo default: ; } - return SCSIZE_MAX; + return ResultNotSet; } |