/* @Copyright Barrett Adair 2015-2017 Distributed under the Boost Software License, Version 1.0. (See accompanying file LICENSE.md or copy at http://boost.org/LICENSE_1_0.txt) */ #ifndef BOOST_CLBL_TRTS_QUALIFIED_class_of_HPP #define BOOST_CLBL_TRTS_QUALIFIED_class_of_HPP #include namespace boost { namespace callable_traits { //[ qualified_class_of_hpp /*` [section:ref_qualified_class_of qualified_class_of] [heading Header] ``#include `` [heading Definition] */ template using qualified_class_of_t = //see below //<- detail::try_but_fail_if_invalid< typename detail::traits>::invoke_type, type_is_not_a_member_pointer>; namespace detail { template struct qualified_class_of_impl {}; template struct qualified_class_of_impl , detail::dummy>::type> { using type = qualified_class_of_t; }; } //-> template struct qualified_class_of : detail::qualified_class_of_impl {}; //<- }} // namespace boost::callable_traits //-> /*` [heading Constraints] * `T` must be a member pointer [heading Behavior] * A substitution failure occurs if the constraints are violated. * If `T` is a member function pointer, the aliased type is the parent class of the member, qualified according to the member qualifiers on `T`. If `T` does not have a member reference qualifier, then the aliased type will be an lvalue reference. * If `T` is a member data pointer, the aliased type is equivalent to `ct::class_of const &`. [heading Input/Output Examples] [table [[`T`] [`qualified_class_of_t`]] [[`void(foo::*)()`] [`foo &`]] [[`void(foo::* volatile)() const`] [`foo const &`]] [[`void(foo::*)() &&`] [`foo &&`]] [[`void(foo::*&)() volatile &&`] [`foo volatile &&`]] [[`int foo::*`] [`foo const &`]] [[`const int foo::*`] [`foo const &`]] ] [heading Example Program] [import ../example/qualified_class_of.cpp] [qualified_class_of] [endsect] */ //] #endif // #ifndef BOOST_CLBL_TRTS_QUALIFIED_class_of_HPP