[clang] Handle variable templates in `isInstantiated` and `isInTemplateInstantiation` matchers (PR #110666)
via cfe-commits
cfe-commits at lists.llvm.org
Tue Oct 1 06:26:00 PDT 2024
llvmbot wrote:
<!--LLVM PR SUMMARY COMMENT-->
@llvm/pr-subscribers-clang
Author: Fred Tingaud (frederic-tingaud-sonarsource)
<details>
<summary>Changes</summary>
Fix `isInstantiated` and `isInTemplateInstantiation` matchers, so they return true for instantiations of variable templates, and any declaration in statements contained in such instantiations.
---
Full diff: https://github.com/llvm/llvm-project/pull/110666.diff
2 Files Affected:
- (modified) clang/include/clang/ASTMatchers/ASTMatchers.h (+4-2)
- (modified) clang/unittests/ASTMatchers/ASTMatchersNarrowingTest.cpp (+41)
``````````diff
diff --git a/clang/include/clang/ASTMatchers/ASTMatchers.h b/clang/include/clang/ASTMatchers/ASTMatchers.h
index f1c72efc238784..2ba3542ec1ae51 100644
--- a/clang/include/clang/ASTMatchers/ASTMatchers.h
+++ b/clang/include/clang/ASTMatchers/ASTMatchers.h
@@ -6750,7 +6750,8 @@ AST_POLYMORPHIC_MATCHER(isTemplateInstantiation,
/// matches 'A(int) {...};' and 'A(unsigned) {...}'.
AST_MATCHER_FUNCTION(internal::Matcher<Decl>, isInstantiated) {
auto IsInstantiation = decl(anyOf(cxxRecordDecl(isTemplateInstantiation()),
- functionDecl(isTemplateInstantiation())));
+ functionDecl(isTemplateInstantiation()),
+ varDecl(isTemplateInstantiation())));
return decl(anyOf(IsInstantiation, hasAncestor(IsInstantiation)));
}
@@ -6771,7 +6772,8 @@ AST_MATCHER_FUNCTION(internal::Matcher<Decl>, isInstantiated) {
AST_MATCHER_FUNCTION(internal::Matcher<Stmt>, isInTemplateInstantiation) {
return stmt(
hasAncestor(decl(anyOf(cxxRecordDecl(isTemplateInstantiation()),
- functionDecl(isTemplateInstantiation())))));
+ functionDecl(isTemplateInstantiation()),
+ varDecl(isTemplateInstantiation())))));
}
/// Matches explicit template specializations of function, class, or
diff --git a/clang/unittests/ASTMatchers/ASTMatchersNarrowingTest.cpp b/clang/unittests/ASTMatchers/ASTMatchersNarrowingTest.cpp
index 611e1f9ba5327c..6147dbd37d3b73 100644
--- a/clang/unittests/ASTMatchers/ASTMatchersNarrowingTest.cpp
+++ b/clang/unittests/ASTMatchers/ASTMatchersNarrowingTest.cpp
@@ -3313,6 +3313,47 @@ TEST_P(ASTMatchersTest,
declStmt(isInTemplateInstantiation())));
}
+
+TEST_P(ASTMatchersTest, IsInstantiated_MatchesVariableInstantiation) {
+ if (!GetParam().isCXX14OrLater()) {
+ return;
+ }
+
+ EXPECT_TRUE(
+ matches("template<typename T> int V = 10; void x() { V<int>; }",
+ varDecl(isInstantiated())));
+}
+
+TEST_P(ASTMatchersTest, IsInstantiated_NotMatchesVariableDefinition) {
+ if (!GetParam().isCXX14OrLater()) {
+ return;
+ }
+
+ EXPECT_TRUE(notMatches("template<typename T> int V = 10;",
+ varDecl(isInstantiated())));
+}
+
+TEST_P(ASTMatchersTest,
+ IsInTemplateInstantiation_MatchesVariableInstantiationStmt) {
+ if (!GetParam().isCXX14OrLater()) {
+ return;
+ }
+
+ EXPECT_TRUE(
+ matches("template<typename T> auto V = []() { T i; }; void x() { V<int>(); }",
+ declStmt(isInTemplateInstantiation())));
+}
+
+TEST_P(ASTMatchersTest,
+ IsInTemplateInstantiation_NotMatchesVariableDefinitionStmt) {
+ if (!GetParam().isCXX14OrLater()) {
+ return;
+ }
+
+ EXPECT_TRUE(notMatches("template<typename T> auto V = []() { T i; };",
+ declStmt(isInTemplateInstantiation())));
+}
+
TEST_P(ASTMatchersTest, IsInTemplateInstantiation_Sharing) {
if (!GetParam().isCXX()) {
return;
``````````
</details>
https://github.com/llvm/llvm-project/pull/110666
More information about the cfe-commits
mailing list