Add missing test

This commit is contained in:
Stephen Kelly 2020-05-24 22:49:00 +01:00
parent 2be92b7f7e
commit e60de8c825
3 changed files with 54 additions and 1 deletions

View File

@ -2909,7 +2909,8 @@ Expr *Expr::IgnoreUnlessSpelledInSource() {
Expr *LastE = nullptr; Expr *LastE = nullptr;
while (E != LastE) { while (E != LastE) {
LastE = E; LastE = E;
E = IgnoreExprNodes(E, IgnoreImplicitSingleStep, IgnoreImpCastsExtraSingleStep, E = IgnoreExprNodes(E, IgnoreImplicitSingleStep,
IgnoreImpCastsExtraSingleStep,
IgnoreParensOnlySingleStep); IgnoreParensOnlySingleStep);
auto SR = E->getSourceRange(); auto SR = E->getSourceRange();

View File

@ -291,6 +291,13 @@ void conversionOperator()
C1 c1 = (*c2); C1 c1 = (*c2);
} }
template <unsigned alignment>
void template_test() {
static_assert(alignment, "");
}
void actual_template_test() {
template_test<4>();
}
)cpp"); )cpp");
{ {
@ -408,6 +415,31 @@ VarDecl 'c1'
VarDecl 'c1' VarDecl 'c1'
`-UnaryOperator `-UnaryOperator
`-DeclRefExpr 'c2' `-DeclRefExpr 'c2'
)cpp");
}
{
auto FN = ast_matchers::match(
functionDecl(hasName("template_test"),
hasDescendant(staticAssertDecl().bind("staticAssert"))),
AST->getASTContext());
EXPECT_EQ(FN.size(), 2u);
EXPECT_EQ(dumpASTString(TK_AsIs, FN[1].getNodeAs<Decl>("staticAssert")),
R"cpp(
StaticAssertDecl
|-ImplicitCastExpr
| `-SubstNonTypeTemplateParmExpr
| `-IntegerLiteral
`-StringLiteral
)cpp");
EXPECT_EQ(dumpASTString(TK_IgnoreUnlessSpelledInSource,
FN[1].getNodeAs<Decl>("staticAssert")),
R"cpp(
StaticAssertDecl
|-IntegerLiteral
`-StringLiteral
)cpp"); )cpp");
} }
} }

View File

@ -1867,6 +1867,26 @@ void conversionOperator()
hasDescendant(varDecl( hasDescendant(varDecl(
hasName("c1"), hasInitializer(unaryOperator( hasName("c1"), hasInitializer(unaryOperator(
hasOperatorName("*"))))))))); hasOperatorName("*")))))))));
Code = R"cpp(
template <unsigned alignment>
void template_test() {
static_assert(alignment, "");
}
void actual_template_test() {
template_test<4>();
}
)cpp";
EXPECT_TRUE(matches(
Code,
traverse(TK_AsIs,
staticAssertDecl(has(implicitCastExpr(has(
substNonTypeTemplateParmExpr(has(integerLiteral())))))))));
EXPECT_TRUE(matches(Code, traverse(TK_IgnoreUnlessSpelledInSource,
staticAssertDecl(has(integerLiteral())))));
} }
template <typename MatcherT> template <typename MatcherT>