/*! @file Defines `boost::hana::greater_equal`. @copyright Louis Dionne 2013-2017 Distributed under the Boost Software License, Version 1.0. (See accompanying file LICENSE.md or copy at http://boost.org/LICENSE_1_0.txt) */ #ifndef BOOST_HANA_GREATER_EQUAL_HPP #define BOOST_HANA_GREATER_EQUAL_HPP #include #include #include #include #include #include #include #include #include // required by fwd decl #include #include namespace boost { namespace hana { //! @cond template constexpr decltype(auto) greater_equal_t::operator()(X&& x, Y&& y) const { using T = typename hana::tag_of::type; using U = typename hana::tag_of::type; using GreaterEqual = BOOST_HANA_DISPATCH_IF( decltype(greater_equal_impl{}), hana::Orderable::value && hana::Orderable::value ); #ifndef BOOST_HANA_CONFIG_DISABLE_CONCEPT_CHECKS static_assert(hana::Orderable::value, "hana::greater_equal(x, y) requires 'x' to be Orderable"); static_assert(hana::Orderable::value, "hana::greater_equal(x, y) requires 'y' to be Orderable"); #endif return GreaterEqual::apply(static_cast(x), static_cast(y)); } //! @endcond template struct greater_equal_impl> : default_ { template static constexpr decltype(auto) apply(X x, Y y) { return hana::not_(hana::less(static_cast(x), static_cast(y))); } }; // Cross-type overload template struct greater_equal_impl::value >> { using C = typename hana::common::type; template static constexpr decltype(auto) apply(X&& x, Y&& y) { return hana::greater_equal(hana::to(static_cast(x)), hana::to(static_cast(y))); } }; }} // end namespace boost::hana #endif // !BOOST_HANA_GREATER_EQUAL_HPP