boost/beast/core/detail/type_traits.hpp
// // Copyright (c) 2016-2019 Vinnie Falco (vinnie dot falco at gmail 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) // // Official repository: https://github.com/boostorg/beast // #ifndef BOOST_BEAST_DETAIL_TYPE_TRAITS_HPP #define BOOST_BEAST_DETAIL_TYPE_TRAITS_HPP #include <boost/beast/core/error.hpp> #include <boost/beast/core/detail/is_invocable.hpp> #include <boost/asio/buffer.hpp> #include <boost/mp11/function.hpp> #include <boost/type_traits/make_void.hpp> #include <iterator> #include <tuple> #include <type_traits> #include <string> #include <utility> namespace boost { namespace beast { namespace detail { // variadic min template<class T> T constexpr min(T t) { return t; } template<class T, class...Tn> T constexpr min(T t0, T t1, Tn... tn) { return (t0 < t1) ? (detail::min)(t0, tn...) : (detail::min)(t1, tn...); } template<class U> std::size_t constexpr max_sizeof() { return sizeof(U); } template<class U0, class U1, class... Us> std::size_t constexpr max_sizeof() { return max_sizeof<U0>() > max_sizeof<U1, Us...>() ? max_sizeof<U0>() : max_sizeof<U1, Us...>(); } template<class U> std::size_t constexpr max_alignof() { return alignof(U); } template<class U0, class U1, class... Us> std::size_t constexpr max_alignof() { return max_alignof<U0>() > max_alignof<U1, Us...>() ? max_alignof<U0>() : max_alignof<U1, Us...>(); } // (since C++17) template<class... Ts> using make_void = boost::make_void<Ts...>; template<class... Ts> using void_t = boost::void_t<Ts...>; // (since C++11) missing from g++4.8 template<std::size_t Len, class... Ts> struct aligned_union { static std::size_t constexpr alignment_value = max_alignof<Ts...>(); using type = typename std::aligned_storage< (Len > max_sizeof<Ts...>()) ? Len : (max_sizeof<Ts...>()), alignment_value>::type; }; template<std::size_t Len, class... Ts> using aligned_union_t = typename aligned_union<Len, Ts...>::type; //------------------------------------------------------------------------------ template<class T> void accept_rv(T){} //------------------------------------------------------------------------------ // for span template<class T, class E, class = void> struct is_contiguous_container: std::false_type {}; template<class T, class E> struct is_contiguous_container<T, E, void_t< decltype( std::declval<std::size_t&>() = std::declval<T const&>().size(), std::declval<E*&>() = std::declval<T&>().data()), typename std::enable_if< std::is_same< typename std::remove_cv<E>::type, typename std::remove_cv< typename std::remove_pointer< decltype(std::declval<T&>().data()) >::type >::type >::value >::type>>: std::true_type {}; } // detail } // beast } // boost #endif