[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:14 PDT 2026
https://github.com/llvmbot created https://github.com/llvm/llvm-project/pull/189596
Backport 2b439327026d45bf53e59159c8e40fccf87930b6
Requested by: @zyn0217
>From 9ed11aa086a88cec86e961503b08f6209dc667d9 Mon Sep 17 00:00:00 2001
From: Matheus Izvekov <mizvekov at gmail.com>
Date: Tue, 31 Mar 2026 11:41:42 +0100
Subject: [PATCH] [clang] fix getReplacedTemplateParameter for function
template specializations (#189559)
(cherry picked from commit 2b439327026d45bf53e59159c8e40fccf87930b6)
---
clang/lib/AST/DeclTemplate.cpp | 10 ++++++----
clang/test/SemaTemplate/GH188759.cpp | 13 +++++++++++++
2 files changed, 19 insertions(+), 4 deletions(-)
create mode 100644 clang/test/SemaTemplate/GH188759.cpp
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
More information about the llvm-branch-commits
mailing list