[clang] [Clang][Sema] Revise the transformation of CTAD parameters of nested class templates (PR #91628)
Haojian Wu via cfe-commits
cfe-commits at lists.llvm.org
Fri May 10 01:35:48 PDT 2024
================
@@ -2583,11 +2580,27 @@ struct ConvertConstructorToDeductionGuideTransform {
// -- The types of the function parameters are those of the constructor.
for (auto *OldParam : TL.getParams()) {
- ParmVarDecl *NewParam =
- transformFunctionTypeParam(OldParam, Args, MaterializedTypedefs);
- if (NestedPattern && NewParam)
+ ParmVarDecl *NewParam = OldParam;
+ // Given
+ // template <class T> struct C {
+ // template <class U> struct D {
+ // template <class V> D(U, V);
+ // };
+ // };
+ // First, transform all the references to template parameters that are
+ // defined outside of the surrounding class template. That is T in the
+ // above example.
+ if (NestedPattern) {
NewParam = transformFunctionTypeParam(NewParam, OuterInstantiationArgs,
MaterializedTypedefs);
+ if (!NewParam)
+ return QualType();
+ }
+ // Then, transform all the references to template parameters that are
+ // defined at the class template and the constructor. In this example,
+ // they're U and V, respectively.
+ NewParam =
+ transformFunctionTypeParam(NewParam, Args, MaterializedTypedefs);
----------------
hokein wrote:
We have the same pattern on Line 2438-2452 in this file, where we perform a substitution of `OuterInstantiationArgs` on a new transformed parameter decl, I think we should probably fix it as well.
https://github.com/llvm/llvm-project/pull/91628
More information about the cfe-commits
mailing list