Namespaces
Variants
Views
Actions

Difference between revisions of "cpp/utility/tuple/tuple cat"

From cppreference.com
< cpp‎ | utility‎ | tuple
m (fmt with "multi" wiki-templates, no changes in meaning)
(Uses tuple-like.)
Line 10: Line 10:
 
constexpr std::tuple<CTypes...> tuple_cat( Tuples&&... args );
 
constexpr std::tuple<CTypes...> tuple_cat( Tuples&&... args );
 
|dcl3=
 
|dcl3=
template< /*tuple-like*/... Tuples >
+
template< tuple-like... Tuples >
 
constexpr std::tuple<CTypes...> tuple_cat( Tuples&&... args );
 
constexpr std::tuple<CTypes...> tuple_cat( Tuples&&... args );
 
}}
 
}}
 
{{dcl end}}
 
{{dcl end}}
  
Constructs a tuple that is a concatenation of all tuples in {{tt|args}}.
+
Constructs a tuple that is a concatenation of all tuples in {{c|args}}.
  
 
{{rrev multi|until1=c++23
 
{{rrev multi|until1=c++23
 
|rev1=
 
|rev1=
The behavior is undefined if any type in {{c|std::decay_t<Tuples>...}} is not a specialization of {{lc|std::tuple}}. However, an implementation may choose to support types (such as {{lc|std::array}} and {{lc|std::pair}}) that follow the tuple-like protocol.
+
The behavior is undefined if any type in {{c/core|std::decay_t<Tuples>...}} is not a specialization of {{lc|std::tuple}}. However, an implementation may choose to support types (such as {{lc|std::array}} and {{lc|std::pair}}) that follow the tuple-like protocol.
 
|rev2=
 
|rev2=
The types {{c|std::decay_t<Tuples>...}} are constrained to be tuple-like, i.e. each type therein is required to be a specialization of {{lc|std::tuple}} or another type (such as {{lc|std::array}} and {{lc|std::pair}}) that models the tuple-like concept.
+
The types {{c/core|std::decay_t<Tuples>...}} are constrained to be tuple-like, i.e. each type therein is required to be a specialization of {{lc|std::tuple}} or another type (such as {{lc|std::array}} and {{lc|std::pair}}) that models {{rlpi|tuple-like}}.
 
}}
 
}}
  
Line 36: Line 36:
 
|code=
 
|code=
 
#include <iostream>
 
#include <iostream>
#include <tuple>
 
 
#include <string>
 
#include <string>
 +
#include <tuple>
  
 
// helper function to print a tuple of any size
 
// helper function to print a tuple of any size
template <class Tuple, std::size_t N>
+
template<class Tuple, std::size_t N>
 
struct TuplePrinter
 
struct TuplePrinter
 
{
 
{
 
     static void print(const Tuple& t)
 
     static void print(const Tuple& t)
 
     {
 
     {
         TuplePrinter<Tuple, N-1>::print(t);
+
         TuplePrinter<Tuple, N - 1>::print(t);
 
         std::cout << ", " << std::get<N-1>(t);
 
         std::cout << ", " << std::get<N-1>(t);
 
     }
 
     }
 
};
 
};
  
template <class Tuple>
+
template<class Tuple>
 
struct TuplePrinter<Tuple, 1>
 
struct TuplePrinter<Tuple, 1>
 
{
 
{
Line 59: Line 59:
 
};
 
};
  
template <typename... Args, std::enable_if_t<sizeof...(Args) == 0, int> = 0>
+
template<typename... Args, std::enable_if_t<sizeof...(Args) == 0, int> = 0>
 
void print(const std::tuple<Args...>& t)
 
void print(const std::tuple<Args...>& t)
 
{
 
{
Line 65: Line 65:
 
}
 
}
  
template <typename... Args, std::enable_if_t<sizeof...(Args) != 0, int> = 0>
+
template<typename... Args, std::enable_if_t<sizeof...(Args) != 0, int> = 0>
 
void print(const std::tuple<Args...>& t)
 
void print(const std::tuple<Args...>& t)
 
{
 
{

Revision as of 01:32, 16 May 2023

 
 
Utilities library
General utilities
Relational operators (deprecated in C++20)
 
 
Defined in header <tuple>
template< class... Tuples >
std::tuple<CTypes...> tuple_cat( Tuples&&... args );
(since C++11)
(until C++14)
template< class... Tuples >
constexpr std::tuple<CTypes...> tuple_cat( Tuples&&... args );
(since C++14)
(until C++23)
template< tuple-like... Tuples >
constexpr std::tuple<CTypes...> tuple_cat( Tuples&&... args );
(since C++23)

Constructs a tuple that is a concatenation of all tuples in args.

The behavior is undefined if any type in std::decay_t<Tuples>... is not a specialization of std::tuple. However, an implementation may choose to support types (such as std::array and std::pair) that follow the tuple-like protocol.

(until C++23)

The types std::decay_t<Tuples>... are constrained to be tuple-like, i.e. each type therein is required to be a specialization of std::tuple or another type (such as std::array and std::pair) that models tuple-like.

(since C++23)

Contents

Parameters

args - zero or more tuples to concatenate

Return value

A std::tuple object composed of all elements of all argument tuples constructed from std::get<j>(std::forward<Ti>(arg)) for each individual element.

Example

#include <iostream>
#include <string>
#include <tuple>
 
// helper function to print a tuple of any size
template<class Tuple, std::size_t N>
struct TuplePrinter
{
    static void print(const Tuple& t)
    {
        TuplePrinter<Tuple, N - 1>::print(t);
        std::cout << ", " << std::get<N-1>(t);
    }
};
 
template<class Tuple>
struct TuplePrinter<Tuple, 1>
{
    static void print(const Tuple& t)
    {
        std::cout << std::get<0>(t);
    }
};
 
template<typename... Args, std::enable_if_t<sizeof...(Args) == 0, int> = 0>
void print(const std::tuple<Args...>& t)
{
    std::cout << "()\n";
}
 
template<typename... Args, std::enable_if_t<sizeof...(Args) != 0, int> = 0>
void print(const std::tuple<Args...>& t)
{
    std::cout << "(";
    TuplePrinter<decltype(t), sizeof...(Args)>::print(t);
    std::cout << ")\n";
}
// end helper function
 
int main()
{
    std::tuple<int, std::string, float> t1(10, "Test", 3.14);
    int n = 7;
    auto t2 = std::tuple_cat(t1, std::make_tuple("Foo", "bar"), t1, std::tie(n));
    n = 42;
    print(t2);
}

Output:

(10, Test, 3.14, Foo, bar, 10, Test, 3.14, 42)

See also

creates a tuple object of the type defined by the argument types
(function template) [edit]
(C++11)
creates a tuple of lvalue references or unpacks a tuple into individual objects
(function template) [edit]
creates a tuple of forwarding references
(function template) [edit]