mirror of
				https://github.com/Atmosphere-NX/Atmosphere.git
				synced 2025-10-31 19:25:46 +01:00 
			
		
		
		
	
		
			
				
	
	
		
			98 lines
		
	
	
		
			3.5 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			98 lines
		
	
	
		
			3.5 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| /*
 | |
| 
 | |
| @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_ARGS_HPP
 | |
| #define BOOST_CLBL_TRTS_ARGS_HPP
 | |
| 
 | |
| #include <boost/callable_traits/detail/core.hpp>
 | |
| 
 | |
| namespace boost { namespace callable_traits {
 | |
| 
 | |
| //[ args_hpp
 | |
| /*`[section:ref_args args]
 | |
| [heading Header]
 | |
| ``#include <boost/callable_traits/args.hpp>``
 | |
| [heading Definition]
 | |
| */
 | |
| 
 | |
| template<typename T, template<class...> class Container = std::tuple>
 | |
| using args_t = //see below
 | |
| //<-
 | |
|     detail::try_but_fail_if_invalid<
 | |
|         typename detail::traits<
 | |
|             detail::shallow_decay<T>>::template expand_args<Container>,
 | |
|         cannot_expand_the_parameter_list_of_first_template_argument>;
 | |
| 
 | |
| namespace detail {
 | |
| 
 | |
|     template<typename T, template<class...> class Container,
 | |
|         typename = std::false_type>
 | |
|     struct args_impl {};
 | |
| 
 | |
|     template<typename T, template<class...> class Container>
 | |
|     struct args_impl <T, Container, typename std::is_same<
 | |
|         args_t<T, Container>, detail::dummy>::type>
 | |
|     {
 | |
|         using type = args_t<T, Container>;
 | |
|     };
 | |
| }
 | |
| 
 | |
| //->
 | |
| 
 | |
| template<typename T,
 | |
|     template<class...> class Container = std::tuple>
 | |
| struct args : detail::args_impl<T, Container> {};
 | |
| 
 | |
| //<-
 | |
| }} // namespace boost::callable_traits
 | |
| //->
 | |
| 
 | |
| /*`
 | |
| [heading Constraints]
 | |
| * `T` must be one of the following:
 | |
|   * function
 | |
|   * function pointer
 | |
|   * function reference
 | |
|   * member function pointer
 | |
|   * member data pointer
 | |
|   * user-defined type with a non-overloaded `operator()`
 | |
|   * type of a non-generic lambda
 | |
| 
 | |
| [heading Behavior]
 | |
| * When the constraints are violated, a substitution failure occurs.
 | |
| * When `T` is a function, function pointer, or function reference, the aliased type is `Container` instantiated with the function's parameter types.
 | |
| * When `T` is a function object, the aliased type is `Container` instantiated with the `T::operator()` parameter types.
 | |
| * When `T` is a member function pointer, the aliased type is a `Container` instantiation, where the first type argument is a reference to the parent class of `T`, qualified according to the member qualifiers on `T`, such that the first type is equivalent to `boost::callable_traits::qualified_class_of_t<T>`. The subsequent type arguments, if any, are the parameter types of the member function.
 | |
| * When `T` is a member data pointer, the aliased type is `Container` with a single element, which is a `const` reference to the parent class of `T`.
 | |
| 
 | |
| [heading Input/Output Examples]
 | |
| [table
 | |
|     [[`T`]                              [`args_t<T>`]]
 | |
|     [[`void(float, char, int)`]         [`std::tuple<float, char, int>`]]
 | |
|     [[`void(*)(float, char, int)`]      [`std::tuple<float, char, int`]]
 | |
|     [[`void(&)(float, char, int)`]      [`std::tuple<float, char, int`]]
 | |
|     [[`void(float, char, int) const &&`][`std::tuple<float, char, int>`]]
 | |
|     [[`void(*)()`]                      [`std::tuple<>`]]
 | |
|     [[`void(foo::* const &)(float, char, int)`] [`std::tuple<foo&, float, char, int>`]]
 | |
|     [[`int(foo::*)(int) const`]         [`std::tuple<const foo&, int>`]]
 | |
|     [[`void(foo::*)() volatile &&`]     [`std::tuple<volatile foo &&>`]]
 | |
|     [[`int foo::*`]                     [`std::tuple<const foo&>`]]
 | |
|     [[`const int foo::*`]               [`std::tuple<const foo&>`]]
 | |
|     [[`int`]                            [(substitution failure)]]
 | |
|     [[`int (*const)()`]                 [(substitution failure)]]
 | |
| ]
 | |
| 
 | |
| [heading Example Program]
 | |
| [import ../example/args.cpp]
 | |
| [args]
 | |
| [endsect]
 | |
| */
 | |
| //]
 | |
| 
 | |
| #endif // #ifndef BOOST_CLBL_TRTS_ARGS_HPP
 |