Sprout/sprout/functional/less_equal.hpp

47 lines
1.4 KiB
C++
Raw Normal View History

2013-08-08 09:54:33 +00:00
/*=============================================================================
2014-01-08 07:48:12 +00:00
Copyright (c) 2011-2014 Bolero MURAKAMI
2013-08-08 09:54:33 +00:00
Copyright (C) 2011 RiSK (sscrisk)
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-04-01 13:15:09 +00:00
#ifndef SPROUT_FUNCTIONAL_LESS_EQUAL_HPP
#define SPROUT_FUNCTIONAL_LESS_EQUAL_HPP
#include <utility>
2012-04-01 13:15:09 +00:00
#include <sprout/config.hpp>
#include <sprout/utility/forward.hpp>
2012-04-01 13:15:09 +00:00
namespace sprout {
// 20.8.5 Comparisons
2013-08-26 02:52:18 +00:00
template<typename T = void>
2012-04-01 13:15:09 +00:00
struct less_equal {
public:
typedef T first_argument_type;
typedef T second_argument_type;
typedef bool result_type;
public:
SPROUT_CONSTEXPR bool operator()(T const& x, T const& y) const {
return x <= y;
2012-04-01 13:15:09 +00:00
}
};
template<>
struct less_equal<void> {
public:
typedef void is_transparent;
public:
template<typename T, typename U>
SPROUT_CONSTEXPR decltype(std::declval<T>() <= std::declval<U>())
operator()(T&& x, U&& y)
const SPROUT_NOEXCEPT_EXPR(SPROUT_NOEXCEPT_EXPR(std::declval<T>() <= std::declval<U>()))
{
return SPROUT_FORWARD(T, x) <= SPROUT_FORWARD(U, y);
}
};
2012-04-01 13:15:09 +00:00
} // namespace sprout
#endif // #ifndef SPROUT_FUNCTIONAL_LESS_EQUAL_HPP