/*! @file Defines `boost::hana::or_`. @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_OR_HPP #define BOOST_HANA_OR_HPP #include #include #include #include #include #include namespace boost { namespace hana { //! @cond template constexpr decltype(auto) or_t::operator()(X&& x, Y&& y) const { using Bool = typename hana::tag_of::type; using Or = BOOST_HANA_DISPATCH_IF(or_impl, hana::Logical::value ); #ifndef BOOST_HANA_CONFIG_DISABLE_CONCEPT_CHECKS static_assert(hana::Logical::value, "hana::or_(x, y) requires 'x' to be a Logical"); #endif return Or::apply(static_cast(x), static_cast(y)); } template constexpr decltype(auto) or_t::operator()(X&& x, Y&& ...y) const { return detail::variadic::foldl1( *this, static_cast(x), static_cast(y)... ); } //! @endcond template struct or_impl> : hana::default_ { template static constexpr decltype(auto) apply(X&& x, Y&& y) { //! @todo How to forward `x` here? Since the arguments to `if_` //! can be evaluated in any order, we have to be careful not to //! use `x` in a moved-from state. return hana::if_(x, x, static_cast(y)); } }; }} // end namespace boost::hana #endif // !BOOST_HANA_OR_HPP