forked from OSchip/llvm-project
Add missing test
This commit is contained in:
parent
2be92b7f7e
commit
e60de8c825
|
@ -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();
|
||||||
|
|
|
@ -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");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -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>
|
||||||
|
|
Loading…
Reference in New Issue