[llvm-branch-commits] [clang] release/22.x: [clang] fix getReplacedTemplateParameter for function template specializations (#189559) (PR #189596)

via llvm-branch-commits llvm-branch-commits at lists.llvm.org
Tue Mar 31 04:02:50 PDT 2026


llvmbot wrote:


<!--LLVM PR SUMMARY COMMENT-->

@llvm/pr-subscribers-clang

Author: llvmbot

<details>
<summary>Changes</summary>

Backport 2b439327026d45bf53e59159c8e40fccf87930b6

Requested by: @<!-- -->zyn0217

---
Full diff: https://github.com/llvm/llvm-project/pull/189596.diff


2 Files Affected:

- (modified) clang/lib/AST/DeclTemplate.cpp (+6-4) 
- (added) clang/test/SemaTemplate/GH188759.cpp (+13) 


``````````diff
diff --git a/clang/lib/AST/DeclTemplate.cpp b/clang/lib/AST/DeclTemplate.cpp
index ed20c720ce06c..4e77a2c4686eb 100644
--- a/clang/lib/AST/DeclTemplate.cpp
+++ b/clang/lib/AST/DeclTemplate.cpp
@@ -1713,10 +1713,12 @@ clang::getReplacedTemplateParameter(Decl *D, unsigned Index) {
   case Decl::Kind::CXXConstructor:
   case Decl::Kind::CXXDestructor:
   case Decl::Kind::CXXMethod:
-  case Decl::Kind::Function:
-    return getReplacedTemplateParameter(
-        cast<FunctionDecl>(D)->getTemplateSpecializationInfo()->getTemplate(),
-        Index);
+  case Decl::Kind::Function: {
+    const FunctionTemplateSpecializationInfo *Info =
+        cast<FunctionDecl>(D)->getTemplateSpecializationInfo();
+    return {Info->getTemplate()->getTemplateParameters()->getParam(Index),
+            Info->TemplateArguments->asArray()[Index]};
+  }
   default:
     llvm_unreachable("Unhandled templated declaration kind");
   }
diff --git a/clang/test/SemaTemplate/GH188759.cpp b/clang/test/SemaTemplate/GH188759.cpp
new file mode 100644
index 0000000000000..f0d579d1fc3e5
--- /dev/null
+++ b/clang/test/SemaTemplate/GH188759.cpp
@@ -0,0 +1,13 @@
+// RUN: %clang_cc1 -fsyntax-only -verify -std=c++26 %s
+
+namespace t1 {
+  template <int> struct integer_sequence {};
+  template <int> struct array {};
+  template <int ARRAY_SIZE, array<ARRAY_SIZE> test_apdus> void runBlobs() {
+    []<int... INDEX>(integer_sequence<INDEX...>) { // expected-note {{requested here}}
+      int x{operator0<test_apdus, INDEX>()...};
+      // expected-error at -1 {{use of undeclared identifier 'operator0'}}
+    }(integer_sequence<1>{});
+  }
+  template void runBlobs<2, {}>(); // expected-note {{requested here}}
+} // namespace t1

``````````

</details>


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


More information about the llvm-branch-commits mailing list