[PATCH] D157248: [clang][ASTMatcher] Add Matcher 'convertVectorExpr'
This revision was automatically updated to reflect the committed changes. Closed by commit rG8baf86275639: [clang][ASTMatcher] Add Matcher convertVectorExpr (authored by dingfei fd...@feysh.com). Changed prior to commit: https://reviews.llvm.org/D157248?vs=547625=547771#toc Repository: rG LLVM Github Monorepo CHANGES SINCE LAST ACTION https://reviews.llvm.org/D157248/new/ https://reviews.llvm.org/D157248 Files: clang/docs/LibASTMatchersReference.html clang/docs/ReleaseNotes.rst clang/include/clang/ASTMatchers/ASTMatchers.h clang/lib/ASTMatchers/ASTMatchersInternal.cpp clang/lib/ASTMatchers/Dynamic/Registry.cpp clang/unittests/ASTMatchers/ASTMatchersNodeTest.cpp Index: clang/unittests/ASTMatchers/ASTMatchersNodeTest.cpp === --- clang/unittests/ASTMatchers/ASTMatchersNodeTest.cpp +++ clang/unittests/ASTMatchers/ASTMatchersNodeTest.cpp @@ -986,6 +986,17 @@ 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; Index: clang/lib/ASTMatchers/Dynamic/Registry.cpp === --- clang/lib/ASTMatchers/Dynamic/Registry.cpp +++ clang/lib/ASTMatchers/Dynamic/Registry.cpp @@ -178,6 +178,7 @@ REGISTER_MATCHER(constantExpr); REGISTER_MATCHER(containsDeclaration); REGISTER_MATCHER(continueStmt); + REGISTER_MATCHER(convertVectorExpr); REGISTER_MATCHER(coreturnStmt); REGISTER_MATCHER(coroutineBodyStmt); REGISTER_MATCHER(coyieldExpr); Index: clang/lib/ASTMatchers/ASTMatchersInternal.cpp === --- clang/lib/ASTMatchers/ASTMatchersInternal.cpp +++ clang/lib/ASTMatchers/ASTMatchersInternal.cpp @@ -941,6 +941,8 @@ const internal::VariadicDynCastAllOfMatcher cxxNullPtrLiteralExpr; const internal::VariadicDynCastAllOfMatcher chooseExpr; +const internal::VariadicDynCastAllOfMatcher +convertVectorExpr; const internal::VariadicDynCastAllOfMatcher coawaitExpr; const internal::VariadicDynCastAllOfMatcher Index: clang/include/clang/ASTMatchers/ASTMatchers.h === --- clang/include/clang/ASTMatchers/ASTMatchers.h +++ clang/include/clang/ASTMatchers/ASTMatchers.h @@ -2519,6 +2519,10 @@ extern const internal::VariadicDynCastAllOfMatcher chooseExpr; +/// Matches builtin function __builtin_convertvector. +extern const internal::VariadicDynCastAllOfMatcher +convertVectorExpr; + /// Matches GNU __null expression. extern const internal::VariadicDynCastAllOfMatcher gnuNullExpr; Index: clang/docs/ReleaseNotes.rst === --- clang/docs/ReleaseNotes.rst +++ clang/docs/ReleaseNotes.rst @@ -231,6 +231,7 @@ AST Matchers +- Add ``convertVectorExpr``. - Add ``dependentSizedExtVectorType``. clang-format Index: clang/docs/LibASTMatchersReference.html === --- clang/docs/LibASTMatchersReference.html +++ clang/docs/LibASTMatchersReference.html @@ -1491,6 +1491,11 @@ +Matcherhttps://clang.llvm.org/doxygen/classclang_1_1Stmt.html;>StmtconvertVectorExprMatcherhttps://clang.llvm.org/doxygen/classclang_1_1ConvertVectorExpr.html;>ConvertVectorExpr... +Matches builtin function __builtin_convertvector. + + + Matcherhttps://clang.llvm.org/doxygen/classclang_1_1Stmt.html;>StmtcoreturnStmtMatcherhttps://clang.llvm.org/doxygen/classclang_1_1CoreturnStmt.html;>CoreturnStmt... Matches co_return statements. Index: clang/unittests/ASTMatchers/ASTMatchersNodeTest.cpp === --- clang/unittests/ASTMatchers/ASTMatchersNodeTest.cpp +++ clang/unittests/ASTMatchers/ASTMatchersNodeTest.cpp @@ -986,6 +986,17 @@ 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())
[PATCH] D157248: [clang][ASTMatcher] Add Matcher 'convertVectorExpr'
aaron.ballman accepted this revision. aaron.ballman added a comment. This revision is now accepted and ready to land. LGTM! Repository: rG LLVM Github Monorepo CHANGES SINCE LAST ACTION https://reviews.llvm.org/D157248/new/ https://reviews.llvm.org/D157248 ___ cfe-commits mailing list cfe-commits@lists.llvm.org https://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits
[PATCH] D157248: [clang][ASTMatcher] Add Matcher 'convertVectorExpr'
danix800 updated this revision to Diff 547625. Repository: rG LLVM Github Monorepo CHANGES SINCE LAST ACTION https://reviews.llvm.org/D157248/new/ https://reviews.llvm.org/D157248 Files: clang/docs/LibASTMatchersReference.html clang/docs/ReleaseNotes.rst clang/include/clang/ASTMatchers/ASTMatchers.h clang/lib/ASTMatchers/ASTMatchersInternal.cpp clang/lib/ASTMatchers/Dynamic/Registry.cpp clang/unittests/ASTMatchers/ASTMatchersNodeTest.cpp Index: clang/unittests/ASTMatchers/ASTMatchersNodeTest.cpp === --- clang/unittests/ASTMatchers/ASTMatchersNodeTest.cpp +++ clang/unittests/ASTMatchers/ASTMatchersNodeTest.cpp @@ -986,6 +986,17 @@ 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; Index: clang/lib/ASTMatchers/Dynamic/Registry.cpp === --- clang/lib/ASTMatchers/Dynamic/Registry.cpp +++ clang/lib/ASTMatchers/Dynamic/Registry.cpp @@ -178,6 +178,7 @@ REGISTER_MATCHER(constantExpr); REGISTER_MATCHER(containsDeclaration); REGISTER_MATCHER(continueStmt); + REGISTER_MATCHER(convertVectorExpr); REGISTER_MATCHER(coreturnStmt); REGISTER_MATCHER(coroutineBodyStmt); REGISTER_MATCHER(coyieldExpr); Index: clang/lib/ASTMatchers/ASTMatchersInternal.cpp === --- clang/lib/ASTMatchers/ASTMatchersInternal.cpp +++ clang/lib/ASTMatchers/ASTMatchersInternal.cpp @@ -941,6 +941,8 @@ const internal::VariadicDynCastAllOfMatcher cxxNullPtrLiteralExpr; const internal::VariadicDynCastAllOfMatcher chooseExpr; +const internal::VariadicDynCastAllOfMatcher +convertVectorExpr; const internal::VariadicDynCastAllOfMatcher coawaitExpr; const internal::VariadicDynCastAllOfMatcher Index: clang/include/clang/ASTMatchers/ASTMatchers.h === --- clang/include/clang/ASTMatchers/ASTMatchers.h +++ clang/include/clang/ASTMatchers/ASTMatchers.h @@ -2519,6 +2519,10 @@ extern const internal::VariadicDynCastAllOfMatcher chooseExpr; +/// Matches builtin function __builtin_convertvector. +extern const internal::VariadicDynCastAllOfMatcher +convertVectorExpr; + /// Matches GNU __null expression. extern const internal::VariadicDynCastAllOfMatcher gnuNullExpr; Index: clang/docs/ReleaseNotes.rst === --- clang/docs/ReleaseNotes.rst +++ clang/docs/ReleaseNotes.rst @@ -228,6 +228,7 @@ AST Matchers +- Add ``convertVectorExpr``. clang-format Index: clang/docs/LibASTMatchersReference.html === --- clang/docs/LibASTMatchersReference.html +++ clang/docs/LibASTMatchersReference.html @@ -1491,6 +1491,11 @@ +Matcherhttps://clang.llvm.org/doxygen/classclang_1_1Stmt.html;>StmtconvertVectorExprMatcherhttps://clang.llvm.org/doxygen/classclang_1_1ConvertVectorExpr.html;>ConvertVectorExpr... +Matches builtin function __builtin_convertvector. + + + Matcherhttps://clang.llvm.org/doxygen/classclang_1_1Stmt.html;>StmtcoreturnStmtMatcherhttps://clang.llvm.org/doxygen/classclang_1_1CoreturnStmt.html;>CoreturnStmt... Matches co_return statements. Index: clang/unittests/ASTMatchers/ASTMatchersNodeTest.cpp === --- clang/unittests/ASTMatchers/ASTMatchersNodeTest.cpp +++ clang/unittests/ASTMatchers/ASTMatchersNodeTest.cpp @@ -986,6 +986,17 @@ 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; Index: clang/lib/ASTMatchers/Dynamic/Registry.cpp === --- clang/lib/ASTMatchers/Dynamic/Registry.cpp +++ clang/lib/ASTMatchers/Dynamic/Registry.cpp @@ -178,6 +178,7 @@
[PATCH] D157248: [clang][ASTMatcher] Add Matcher 'convertVectorExpr'
danix800 created this revision. danix800 added reviewers: PiotrZSL, aaron.ballman. danix800 added a project: clang. Herald added a project: All. danix800 requested review of this revision. Herald added a subscriber: cfe-commits. Add Matcher `convertVectorExpr`. Repository: rG LLVM Github Monorepo https://reviews.llvm.org/D157248 Files: clang/docs/LibASTMatchersReference.html clang/docs/ReleaseNotes.rst clang/include/clang/ASTMatchers/ASTMatchers.h clang/lib/ASTMatchers/ASTMatchersInternal.cpp clang/lib/ASTMatchers/Dynamic/Registry.cpp clang/unittests/ASTMatchers/ASTMatchersNodeTest.cpp Index: clang/unittests/ASTMatchers/ASTMatchersNodeTest.cpp === --- clang/unittests/ASTMatchers/ASTMatchersNodeTest.cpp +++ clang/unittests/ASTMatchers/ASTMatchersNodeTest.cpp @@ -986,6 +986,17 @@ 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; Index: clang/lib/ASTMatchers/Dynamic/Registry.cpp === --- clang/lib/ASTMatchers/Dynamic/Registry.cpp +++ clang/lib/ASTMatchers/Dynamic/Registry.cpp @@ -165,6 +165,7 @@ REGISTER_MATCHER(castExpr); REGISTER_MATCHER(characterLiteral); REGISTER_MATCHER(chooseExpr); + REGISTER_MATCHER(convertVectorExpr); REGISTER_MATCHER(classTemplateDecl); REGISTER_MATCHER(classTemplatePartialSpecializationDecl); REGISTER_MATCHER(classTemplateSpecializationDecl); Index: clang/lib/ASTMatchers/ASTMatchersInternal.cpp === --- clang/lib/ASTMatchers/ASTMatchersInternal.cpp +++ clang/lib/ASTMatchers/ASTMatchersInternal.cpp @@ -941,6 +941,8 @@ const internal::VariadicDynCastAllOfMatcher cxxNullPtrLiteralExpr; const internal::VariadicDynCastAllOfMatcher chooseExpr; +const internal::VariadicDynCastAllOfMatcher +convertVectorExpr; const internal::VariadicDynCastAllOfMatcher coawaitExpr; const internal::VariadicDynCastAllOfMatcher Index: clang/include/clang/ASTMatchers/ASTMatchers.h === --- clang/include/clang/ASTMatchers/ASTMatchers.h +++ clang/include/clang/ASTMatchers/ASTMatchers.h @@ -2519,6 +2519,10 @@ extern const internal::VariadicDynCastAllOfMatcher chooseExpr; +/// Matches builtin function __builtin_convertvector. +extern const internal::VariadicDynCastAllOfMatcher +convertVectorExpr; + /// Matches GNU __null expression. extern const internal::VariadicDynCastAllOfMatcher gnuNullExpr; Index: clang/docs/ReleaseNotes.rst === --- clang/docs/ReleaseNotes.rst +++ clang/docs/ReleaseNotes.rst @@ -228,6 +228,7 @@ AST Matchers +- Add ``convertVectorExpr``. clang-format Index: clang/docs/LibASTMatchersReference.html === --- clang/docs/LibASTMatchersReference.html +++ clang/docs/LibASTMatchersReference.html @@ -1491,6 +1491,11 @@ +Matcherhttps://clang.llvm.org/doxygen/classclang_1_1Stmt.html;>StmtconvertVectorExprMatcherhttps://clang.llvm.org/doxygen/classclang_1_1ConvertVectorExpr.html;>ConvertVectorExpr... +Matches builtin function __builtin_convertvector. + + + Matcherhttps://clang.llvm.org/doxygen/classclang_1_1Stmt.html;>StmtcoreturnStmtMatcherhttps://clang.llvm.org/doxygen/classclang_1_1CoreturnStmt.html;>CoreturnStmt... Matches co_return statements. Index: clang/unittests/ASTMatchers/ASTMatchersNodeTest.cpp === --- clang/unittests/ASTMatchers/ASTMatchersNodeTest.cpp +++ clang/unittests/ASTMatchers/ASTMatchersNodeTest.cpp @@ -986,6 +986,17 @@ 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; Index: clang/lib/ASTMatchers/Dynamic/Registry.cpp