[clang] [clang][Sema] Fix a CTAD regression after 42239d2e9 (PR #86914)

Younan Zhang via cfe-commits cfe-commits at lists.llvm.org
Fri Mar 29 08:23:39 PDT 2024


================
@@ -1836,7 +1836,19 @@ static TemplateParameterList *GetTemplateParameterList(TemplateDecl *TD) {
   // Make sure we get the template parameter list from the most
   // recent declaration, since that is the only one that is guaranteed to
   // have all the default template argument information.
-  return cast<TemplateDecl>(TD->getMostRecentDecl())->getTemplateParameters();
+  Decl *ND = TD->getMostRecentDecl();
+  // Skip past friend Decls because they are not supposed to contain default
+  // template arguments. Moreover, these declarations may introduce template
+  // parameters living in different template depths than the corresponding
+  // template parameters in TD, causing unmatched constraint substitution.
+  //
+  // C++23 N4950 [temp.param]p12
----------------
zyn0217 wrote:

> Er, I’d just write ‘C++11’ then, because I at least honestly wouldn’t know what N3337 was supposed to be off the top of my head if I just saw that somewhere.

Oops. I promise I wrote down 'C++11' some time ago, but it seems to have been lost during the copy-paste-format process...

https://github.com/llvm/llvm-project/pull/86914


More information about the cfe-commits mailing list