1 // RUN: %clang_cc1 -fsyntax-only -verify -std=c++20 %s
3 // expected-note@temp_arg_template_p0522.cpp:* 1+{{}}
5 template<template<int> typename
> struct Ti
;
6 template<template<int...> typename
> struct TPi
;
7 template<template<int, int...> typename
> struct TiPi
;
8 template<template<int..., int...> typename
> struct TPiPi
; // FIXME: Why is this not ill-formed?
10 template<typename T
, template<T
> typename
> struct tT0
;
11 template<template<typename T
, T
> typename
> struct Tt0
;
13 template<template<typename
> typename
> struct Tt
;
14 template<template<typename
, typename
...> typename
> struct TtPt
;
16 template<int> struct i
;
17 template<int, int = 0> struct iDi
;
18 template<int, int> struct ii
;
19 template<int...> struct Pi
;
20 template<int, int, int...> struct iiPi
;
22 template<int, typename
= int> struct iDt
;
23 template<int, typename
> struct it
;
25 template<typename T
, T v
> struct t0
;
27 template<typename
...> struct Pt
;
34 using err1
= Ti
<ii
>; // expected-error {{different template parameters}}
35 using err2
= Ti
<iiPi
>; // expected-error {{different template parameters}}
36 using err3
= Ti
<t0
>; // expected-error {{different template parameters}}
37 using err4
= Ti
<it
>; // expected-error {{different template parameters}}
40 // These are accepted by the backwards-compatibility "parameter pack in
41 // parameter matches any number of parameters in arguments" rule.
42 namespace IntPackParam
{
44 using ok_compat
= Pt
<TPi
<i
>, TPi
<iDi
>, TPi
<ii
>, TPi
<iiPi
>>;
45 using err1
= TPi
<t0
>; // expected-error {{different template parameters}}
46 using err2
= TPi
<iDt
>; // expected-error {{different template parameters}}
47 using err3
= TPi
<it
>; // expected-error {{different template parameters}}
50 namespace IntAndPackParam
{
52 using ok_compat
= Pt
<TiPi
<ii
>, TiPi
<iDi
>, TiPi
<iiPi
>>;
53 using err
= TiPi
<iDi
>;
56 namespace DependentType
{
57 using ok
= Pt
<tT0
<int, i
>, tT0
<int, iDi
>>;
58 using err1
= tT0
<int, ii
>; // expected-error {{different template parameters}}
59 using err2
= tT0
<short, i
>; // FIXME: should this be OK?
60 using err2a
= tT0
<long long, i
>; // FIXME: should this be OK (if long long is larger than int)?
61 using err2b
= tT0
<void*, i
>; // expected-error {{different template parameters}}
62 using err3
= tT0
<short, t0
>; // expected-error {{different template parameters}}
65 using err4
= Tt0
<it
>; // expected-error {{different template parameters}}
69 template<template<int> typename T
> struct TInt
{};
70 template<template<int*> typename T
> struct TIntPtr
{};
71 template<template<auto> typename T
> struct TAuto
{};
72 template<template<auto*> typename T
> struct TAutoPtr
{};
73 template<template<decltype(auto)> typename T
> struct TDecltypeAuto
{};
74 template<auto> struct Auto
;
75 template<auto*> struct AutoPtr
;
76 template<decltype(auto)> struct DecltypeAuto
;
77 template<int> struct Int
;
78 template<int*> struct IntPtr
;
81 TInt
<AutoPtr
> iap
; // FIXME: ill-formed (?)
82 TInt
<DecltypeAuto
> ida
;
84 TInt
<IntPtr
> iip
; // expected-error {{different template parameters}}
87 TIntPtr
<AutoPtr
> ipap
;
88 TIntPtr
<DecltypeAuto
> ipda
;
89 TIntPtr
<Int
> ipi
; // expected-error {{different template parameters}}
93 TAuto
<AutoPtr
> aap
; // FIXME: ill-formed (?)
94 TAuto
<Int
> ai
; // FIXME: ill-formed (?)
95 TAuto
<IntPtr
> aip
; // FIXME: ill-formed (?)
98 TAutoPtr
<AutoPtr
> apap
;
99 TAutoPtr
<Int
> api
; // FIXME: ill-formed (?)
100 TAutoPtr
<IntPtr
> apip
; // FIXME: ill-formed (?)
102 TDecltypeAuto
<DecltypeAuto
> dada
;
103 TDecltypeAuto
<Int
> dai
; // FIXME: ill-formed (?)
104 TDecltypeAuto
<IntPtr
> daip
; // FIXME: ill-formed (?)
106 // FIXME: It's completely unclear what should happen here, but these results
107 // seem at least plausible:
108 TAuto
<DecltypeAuto
> ada
;
109 TAutoPtr
<DecltypeAuto
> apda
;
110 // Perhaps this case should be invalid, as there are valid 'decltype(auto)'
111 // parameters (such as 'user-defined-type &') that are not valid 'auto'
113 TDecltypeAuto
<Auto
> daa
;
114 TDecltypeAuto
<AutoPtr
> daap
; // FIXME: should probably be ill-formed
117 template<auto A
, decltype(A
) B
= &n
> struct SubstFailure
;
118 TInt
<SubstFailure
> isf
; // FIXME: this should be ill-formed
119 TIntPtr
<SubstFailure
> ipsf
;
123 // Note: the constraint here is just for bypassing a fast-path.
124 template<class T1
> requires(true) using A
= int;
125 template<template<class ...T2s
> class TT1
, class T3
> struct B
{};
126 template<class T4
> B
<A
, T4
> f();
128 } // namespace GH62529
133 constexpr Y(const X
&) {}
137 template<template<X
> class> struct A
{};
138 template<Y
> struct B
;
139 template struct A
<B
>;
142 template<template<Y
> class> struct A
{};
143 template<X
> struct B
;
144 template struct A
<B
>; // expected-error {{different template parameters}}
146 } // namespace GH101394