123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101 |
- // (C) Copyright Edward Diener 2011-2015
- // Use, modification and distribution are subject to 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).
- #if !defined(BOOST_VMD_TO_TUPLE_HPP)
- #define BOOST_VMD_TO_TUPLE_HPP
- #include <boost/vmd/detail/setup.hpp>
- #if BOOST_PP_VARIADICS
- #include <boost/vmd/detail/sequence_to_tuple.hpp>
- /*
- The succeeding comments in this file are in doxygen format.
- */
- /** \file
- */
- /** \def BOOST_VMD_TO_TUPLE(...)
- \brief Converts a sequence to a Boost PP tuple whose elements are the elements of the sequence.
- ... = Variadic parameters.
-
- The first variadic parameter is required and is the sequence to convert.
-
- Further optional variadic parameters can be return type parameters. Return type
- parameters allow each element in the sequence to be converted to a two-element
- tuple where the first tuple element is the type and the second tuple element
- is the element data.
-
- The BOOST_VMD_RETURN_NO_TYPE, the default, does not return the type as part of each
- converted element but just the data. All of the rest return the type and data as the
- two-element tuple. If BOOST_VMD_RETURN_TYPE is specified the specific type of the element
- is returned in the tuple. If BOOST_VMD_RETURN_TYPE_ARRAY is specified an array type is
- returned if the element is an array, else a tuple type is returned if the element is a tuple,
- else the actual type is returned for non-tuple data. If BOOST_VMD_RETURN_TYPE_LIST is specified
- a list type is returned if the element is a list, else a tuple type is returned if the element
- is a tuple, else the actual type is returned for non-tuple data. If BOOST_VMD_RETURN_TYPE_TUPLE
- is specified a tuple type is returned for all tuple-like data, else the actual type is returned
- for non-tuple data. If more than one return type optional parameter is specified the last one
- specified determines the return type.
-
- returns = A Boost PP tuple. If the sequence is empty the return is emptiness
- since an empty tuple does not exist. If an optional return type other
- than BOOST_VMD_RETURN_NO_TYPE is specified the type and the data of
- each element is returned as the tuple element. Otherwise just the data
- is returned as the tuple element, which is the default.
-
- */
- #define BOOST_VMD_TO_TUPLE(...) \
- BOOST_VMD_DETAIL_SEQUENCE_TO_TUPLE(__VA_ARGS__) \
- /**/
- /** \def BOOST_VMD_TO_TUPLE_D(d,...)
- \brief Converts a sequence to a Boost PP tuple whose elements are the elements of the sequence. Re-entrant version.
- d = The next available BOOST_PP_WHILE iteration. <br/>
- ... = Variadic parameters.
-
- The first variadic parameter is required and is the sequence to convert.
-
- Further optional variadic parameters can be return type parameters. Return type
- parameters allow each element in the sequence to be converted to a two-element
- tuple where the first tuple element is the type and the second tuple element
- is the element data.
-
- The BOOST_VMD_RETURN_NO_TYPE, the default, does not return the type as part of each
- converted element but just the data. All of the rest return the type and data as the
- two-element tuple. If BOOST_VMD_RETURN_TYPE is specified the specific type of the element
- is returned in the tuple. If BOOST_VMD_RETURN_TYPE_ARRAY is specified an array type is
- returned if the element is an array, else a tuple type is returned if the element is a tuple,
- else the actual type is returned for non-tuple data. If BOOST_VMD_RETURN_TYPE_LIST is specified
- a list type is returned if the element is a list, else a tuple type is returned if the element
- is a tuple, else the actual type is returned for non-tuple data. If BOOST_VMD_RETURN_TYPE_TUPLE
- is specified a tuple type is returned for all tuple-like data, else the actual type is returned
- for non-tuple data. If more than one return type optional parameter is specified the last one
- specified determines the return type.
-
- returns = A Boost PP tuple. If the sequence is empty the return is emptiness
- since an empty tuple does not exist. If an optional return type other
- than BOOST_VMD_RETURN_NO_TYPE is specified the type and the data of
- each element is returned as the tuple element. Otherwise just the data
- is returned as the tuple element, which is the default.
-
- */
- #define BOOST_VMD_TO_TUPLE_D(d,...) \
- BOOST_VMD_DETAIL_SEQUENCE_TO_TUPLE_D(d,__VA_ARGS__) \
- /**/
- #endif /* BOOST_PP_VARIADICS */
- #endif /* BOOST_VMD_TO_TUPLE_HPP */
|