MXS-1632: Rename value_type to ValueType

Renamed the type as value_type is too close to the member definition of
value_type in various STL containers. Also formatted with Uncrustify.
This commit is contained in:
Markus Mäkelä
2018-09-14 12:11:10 +03:00
parent 37f693fc0a
commit a2761be953

View File

@ -26,8 +26,8 @@
namespace maxscale namespace maxscale
{ {
template <typename T> template<typename T>
using value_type = typename T::value_type; using ValueType = typename T::value_type;
/** /**
* Calculate sum of members * Calculate sum of members
@ -37,10 +37,13 @@ using value_type = typename T::value_type;
* *
* @return Sum of member values * @return Sum of member values
*/ */
template <typename T, typename R> template<typename T, typename R>
R sum(const T& values, R value_type<T>::*member) R sum(const T& values, R ValueType<T>::* member)
{ {
return std::accumulate(values.begin(), values.end(), R {}, [&](R r, value_type<T> t){ return std::accumulate(values.begin(),
values.end(),
R {},
[&](R r, ValueType<T> t) {
return r + t.*member; return r + t.*member;
}); });
} }
@ -53,10 +56,10 @@ R sum(const T& values, R value_type<T>::*member)
* *
* @return Average of member values * @return Average of member values
*/ */
template <typename T, typename R> template<typename T, typename R>
R avg(const T& values, R value_type<T>::*member) R avg(const T& values, R ValueType<T>::* member)
{ {
return values.empty() ? R{} : sum(values, member) / static_cast<R>(values.size()); return values.empty() ? R {} : sum(values, member) / static_cast<R>(values.size());
} }
/** /**
@ -67,13 +70,15 @@ R avg(const T& values, R value_type<T>::*member)
* *
* @return The minimum value of T::*member in `values` * @return The minimum value of T::*member in `values`
*/ */
template <typename T, typename R> template<typename T, typename R>
R min(const T& values, R value_type<T>::*member) R min(const T& values, R ValueType<T>::* member)
{ {
auto it = std::min_element(values.begin(), values.end(), [&](value_type<T> a, value_type<T> b) { auto it = std::min_element(values.begin(),
values.end(),
[&](ValueType<T> a, ValueType<T> b) {
return a.*member < b.*member; return a.*member < b.*member;
}); });
return it != values.end() ? (*it).*member : R{}; return it != values.end() ? (*it).*member : R {};
} }
/** /**
@ -84,13 +89,15 @@ R min(const T& values, R value_type<T>::*member)
* *
* @return The maximum value of T::*member in `values` * @return The maximum value of T::*member in `values`
*/ */
template <typename T, typename R> template<typename T, typename R>
R max(const T& values, R value_type<T>::*member) R max(const T& values, R ValueType<T>::* member)
{ {
auto it = std::max_element(values.begin(), values.end(), [&](value_type<T> a, value_type<T> b) { auto it = std::max_element(values.begin(),
values.end(),
[&](ValueType<T> a, ValueType<T> b) {
return a.*member < b.*member; return a.*member < b.*member;
}); });
return it != values.end() ? (*it).*member : R{}; return it != values.end() ? (*it).*member : R {};
} }
/** /**
@ -104,12 +111,19 @@ R max(const T& values, R value_type<T>::*member)
* *
* @return Accumulated container * @return Accumulated container
*/ */
template <typename T, typename R, typename Accum> template<typename T, typename R, typename Accum>
R accumulate(const T& values, R value_type<T>::*member, Accum accum) R accumulate(const T& values, R ValueType<T>::* member, Accum accum)
{ {
return std::accumulate(values.begin(), values.end(), R {}, [&](R r, const value_type<T>& t){ return std::accumulate(values.begin(),
values.end(),
R {},
[&](R r, const ValueType<T>& t) {
std::transform(r.begin(), r.end(), (t.*member).begin(), r.begin(), [&](value_type<R> a, value_type<R> b){ std::transform(r.begin(),
r.end(),
(t.*member).begin(),
r.begin(),
[&](ValueType<R> a, ValueType<R> b) {
return accum(a, b); return accum(a, b);
}); });
@ -125,10 +139,10 @@ R accumulate(const T& values, R value_type<T>::*member, Accum accum)
* *
* @return Sum of members * @return Sum of members
*/ */
template <typename T, typename R> template<typename T, typename R>
R sum_element(const T& values, R value_type<T>::*member) R sum_element(const T& values, R ValueType<T>::* member)
{ {
return accumulate(values, member, std::plus<value_type<R>>()); return accumulate(values, member, std::plus<ValueType<R>>());
} }
/** /**
@ -139,14 +153,15 @@ R sum_element(const T& values, R value_type<T>::*member)
* *
* @return Average of members * @return Average of members
*/ */
template <typename T, typename R> template<typename T, typename R>
R avg_element(const T& values, R value_type<T>::*member) R avg_element(const T& values, R ValueType<T>::* member)
{ {
auto result = sum_element(values, member); auto result = sum_element(values, member);
for (auto&& a : result) for (auto&& a : result)
{ {
a /= static_cast<value_type<R>>(values.size()); // Using C-style cast to work around an uncrustify bug
a /= (ValueType<R>)(values.size());
} }
return result; return result;
@ -160,10 +175,12 @@ R avg_element(const T& values, R value_type<T>::*member)
* *
* @return Minimum of members * @return Minimum of members
*/ */
template <typename T, typename R> template<typename T, typename R>
R min_element(const T& values, R value_type<T>::*member) R min_element(const T& values, R ValueType<T>::* member)
{ {
return accumulate(values, member, [](const value_type<R>& a, const value_type<R>& b){ return accumulate(values,
member,
[](const ValueType<R>& a, const ValueType<R>& b) {
return std::min(a, b); return std::min(a, b);
}); });
} }
@ -176,12 +193,13 @@ R min_element(const T& values, R value_type<T>::*member)
* *
* @return Maximum of members * @return Maximum of members
*/ */
template <typename T, typename R> template<typename T, typename R>
R max_element(const T& values, R value_type<T>::*member) R max_element(const T& values, R ValueType<T>::* member)
{ {
return accumulate(values, member, [](const value_type<R>& a, const value_type<R>& b){ return accumulate(values,
member,
[](const ValueType<R>& a, const ValueType<R>& b) {
return std::max(a, b); return std::max(a, b);
}); });
} }
} }