[clang][ASTMatcher] Add Matcher 'convertVectorExpr'
Add Matcher convertVectorExpr. Reviewed By: aaron.ballman Differential Revision: https://reviews.llvm.org/D157248
This commit is contained in:
parent
4cce27d918
commit
8baf862756
@ -1491,6 +1491,11 @@ continueStmt()
|
||||
</pre></td></tr>
|
||||
|
||||
|
||||
<tr><td>Matcher<<a href="https://clang.llvm.org/doxygen/classclang_1_1Stmt.html">Stmt</a>></td><td class="name" onclick="toggle('convertVectorExpr0')"><a name="convertVectorExpr0Anchor">convertVectorExpr</a></td><td>Matcher<<a href="https://clang.llvm.org/doxygen/classclang_1_1ConvertVectorExpr.html">ConvertVectorExpr</a>>...</td></tr>
|
||||
<tr><td colspan="4" class="doc" id="convertVectorExpr0"><pre>Matches builtin function __builtin_convertvector.
|
||||
</pre></td></tr>
|
||||
|
||||
|
||||
<tr><td>Matcher<<a href="https://clang.llvm.org/doxygen/classclang_1_1Stmt.html">Stmt</a>></td><td class="name" onclick="toggle('coreturnStmt0')"><a name="coreturnStmt0Anchor">coreturnStmt</a></td><td>Matcher<<a href="https://clang.llvm.org/doxygen/classclang_1_1CoreturnStmt.html">CoreturnStmt</a>>...</td></tr>
|
||||
<tr><td colspan="4" class="doc" id="coreturnStmt0"><pre>Matches co_return statements.
|
||||
|
||||
|
||||
@ -231,6 +231,7 @@ Floating Point Support in Clang
|
||||
|
||||
AST Matchers
|
||||
------------
|
||||
- Add ``convertVectorExpr``.
|
||||
- Add ``dependentSizedExtVectorType``.
|
||||
|
||||
clang-format
|
||||
|
||||
@ -2519,6 +2519,10 @@ extern const internal::VariadicDynCastAllOfMatcher<Stmt, CXXNullPtrLiteralExpr>
|
||||
extern const internal::VariadicDynCastAllOfMatcher<Stmt, ChooseExpr>
|
||||
chooseExpr;
|
||||
|
||||
/// Matches builtin function __builtin_convertvector.
|
||||
extern const internal::VariadicDynCastAllOfMatcher<Stmt, ConvertVectorExpr>
|
||||
convertVectorExpr;
|
||||
|
||||
/// Matches GNU __null expression.
|
||||
extern const internal::VariadicDynCastAllOfMatcher<Stmt, GNUNullExpr>
|
||||
gnuNullExpr;
|
||||
|
||||
@ -941,6 +941,8 @@ const internal::VariadicDynCastAllOfMatcher<Stmt, CompoundLiteralExpr>
|
||||
const internal::VariadicDynCastAllOfMatcher<Stmt, CXXNullPtrLiteralExpr>
|
||||
cxxNullPtrLiteralExpr;
|
||||
const internal::VariadicDynCastAllOfMatcher<Stmt, ChooseExpr> chooseExpr;
|
||||
const internal::VariadicDynCastAllOfMatcher<Stmt, ConvertVectorExpr>
|
||||
convertVectorExpr;
|
||||
const internal::VariadicDynCastAllOfMatcher<Stmt, CoawaitExpr>
|
||||
coawaitExpr;
|
||||
const internal::VariadicDynCastAllOfMatcher<Stmt, DependentCoawaitExpr>
|
||||
|
||||
@ -178,6 +178,7 @@ RegistryMaps::RegistryMaps() {
|
||||
REGISTER_MATCHER(constantExpr);
|
||||
REGISTER_MATCHER(containsDeclaration);
|
||||
REGISTER_MATCHER(continueStmt);
|
||||
REGISTER_MATCHER(convertVectorExpr);
|
||||
REGISTER_MATCHER(coreturnStmt);
|
||||
REGISTER_MATCHER(coroutineBodyStmt);
|
||||
REGISTER_MATCHER(coyieldExpr);
|
||||
|
||||
@ -986,6 +986,17 @@ TEST_P(ASTMatchersTest, ChooseExpr) {
|
||||
chooseExpr()));
|
||||
}
|
||||
|
||||
TEST_P(ASTMatchersTest, ConvertVectorExpr) {
|
||||
EXPECT_TRUE(matches(
|
||||
"typedef double vector4double __attribute__((__vector_size__(32)));"
|
||||
"typedef float vector4float __attribute__((__vector_size__(16)));"
|
||||
"vector4float vf;"
|
||||
"void f() { (void)__builtin_convertvector(vf, vector4double); }",
|
||||
convertVectorExpr()));
|
||||
EXPECT_TRUE(notMatches("void f() { (void)__builtin_choose_expr(1, 2, 3); }",
|
||||
convertVectorExpr()));
|
||||
}
|
||||
|
||||
TEST_P(ASTMatchersTest, GNUNullExpr) {
|
||||
if (!GetParam().isCXX()) {
|
||||
return;
|
||||
|
||||
Loading…
x
Reference in New Issue
Block a user