|  | // RUN: %clang_cc1 -std=c++2a -verify -ast-dump -ast-dump-decl-types -ast-dump-filter "deduction guide" %s | FileCheck %s --strict-whitespace | 
|  |  | 
|  | template<auto ...> struct X {}; | 
|  | template<template<typename X, X> typename> struct Y {}; | 
|  | template<typename ...> struct Z {}; | 
|  |  | 
|  | template<typename T, typename ...Ts> struct A { | 
|  | template<Ts ...Ns, T *...Ps> A(X<Ps...>, Ts (*...qs)[Ns]); | 
|  | }; | 
|  | int arr1[3], arr2[3]; | 
|  | short arr3[4]; | 
|  | A a(X<&arr1, &arr2>{}, &arr1, &arr2, &arr3); | 
|  | using AT = decltype(a); | 
|  | using AT = A<int[3], int, int, short>; | 
|  |  | 
|  | // CHECK-LABEL: Dumping <deduction guide for A>: | 
|  | // CHECK: FunctionTemplateDecl | 
|  | // CHECK: |-TemplateTypeParmDecl {{.*}} typename depth 0 index 0 T | 
|  | // CHECK: |-TemplateTypeParmDecl {{.*}} typename depth 0 index 1 ... Ts | 
|  | // CHECK: |-NonTypeTemplateParmDecl {{.*}} 'Ts...' depth 0 index 2 ... Ns | 
|  | // CHECK: |-NonTypeTemplateParmDecl {{.*}} 'T *' depth 0 index 3 ... Ps | 
|  | // CHECK: |-CXXDeductionGuideDecl | 
|  | // CHECK: | |-ParmVarDecl {{.*}} 'X<Ps...>' | 
|  | // CHECK: | `-ParmVarDecl {{.*}} 'Ts (*)[Ns]...' pack | 
|  | // CHECK: `-CXXDeductionGuideDecl | 
|  | // CHECK:   |-TemplateArgument type 'int[3]' | 
|  | // CHECK:   |-TemplateArgument pack | 
|  | // CHECK:   | |-TemplateArgument type 'int' | 
|  | // CHECK:   | |-TemplateArgument type 'int' | 
|  | // CHECK:   | `-TemplateArgument type 'short' | 
|  | // CHECK:   |-TemplateArgument pack | 
|  | // CHECK:   | |-TemplateArgument integral '3' | 
|  | // CHECK:   | |-TemplateArgument integral '3' | 
|  | // CHECK:   | `-TemplateArgument integral '(short)4' | 
|  | // CHECK:   |-TemplateArgument pack | 
|  | // CHECK:   | |-TemplateArgument decl | 
|  | // CHECK:   | | `-Var {{.*}} 'arr1' 'int[3]' | 
|  | // CHECK:   | `-TemplateArgument decl | 
|  | // CHECK:   |   `-Var {{.*}} 'arr2' 'int[3]' | 
|  | // CHECK:   |-ParmVarDecl {{.*}} 'X<&arr1, &arr2>' | 
|  | // CHECK:   |-ParmVarDecl {{.*}} 'int (*)[3]' | 
|  | // CHECK:   |-ParmVarDecl {{.*}} 'int (*)[3]' | 
|  | // CHECK:   `-ParmVarDecl {{.*}} 'short (*)[4]' | 
|  | // CHECK: FunctionProtoType {{.*}} 'auto (X<Ps...>, Ts (*)[Ns]...) -> A<T, Ts...>' dependent trailing_return | 
|  | // CHECK: |-InjectedClassNameType {{.*}} 'A<T, Ts...>' dependent | 
|  | // CHECK: |-ElaboratedType {{.*}} 'X<Ps...>' sugar dependent | 
|  | // CHECK: | `-TemplateSpecializationType {{.*}} 'X<Ps...>' dependent | 
|  | // CHECK: |   `-TemplateArgument expr | 
|  | // CHECK: |     `-PackExpansionExpr {{.*}} 'T *' | 
|  | // CHECK: |       `-DeclRefExpr {{.*}} 'T *' NonTypeTemplateParm {{.*}} 'Ps' 'T *' | 
|  | // CHECK: `-PackExpansionType {{.*}} 'Ts (*)[Ns]...' dependent | 
|  | // CHECK:   `-PointerType {{.*}} 'Ts (*)[Ns]' dependent contains_unexpanded_pack | 
|  | // CHECK:     `-ParenType {{.*}} 'Ts[Ns]' sugar dependent contains_unexpanded_pack | 
|  | // CHECK:       `-DependentSizedArrayType {{.*}} 'Ts[Ns]' dependent contains_unexpanded_pack | 
|  | // CHECK:         |-TemplateTypeParmType {{.*}} 'Ts' dependent contains_unexpanded_pack depth 0 index 1 pack | 
|  | // CHECK:         | `-TemplateTypeParm {{.*}} 'Ts' | 
|  | // CHECK:         `-DeclRefExpr {{.*}} 'Ts' NonTypeTemplateParm {{.*}} 'Ns' 'Ts...' | 
|  |  | 
|  | template<typename T, T V> struct B { | 
|  | template<typename U, U W> B(X<W, V>); | 
|  | }; | 
|  | B b(X<nullptr, 'x'>{}); | 
|  | using BT = decltype(b); | 
|  | using BT = B<char, 'x'>; | 
|  |  | 
|  | // CHECK-LABEL: Dumping <deduction guide for B>: | 
|  | // CHECK: FunctionTemplateDecl | 
|  | // CHECK: |-TemplateTypeParmDecl {{.*}} typename depth 0 index 0 T | 
|  | // CHECK: |-NonTypeTemplateParmDecl {{.*}} 'T' depth 0 index 1 V | 
|  | // CHECK: |-TemplateTypeParmDecl {{.*}} typename depth 0 index 2 U | 
|  | // CHECK: |-NonTypeTemplateParmDecl {{.*}} 'U' depth 0 index 3 W | 
|  | // CHECK: |-CXXDeductionGuideDecl {{.*}} 'auto (X<W, V>) -> B<T, V>' | 
|  | // CHECK: | `-ParmVarDecl {{.*}} 'X<W, V>' | 
|  | // CHECK: `-CXXDeductionGuideDecl {{.*}} 'auto (X<nullptr, 'x'>) -> B<char, 'x'>' | 
|  | // CHECK:   |-TemplateArgument type 'char' | 
|  | // CHECK:   |-TemplateArgument integral ''x'' | 
|  | // CHECK:   |-TemplateArgument type 'std::nullptr_t' | 
|  | // CHECK:   |-TemplateArgument nullptr | 
|  | // CHECK:   `-ParmVarDecl {{.*}} 'X<nullptr, 'x'>' | 
|  | // CHECK: FunctionProtoType {{.*}} 'auto (X<W, V>) -> B<T, V>' dependent trailing_return | 
|  | // CHECK: |-InjectedClassNameType {{.*}} 'B<T, V>' dependent | 
|  | // CHECK: `-TemplateSpecializationType {{.*}} 'X<W, V>' dependent | 
|  | // CHECK:   |-TemplateArgument expr | 
|  | // CHECK:   | `-DeclRefExpr {{.*}} 'U' NonTypeTemplateParm {{.*}} 'W' 'U' | 
|  | // CHECK:   `-TemplateArgument expr | 
|  | // CHECK:     `-DeclRefExpr {{.*}} 'T' NonTypeTemplateParm {{.*}} 'V' 'T' | 
|  |  | 
|  | template<typename A> struct C { | 
|  | template<template<typename X, X> typename T, typename U, U V = 0> C(A, Y<T>, U); | 
|  | }; | 
|  | C c(1, Y<B>{}, 2); | 
|  | using CT = decltype(c); | 
|  | using CT = C<int>; | 
|  |  | 
|  | // CHECK-LABEL: Dumping <deduction guide for C>: | 
|  | // CHECK: FunctionTemplateDecl | 
|  | // CHECK: |-TemplateTypeParmDecl {{.*}} typename depth 0 index 0 A | 
|  | // CHECK: |-TemplateTemplateParmDecl {{.*}} depth 0 index 1 T | 
|  | // CHECK: | |-TemplateTypeParmDecl {{.*}} typename depth 1 index 0 X | 
|  | // CHECK: | `-NonTypeTemplateParmDecl {{.*}} 'X' depth 1 index 1 | 
|  | // CHECK: |-TemplateTypeParmDecl {{.*}} typename depth 0 index 2 U | 
|  | // CHECK: |-NonTypeTemplateParmDecl {{.*}} 'U' depth 0 index 3 V | 
|  | // CHECK: | `-TemplateArgument {{.*}} expr | 
|  | // CHECK: |   `-IntegerLiteral {{.*}} 'int' 0 | 
|  | // CHECK: |-CXXDeductionGuideDecl {{.*}} 'auto (A, Y<T>, U) -> C<A>' | 
|  | // CHECK: | |-ParmVarDecl {{.*}} 'A' | 
|  | // CHECK: | |-ParmVarDecl {{.*}} 'Y<T>' | 
|  | // CHECK: | `-ParmVarDecl {{.*}} 'U' | 
|  | // CHECK: `-CXXDeductionGuideDecl {{.*}} 'auto (int, Y<B>, int) -> C<int>' | 
|  | // CHECK:  |-TemplateArgument type 'int' | 
|  | // CHECK:  |-TemplateArgument template 'B' | 
|  | // CHECK:  |-TemplateArgument type 'int' | 
|  | // CHECK:  |-TemplateArgument integral '0' | 
|  | // CHECK:  |-ParmVarDecl {{.*}} 'int' | 
|  | // CHECK:  |-ParmVarDecl {{.*}} 'Y<B>' | 
|  | // CHECK:  `-ParmVarDecl {{.*}} 'int' | 
|  | // CHECK: FunctionProtoType {{.*}} 'auto (A, Y<T>, U) -> C<A>' dependent trailing_return cdecl | 
|  | // CHECK: |-InjectedClassNameType {{.*}} 'C<A>' dependent | 
|  | // CHECK: |-TemplateTypeParmType {{.*}} 'A' dependent depth 0 index 0 | 
|  | // CHECK: | `-TemplateTypeParm {{.*}} 'A' | 
|  | // CHECK: |-ElaboratedType {{.*}} 'Y<T>' sugar dependent | 
|  | // CHECK: | `-TemplateSpecializationType {{.*}} 'Y<T>' dependent | 
|  | // CHECK: |   `-TemplateArgument template | 
|  | // CHECK: `-TemplateTypeParmType {{.*}} 'U' dependent depth 0 index 2 | 
|  |  | 
|  | template<typename ...T> struct D { // expected-note {{candidate}} \ | 
|  | // expected-note {{implicit deduction guide declared as 'template <typename ...T> D(D<T...>) -> D<T...>'}} | 
|  | template<typename... U> using B = int(int (*...p)(T, U)); | 
|  | template<typename U1, typename U2> D(B<U1, U2>*); // expected-note {{candidate}} \ | 
|  | // expected-note {{implicit deduction guide declared as 'template <typename ...T, typename U1, typename U2> D(B<U1, U2> *) -> D<T...>'}} | 
|  | }; | 
|  | int f(int(int, int), int(int, int)); | 
|  | // FIXME: We can't deduce this because we can't deduce through a | 
|  | // SubstTemplateTypeParmPackType. | 
|  | D d = f; // expected-error {{no viable}} | 
|  | using DT = decltype(d); | 
|  | using DT = D<int, int>; | 
|  |  | 
|  | // CHECK-LABEL: Dumping <deduction guide for D>: | 
|  | // CHECK: FunctionTemplateDecl | 
|  | // CHECK: |-TemplateTypeParmDecl {{.*}} typename depth 0 index 0 ... T | 
|  | // CHECK: |-TemplateTypeParmDecl {{.*}} typename depth 0 index 1 U1 | 
|  | // CHECK: |-TemplateTypeParmDecl {{.*}} typename depth 0 index 2 U2 | 
|  | // CHECK: `-CXXDeductionGuideDecl {{.*}} 'auto (B<U1, U2> *) -> D<T...>' | 
|  | // CHECK:   `-ParmVarDecl {{.*}} 'B<U1, U2> *' | 
|  | // CHECK: FunctionProtoType {{.*}} 'auto (B<U1, U2> *) -> D<T...>' dependent trailing_return | 
|  | // CHECK: |-InjectedClassNameType {{.*}} 'D<T...>' dependent | 
|  | // CHECK: `-PointerType {{.*}} 'B<U1, U2> *' dependent | 
|  | // CHECK:   `-TemplateSpecializationType {{.*}} 'B<U1, U2>' sugar dependent alias | 
|  | // CHECK:     |-TemplateArgument type 'U1' | 
|  | // CHECK:     |-TemplateArgument type 'U2' | 
|  | // CHECK:     `-FunctionProtoType {{.*}} 'int (int (*)(T, U)...)' dependent cdecl | 
|  | // CHECK:       |-BuiltinType {{.*}} 'int' | 
|  | // CHECK:       `-PackExpansionType {{.*}} 'int (*)(T, U)...' dependent expansions 2 | 
|  | // CHECK:         `-PointerType {{.*}} 'int (*)(T, U)' dependent contains_unexpanded_pack | 
|  | // CHECK:           `-ParenType {{.*}} 'int (T, U)' sugar dependent contains_unexpanded_pack | 
|  | // CHECK:             `-FunctionProtoType {{.*}} 'int (T, U)' dependent contains_unexpanded_pack cdecl | 
|  | // CHECK:               |-BuiltinType {{.*}} 'int' | 
|  | // CHECK:               |-TemplateTypeParmType {{.*}} 'T' dependent contains_unexpanded_pack depth 0 index 0 pack | 
|  | // CHECK:               | `-TemplateTypeParm {{.*}} 'T' | 
|  | // CHECK:               `-SubstTemplateTypeParmPackType {{.*}} 'U' dependent contains_unexpanded_pack typename depth 1 index 0 ... U | 
|  | // CHECK:                 |-TypeAliasTemplate {{.*}} 'B' | 
|  | // CHECK:                 `-TemplateArgument pack | 
|  | // CHECK:                   |-TemplateArgument type 'U1':'type-parameter-0-1' | 
|  | // CHECK-NOT: Subst | 
|  | // CHECK:                   | `-TemplateTypeParmType | 
|  | // CHECK:                   `-TemplateArgument type 'U2':'type-parameter-0-2' | 
|  | // CHECK-NOT: Subst | 
|  | // CHECK:                     `-TemplateTypeParmType | 
|  |  | 
|  | template<int ...N> struct E { // expected-note {{candidate}} \ | 
|  | expected-note {{implicit deduction guide declared as 'template <int ...N> E(E<N...>) -> E<N...>'}} | 
|  | template<int ...M> using B = Z<X<N, M>...>; | 
|  | template<int M1, int M2> E(B<M1, M2>); // expected-note {{candidate}} \ | 
|  | // expected-note {{implicit deduction guide declared as 'template <int ...N, int M1, int M2> E(B<M1, M2>) -> E<N...>'}}}} | 
|  | }; | 
|  | // FIXME: We can't deduce this because we can't deduce through a | 
|  | // SubstNonTypeTemplateParmPackExpr. | 
|  | E e = Z<X<1, 2>, X<3, 4>>(); // expected-error {{no viable}} | 
|  | using ET = decltype(e); | 
|  | using ET = E<1, 3>; | 
|  |  | 
|  | // CHECK-LABEL: Dumping <deduction guide for E>: | 
|  | // CHECK: FunctionTemplateDecl | 
|  | // CHECK: |-NonTypeTemplateParmDecl [[N:0x[0-9a-f]*]] {{.*}} 'int' depth 0 index 0 ... N | 
|  | // CHECK: |-NonTypeTemplateParmDecl [[M1:0x[0-9a-f]*]] {{.*}} 'int' depth 0 index 1 M1 | 
|  | // CHECK: |-NonTypeTemplateParmDecl [[M2:0x[0-9a-f]*]] {{.*}} 'int' depth 0 index 2 M2 | 
|  | // CHECK: `-CXXDeductionGuideDecl {{.*}} 'auto (B<M1, M2>) -> E<N...>' | 
|  | // CHECK:   `-ParmVarDecl {{.*}} 'B<M1, M2>':'Z<X<N, M>...>' | 
|  | // CHECK: FunctionProtoType {{.*}} 'auto (B<M1, M2>) -> E<N...>' dependent trailing_return | 
|  | // CHECK: |-InjectedClassNameType {{.*}} 'E<N...>' dependent | 
|  | // CHECK: `-TemplateSpecializationType {{.*}} 'B<M1, M2>' sugar dependent alias | 
|  | // CHECK:   |-TemplateArgument expr | 
|  | // CHECK:   | `-DeclRefExpr {{.*}} 'int' NonTypeTemplateParm {{.*}} 'M1' 'int' | 
|  | // CHECK:   |-TemplateArgument expr | 
|  | // CHECK:   | `-DeclRefExpr {{.*}} 'int' NonTypeTemplateParm {{.*}} 'M2' 'int' | 
|  | // CHECK:   `-TemplateSpecializationType {{.*}} 'Z<X<N, M>...>' dependent | 
|  | // CHECK:     `-TemplateArgument type 'X<N, M>...' | 
|  | // CHECK:       `-PackExpansionType {{.*}} 'X<N, M>...' dependent expansions 2 | 
|  | // CHECK:         `-TemplateSpecializationType {{.*}} 'X<N, M>' dependent contains_unexpanded_pack | 
|  | // CHECK:           |-TemplateArgument expr | 
|  | // CHECK-NOT: Subst | 
|  | // CHECK:           | `-DeclRefExpr {{.*}} 'int' NonTypeTemplateParm [[N]] 'N' 'int' | 
|  | // CHECK:           `-TemplateArgument expr | 
|  | // CHECK:             `-SubstNonTypeTemplateParmPackExpr {{.*}} 'int' | 
|  | // CHECK:               |-NonTypeTemplateParmDecl {{.*}} referenced 'int' depth 1 index 0 ... M | 
|  | // CHECK:               `-TemplateArgument pack | 
|  | // CHECK:                 |-TemplateArgument expr | 
|  | // CHECK-NOT: Subst | 
|  | // CHECK:                 | `-DeclRefExpr {{.*}} 'int' NonTypeTemplateParm [[M1]] 'M1' 'int' | 
|  | // CHECK:                 `-TemplateArgument expr | 
|  | // CHECK-NOT: Subst | 
|  | // CHECK:                   `-DeclRefExpr {{.*}} 'int' NonTypeTemplateParm [[M2]] 'M2' 'int' | 
|  |  | 
|  | template <char = 'x'> struct F; | 
|  |  | 
|  | template <char> struct F { | 
|  | template <typename U> | 
|  | requires(false) F(U); | 
|  | template <typename U> | 
|  | requires(true) F(U); | 
|  | }; | 
|  |  | 
|  | F s(0); | 
|  |  | 
|  | // CHECK-LABEL: Dumping <deduction guide for F>: | 
|  | // CHECK: FunctionTemplateDecl | 
|  | // CHECK: |-NonTypeTemplateParmDecl {{.*}} 'char' depth 0 index 0 | 
|  | // CHECK:   `-TemplateArgument {{.*}} expr | 
|  | // CHECK: |   |-inherited from NonTypeTemplateParm {{.*}} depth 0 index 0 'char' | 
|  | // CHECK: |   `-CharacterLiteral {{.*}} 'char' 120 | 
|  | // CHECK: |-TemplateTypeParmDecl {{.*}} typename depth 0 index 1 U | 
|  | // CHECK: |-ParenExpr {{.*}} 'bool' | 
|  | // CHECK: | `-CXXBoolLiteralExpr {{.*}} 'bool' false | 
|  | // CHECK: |-CXXDeductionGuideDecl {{.*}} implicit <deduction guide for F> 'auto (U) -> F<value-parameter-0-0>' | 
|  | // CHECK: | `-ParmVarDecl {{.*}} 'U' | 
|  | // CHECK: `-CXXDeductionGuideDecl {{.*}} implicit used <deduction guide for F> 'auto (int) -> F<>' | 
|  | // CHECK:   |-TemplateArgument integral ''x'' | 
|  | // CHECK:   |-TemplateArgument type 'int' | 
|  | // CHECK:   | `-BuiltinType {{.*}} 'int' | 
|  | // CHECK:   `-ParmVarDecl {{.*}} 'int' | 
|  | // CHECK: FunctionProtoType {{.*}} 'auto (U) -> F<value-parameter-0-0>' dependent trailing_return cdecl | 
|  | // CHECK: |-InjectedClassNameType {{.*}} 'F<value-parameter-0-0>' dependent | 
|  | // CHECK: | `-CXXRecord {{.*}} 'F' | 
|  | // CHECK: `-TemplateTypeParmType {{.*}} 'U' dependent depth 0 index 1 | 
|  |  | 
|  | template<typename T> | 
|  | struct G { T t; }; | 
|  |  | 
|  | G g = {1}; | 
|  | // CHECK-LABEL: Dumping <deduction guide for G>: | 
|  | // CHECK: FunctionTemplateDecl | 
|  | // CHECK: |-CXXDeductionGuideDecl {{.*}} implicit <deduction guide for G> 'auto (T) -> G<T>' aggregate | 
|  | // CHECK: `-CXXDeductionGuideDecl {{.*}} implicit used <deduction guide for G> 'auto (int) -> G<int>' implicit_instantiation aggregate | 
|  |  | 
|  | template<typename X> | 
|  | using AG = G<X>; | 
|  | AG ag = {1}; | 
|  | // Verify that the aggregate deduction guide for alias templates is built. | 
|  | // CHECK-LABEL: Dumping <deduction guide for AG> | 
|  | // CHECK: FunctionTemplateDecl | 
|  | // CHECK: |-CXXDeductionGuideDecl {{.*}} 'auto (X) -> G<X>' | 
|  | // CHECK: `-CXXDeductionGuideDecl {{.*}} 'auto (int) -> G<int>' implicit_instantiation | 
|  | // CHECK:   |-TemplateArgument type 'int' | 
|  | // CHECK:   | `-BuiltinType {{.*}} 'int' | 
|  | // CHECK:   `-ParmVarDecl {{.*}} 'int' | 
|  |  | 
|  | template <typename X = int> | 
|  | using BG = G<int>; | 
|  | BG bg(1.0); | 
|  | // CHECK-LABEL: Dumping <deduction guide for BG> | 
|  | // CHECK: FunctionTemplateDecl {{.*}} implicit <deduction guide for BG> | 
|  | // CHECK: |-CXXDeductionGuideDecl {{.*}} 'auto (int) -> G<int>' aggregate | 
|  |  | 
|  | template <typename D> | 
|  | requires (sizeof(D) == 4) | 
|  | struct Foo { | 
|  | Foo(D); | 
|  | }; | 
|  |  | 
|  | template <typename U> | 
|  | using AFoo = Foo<G<U>>; | 
|  | // Verify that the require-clause from the Foo deduction guide is transformed. | 
|  | // The D occurrence should be rewritten to G<U>. | 
|  | // | 
|  | // CHECK-LABEL: Dumping <deduction guide for AFoo> | 
|  | // CHECK: FunctionTemplateDecl {{.*}} implicit <deduction guide for AFoo> | 
|  | // CHECK-NEXT: |-TemplateTypeParmDecl {{.*}} typename depth 0 index 0 U | 
|  | // CHECK-NEXT: |-BinaryOperator {{.*}} '&&' | 
|  | // CHECK-NEXT: | |-ParenExpr {{.*}} 'bool' | 
|  | // CHECK-NEXT: | | `-BinaryOperator {{.*}} 'bool' '==' | 
|  | // CHECK-NEXT: | |   |-UnaryExprOrTypeTraitExpr {{.*}} 'G<U>' | 
|  | // CHECK-NEXT: | |   `-ImplicitCastExpr {{.*}} | 
|  | // CHECK-NEXT: | |     `-IntegerLiteral {{.*}} | 
|  | // CHECK-NEXT: | `-TypeTraitExpr {{.*}} 'bool' __is_deducible | 
|  | // CHECK-NEXT: |   |-DeducedTemplateSpecializationType {{.*}} 'AFoo' dependent | 
|  | // CHECK-NEXT: |   | `-name: 'AFoo' | 
|  | // CHECK-NEXT: |   |   `-TypeAliasTemplateDecl {{.+}} AFoo | 
|  | // CHECK-NEXT: |   `-TemplateSpecializationType {{.*}} 'Foo<G<U>>' dependent | 
|  | // CHECK:      |-CXXDeductionGuideDecl {{.*}} implicit <deduction guide for AFoo> 'auto (G<U>) -> Foo<G<U>>' | 
|  | // CHECK-NEXT: | `-ParmVarDecl {{.*}} 'G<U>' | 
|  | // CHECK-NEXT: `-CXXDeductionGuideDecl {{.*}} implicit used <deduction guide for AFoo> 'auto (G<int>) -> Foo<G<int>>' implicit_instantiation | 
|  | // CHECK-NEXT:   |-TemplateArgument type 'int' | 
|  | // CHECK-NEXT:   | `-BuiltinType {{.*}} 'int' | 
|  | // CHECK-NEXT:   `-ParmVarDecl {{.*}} 'G<int>' | 
|  |  | 
|  | AFoo aa(G<int>{}); | 
|  |  | 
|  | namespace TTP { | 
|  | template<typename> struct A {}; | 
|  |  | 
|  | template<class T> struct B { | 
|  | template<template <class> typename TT> B(TT<T>); | 
|  | }; | 
|  |  | 
|  | B b(A<int>{}); | 
|  | } // namespace TTP | 
|  |  | 
|  | // CHECK-LABEL: Dumping TTP::<deduction guide for B>: | 
|  | // CHECK-NEXT:  FunctionTemplateDecl 0x{{.+}} <{{.+}}:[[# @LINE - 7]]:5, col:51> | 
|  | // CHECK-NEXT:  |-TemplateTypeParmDecl {{.+}} class depth 0 index 0 T{{$}} | 
|  | // CHECK-NEXT:  |-TemplateTemplateParmDecl {{.+}} depth 0 index 1 TT{{$}} | 
|  | // CHECK-NEXT:  | `-TemplateTypeParmDecl {{.+}} class depth 1 index 0{{$}} | 
|  | // CHECK-NEXT:  |-CXXDeductionGuideDecl {{.+}} 'auto (TT<T>) -> B<T>'{{$}} | 
|  | // CHECK-NEXT:  | `-ParmVarDecl {{.+}} 'TT<T>'{{$}} | 
|  | // CHECK-NEXT:  `-CXXDeductionGuideDecl {{.+}} 'auto (A<int>) -> TTP::B<int>' | 
|  | // CHECK-NEXT:    |-TemplateArgument type 'int' | 
|  | // CHECK-NEXT:    | `-BuiltinType {{.+}} 'int'{{$}} | 
|  | // CHECK-NEXT:    |-TemplateArgument template 'TTP::A'{{$}} | 
|  | // CHECK-NEXT:    | `-ClassTemplateDecl {{.+}} A{{$}} | 
|  | // CHECK-NEXT:    `-ParmVarDecl {{.+}} 'A<int>':'TTP::A<int>'{{$}} | 
|  | // CHECK-NEXT:  FunctionProtoType {{.+}} 'auto (TT<T>) -> B<T>' dependent trailing_return cdecl{{$}} | 
|  | // CHECK-NEXT:  |-InjectedClassNameType {{.+}} 'B<T>' dependent{{$}} | 
|  | // CHECK-NEXT:  | `-CXXRecord {{.+}} 'B'{{$}} | 
|  | // CHECK-NEXT:  `-ElaboratedType {{.+}} 'TT<T>' sugar dependent{{$}} | 
|  | // CHECK-NEXT:    `-TemplateSpecializationType {{.+}} 'TT<T>' dependent{{$}} | 
|  | // CHECK-NEXT:      |-name: 'TT':'template-parameter-0-1' qualified | 
|  | // CHECK-NEXT:      | `-TemplateTemplateParmDecl {{.+}} depth 0 index 1 | 
|  | // CHECK-NEXT:      `-TemplateArgument type 'T':'type-parameter-0-0'{{$}} | 
|  | // CHECK-NEXT:        `-TemplateTypeParmType {{.+}} 'T' dependent depth 0 index 0{{$}} | 
|  | // CHECK-NEXT:          `-TemplateTypeParm {{.+}} 'T'{{$}} | 
|  |  | 
|  | namespace GH64625 { | 
|  |  | 
|  | template <class T> struct X { | 
|  | T t[2]; | 
|  | }; | 
|  |  | 
|  | X x = {{1, 2}}; | 
|  |  | 
|  | // CHECK-LABEL: Dumping GH64625::<deduction guide for X>: | 
|  | // CHECK-NEXT: FunctionTemplateDecl {{.+}} <{{.+}}:[[#@LINE - 7]]:1, col:27> col:27 implicit <deduction guide for X> | 
|  | // CHECK-NEXT: |-TemplateTypeParmDecl {{.+}} <col:11, col:17> col:17 referenced class depth 0 index 0 T | 
|  | // CHECK:      |-CXXDeductionGuideDecl {{.+}} <col:27> col:27 implicit <deduction guide for X> 'auto (T (&&)[2]) -> X<T>' aggregate | 
|  | // CHECK-NEXT: | `-ParmVarDecl {{.+}} <col:27> col:27 'T (&&)[2]' | 
|  | // CHECK-NEXT: `-CXXDeductionGuideDecl {{.+}} <col:27> col:27 implicit used <deduction guide for X> 'auto (int (&&)[2]) -> GH64625::X<int>' implicit_instantiation aggregate | 
|  | // CHECK-NEXT:  |-TemplateArgument type 'int' | 
|  | // CHECK-NEXT:  | `-BuiltinType {{.+}} 'int' | 
|  | // CHECK-NEXT:  `-ParmVarDecl {{.+}} <col:27> col:27 'int (&&)[2]' | 
|  | // CHECK-NEXT: FunctionProtoType {{.+}} 'auto (T (&&)[2]) -> X<T>' dependent trailing_return | 
|  | // CHECK-NEXT: |-InjectedClassNameType {{.+}} 'X<T>' dependent | 
|  | // CHECK-NEXT: | `-CXXRecord {{.+}} 'X' | 
|  | // CHECK-NEXT: `-RValueReferenceType {{.+}} 'T (&&)[2]' dependent | 
|  | // CHECK-NEXT:  `-ConstantArrayType {{.+}} 'T[2]' dependent 2 | 
|  | // CHECK-NEXT:    `-TemplateTypeParmType {{.+}} 'T' dependent depth 0 index 0 | 
|  | // CHECK-NEXT:      `-TemplateTypeParm {{.+}} 'T' | 
|  |  | 
|  | template <class T, class U> struct TwoArrays { | 
|  | T t[2]; | 
|  | U u[3]; | 
|  | }; | 
|  |  | 
|  | TwoArrays ta = {{1, 2}, {3, 4, 5}}; | 
|  | // CHECK-LABEL: Dumping GH64625::<deduction guide for TwoArrays>: | 
|  | // CHECK-NEXT: FunctionTemplateDecl {{.+}} <{{.+}}:[[#@LINE - 7]]:1, col:36> col:36 implicit <deduction guide for TwoArrays> | 
|  | // CHECK-NEXT: |-TemplateTypeParmDecl {{.+}} <col:11, col:17> col:17 referenced class depth 0 index 0 T | 
|  | // CHECK-NEXT: |-TemplateTypeParmDecl {{.+}} <col:20, col:26> col:26 referenced class depth 0 index 1 U | 
|  | // CHECK:      |-CXXDeductionGuideDecl {{.+}} <col:36> col:36 implicit <deduction guide for TwoArrays> 'auto (T (&&)[2], U (&&)[3]) -> TwoArrays<T, U>' aggregate | 
|  | // CHECK-NEXT: | |-ParmVarDecl {{.+}} <col:36> col:36 'T (&&)[2]' | 
|  | // CHECK-NEXT: | `-ParmVarDecl {{.+}} <col:36> col:36 'U (&&)[3]' | 
|  | // CHECK-NEXT: `-CXXDeductionGuideDecl {{.+}} <col:36> col:36 implicit used <deduction guide for TwoArrays> 'auto (int (&&)[2], int (&&)[3]) -> GH64625::TwoArrays<int, int>' implicit_instantiation aggregate | 
|  | // CHECK-NEXT:   |-TemplateArgument type 'int' | 
|  | // CHECK-NEXT:   | `-BuiltinType {{.+}} 'int' | 
|  | // CHECK-NEXT:   |-TemplateArgument type 'int' | 
|  | // CHECK-NEXT:   | `-BuiltinType {{.+}} 'int' | 
|  | // CHECK-NEXT:   |-ParmVarDecl {{.+}} <col:36> col:36 'int (&&)[2]' | 
|  | // CHECK-NEXT:   `-ParmVarDecl {{.+}} <col:36> col:36 'int (&&)[3]' | 
|  | // CHECK-NEXT: FunctionProtoType {{.+}} 'auto (T (&&)[2], U (&&)[3]) -> TwoArrays<T, U>' dependent trailing_return | 
|  | // CHECK-NEXT: |-InjectedClassNameType {{.+}} 'TwoArrays<T, U>' dependent | 
|  | // CHECK-NEXT: | `-CXXRecord {{.+}} 'TwoArrays' | 
|  | // CHECK-NEXT: |-RValueReferenceType {{.+}} 'T (&&)[2]' dependent | 
|  | // CHECK-NEXT: | `-ConstantArrayType {{.+}} 'T[2]' dependent 2 | 
|  | // CHECK-NEXT: |   `-TemplateTypeParmType {{.+}} 'T' dependent depth 0 index 0 | 
|  | // CHECK-NEXT: |     `-TemplateTypeParm {{.+}} 'T' | 
|  | // CHECK-NEXT: `-RValueReferenceType {{.+}} 'U (&&)[3]' dependent | 
|  | // CHECK-NEXT:   `-ConstantArrayType {{.+}} 'U[3]' dependent 3 | 
|  | // CHECK-NEXT:     `-TemplateTypeParmType {{.+}} 'U' dependent depth 0 index 1 | 
|  | // CHECK-NEXT:       `-TemplateTypeParm {{.+}} 'U' | 
|  |  | 
|  | TwoArrays tb = {1, 2, {3, 4, 5}}; | 
|  | // CHECK:   |-CXXDeductionGuideDecl {{.+}} <col:36> col:36 implicit <deduction guide for TwoArrays> 'auto (T, T, U (&&)[3]) -> TwoArrays<T, U>' aggregate | 
|  | // CHECK-NEXT: | |-ParmVarDecl {{.+}} <col:36> col:36 'T' | 
|  | // CHECK-NEXT: | |-ParmVarDecl {{.+}} <col:36> col:36 'T' | 
|  | // CHECK-NEXT: | `-ParmVarDecl {{.+}} <col:36> col:36 'U (&&)[3]' | 
|  | // CHECK-NEXT: `-CXXDeductionGuideDecl {{.+}} <col:36> col:36 implicit used <deduction guide for TwoArrays> 'auto (int, int, int (&&)[3]) -> GH64625::TwoArrays<int, int>' implicit_instantiation aggregate | 
|  | // CHECK-NEXT:   |-TemplateArgument type 'int' | 
|  | // CHECK-NEXT:   | `-BuiltinType {{.+}} 'int' | 
|  | // CHECK-NEXT:   |-TemplateArgument type 'int' | 
|  | // CHECK-NEXT:   | `-BuiltinType {{.+}} 'int' | 
|  | // CHECK-NEXT:   |-ParmVarDecl {{.+}} <col:36> col:36 'int' | 
|  | // CHECK-NEXT:   |-ParmVarDecl {{.+}} <col:36> col:36 'int' | 
|  | // CHECK-NEXT:   `-ParmVarDecl {{.+}} <col:36> col:36 'int (&&)[3]' | 
|  | // CHECK-NEXT: FunctionProtoType {{.+}} 'auto (T, T, U (&&)[3]) -> TwoArrays<T, U>' dependent trailing_return | 
|  | // CHECK-NEXT: |-InjectedClassNameType {{.+}} 'TwoArrays<T, U>' dependent | 
|  | // CHECK-NEXT: | `-CXXRecord {{.+}} 'TwoArrays' | 
|  | // CHECK-NEXT: |-TemplateTypeParmType {{.+}} 'T' dependent depth 0 index 0 | 
|  | // CHECK-NEXT: | `-TemplateTypeParm {{.+}} 'T' | 
|  | // CHECK-NEXT: |-TemplateTypeParmType {{.+}} 'T' dependent depth 0 index 0 | 
|  | // CHECK-NEXT: | `-TemplateTypeParm {{.+}} 'T' | 
|  | // CHECK-NEXT: `-RValueReferenceType {{.+}} 'U (&&)[3]' dependent | 
|  | // CHECK-NEXT:   `-ConstantArrayType {{.+}} 'U[3]' dependent 3 | 
|  | // CHECK-NEXT:     `-TemplateTypeParmType {{.+}} 'U' dependent depth 0 index 1 | 
|  | // CHECK-NEXT:       `-TemplateTypeParm {{.+}} 'U' | 
|  |  | 
|  | TwoArrays tc = {{1, 2}, 3, 4, 5}; | 
|  | // CHECK: |-CXXDeductionGuideDecl {{.+}} <col:36> col:36 implicit <deduction guide for TwoArrays> 'auto (T (&&)[2], U, U, U) -> TwoArrays<T, U>' aggregate | 
|  | // CHECK-NEXT: | |-ParmVarDecl {{.+}} <col:36> col:36 'T (&&)[2]' | 
|  | // CHECK-NEXT: | |-ParmVarDecl {{.+}} <col:36> col:36 'U' | 
|  | // CHECK-NEXT: | |-ParmVarDecl {{.+}} <col:36> col:36 'U' | 
|  | // CHECK-NEXT: | `-ParmVarDecl {{.+}} <col:36> col:36 'U' | 
|  | // CHECK-NEXT: `-CXXDeductionGuideDecl {{.+}} <col:36> col:36 implicit used <deduction guide for TwoArrays> 'auto (int (&&)[2], int, int, int) -> GH64625::TwoArrays<int, int>' implicit_instantiation aggregate | 
|  | // CHECK-NEXT:   |-TemplateArgument type 'int' | 
|  | // CHECK-NEXT:   | `-BuiltinType {{.+}} 'int' | 
|  | // CHECK-NEXT:   |-TemplateArgument type 'int' | 
|  | // CHECK-NEXT:   | `-BuiltinType {{.+}} 'int' | 
|  | // CHECK-NEXT:   |-ParmVarDecl {{.+}} <col:36> col:36 'int (&&)[2]' | 
|  | // CHECK-NEXT:   |-ParmVarDecl {{.+}} <col:36> col:36 'int' | 
|  | // CHECK-NEXT:   |-ParmVarDecl {{.+}} <col:36> col:36 'int' | 
|  | // CHECK-NEXT:   `-ParmVarDecl {{.+}} <col:36> col:36 'int' | 
|  | // CHECK-NEXT: FunctionProtoType {{.+}} 'auto (T (&&)[2], U, U, U) -> TwoArrays<T, U>' dependent trailing_return | 
|  | // CHECK-NEXT: |-InjectedClassNameType {{.+}} 'TwoArrays<T, U>' dependent | 
|  | // CHECK-NEXT: | `-CXXRecord {{.+}} 'TwoArrays' | 
|  | // CHECK-NEXT: |-RValueReferenceType {{.+}} 'T (&&)[2]' dependent | 
|  | // CHECK-NEXT: | `-ConstantArrayType {{.+}} 'T[2]' dependent 2 | 
|  | // CHECK-NEXT: |   `-TemplateTypeParmType {{.+}} 'T' dependent depth 0 index 0 | 
|  | // CHECK-NEXT: |     `-TemplateTypeParm {{.+}} 'T' | 
|  | // CHECK-NEXT: |-TemplateTypeParmType {{.+}} 'U' dependent depth 0 index 1 | 
|  | // CHECK-NEXT: | `-TemplateTypeParm {{.+}} 'U' | 
|  | // CHECK-NEXT: |-TemplateTypeParmType {{.+}} 'U' dependent depth 0 index 1 | 
|  | // CHECK-NEXT: | `-TemplateTypeParm {{.+}} 'U' | 
|  | // CHECK-NEXT: `-TemplateTypeParmType {{.+}} 'U' dependent depth 0 index 1 | 
|  | // CHECK-NEXT:   `-TemplateTypeParm {{.+}} 'U' | 
|  |  | 
|  | } // namespace GH64625 | 
|  |  | 
|  | namespace GH83368 { | 
|  |  | 
|  | template <int N> struct A { | 
|  | int f1[N]; | 
|  | }; | 
|  |  | 
|  | A a{.f1 = {1}}; | 
|  |  | 
|  | // CHECK-LABEL: Dumping GH83368::<deduction guide for A>: | 
|  | // CHECK-NEXT: FunctionTemplateDecl 0x{{.+}} <{{.+}}:[[#@LINE - 7]]:1, col:25> col:25 implicit <deduction guide for A> | 
|  | // CHECK-NEXT: |-NonTypeTemplateParmDecl {{.+}} <col:11, col:15> col:15 referenced 'int' depth 0 index 0 N | 
|  | // CHECK:      |-CXXDeductionGuideDecl {{.+}} <col:25> col:25 implicit <deduction guide for A> 'auto (int (&&)[N]) -> A<N>' aggregate | 
|  | // CHECK-NEXT: | `-ParmVarDecl {{.+}} <col:25> col:25 'int (&&)[N]' | 
|  | // CHECK-NEXT: `-CXXDeductionGuideDecl {{.+}} <col:25> col:25 implicit used <deduction guide for A> 'auto (int (&&)[1]) -> GH83368::A<1>' implicit_instantiation aggregate | 
|  | // CHECK-NEXT:   |-TemplateArgument integral '1' | 
|  | // CHECK-NEXT:   `-ParmVarDecl {{.+}} <col:25> col:25 'int (&&)[1]' | 
|  | // CHECK-NEXT: FunctionProtoType {{.+}} 'auto (int (&&)[N]) -> A<N>' dependent trailing_return | 
|  | // CHECK-NEXT: |-InjectedClassNameType {{.+}} 'A<N>' dependent | 
|  | // CHECK-NEXT: | `-CXXRecord {{.+}} 'A' | 
|  | // CHECK-NEXT: `-RValueReferenceType {{.+}} 'int (&&)[N]' dependent | 
|  | // CHECK-NEXT:   `-DependentSizedArrayType {{.+}} 'int[N]' dependent | 
|  | // CHECK-NEXT:     |-BuiltinType {{.+}} 'int' | 
|  | // CHECK-NEXT:     `-DeclRefExpr {{.+}} <{{.+}}:10> 'int' NonTypeTemplateParm {{.+}} 'N' 'int' | 
|  |  | 
|  | } // namespace GH83368 | 
|  |  | 
|  | namespace GH60777 { | 
|  |  | 
|  | template <typename... Ts> constexpr bool True() { return true; } | 
|  |  | 
|  | template <typename T> | 
|  | requires(sizeof(T) > 1) | 
|  | struct A { | 
|  | template <typename... Ts> | 
|  | requires(sizeof...(Ts) == 0) | 
|  | A(T val, Ts... tail) | 
|  | requires(True<Ts...>()) | 
|  | {} | 
|  | }; | 
|  |  | 
|  | A a(42); | 
|  |  | 
|  | // `requires (sizeof(T) > 1)` goes into the deduction guide together with | 
|  | // `requires (True<Ts...>())`, while `requires(sizeof...(Ts) == 0)` goes into | 
|  | // the template parameter list of the synthesized declaration. | 
|  |  | 
|  | // CHECK-LABEL: Dumping GH60777::<deduction guide for A>: | 
|  | // CHECK-NEXT: FunctionTemplateDecl 0x{{.+}} <{{.+}}> {{.+}} implicit <deduction guide for A> | 
|  | // CHECK-NEXT: |-TemplateTypeParmDecl 0x{{.+}} <{{.+}}> col:20 referenced typename depth 0 index 0 T | 
|  | // CHECK-NEXT: |-TemplateTypeParmDecl 0x{{.+}} <{{.+}}> col:25 typename depth 0 index 1 ... Ts | 
|  | // CHECK-NEXT: |-ParenExpr 0x{{.+}} <{{.+}}> 'bool' | 
|  | // CHECK-NEXT: | `-BinaryOperator 0x{{.+}} <{{.+}}> 'bool' '==' | 
|  | // CHECK-NEXT: |   |-SizeOfPackExpr {{.+}} Ts | 
|  | // CHECK-NEXT: |   | `-TemplateArgument type 'Ts...':'type-parameter-0-1...' | 
|  | // CHECK-NEXT: |   |   `-PackExpansionType 0x{{.+}} 'Ts...' dependent | 
|  | // CHECK-NEXT: |   |     `-TemplateTypeParmType 0x{{.+}} 'Ts' dependent contains_unexpanded_pack depth 0 index 1 pack | 
|  | // CHECK-NEXT: |   |       `-TemplateTypeParm 0x{{.+}} 'Ts' | 
|  | // CHECK-NEXT: |   `-ImplicitCastExpr {{.+}} <IntegralCast> | 
|  | // CHECK-NEXT: |     `-IntegerLiteral 0x{{.+}} <{{.+}}> 'int' 0 | 
|  | // CHECK-NEXT: |-CXXDeductionGuideDecl 0x{{.+}} <{{.+}}> line:{{.+}} implicit <deduction guide for A> 'auto (T, Ts...) -> A<T>' | 
|  | // CHECK-NEXT: | |-ParmVarDecl 0x{{.+}} <{{.+}}> col:{{.+}} val 'T' | 
|  | // CHECK-NEXT: | |-ParmVarDecl 0x{{.+}} <{{.+}}> col:{{.+}} tail 'Ts...' pack | 
|  | // CHECK-NEXT: | `-BinaryOperator 0x{{.+}} <{{.+}}> 'bool' '&&' | 
|  | // CHECK-NEXT: |   |-ParenExpr 0x{{.+}} <{{.+}}> 'bool' | 
|  | // CHECK-NEXT: |   | `-BinaryOperator 0x{{.+}} <{{.+}}> 'bool' '>' | 
|  | // CHECK-NEXT: |   |   |-UnaryExprOrTypeTraitExpr {{.+}} sizeof 'T' | 
|  | // CHECK-NEXT: |   |   `-ImplicitCastExpr {{.+}} <IntegralCast> | 
|  | // CHECK-NEXT: |   |     `-IntegerLiteral 0x{{.+}} <{{.+}}> 'int' 1 | 
|  | // CHECK-NEXT: |   `-ParenExpr 0x{{.+}} <{{.+}}> '<dependent type>' | 
|  | // CHECK-NEXT: |     `-CallExpr 0x{{.+}} <{{.+}}> '<dependent type>' | 
|  | // CHECK-NEXT: |       `-UnresolvedLookupExpr 0x{{.+}} <col:14, col:24> '<dependent type>' {{.+}} | 
|  | // CHECK-NEXT: |         `-TemplateArgument type 'Ts...':'type-parameter-0-1...' | 
|  | // CHECK-NEXT: |           `-PackExpansionType 0x{{.+}} 'Ts...' dependent | 
|  | // CHECK-NEXT: |             `-TemplateTypeParmType 0x{{.+}} 'Ts' dependent contains_unexpanded_pack depth 0 index 1 pack | 
|  | // CHECK-NEXT: |               `-TemplateTypeParm 0x{{.+}} 'Ts' | 
|  |  | 
|  | template <typename T> | 
|  | struct B { | 
|  | template <typename... Ts> | 
|  | B(T val, Ts... tail) | 
|  | requires(True<tail...>()) | 
|  | {} | 
|  | }; | 
|  |  | 
|  | B b(42, 43); | 
|  | // expected-error@-1 {{no viable constructor}} \ | 
|  | //   expected-note@-6 {{constraints not satisfied}} \ | 
|  | //   expected-note@-5 {{because substituted constraint expression is ill-formed}} \ | 
|  | //   expected-note@-6 {{implicit deduction guide declared as 'template <typename T, typename ...Ts> B(T val, Ts ...tail) -> B<T> requires (True<tail...>())'}} \ | 
|  | //   expected-note@-8 {{function template not viable}} \ | 
|  | //   expected-note@-8 {{implicit deduction guide declared as 'template <typename T> B(B<T>) -> B<T>'}} | 
|  |  | 
|  | } // namespace GH60777 | 
|  |  | 
|  | // Examples from @hokein. | 
|  | namespace GH98592 { | 
|  |  | 
|  | template <class T> concept True = true; | 
|  | double arr3[3]; | 
|  |  | 
|  | template <class T> | 
|  | struct X { | 
|  | const int size; | 
|  | template <class U> | 
|  | constexpr X(T, U(&)[3]) requires True<T> : size(sizeof(T)) {} | 
|  | }; | 
|  |  | 
|  | template <typename T, typename U> | 
|  | X(T, U (&)[3]) -> X<U>; | 
|  |  | 
|  | constexpr X x(3, arr3); | 
|  |  | 
|  | // The synthesized deduction guide is more constrained than the explicit one. | 
|  | static_assert(x.size == 4); | 
|  |  | 
|  | // CHECK-LABEL: Dumping GH98592::<deduction guide for X>: | 
|  | // CHECK-NEXT: FunctionTemplateDecl 0x{{.+}} <{{.+}}> col:13 implicit <deduction guide for X> | 
|  | // CHECK-NEXT: |-TemplateTypeParmDecl 0x{{.+}} <{{.+}}> col:17 referenced class depth 0 index 0 T | 
|  | // CHECK-NEXT: |-TemplateTypeParmDecl 0x{{.+}} <{{.+}}> col:19 class depth 0 index 1 U | 
|  | // CHECK-NEXT: |-CXXDeductionGuideDecl 0x{{.+}} <{{.+}}> col:13 implicit <deduction guide for X> 'auto (T, U (&)[3]) -> X<T>' | 
|  | // CHECK-NEXT: | |-ParmVarDecl 0x{{.+}} <col:15> col:16 'T' | 
|  | // CHECK-NEXT: | |-ParmVarDecl 0x{{.+}} <col:18, col:24> col:21 'U (&)[3]' | 
|  | // CHECK-NEXT: | `-ConceptSpecializationExpr 0x{{.+}} <col:36, col:42> 'bool' Concept 0x{{.+}} 'True' | 
|  | // CHECK-NEXT: |   |-ImplicitConceptSpecializationDecl 0x{{.+}} <{{.+}}> col:28 | 
|  | // CHECK-NEXT: |   | `-TemplateArgument type 'type-parameter-0-0' | 
|  | // CHECK-NEXT: |   |   `-TemplateTypeParmType 0x{{.+}} 'type-parameter-0-0' dependent depth 0 index 0 | 
|  | // CHECK-NEXT: |   `-TemplateArgument <{{.+}}> type 'T':'type-parameter-0-0' | 
|  | // CHECK-NEXT: |     `-TemplateTypeParmType 0x{{.+}} 'T' dependent depth 0 index 0 | 
|  | // CHECK-NEXT: |       `-TemplateTypeParm 0x{{.+}} 'T' | 
|  | // CHECK-NEXT: `-CXXDeductionGuideDecl 0x{{.+}} <col:3, col:63> col:13 implicit used <deduction guide for X> 'auto (int, double (&)[3]) -> GH98592::X<int>' implicit_instantiation | 
|  | // CHECK-NEXT:   |-TemplateArgument type 'int' | 
|  | // CHECK-NEXT:   | `-BuiltinType 0x{{.+}} 'int' | 
|  | // CHECK-NEXT:   |-TemplateArgument type 'double' | 
|  | // CHECK-NEXT:   | `-BuiltinType 0x{{.+}} 'double' | 
|  | // CHECK-NEXT:   |-ParmVarDecl 0x{{.+}} <col:15> col:16 'int' | 
|  | // CHECK-NEXT:   |-ParmVarDecl 0x{{.+}} <col:18, col:24> col:21 'double (&)[3]' | 
|  | // CHECK-NEXT:   `-ConceptSpecializationExpr 0x{{.+}} <col:36, col:42> 'bool' Concept 0x{{.+}} 'True' | 
|  | // CHECK-NEXT:     |-ImplicitConceptSpecializationDecl 0x{{.+}} <{{.+}}> col:28 | 
|  | // CHECK-NEXT:     | `-TemplateArgument type 'type-parameter-0-0' | 
|  | // CHECK-NEXT:     |   `-TemplateTypeParmType 0x{{.+}} 'type-parameter-0-0' dependent depth 0 index 0 | 
|  | // CHECK-NEXT:     `-TemplateArgument <{{.+}}> type 'T':'type-parameter-0-0' | 
|  | // CHECK-NEXT:       `-TemplateTypeParmType 0x{{.+}} 'T' dependent depth 0 index 0 | 
|  | // CHECK-NEXT:         `-TemplateTypeParm 0x{{.+}} 'T' | 
|  |  | 
|  | template <class T> requires True<T> struct Y { | 
|  | const int size; | 
|  | template <class U> | 
|  | constexpr Y(T, U(&)[3]) : size(sizeof(T)) {} | 
|  | }; | 
|  |  | 
|  | template <typename T, typename U> Y(T, U (&)[3]) -> Y<U>; | 
|  |  | 
|  | constexpr Y y(3, arr3); | 
|  |  | 
|  | // Likewise, the synthesized deduction guide should be preferred | 
|  | // according to [over.match.class.deduct]p1. | 
|  | static_assert(y.size == 4); | 
|  |  | 
|  | // Dumping GH98592::<deduction guide for Y>: | 
|  | // FunctionTemplateDecl 0x{{.+}} <{{.+}}> col:13 implicit <deduction guide for Y> | 
|  | // |-TemplateTypeParmDecl 0x{{.+}} <{{.+}}> col:17 referenced class depth 0 index 0 T | 
|  | // |-TemplateTypeParmDecl 0x{{.+}} <{{.+}}> col:19 class depth 0 index 1 U | 
|  | // |-CXXDeductionGuideDecl 0x{{.+}} <{{.+}}> col:13 implicit <deduction guide for Y> 'auto (T, U (&)[3]) -> Y<T>' | 
|  | // | |-ParmVarDecl 0x{{.+}} <col:15> col:16 'T' | 
|  | // | |-ParmVarDecl 0x{{.+}} <col:18, col:24> col:21 'U (&)[3]' | 
|  | // | `-ConceptSpecializationExpr 0x{{.+}} <{{.+}}> 'bool' Concept 0x{{.+}} 'True' | 
|  | // |   |-ImplicitConceptSpecializationDecl 0x{{.+}} <{{.+}}> col:28 | 
|  | // |   | `-TemplateArgument type 'type-parameter-0-0' | 
|  | // |   |   `-TemplateTypeParmType 0x{{.+}} 'type-parameter-0-0' dependent depth 0 index 0 | 
|  | // |   `-TemplateArgument <{{.+}}> type 'T':'type-parameter-0-0' | 
|  | // |     `-TemplateTypeParmType 0x{{.+}} 'T' dependent depth 0 index 0 | 
|  | // |       `-TemplateTypeParm 0x{{.+}} 'T' | 
|  | // `-CXXDeductionGuideDecl 0x{{.+}} <{{.+}}> col:13 implicit used <deduction guide for Y> 'auto (int, double (&)[3]) -> GH98592::Y<int>' implicit_instantiation | 
|  | //   |-TemplateArgument type 'int' | 
|  | //   | `-BuiltinType 0x{{.+}} 'int' | 
|  | //   |-TemplateArgument type 'double' | 
|  | //   | `-BuiltinType 0x{{.+}} 'double' | 
|  | //   |-ParmVarDecl 0x{{.+}} <col:15> col:16 'int' | 
|  | //   |-ParmVarDecl 0x{{.+}} <col:18, col:24> col:21 'double (&)[3]' | 
|  | //   `-ConceptSpecializationExpr 0x{{.+}} <{{.+}}> 'bool' Concept 0x{{.+}} 'True' | 
|  | //     |-ImplicitConceptSpecializationDecl 0x{{.+}} <{{.+}}> col:28 | 
|  | //     | `-TemplateArgument type 'type-parameter-0-0' | 
|  | //     |   `-TemplateTypeParmType 0x{{.+}} 'type-parameter-0-0' dependent depth 0 index 0 | 
|  | //     `-TemplateArgument <{{.+}}> type 'T':'type-parameter-0-0' | 
|  | //       `-TemplateTypeParmType 0x{{.+}} 'T' dependent depth 0 index 0 | 
|  | //         `-TemplateTypeParm 0x{{.+}} 'T' | 
|  |  | 
|  | } // namespce GH98592 | 
|  |  | 
|  | namespace GH122134 { | 
|  |  | 
|  | template <class, class> | 
|  | concept Constraint = true; | 
|  |  | 
|  | template <class T, int> struct Struct { | 
|  | Struct(Constraint<T> auto) {} | 
|  | }; | 
|  |  | 
|  | template <int N = 0> using Test = Struct<int, N>; | 
|  |  | 
|  | Test test(42); | 
|  |  | 
|  | // CHECK-LABEL: Dumping GH122134::<deduction guide for Test>: | 
|  | // CHECK-NEXT: FunctionTemplateDecl {{.*}} implicit <deduction guide for Test> | 
|  | // CHECK-NEXT: |-NonTypeTemplateParmDecl {{.*}} 'int' depth 0 index 0 N | 
|  | // CHECK-NEXT: | `-TemplateArgument {{.*}} expr '0' | 
|  | // CHECK-NEXT: |   `-IntegerLiteral {{.*}} 'int' 0 | 
|  | // CHECK-NEXT: |-TemplateTypeParmDecl {{.*}} Concept {{.*}} 'Constraint' depth 0 index 1 auto:1 | 
|  | // CHECK-NEXT: | `-ConceptSpecializationExpr {{.*}} 'bool' Concept {{.*}} 'Constraint' | 
|  | // CHECK-NEXT: |   |-ImplicitConceptSpecializationDecl {{.*}} | 
|  | // CHECK-NEXT: |   | |-TemplateArgument type 'type-parameter-0-1' | 
|  | // CHECK-NEXT: |   | | `-TemplateTypeParmType {{.*}} 'type-parameter-0-1' dependent depth 0 index 1 | 
|  | // CHECK-NEXT: |   | `-TemplateArgument type 'int' | 
|  | // CHECK-NEXT: |   |   `-BuiltinType {{.*}} 'int' | 
|  | // CHECK-NEXT: |   |-TemplateArgument {{.*}} type 'auto:1':'type-parameter-0-1' | 
|  | // CHECK-NEXT: |   | `-TemplateTypeParmType {{.*}} 'auto:1' dependent depth 0 index 1 | 
|  | // CHECK-NEXT: |   |   `-TemplateTypeParm {{.*}} 'auto:1' | 
|  | // CHECK-NEXT: |   `-TemplateArgument {{.*}} type 'int' | 
|  | // CHECK-NEXT: |     `-BuiltinType {{.*}} 'int' | 
|  | // CHECK-NEXT: |-TypeTraitExpr {{.*}} 'bool' __is_deducible | 
|  | // CHECK-NEXT: | |-DeducedTemplateSpecializationType {{.*}} 'GH122134::Test' dependent | 
|  | // CHECK-NEXT: | | `-name: 'GH122134::Test' | 
|  | // CHECK-NEXT: | |   `-TypeAliasTemplateDecl {{.*}} Test | 
|  | // CHECK-NEXT: | `-TemplateSpecializationType {{.*}} 'Struct<int, N>' dependent | 
|  | // CHECK-NEXT: |   |-name: 'Struct':'GH122134::Struct' qualified | 
|  | // CHECK-NEXT: |   | `-ClassTemplateDecl {{.*}} Struct | 
|  | // CHECK-NEXT: |   |-TemplateArgument type 'int' | 
|  | // CHECK-NEXT: |   | `-SubstTemplateTypeParmType {{.*}} 'int' sugar class depth 0 index 0 T | 
|  | // CHECK-NEXT: |   |   |-FunctionTemplate {{.*}} '<deduction guide for Struct>' | 
|  | // CHECK-NEXT: |   |   `-BuiltinType {{.*}} 'int' | 
|  | // CHECK-NEXT: |   `-TemplateArgument expr 'N' | 
|  | // CHECK-NEXT: |     `-SubstNonTypeTemplateParmExpr {{.*}} 'int' | 
|  | // CHECK-NEXT: |       |-NonTypeTemplateParmDecl {{.*}} 'int' depth 0 index 1 | 
|  | // CHECK-NEXT: |       `-DeclRefExpr {{.*}} 'int' NonTypeTemplateParm {{.*}} 'N' 'int' | 
|  | // CHECK-NEXT: |-CXXDeductionGuideDecl {{.*}} implicit <deduction guide for Test> 'auto (auto:1) -> Struct<int, N>' | 
|  | // CHECK-NEXT: | `-ParmVarDecl {{.*}} 'auto:1' | 
|  |  | 
|  | } // namespace GH122134 | 
|  |  | 
|  | namespace GH128691 { | 
|  |  | 
|  | template <typename = void> | 
|  | class NewDeleteAllocator; | 
|  |  | 
|  | template <> | 
|  | struct NewDeleteAllocator<> { | 
|  | template <typename T> | 
|  | NewDeleteAllocator(T); // expected-note {{candidate template ignored}} \ | 
|  | // expected-note {{implicit deduction guide declared as}} | 
|  | }; | 
|  |  | 
|  | template <typename> | 
|  | struct NewDeleteAllocator : NewDeleteAllocator<> { // expected-note {{candidate template ignored}} \ | 
|  | // expected-note {{implicit deduction guide declared as}} | 
|  | using NewDeleteAllocator<>::NewDeleteAllocator; | 
|  | }; | 
|  |  | 
|  | void test() { NewDeleteAllocator abc(42); } // expected-error {{no viable constructor or deduction guide}} | 
|  |  | 
|  | // CHECK-LABEL: Dumping GH128691::<deduction guide for NewDeleteAllocator>: | 
|  | // CHECK-NEXT: FunctionTemplateDecl {{.+}} <deduction guide for NewDeleteAllocator> | 
|  | // CHECK-NEXT: |-TemplateTypeParmDecl {{.+}} typename depth 0 index 0 | 
|  | // CHECK-NEXT: | `-TemplateArgument type 'void' | 
|  | // CHECK-NEXT: |   |-inherited from TemplateTypeParm {{.+}} depth 0 index 0 | 
|  | // CHECK-NEXT: |   `-BuiltinType {{.+}} 'void' | 
|  | // CHECK-NEXT: |-TemplateTypeParmDecl {{.+}} typename depth 0 index 1 T | 
|  | // CHECK-NEXT: `-CXXDeductionGuideDecl {{.+}} <deduction guide for NewDeleteAllocator> 'auto (T) -> NewDeleteAllocator<type-parameter-0-0>' | 
|  | // CHECK-NEXT:  `-ParmVarDecl {{.+}} 'T' | 
|  |  | 
|  | } // namespace GH128691 | 
|  |  | 
|  | namespace GH132616_DeductionGuide { | 
|  |  | 
|  | template <class T> struct A { | 
|  | template <class U> | 
|  | A(U); | 
|  | }; | 
|  |  | 
|  | template <typename> | 
|  | struct B : A<int> { | 
|  | using A::A; | 
|  | }; | 
|  |  | 
|  | template <class T> | 
|  | B(T) -> B<T>; | 
|  |  | 
|  | B b(24); | 
|  |  | 
|  | // CHECK-LABEL: Dumping GH132616_DeductionGuide::<deduction guide for B>: | 
|  | // CHECK-NEXT: FunctionTemplateDecl {{.+}} implicit <deduction guide for B> | 
|  | // CHECK-NEXT: |-TemplateTypeParmDecl {{.+}} typename depth 0 index 0 | 
|  | // CHECK-NEXT: |-TemplateTypeParmDecl {{.+}} class depth 0 index 1 U | 
|  | // CHECK-NEXT: `-CXXDeductionGuideDecl {{.+}} implicit <deduction guide for B> 'auto (U) -> B<type-parameter-0-0>' | 
|  | // CHECK-NEXT:  `-ParmVarDecl {{.+}} 'U' | 
|  |  | 
|  | struct C { | 
|  | template <class U> | 
|  | C(U); | 
|  | }; | 
|  |  | 
|  | template <typename> | 
|  | struct D : C { | 
|  | using C::C; | 
|  | }; | 
|  |  | 
|  | template <class T> | 
|  | D(T) -> D<T>; | 
|  |  | 
|  | D d(24); | 
|  |  | 
|  | // CHECK-LABEL: Dumping GH132616_DeductionGuide::<deduction guide for D>: | 
|  | // CHECK-NEXT: FunctionTemplateDecl {{.+}} implicit <deduction guide for D> | 
|  | // CHECK-NEXT: |-TemplateTypeParmDecl {{.+}} typename depth 0 index 0 | 
|  | // CHECK-NEXT: |-TemplateTypeParmDecl {{.+}} class depth 0 index 1 U | 
|  | // CHECK-NEXT: `-CXXDeductionGuideDecl {{.+}} implicit <deduction guide for D> 'auto (U) -> D<type-parameter-0-0>' | 
|  | // CHECK-NEXT:  `-ParmVarDecl {{.+}} 'U' | 
|  |  | 
|  | } // namespace GH132616_DeductionGuide | 
|  |  | 
|  | namespace GH133132 { | 
|  |  | 
|  | template <class _Ty> | 
|  | struct A {}; | 
|  |  | 
|  | template <class T = int, class U = T> | 
|  | using AA = A<U>; | 
|  |  | 
|  | AA a{}; | 
|  |  | 
|  | // CHECK-LABEL: Dumping GH133132::<deduction guide for AA>: | 
|  | // CHECK-NEXT:  FunctionTemplateDecl {{.+}} implicit <deduction guide for AA> | 
|  | // CHECK-NEXT:  |-TemplateTypeParmDecl {{.+}} class depth 0 index 0 T | 
|  | // CHECK-NEXT:  | `-TemplateArgument type 'int' | 
|  | // CHECK-NEXT:  |   `-BuiltinType {{.+}} 'int' | 
|  | // CHECK-NEXT:  |-TemplateTypeParmDecl {{.+}} class depth 0 index 1 U | 
|  | // CHECK-NEXT:  | `-TemplateArgument type 'T':'type-parameter-0-0' | 
|  | // CHECK-NEXT:  |   `-TemplateTypeParmType {{.+}} 'T' dependent depth 0 index 0 | 
|  | // CHECK-NEXT:  |     `-TemplateTypeParm {{.+}} 'T' | 
|  | // CHECK-NEXT:  |-TypeTraitExpr {{.+}} 'bool' __is_deducible | 
|  | // CHECK-NEXT:  | |-DeducedTemplateSpecializationType {{.+}} 'GH133132::AA' dependent | 
|  | // CHECK-NEXT:  | | `-name: 'GH133132::AA' | 
|  | // CHECK-NEXT:  | |   `-TypeAliasTemplateDecl {{.+}} AA | 
|  | // CHECK-NEXT:  | `-TemplateSpecializationType {{.+}} 'A<U>' dependent | 
|  | // CHECK-NEXT:  |   |-name: 'A':'GH133132::A' qualified | 
|  | // CHECK-NEXT:  |   | `-ClassTemplateDecl {{.+}} A | 
|  | // CHECK-NEXT:  |   `-TemplateArgument type 'U':'type-parameter-0-1' | 
|  | // CHECK-NEXT:  |     `-SubstTemplateTypeParmType {{.+}} 'U' sugar dependent class depth 0 index 0 _Ty | 
|  | // CHECK-NEXT:  |       |-FunctionTemplate {{.+}} '<deduction guide for A>' | 
|  | // CHECK-NEXT:  |       `-TemplateTypeParmType {{.+}} 'U' dependent depth 0 index 1 | 
|  | // CHECK-NEXT:  |         `-TemplateTypeParm {{.+}} 'U' | 
|  | // CHECK-NEXT:  |-CXXDeductionGuideDecl {{.+}} implicit <deduction guide for AA> 'auto () -> A<U>' | 
|  | // CHECK-NEXT:  `-CXXDeductionGuideDecl {{.+}} implicit used <deduction guide for AA> 'auto () -> A<int>' implicit_instantiation | 
|  | // CHECK-NEXT:    |-TemplateArgument type 'int' | 
|  | // CHECK-NEXT:    | `-BuiltinType {{.+}} 'int' | 
|  | // CHECK-NEXT:    `-TemplateArgument type 'int' | 
|  | // CHECK-NEXT:      `-BuiltinType {{.+}} 'int' | 
|  |  | 
|  | template <template <class> class _X> | 
|  | struct B {}; | 
|  |  | 
|  | template <template <class> class _X = A, template <class> class _Y = _X> | 
|  | using BB = B<_Y>; | 
|  |  | 
|  | BB b{}; | 
|  |  | 
|  | // CHECK-LABEL: Dumping GH133132::<deduction guide for BB>: | 
|  | // CHECK-NEXT:  FunctionTemplateDecl {{.+}} implicit <deduction guide for BB> | 
|  | // CHECK-NEXT:  |-TemplateTemplateParmDecl {{.+}} depth 0 index 0 _X | 
|  | // CHECK-NEXT:  | |-TemplateTypeParmDecl {{.+}} class depth 0 index 0 | 
|  | // CHECK-NEXT:  | `-TemplateArgument {{.+}} template 'A':'GH133132::A' qualified | 
|  | // CHECK-NEXT:  |   `-ClassTemplateDecl {{.+}} A | 
|  | // CHECK-NEXT:  |-TemplateTemplateParmDecl {{.+}} depth 0 index 1 _Y | 
|  | // CHECK-NEXT:  | |-TemplateTypeParmDecl {{.+}} class depth 0 index 0 | 
|  | // CHECK-NEXT:  | `-TemplateArgument {{.+}} template '_X':'template-parameter-0-0' qualified | 
|  | // CHECK-NEXT:  |   `-TemplateTemplateParmDecl {{.+}} depth 0 index 0 _X | 
|  | // CHECK-NEXT:  |-TypeTraitExpr {{.+}} 'bool' __is_deducible | 
|  | // CHECK-NEXT:  | |-DeducedTemplateSpecializationType {{.+}} 'GH133132::BB' dependent | 
|  | // CHECK-NEXT:  | | `-name: 'GH133132::BB' | 
|  | // CHECK-NEXT:  | |   `-TypeAliasTemplateDecl {{.+}} BB | 
|  | // CHECK-NEXT:  | `-TemplateSpecializationType {{.+}} 'B<_Y>' dependent | 
|  | // CHECK-NEXT:  |   |-name: 'B':'GH133132::B' qualified | 
|  | // CHECK-NEXT:  |   | `-ClassTemplateDecl {{.+}} B | 
|  | // CHECK-NEXT:  |   `-TemplateArgument template '_Y':'template-parameter-0-1' subst index 0 | 
|  | // CHECK-NEXT:  |     |-parameter: TemplateTemplateParmDecl {{.+}} depth 0 index 0 _X | 
|  | // CHECK-NEXT:  |     |-associated FunctionTemplate {{.+}} '<deduction guide for B>' | 
|  | // CHECK-NEXT:  |     `-replacement: '_Y':'template-parameter-0-1' qualified | 
|  | // CHECK-NEXT:  |       `-TemplateTemplateParmDecl {{.+}} depth 0 index 1 _Y | 
|  | // CHECK-NEXT:  |-CXXDeductionGuideDecl {{.+}} implicit <deduction guide for BB> 'auto () -> B<_Y>' | 
|  | // CHECK-NEXT:  `-CXXDeductionGuideDecl {{.+}} implicit used <deduction guide for BB> 'auto () -> B<GH133132::A>' implicit_instantiation | 
|  | // CHECK-NEXT:    |-TemplateArgument template 'GH133132::A' | 
|  | // CHECK-NEXT:    | `-ClassTemplateDecl {{.+}} A | 
|  | // CHECK-NEXT:    `-TemplateArgument template 'GH133132::A' | 
|  | // CHECK-NEXT:      `-ClassTemplateDecl {{.+}} A | 
|  |  | 
|  | template <int N = 42, class U = A<decltype(N)>> | 
|  | using CC = A<U>; | 
|  |  | 
|  | CC c{}; | 
|  |  | 
|  | // CHECK-LABEL: Dumping GH133132::<deduction guide for CC>: | 
|  | // CHECK-NEXT:  FunctionTemplateDecl {{.+}} implicit <deduction guide for CC> | 
|  | // CHECK-NEXT:  |-NonTypeTemplateParmDecl {{.+}} 'int' depth 0 index 0 N | 
|  | // CHECK-NEXT:  | `-TemplateArgument {{.+}} expr '42' | 
|  | // CHECK-NEXT:  |   `-IntegerLiteral {{.+}} 'int' 42 | 
|  | // CHECK-NEXT:  |-TemplateTypeParmDecl {{.+}} class depth 0 index 1 U | 
|  | // CHECK-NEXT:  | `-TemplateArgument type 'A<decltype(N)>' | 
|  | // CHECK-NEXT:  |   `-ElaboratedType {{.+}} 'A<decltype(N)>' sugar dependent | 
|  | // CHECK-NEXT:  |     `-TemplateSpecializationType {{.+}} 'A<decltype(N)>' dependent | 
|  | // CHECK-NEXT:  |       |-name: 'A':'GH133132::A' qualified | 
|  | // CHECK-NEXT:  |       | `-ClassTemplateDecl {{.+}} A | 
|  | // CHECK-NEXT:  |       `-TemplateArgument type 'decltype(N)' | 
|  | // CHECK-NEXT:  |         `-DecltypeType {{.+}} 'decltype(N)' dependent | 
|  | // CHECK-NEXT:  |           `-DeclRefExpr {{.+}} 'int' NonTypeTemplateParm {{.+}} 'N' 'int' | 
|  | // CHECK-NEXT:  |-TypeTraitExpr {{.+}} 'bool' __is_deducible | 
|  | // CHECK-NEXT:  | |-DeducedTemplateSpecializationType {{.+}} 'GH133132::CC' dependent | 
|  | // CHECK-NEXT:  | | `-name: 'GH133132::CC' | 
|  | // CHECK-NEXT:  | |   `-TypeAliasTemplateDecl {{.+}} CC | 
|  | // CHECK-NEXT:  | `-TemplateSpecializationType {{.+}} 'A<U>' dependent | 
|  | // CHECK-NEXT:  |   |-name: 'A':'GH133132::A' qualified | 
|  | // CHECK-NEXT:  |   | `-ClassTemplateDecl {{.+}} A | 
|  | // CHECK-NEXT:  |   `-TemplateArgument type 'U':'type-parameter-0-1' | 
|  | // CHECK-NEXT:  |     `-SubstTemplateTypeParmType {{.+}} 'U' sugar dependent class depth 0 index 0 _Ty | 
|  | // CHECK-NEXT:  |       |-FunctionTemplate {{.+}} '<deduction guide for A>' | 
|  | // CHECK-NEXT:  |       `-TemplateTypeParmType {{.+}} 'U' dependent depth 0 index 1 | 
|  | // CHECK-NEXT:  |         `-TemplateTypeParm {{.+}} 'U' | 
|  | // CHECK-NEXT:  |-CXXDeductionGuideDecl {{.+}} implicit <deduction guide for CC> 'auto () -> A<U>' | 
|  | // CHECK-NEXT:  `-CXXDeductionGuideDecl {{.+}} implicit used <deduction guide for CC> 'auto () -> A<GH133132::A<int>>' implicit_instantiation | 
|  | // CHECK-NEXT:    |-TemplateArgument integral '42' | 
|  | // CHECK-NEXT:    `-TemplateArgument type 'GH133132::A<int>' | 
|  | // CHECK-NEXT:      `-RecordType {{.+}} 'GH133132::A<int>' | 
|  | // CHECK-NEXT:        `-ClassTemplateSpecialization {{.+}} 'A' | 
|  |  | 
|  | } | 
|  |  | 
|  | namespace GH67173 { | 
|  |  | 
|  | template <class T> struct Vec2d { | 
|  | struct { | 
|  | T x; | 
|  | T y; | 
|  | }; | 
|  | }; | 
|  |  | 
|  | void f() { | 
|  | Vec2d v{.x = 1, .y = 2}; | 
|  | } | 
|  |  | 
|  | // CHECK-LABEL: Dumping GH67173::<deduction guide for Vec2d>: | 
|  | // CHECK-NEXT: FunctionTemplateDecl {{.+}} implicit <deduction guide for Vec2d> | 
|  | // CHECK-NEXT: |-TemplateTypeParmDecl {{.+}} referenced class depth 0 index 0 T | 
|  | // CHECK:      |-CXXDeductionGuideDecl {{.+}} implicit <deduction guide for Vec2d> 'auto (T, T) -> Vec2d<T>' aggregate | 
|  | // CHECK-NEXT: | |-ParmVarDecl {{.+}} col:27 'T' | 
|  | // CHECK-NEXT: | `-ParmVarDecl {{.+}} col:27 'T' | 
|  | // CHECK-NEXT: `-CXXDeductionGuideDecl {{.+}} implicit used <deduction guide for Vec2d> 'auto (int, int) -> GH67173::Vec2d<int>' implicit_instantiation aggregate | 
|  | // CHECK-NEXT:   |-TemplateArgument type 'int' | 
|  | // CHECK-NEXT:   | `-BuiltinType {{.+}} 'int' | 
|  | // CHECK-NEXT:   |-ParmVarDecl {{.+}} 'int' | 
|  | // CHECK-NEXT:   `-ParmVarDecl {{.+}} 'int' | 
|  |  | 
|  | } | 
|  |  | 
|  | namespace GH141425 { | 
|  |  | 
|  | template<class... Lambda> | 
|  | struct Container | 
|  | { | 
|  | Container(Lambda...) {} | 
|  | }; | 
|  |  | 
|  | template<class... T> | 
|  | using Alias = Container<T...>; | 
|  |  | 
|  | template<class = void> | 
|  | struct Invocable { | 
|  | using T = decltype([]() { | 
|  | (void)Alias([]() -> void {}); | 
|  | }()); | 
|  | }; | 
|  |  | 
|  | struct Type { | 
|  | using T = bool; | 
|  | }; | 
|  |  | 
|  | template<class...> | 
|  | struct ExpandType { | 
|  | using T = bool; | 
|  | }; | 
|  |  | 
|  | template<class... X> | 
|  | using Expand = ExpandType<typename X::T...>; | 
|  |  | 
|  | Expand<Type, Invocable<>> _{}; | 
|  |  | 
|  | // CHECK-LABEL: Dumping GH141425::<deduction guide for Alias>: | 
|  | // CHECK-NEXT:  FunctionTemplateDecl {{.+}} implicit <deduction guide for Alias> | 
|  | // CHECK-NEXT:   |-TemplateTypeParmDecl {{.+}} class depth 0 index 0 ... T | 
|  | // CHECK-NEXT:   |-TypeTraitExpr {{.+}} 'bool' __is_deducible | 
|  | // CHECK-NEXT:   | |-DeducedTemplateSpecializationType {{.+}} 'GH141425::Alias' dependent | 
|  | // CHECK-NEXT:   | | `-name: 'GH141425::Alias' | 
|  | // CHECK-NEXT:   | |   `-TypeAliasTemplateDecl {{.+}} Alias | 
|  | // CHECK-NEXT:   | `-TemplateSpecializationType {{.+}} 'Container<T...>' dependent | 
|  | // CHECK-NEXT:   |   |-name: 'Container':'GH141425::Container' qualified | 
|  | // CHECK-NEXT:   |   | `-ClassTemplateDecl {{.+}} Container | 
|  | // CHECK-NEXT:   |   `-TemplateArgument type 'T...':'type-parameter-0-0...' | 
|  | // CHECK-NEXT:   |     `-PackExpansionType {{.+}} 'T...' dependent | 
|  | // CHECK-NEXT:   |       `-SubstTemplateTypeParmType {{.+}} 'T' sugar dependent contains_unexpanded_pack class depth 0 index 0 ... Lambda pack_index 0 | 
|  | // CHECK-NEXT:   |         |-FunctionTemplate {{.+}} '<deduction guide for Container>' | 
|  | // CHECK-NEXT:   |         `-TemplateTypeParmType {{.+}} 'T' dependent contains_unexpanded_pack depth 0 index 0 pack | 
|  | // CHECK-NEXT:   |           `-TemplateTypeParm {{.+}} 'T' | 
|  | // CHECK-NEXT:   |-CXXDeductionGuideDecl {{.+}} implicit <deduction guide for Alias> 'auto (T...) -> Container<T...>' | 
|  | // CHECK-NEXT:   | `-ParmVarDecl {{.+}} 'T...' pack | 
|  |  | 
|  | } |