// // traits/static_require.hpp // ~~~~~~~~~~~~~~~~~~~~~~~~~ // // Copyright (c) 2003-2024 Christopher M. Kohlhoff (chris at kohlhoff dot com) // // 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) // #ifndef BOOST_ASIO_TRAITS_STATIC_REQUIRE_HPP #define BOOST_ASIO_TRAITS_STATIC_REQUIRE_HPP #if defined(_MSC_VER) && (_MSC_VER >= 1200) # pragma once #endif // defined(_MSC_VER) && (_MSC_VER >= 1200) #include #include #include #define BOOST_ASIO_HAS_DEDUCED_STATIC_REQUIRE_TRAIT 1 #include namespace boost { namespace asio { namespace traits { template struct static_require_default; template struct static_require; } // namespace traits namespace detail { struct no_static_require { static constexpr bool is_valid = false; }; template struct static_require_trait : conditional_t< is_same>::value && is_same>::value, no_static_require, traits::static_require< decay_t, decay_t> > { }; #if defined(BOOST_ASIO_HAS_WORKING_EXPRESSION_SFINAE) template struct static_require_trait::value() == traits::static_query::value() >> { static constexpr bool is_valid = true; }; #else // defined(BOOST_ASIO_HAS_WORKING_EXPRESSION_SFINAE) false_type static_require_test(...); template true_type static_require_test(T*, Property*, enable_if_t< Property::value() == traits::static_query::value() >* = 0); template struct has_static_require { static constexpr bool value = decltype((static_require_test)( static_cast(0), static_cast(0)))::value; }; template struct static_require_trait, decay_t>::value >> { static constexpr bool is_valid = true; }; #endif // defined(BOOST_ASIO_HAS_WORKING_EXPRESSION_SFINAE) } // namespace detail namespace traits { template struct static_require_default : detail::static_require_trait { }; template struct static_require : static_require_default { }; } // namespace traits } // namespace asio } // namespace boost #include #endif // BOOST_ASIO_TRAITS_STATIC_REQUIRE_HPP