|
#define | CPP_and && |
|
#define | CPP_and_sfinae && CPP_BOOL(CPP_true), int> = 0, std::enable_if_t< |
|
#define | CPP_and_sfinae_def && CPP_BOOL(CPP_true), int>, std::enable_if_t< |
|
#define | CPP_assert(...) |
|
#define | CPP_assert_msg static_assert |
|
#define | CPP_auto_fun(X) X CPP_AUTO_FUN_IMPL_ |
|
#define | CPP_AUTO_FUN_DECLTYPE_NOEXCEPT_(...) |
| INTERNAL ONLY. More...
|
|
#define | CPP_AUTO_FUN_IMPL_(...) (__VA_ARGS__) CPP_AUTO_FUN_RETURNS_ |
| INTERNAL ONLY.
|
|
#define | CPP_AUTO_FUN_RETURNS_(...) |
| INTERNAL ONLY. More...
|
|
#define | CPP_AUTO_FUN_RETURNS_CONST_0(...) |
| INTERNAL ONLY. More...
|
|
#define | CPP_AUTO_FUN_RETURNS_CONST_1(...) __VA_ARGS__ CPP_AUTO_FUN_RETURNS_CONST_0 |
| INTERNAL ONLY.
|
|
#define | CPP_AUTO_FUN_RETURNS_CONST_2(...) CPP_PP_CAT(CPP_PP_EAT_MUTABLE_, __VA_ARGS__) CPP_AUTO_FUN_RETURNS_CONST_0 |
| INTERNAL ONLY.
|
|
#define | CPP_AUTO_FUN_RETURNS_return |
| INTERNAL ONLY.
|
|
#define | CPP_AUTO_FUN_SELECT_RETURNS_(MAYBE_CONST, ...) |
| INTERNAL ONLY. More...
|
|
#define | CPP_BOOL(...) __VA_ARGS__ |
|
#define | CPP_broken_friend_ret(...) __VA_ARGS__ CPP_PP_EXPAND |
|
#define | CPP_concept META_CONCEPT |
|
#define | CPP_CONCEPT_NAME_(DECL) |
| INTERNAL ONLY. More...
|
|
#define | CPP_CONCEPT_PARAMS_(DECL) CPP_PP_EVAL(CPP_PP_SECOND, CPP_EAT_CONCEPT_(DECL)) |
| INTERNAL ONLY.
|
|
#define | CPP_concept_ref(NAME, ...) CPP_PP_CAT(NAME, _concept_)<__VA_ARGS__> |
|
#define | CPP_ctor(TYPE) TYPE CPP_CTOR_IMPL_1_ |
|
#define | CPP_CTOR_IMPL_1_(...) (__VA_ARGS__) CPP_CTOR_IMPL_2_ |
| INTERNAL ONLY.
|
|
#define | CPP_CTOR_IMPL_2_(...) __VA_ARGS__ ` |
|
#define | CPP_ctor_sfinae(TYPE) |
|
#define | CPP_CTOR_SFINAE_EAT_NOEXCEPT_noexcept(...) |
| INTERNAL ONLY.
|
|
#define | CPP_CTOR_SFINAE_IMPL_1_(...) |
| INTERNAL ONLY. More...
|
|
#define | CPP_CTOR_SFINAE_MAKE_PROBE(FIRST, ...) CPP_PP_CAT(CPP_CTOR_SFINAE_PROBE_NOEXCEPT_, FIRST) |
| INTERNAL ONLY.
|
|
#define | CPP_CTOR_SFINAE_PROBE_NOEXCEPT_noexcept CPP_PP_PROBE(~) |
| INTERNAL ONLY.
|
|
#define | CPP_CTOR_SFINAE_REQUIRES(...) |
| INTERNAL ONLY. More...
|
|
#define | CPP_CTOR_SFINAE_REQUIRES_0(...) |
| INTERNAL ONLY. More...
|
|
#define | CPP_CTOR_SFINAE_REQUIRES_1(...) |
| INTERNAL ONLY. More...
|
|
#define | CPP_CTOR_SFINAE_SHOW_NOEXCEPT_noexcept(...) |
| INTERNAL ONLY. More...
|
|
#define | CPP_CXX_CONCEPTS 201800L |
|
#define | CPP_CXX_VA_OPT 0 |
|
#define | CPP_EAT_CONCEPT_(DECL) CPP_PP_CAT(CPP_EAT_CONCEPT_, DECL) |
| INTERNAL ONLY.
|
|
#define | CPP_EAT_CONCEPT_concept |
| INTERNAL ONLY.
|
|
#define | CPP_fun(X) X CPP_FUN_IMPL_1_ |
|
#define | CPP_FUN_IMPL_1_(...) |
| INTERNAL ONLY. More...
|
|
#define | CPP_FUN_IMPL_2_(...) __VA_ARGS__ ` |
|
#define | CPP_member |
|
#define | CPP_member_sfinae CPP_broken_friend_member |
|
#define | CPP_NOT(...) (!(__VA_ARGS__)) |
|
#define | CPP_PP_CAT(X, ...) CPP_PP_CAT_(X, __VA_ARGS__) |
|
#define | CPP_PP_CAT_(X, ...) X ## __VA_ARGS__ |
|
#define | CPP_PP_CHECK(...) CPP_PP_EXPAND(CPP_PP_CHECK_N(__VA_ARGS__, 0,)) |
|
#define | CPP_PP_CHECK_N(x, n, ...) n |
|
#define | CPP_PP_COMMA() , |
|
#define | CPP_PP_COMMA_IIF(X) CPP_PP_IIF(X)(CPP_PP_EMPTY, CPP_PP_COMMA)() |
|
#define | CPP_PP_COUNT(...) |
|
#define | CPP_PP_COUNT_( _01, _02, _03, _04, _05, _06, _07, _08, _09, _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, N, ...) N |
|
#define | CPP_PP_EAT(...) |
|
#define | CPP_PP_EAT_MUTABLE_mutable |
| INTERNAL ONLY.
|
|
#define | CPP_PP_EMPTY() |
|
#define | CPP_PP_EVAL(X, ...) CPP_PP_EVAL_(X, (__VA_ARGS__)) |
|
#define | CPP_PP_EVAL2(X, ...) CPP_PP_EVAL2_(X, (__VA_ARGS__)) |
|
#define | CPP_PP_EVAL2_(X, ARGS) X ARGS |
|
#define | CPP_PP_EVAL_(X, ARGS) X ARGS |
|
#define | CPP_PP_EXPAND(...) __VA_ARGS__ |
|
#define | CPP_PP_FIRST(LIST) CPP_PP_FIRST_ LIST |
|
#define | CPP_PP_FIRST_(...) __VA_ARGS__ CPP_PP_EAT |
|
#define | CPP_PP_FOR_EACH(M, ...) CPP_PP_FOR_EACH_N(CPP_PP_COUNT(__VA_ARGS__), M, __VA_ARGS__) |
|
#define | CPP_PP_FOR_EACH_1(M, _1) M(_1) |
|
#define | CPP_PP_FOR_EACH_2(M, _1, _2) M(_1), M(_2) |
|
#define | CPP_PP_FOR_EACH_3(M, _1, _2, _3) M(_1), M(_2), M(_3) |
|
#define | CPP_PP_FOR_EACH_4(M, _1, _2, _3, _4) M(_1), M(_2), M(_3), M(_4) |
|
#define | CPP_PP_FOR_EACH_5(M, _1, _2, _3, _4, _5) M(_1), M(_2), M(_3), M(_4), M(_5) |
|
#define | CPP_PP_FOR_EACH_6(M, _1, _2, _3, _4, _5, _6) M(_1), M(_2), M(_3), M(_4), M(_5), M(_6) |
|
#define | CPP_PP_FOR_EACH_7(M, _1, _2, _3, _4, _5, _6, _7) M(_1), M(_2), M(_3), M(_4), M(_5), M(_6), M(_7) |
|
#define | CPP_PP_FOR_EACH_8(M, _1, _2, _3, _4, _5, _6, _7, _8) M(_1), M(_2), M(_3), M(_4), M(_5), M(_6), M(_7), M(_8) |
|
#define | CPP_PP_FOR_EACH_N(N, M, ...) CPP_PP_CAT(CPP_PP_FOR_EACH_, N)(M, __VA_ARGS__) |
|
#define | CPP_PP_IGNORE_CXX2A_COMPAT_BEGIN |
|
#define | CPP_PP_IGNORE_CXX2A_COMPAT_END |
|
#define | CPP_PP_IIF(BIT) CPP_PP_CAT_(CPP_PP_IIF_, BIT) |
|
#define | CPP_PP_IIF_0(TRUE, ...) __VA_ARGS__ |
|
#define | CPP_PP_IIF_1(TRUE, ...) TRUE |
|
#define | CPP_PP_IS_NOT_EMPTY(...) |
|
#define | CPP_PP_IS_PAREN(x) CPP_PP_CHECK(CPP_PP_IS_PAREN_PROBE x) |
|
#define | CPP_PP_IS_PAREN_PROBE(...) CPP_PP_PROBE(~) |
|
#define | CPP_PP_LBRACE() { |
|
#define | CPP_PP_LPAREN ( |
|
#define | CPP_PP_NOT(BIT) CPP_PP_CAT_(CPP_PP_NOT_, BIT) |
|
#define | CPP_PP_NOT_0 1 |
|
#define | CPP_PP_NOT_1 0 |
|
#define | CPP_PP_PROBE(x) x, 1, |
|
#define | CPP_PP_PROBE_CONST_MUTABLE_PROBE_const CPP_PP_PROBE_N(~, 1) |
| INTERNAL ONLY.
|
|
#define | CPP_PP_PROBE_CONST_MUTABLE_PROBE_mutable CPP_PP_PROBE_N(~, 2) |
| INTERNAL ONLY.
|
|
#define | CPP_PP_PROBE_EMPTY() |
|
#define | CPP_PP_PROBE_EMPTY_PROBE_CPP_PP_PROBE_EMPTY CPP_PP_PROBE(~) |
|
#define | CPP_PP_PROBE_N(x, n) x, n, |
|
#define | CPP_PP_RBRACE() } |
|
#define | CPP_PP_RPAREN ) |
|
#define | CPP_PP_SECOND(LIST) CPP_PP_SECOND_ LIST |
|
#define | CPP_PP_SECOND_(...) CPP_PP_EXPAND |
|
#define | CPP_requires(NAME, REQS) |
|
#define | CPP_REQUIRES_AUX_(...) { __VA_ARGS__; } |
| INTERNAL ONLY.
|
|
#define | CPP_requires_ref(NAME, ...) CPP_PP_CAT(NAME, _requires_)<__VA_ARGS__> |
|
#define | CPP_REQUIRES_requires(...) requires(__VA_ARGS__) CPP_REQUIRES_AUX_ |
| INTERNAL ONLY.
|
|
#define | CPP_ret(...) __VA_ARGS__ CPP_RET_AUX_ |
|
#define | CPP_RET_AUX_(...) __VA_ARGS__ ` |
|
#define | CPP_template(...) template<__VA_ARGS__ CPP_TEMPLATE_AUX_ |
|
#define | CPP_TEMPLATE_AUX_(...) |
| INTERNAL ONLY. More...
|
|
#define | CPP_TEMPLATE_AUX_0(...) __VA_ARGS__` |
| INTERNAL ONLY.
|
|
#define | CPP_TEMPLATE_AUX_1(DECL, ...) CPP_concept CPP_CONCEPT_NAME_(DECL) = __VA_ARGS__ |
| INTERNAL ONLY.
|
|
#define | CPP_TEMPLATE_AUX_WHICH_(FIRST, ...) |
| INTERNAL ONLY. More...
|
|
#define | CPP_template_def CPP_template |
|
#define | CPP_template_def_sfinae(...) template<__VA_ARGS__ CPP_TEMPLATE_DEF_SFINAE_AUX_ |
|
#define | CPP_TEMPLATE_DEF_SFINAE_AUX_(...) |
| INTERNAL ONLY. More...
|
|
#define | CPP_TEMPLATE_PROBE_CONCEPT_concept CPP_PP_PROBE(~) |
| INTERNAL ONLY.
|
|
#define | CPP_template_sfinae(...) |
|
#define | CPP_TEMPLATE_SFINAE_AUX_(...) |
| INTERNAL ONLY. More...
|
|
#define | CPP_TEMPLATE_SFINAE_AUX_0(...) |
| INTERNAL ONLY. More...
|
|
#define | CPP_TEMPLATE_SFINAE_AUX_1(DECL, ...) |
| INTERNAL ONLY. More...
|
|
#define | CPP_TEMPLATE_SFINAE_AUX_3_requires |
| INTERNAL ONLY.
|
|
#define | CPP_TEMPLATE_SFINAE_AUX_WHICH_(FIRST, ...) |
| INTERNAL ONLY. More...
|
|
#define | CPP_TEMPLATE_SFINAE_PROBE_CONCEPT_concept CPP_PP_PROBE(~) |
| INTERNAL ONLY.
|
|
#define | CPP_TRUE_FN CPP_true_fn(::concepts::detail::xNil{}) |
|
#define | requires requires ` |
|
|
template<bool... Bs> |
constexpr bool | concepts::and_v |
|
template<typename T , typename U > |
concept | concepts::assignable_from |
|
concept() | concepts::assignable_from< T &, T > |
|
concept() | concepts::assignable_from< T &, T const & > |
|
template<typename T , typename U > |
concept | concepts::assignable_from__requires_ = CPP_REQUIRES_requires ` (T t, U && u) ( t = (U &&) u, requires_<same_as<T, decltype(t = (U &&) u)>> ) |
|
template<typename T > |
concept | concepts::detail::boolean_testable_ |
|
template<typename T > |
concept | concepts::detail::boolean_testable_frag__requires_ = CPP_REQUIRES_requires ` (T && t) ( !(T&&) t, concepts::requires_<boolean_testable_impl_<decltype(!(T&&) t)>> ) |
|
template<typename T > |
concept | concepts::detail::boolean_testable_impl_ = convertible_to<T, bool> |
|
template<typename T , typename U > |
concept | concepts::common_reference_with |
|
template<typename T , typename U > |
concept | concepts::common_with |
|
template<typename T , typename... Args> |
concept | concepts::constructible_from |
|
template<typename From , typename To > |
concept | concepts::convertible_to |
|
concept() | concepts::convertible_to< T const volatile *, U const volatile * > |
|
concept() constructible_from< T, T & > &&constructible_from< T, T const & > &&constructible_from< T, T const > &&convertible_to< T &, T > &&convertible_to< T const &, T > && | concepts::convertible_to< T const, T > |
|
concept() same_as< common_reference_t< T, U >, common_reference_t< U, T > > &&convertible_to< T, common_reference_t< T, U > > && | concepts::convertible_to< U, common_reference_t< T, U > > |
|
template<typename T > |
concept | concepts::copy_constructible |
|
template<typename T > |
concept | concepts::copyable |
|
template<typename T , typename U > |
| concepts::CPP_TEMPLATE_AUX_1 |
|
template<typename T , typename U > |
| concepts::CPP_TEMPLATE_AUX_1 |
|
template<typename T , typename U > |
| concepts::CPP_TEMPLATE_AUX_1 |
|
template<typename T , typename U > |
| concepts::CPP_TEMPLATE_AUX_1 |
|
template<typename T , typename U > |
| concepts::CPP_TEMPLATE_AUX_1 |
|
template<typename T > |
| concepts::CPP_TEMPLATE_AUX_1 |
|
template<typename T > |
| concepts::CPP_TEMPLATE_AUX_1 |
|
template<typename T > |
| concepts::CPP_TEMPLATE_AUX_1 |
|
template<typename T > |
concept | concepts::default_constructible |
|
template<typename T , typename U > |
concept | concepts::derived_from |
|
template<typename T > |
concept | concepts::destructible |
|
template<typename T > |
concept | concepts::equality_comparable |
|
template<typename T , typename U > |
concept | concepts::equality_comparable_with |
|
template<typename T > |
constexpr T | concepts::detail::instance_ = T{} |
|
template<typename T > |
concept | concepts::integral |
|
template<bool B> |
concept | concepts::is_true = B |
|
template<typename T > |
concept | concepts::movable |
|
template<typename T > |
concept | concepts::move_constructible |
|
template<bool... Bs> |
constexpr bool | concepts::or_v |
|
template<typename T , typename U > |
concept | concepts::detail::partially_ordered_with_ |
|
template<typename T , typename U > |
concept | concepts::detail::partially_ordered_with_frag__requires_ = CPP_REQUIRES_requires ` (detail::as_cref_t<T>& t, detail::as_cref_t<U>& u) ( concepts::requires_<boolean_testable_<decltype(t < u)>>, concepts::requires_<boolean_testable_<decltype(t > u)>>, concepts::requires_<boolean_testable_<decltype(t <= u)>>, concepts::requires_<boolean_testable_<decltype(t >= u)>>, concepts::requires_<boolean_testable_<decltype(u < t)>>, concepts::requires_<boolean_testable_<decltype(u > t)>>, concepts::requires_<boolean_testable_<decltype(u <= t)>>, concepts::requires_<boolean_testable_<decltype(u >= t)>> ) |
|
template<typename T > |
concept | concepts::regular |
|
template<bool B> |
constexpr std::enable_if_t< B, int > | concepts::requires_ = 0 |
|
template<typename A , typename B > |
concept | concepts::same_as |
|
template<class T , template< typename... > class Trait, typename... Args> |
concept | concepts::satisfies |
|
template<typename T > |
concept | concepts::semiregular |
|
template<typename T > |
concept | concepts::signed_integral |
|
template<typename T > |
concept | concepts::swappable |
|
template<typename T > |
concept | concepts::swappable__requires_ = CPP_REQUIRES_requires ` (T & t, T & u) ( concepts::swap(t, u) ) |
|
template<typename T , typename U > |
concept | concepts::swappable_with |
|
template<typename T , typename U > |
concept | concepts::swappable_with__requires_ = CPP_REQUIRES_requires ` (T && t, U && u) ( concepts::swap((T &&) t, (T &&) t), concepts::swap((U &&) u, (U &&) u), concepts::swap((U &&) u, (T &&) t), concepts::swap((T &&) t, (U &&) u) ) |
|
template<typename T > |
concept | concepts::totally_ordered |
|
template<typename T , typename U > |
concept | concepts::totally_ordered_with |
|
template<typename... Args> |
concept | concepts::type = true |
|
template<typename T > |
concept | concepts::unsigned_integral |
|
template<typename T , typename U > |
concept | concepts::detail::weakly_equality_comparable_with_ |
|
template<typename T , typename U > |
concept | concepts::detail::weakly_equality_comparable_with_frag__requires_ = CPP_REQUIRES_requires ` (detail::as_cref_t<T> t, detail::as_cref_t<U> u) ( concepts::requires_<boolean_testable_<decltype(t == u)>>, concepts::requires_<boolean_testable_<decltype(t != u)>>, concepts::requires_<boolean_testable_<decltype(u == t)>>, concepts::requires_<boolean_testable_<decltype(u != t)>> ) |
|