15a83710eSEric Fiselier //===----------------------------------------------------------------------===//
25a83710eSEric Fiselier //
357b08b09SChandler Carruth // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
457b08b09SChandler Carruth // See https://llvm.org/LICENSE.txt for license information.
557b08b09SChandler Carruth // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
65a83710eSEric Fiselier //
75a83710eSEric Fiselier //===----------------------------------------------------------------------===//
85a83710eSEric Fiselier 
95a83710eSEric Fiselier // <tuple>
105a83710eSEric Fiselier 
115a83710eSEric Fiselier // template <class... Types> class tuple;
125a83710eSEric Fiselier 
135a83710eSEric Fiselier // template <class Alloc, class U1, class U2>
145a83710eSEric Fiselier //   tuple(allocator_arg_t, const Alloc& a, pair<U1, U2>&&);
155a83710eSEric Fiselier 
1631cbe0f2SLouis Dionne // UNSUPPORTED: c++03
170a52cd79SEric Fiselier 
185a83710eSEric Fiselier #include <tuple>
195a83710eSEric Fiselier #include <utility>
205a83710eSEric Fiselier #include <memory>
215a83710eSEric Fiselier #include <cassert>
225a83710eSEric Fiselier 
237fc6a556SMarshall Clow #include "test_macros.h"
245a83710eSEric Fiselier #include "allocators.h"
255a83710eSEric Fiselier #include "../alloc_first.h"
265a83710eSEric Fiselier #include "../alloc_last.h"
275a83710eSEric Fiselier 
285a83710eSEric Fiselier struct B
295a83710eSEric Fiselier {
305a83710eSEric Fiselier     int id_;
315a83710eSEric Fiselier 
BB325a83710eSEric Fiselier     explicit B(int i) : id_(i) {}
335a83710eSEric Fiselier 
~BB345a83710eSEric Fiselier     virtual ~B() {}
355a83710eSEric Fiselier };
365a83710eSEric Fiselier 
375a83710eSEric Fiselier struct D
385a83710eSEric Fiselier     : B
395a83710eSEric Fiselier {
DD405a83710eSEric Fiselier     explicit D(int i) : B(i) {}
415a83710eSEric Fiselier };
425a83710eSEric Fiselier 
main(int,char **)432df59c50SJF Bastien int main(int, char**)
445a83710eSEric Fiselier {
455a83710eSEric Fiselier     {
465a83710eSEric Fiselier         typedef std::pair<int, std::unique_ptr<D>> T0;
475a83710eSEric Fiselier         typedef std::tuple<alloc_first, std::unique_ptr<B>> T1;
485a83710eSEric Fiselier         T0 t0(2, std::unique_ptr<D>(new D(3)));
495a83710eSEric Fiselier         alloc_first::allocator_constructed = false;
505a83710eSEric Fiselier         T1 t1(std::allocator_arg, A1<int>(5), std::move(t0));
515a83710eSEric Fiselier         assert(alloc_first::allocator_constructed);
525a83710eSEric Fiselier         assert(std::get<0>(t1) == 2);
535a83710eSEric Fiselier         assert(std::get<1>(t1)->id_ == 3);
545a83710eSEric Fiselier     }
55*a3ab5120SLouis Dionne     {
56*a3ab5120SLouis Dionne         // Test that we can use a tag derived from allocator_arg_t
57*a3ab5120SLouis Dionne         struct DerivedFromAllocatorArgT : std::allocator_arg_t { };
58*a3ab5120SLouis Dionne         DerivedFromAllocatorArgT derived;
59*a3ab5120SLouis Dionne         std::pair<int, int> from(1, 2);
60*a3ab5120SLouis Dionne         std::tuple<int, int> t0(derived, A1<int>(), std::move(from));
61*a3ab5120SLouis Dionne     }
622df59c50SJF Bastien 
632df59c50SJF Bastien     return 0;
645a83710eSEric Fiselier }
65