Author: ymandel Date: Thu Jun 6 07:20:29 2019 New Revision: 362707 URL: http://llvm.org/viewvc/llvm-project?rev=362707&view=rev Log: [LibTooling] Add insert/remove convenience functions for creating `ASTEdit`s.
Summary: `change()` is an all purpose function; the revision adds simple shortcuts for the specific operations of inserting (before/after) or removing source. Reviewers: ilya-biryukov Subscribers: cfe-commits Tags: #clang Differential Revision: https://reviews.llvm.org/D62621 Modified: cfe/trunk/include/clang/Tooling/Refactoring/Transformer.h cfe/trunk/unittests/Tooling/TransformerTest.cpp Modified: cfe/trunk/include/clang/Tooling/Refactoring/Transformer.h URL: http://llvm.org/viewvc/llvm-project/cfe/trunk/include/clang/Tooling/Refactoring/Transformer.h?rev=362707&r1=362706&r2=362707&view=diff ============================================================================== --- cfe/trunk/include/clang/Tooling/Refactoring/Transformer.h (original) +++ cfe/trunk/include/clang/Tooling/Refactoring/Transformer.h Thu Jun 6 07:20:29 2019 @@ -193,6 +193,23 @@ inline ASTEdit change(TextGenerator Repl return change(node(RewriteRule::RootID), std::move(Replacement)); } +/// Inserts \p Replacement before \p S, leaving the source selected by \S +/// unchanged. +inline ASTEdit insertBefore(RangeSelector S, TextGenerator Replacement) { + return change(before(std::move(S)), std::move(Replacement)); +} + +/// Inserts \p Replacement after \p S, leaving the source selected by \S +/// unchanged. +inline ASTEdit insertAfter(RangeSelector S, TextGenerator Replacement) { + return change(after(std::move(S)), std::move(Replacement)); +} + +/// Removes the source selected by \p S. +inline ASTEdit remove(RangeSelector S) { + return change(std::move(S), text("")); +} + /// The following three functions are a low-level part of the RewriteRule /// API. We expose them for use in implementing the fixtures that interpret /// RewriteRule, like Transformer and TransfomerTidy, or for more advanced Modified: cfe/trunk/unittests/Tooling/TransformerTest.cpp URL: http://llvm.org/viewvc/llvm-project/cfe/trunk/unittests/Tooling/TransformerTest.cpp?rev=362707&r1=362706&r2=362707&view=diff ============================================================================== --- cfe/trunk/unittests/Tooling/TransformerTest.cpp (original) +++ cfe/trunk/unittests/Tooling/TransformerTest.cpp Thu Jun 6 07:20:29 2019 @@ -349,6 +349,64 @@ TEST_F(TransformerTest, NodePartMemberMu Input, Expected); } +TEST_F(TransformerTest, InsertBeforeEdit) { + std::string Input = R"cc( + int f() { + return 7; + } + )cc"; + std::string Expected = R"cc( + int f() { + int y = 3; + return 7; + } + )cc"; + + StringRef Ret = "return"; + testRule(makeRule(returnStmt().bind(Ret), + insertBefore(statement(Ret), text("int y = 3;"))), + Input, Expected); +} + +TEST_F(TransformerTest, InsertAfterEdit) { + std::string Input = R"cc( + int f() { + int x = 5; + return 7; + } + )cc"; + std::string Expected = R"cc( + int f() { + int x = 5; + int y = 3; + return 7; + } + )cc"; + + StringRef Decl = "decl"; + testRule(makeRule(declStmt().bind(Decl), + insertAfter(statement(Decl), text("int y = 3;"))), + Input, Expected); +} + +TEST_F(TransformerTest, RemoveEdit) { + std::string Input = R"cc( + int f() { + int x = 5; + return 7; + } + )cc"; + std::string Expected = R"cc( + int f() { + return 7; + } + )cc"; + + StringRef Decl = "decl"; + testRule(makeRule(declStmt().bind(Decl), remove(statement(Decl))), Input, + Expected); +} + TEST_F(TransformerTest, MultiChange) { std::string Input = R"cc( void foo() { _______________________________________________ cfe-commits mailing list cfe-commits@lists.llvm.org https://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits