// // traits/require_member.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 ASIO_TRAITS_REQUIRE_MEMBER_HPP #define ASIO_TRAITS_REQUIRE_MEMBER_HPP #if defined(_MSC_VER) && (_MSC_VER >= 1200) # pragma once #endif // defined(_MSC_VER) && (_MSC_VER >= 1200) #include "asio/detail/config.hpp" #include "asio/detail/type_traits.hpp" #if defined(ASIO_HAS_WORKING_EXPRESSION_SFINAE) # define ASIO_HAS_DEDUCED_REQUIRE_MEMBER_TRAIT 1 #endif // defined(ASIO_HAS_WORKING_EXPRESSION_SFINAE) #include "asio/detail/push_options.hpp" namespace asio { namespace traits { template struct require_member_default; template struct require_member; } // namespace traits namespace detail { struct no_require_member { static constexpr bool is_valid = false; static constexpr bool is_noexcept = false; }; #if defined(ASIO_HAS_DEDUCED_REQUIRE_MEMBER_TRAIT) template struct require_member_trait : no_require_member { }; template struct require_member_trait().require(declval())) >> { static constexpr bool is_valid = true; using result_type = decltype( declval().require(declval())); static constexpr bool is_noexcept = noexcept(declval().require(declval())); }; #else // defined(ASIO_HAS_DEDUCED_REQUIRE_MEMBER_TRAIT) template struct require_member_trait : conditional_t< is_same>::value && is_same>::value, no_require_member, traits::require_member< decay_t, decay_t> > { }; #endif // defined(ASIO_HAS_DEDUCED_REQUIRE_MEMBER_TRAIT) } // namespace detail namespace traits { template struct require_member_default : detail::require_member_trait { }; template struct require_member : require_member_default { }; } // namespace traits } // namespace asio #include "asio/detail/pop_options.hpp" #endif // ASIO_TRAITS_REQUIRE_MEMBER_HPP