/* Copyright Barrett Adair 2016 Distributed under the Boost Software License, Version 1.0. (See accompanying file LICENSE.md or copy at http ://boost.org/LICENSE_1_0.txt) */ #include #include #include #include #ifndef CT_ASSERT #define CT_ASSERT(...) static_assert(__VA_ARGS__, #__VA_ARGS__) #endif //CT_ASSERT #ifdef CALLABLE_TRAITS_DISABLE_REFERENCE_QUALIFIERS #define LREF #define RREF #else #define LREF & #define RREF && #endif struct foo {}; namespace ct = callable_traits; template void assert_const_qualified() { CT_ASSERT(ct::is_const_member()); CT_ASSERT(ct::is_const_member()); CT_ASSERT(ct::is_const_member()); CT_ASSERT(ct::is_const_member()); CT_ASSERT(ct::is_const_member()); CT_ASSERT(ct::is_const_member()); CT_ASSERT(ct::is_const_member()); CT_ASSERT(ct::is_const_member()); CT_ASSERT(ct::is_const_member()); CT_ASSERT(ct::is_const_member()); CT_ASSERT(ct::is_const_member()); CT_ASSERT(decltype(ct::is_const_member(std::declval()))::value); CT_ASSERT(decltype(ct::is_const_member(std::declval()))::value); CT_ASSERT(decltype(ct::is_const_member(std::declval()))::value); CT_ASSERT(decltype(ct::is_const_member(std::declval()))::value); CT_ASSERT(decltype(ct::is_const_member(std::declval()))::value); CT_ASSERT(decltype(ct::is_const_member(std::declval()))::value); CT_ASSERT(decltype(ct::is_const_member(std::declval()))::value); CT_ASSERT(decltype(ct::is_const_member(std::declval()))::value); CT_ASSERT(decltype(ct::is_const_member(std::declval()))::value); CT_ASSERT(decltype(ct::is_const_member(std::declval()))::value); CT_ASSERT(decltype(ct::is_const_member(std::declval()))::value); } template void assert_not_const_qualified() { CT_ASSERT(!ct::is_const_member()); CT_ASSERT(!ct::is_const_member()); CT_ASSERT(!ct::is_const_member()); CT_ASSERT(!ct::is_const_member()); CT_ASSERT(!ct::is_const_member()); CT_ASSERT(!ct::is_const_member()); CT_ASSERT(!ct::is_const_member()); CT_ASSERT(!ct::is_const_member()); CT_ASSERT(!ct::is_const_member()); CT_ASSERT(!ct::is_const_member()); CT_ASSERT(!ct::is_const_member()); CT_ASSERT(!decltype(ct::is_const_member(std::declval()))::value); CT_ASSERT(!decltype(ct::is_const_member(std::declval()))::value); CT_ASSERT(!decltype(ct::is_const_member(std::declval()))::value); CT_ASSERT(!decltype(ct::is_const_member(std::declval()))::value); CT_ASSERT(!decltype(ct::is_const_member(std::declval()))::value); CT_ASSERT(!decltype(ct::is_const_member(std::declval()))::value); CT_ASSERT(!decltype(ct::is_const_member(std::declval()))::value); CT_ASSERT(!decltype(ct::is_const_member(std::declval()))::value); CT_ASSERT(!decltype(ct::is_const_member(std::declval()))::value); CT_ASSERT(!decltype(ct::is_const_member(std::declval()))::value); CT_ASSERT(!decltype(ct::is_const_member(std::declval()))::value); } int main() { { using f = void(foo::*)(); using l = void(foo::*)() LREF; using r = void(foo::*)() RREF ; using c = void(foo::*)() const; using cl = void(foo::*)() const LREF; using cr = void(foo::*)() const RREF; using v = void(foo::*)() volatile; using vl = void(foo::*)() volatile LREF; using vr = void(foo::*)() volatile RREF; using cv = void(foo::*)() const volatile; using cvl = void(foo::*)() const volatile LREF; using cvr = void(foo::*)() const volatile RREF; assert_not_const_qualified(); assert_not_const_qualified(); assert_not_const_qualified(); assert_const_qualified(); assert_const_qualified(); assert_const_qualified(); assert_not_const_qualified(); assert_not_const_qualified(); assert_not_const_qualified(); assert_const_qualified(); assert_const_qualified(); assert_const_qualified(); } { struct f { int operator()() { return 0; } }; struct l { int operator()() LREF { return 0; } }; struct r { int operator()() RREF { return 0; } }; struct c { int operator()() const { return 0; } }; struct cl { int operator()() const LREF { return 0; } }; struct cr { int operator()() const RREF { return 0; } }; struct v { int operator()() volatile { return 0; } }; struct vl { int operator()() volatile LREF { return 0; } }; struct vr { int operator()() volatile RREF { return 0; } }; struct cv { int operator()() const volatile { return 0; } }; struct cvl { int operator()() const volatile LREF { return 0; } }; struct cvr { int operator()() const volatile RREF { return 0; } }; assert_not_const_qualified(); assert_not_const_qualified(); assert_not_const_qualified(); assert_const_qualified(); assert_const_qualified(); assert_const_qualified(); assert_not_const_qualified(); assert_not_const_qualified(); assert_not_const_qualified(); assert_const_qualified(); assert_const_qualified(); assert_const_qualified(); } #ifndef CALLABLE_TRAITS_DISABLE_ABOMINABLE_FUNCTIONS { using f = void(); using l = void() LREF; using r = void() RREF ; using c = void() const; using cl = void() const LREF; using cr = void() const RREF; using v = void() volatile; using vl = void() volatile LREF; using vr = void() volatile RREF; using cv = void() const volatile; using cvl = void() const volatile LREF; using cvr = void() const volatile RREF; CT_ASSERT(!ct::is_const_member()); CT_ASSERT(!ct::is_const_member()); CT_ASSERT(!ct::is_const_member()); CT_ASSERT(ct::is_const_member()); CT_ASSERT(ct::is_const_member()); CT_ASSERT(ct::is_const_member()); CT_ASSERT(!ct::is_const_member()); CT_ASSERT(!ct::is_const_member()); CT_ASSERT(!ct::is_const_member()); CT_ASSERT(ct::is_const_member()); CT_ASSERT(ct::is_const_member()); CT_ASSERT(ct::is_const_member()); } #endif using f_ptr = void(*)(); assert_not_const_qualified(); assert_not_const_qualified(); assert_not_const_qualified(); assert_not_const_qualified(); }