[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