2012-04-09 16:38:55 +00:00
|
|
|
#ifndef SPROUT_FUNCTIONAL_LOGICAL_AND_HPP
|
|
|
|
#define SPROUT_FUNCTIONAL_LOGICAL_AND_HPP
|
|
|
|
|
2012-10-25 03:50:03 +00:00
|
|
|
#include <utility>
|
2012-04-09 16:38:55 +00:00
|
|
|
#include <sprout/config.hpp>
|
2012-10-25 03:50:03 +00:00
|
|
|
#include <sprout/utility/forward.hpp>
|
2012-04-09 16:38:55 +00:00
|
|
|
|
|
|
|
namespace sprout {
|
|
|
|
// 20.8.6 logical operations
|
2012-10-25 03:50:03 +00:00
|
|
|
template<typename T = void>
|
2012-04-09 16:38:55 +00:00
|
|
|
struct logical_and {
|
|
|
|
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 {
|
2012-05-21 16:06:13 +00:00
|
|
|
return x && y;
|
2012-04-09 16:38:55 +00:00
|
|
|
}
|
|
|
|
};
|
2012-10-25 03:50:03 +00:00
|
|
|
|
|
|
|
template<>
|
|
|
|
struct logical_and<void> {
|
|
|
|
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-09 16:38:55 +00:00
|
|
|
} // namespace sprout
|
|
|
|
|
|
|
|
#endif // #ifndef SPROUT_FUNCTIONAL_LOGICAL_AND_HPP
|