2013-08-08 09:54:33 +00:00
|
|
|
/*=============================================================================
|
|
|
|
Copyright (c) 2011-2013 Bolero MURAKAMI
|
|
|
|
https://github.com/bolero-MURAKAMI/Sprout
|
|
|
|
|
|
|
|
Distributed under the Boost Software License, Version 1.0. (See accompanying
|
|
|
|
file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
|
|
|
|
=============================================================================*/
|
2012-06-22 10:14:21 +00:00
|
|
|
#ifndef SPROUT_ARRAY_COMPARISON_HPP
|
|
|
|
#define SPROUT_ARRAY_COMPARISON_HPP
|
|
|
|
|
|
|
|
#include <cstddef>
|
|
|
|
#include <sprout/config.hpp>
|
|
|
|
#include <sprout/array/array.hpp>
|
2013-01-11 19:08:44 +00:00
|
|
|
#include <sprout/algorithm/equal.hpp>
|
|
|
|
#include <sprout/algorithm/lexicographical_compare.hpp>
|
2012-06-22 10:14:21 +00:00
|
|
|
|
|
|
|
namespace sprout {
|
|
|
|
//
|
|
|
|
// operator==
|
|
|
|
// operator!=
|
|
|
|
// operator<
|
|
|
|
// operator>
|
|
|
|
// operator<=
|
|
|
|
// operator>=
|
|
|
|
//
|
|
|
|
template<typename T, std::size_t N>
|
2012-10-05 15:58:56 +00:00
|
|
|
inline SPROUT_CONSTEXPR bool
|
|
|
|
operator==(sprout::array<T, N> const& lhs, sprout::array<T, N> const& rhs) {
|
2013-01-11 19:08:44 +00:00
|
|
|
return sprout::equal(lhs.begin(), lhs.end(), rhs.begin());
|
2012-06-22 10:14:21 +00:00
|
|
|
}
|
|
|
|
template<typename T, std::size_t N>
|
2012-10-05 15:58:56 +00:00
|
|
|
inline SPROUT_CONSTEXPR bool
|
|
|
|
operator!=(sprout::array<T, N> const& lhs, sprout::array<T, N> const& rhs) {
|
2012-06-22 10:14:21 +00:00
|
|
|
return !(lhs == rhs);
|
|
|
|
}
|
|
|
|
template<typename T, std::size_t N>
|
2012-10-05 15:58:56 +00:00
|
|
|
inline SPROUT_CONSTEXPR bool
|
|
|
|
operator<(sprout::array<T, N> const& lhs, sprout::array<T, N> const& rhs) {
|
2013-01-11 19:08:44 +00:00
|
|
|
return sprout::lexicographical_compare(lhs.begin(), lhs.end(), rhs.begin(), rhs.end());
|
2012-06-22 10:14:21 +00:00
|
|
|
}
|
|
|
|
template<typename T, std::size_t N>
|
2012-10-05 15:58:56 +00:00
|
|
|
inline SPROUT_CONSTEXPR bool
|
|
|
|
operator>(sprout::array<T, N> const& lhs, sprout::array<T, N> const& rhs) {
|
2012-06-22 10:14:21 +00:00
|
|
|
return rhs < lhs;
|
|
|
|
}
|
|
|
|
template<typename T, std::size_t N>
|
2012-10-05 15:58:56 +00:00
|
|
|
inline SPROUT_CONSTEXPR bool
|
|
|
|
operator<=(sprout::array<T, N> const& lhs, sprout::array<T, N> const& rhs) {
|
2012-06-22 10:14:21 +00:00
|
|
|
return !(rhs < lhs);
|
|
|
|
}
|
|
|
|
template<typename T, std::size_t N>
|
2012-10-05 15:58:56 +00:00
|
|
|
inline SPROUT_CONSTEXPR bool
|
|
|
|
operator>=(sprout::array<T, N> const& lhs, sprout::array<T, N> const& rhs) {
|
2012-06-22 10:14:21 +00:00
|
|
|
return !(lhs < rhs);
|
|
|
|
}
|
|
|
|
} // namespace sprout
|
|
|
|
|
|
|
|
#endif // #ifndef SPROUT_ARRAY_COMPARISON_HPP
|