liuxiaolong
2021-07-20 58d904a328c0d849769b483e901a0be9426b8209
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
#ifndef BOOST_TYPE_TRAITS_DETAIL_MP_DEFER_HPP_INCLUDED
#define BOOST_TYPE_TRAITS_DETAIL_MP_DEFER_HPP_INCLUDED
 
//
//  Copyright 2015 Peter Dimov
//
//  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
//
 
#include <boost/type_traits/integral_constant.hpp>
#include <boost/type_traits/conditional.hpp>
 
namespace boost
{
 
namespace type_traits_detail
{
 
// mp_valid
// implementation by Bruno Dutra (by the name is_evaluable)
 
template<template<class...> class F, class... T>
struct mp_valid_impl
{
    template<template<class...> class G, class = G<T...>>
    static boost::true_type check_s(int);
 
    template<template<class...> class>
    static boost::false_type check_s(...);
 
    using type = decltype(check_s<F>(0));
};
 
template<template<class...> class F, class... T>
using mp_valid = typename mp_valid_impl<F, T...>::type;
 
// mp_defer
 
struct mp_empty
{
};
 
template<template<class...> class F, class... T> struct mp_defer_impl
{
    using type = F<T...>;
};
 
template<template<class...> class F, class... T> using mp_defer = typename boost::conditional<mp_valid<F, T...>::value, mp_defer_impl<F, T...>, mp_empty>::type;
 
} // namespace type_traits_detail
 
} // namespace boost
 
#endif // #ifndef BOOST_TYPE_TRAITS_DETAIL_MP_DEFER_HPP_INCLUDED