Rewrite enables large-scale distributed source code refactoring for framework migrations, vulnerability patches, and API migrations with an early focus on the Java language.
The Rewrite project is a semantic code search and transformation ecosystem for Java and other source code. It consists of a platform of prepackaged refactoring recipes for common framework migration and stylistic consistency tasks. It also allows you to define custom recipes to achieve a wide range of source code transformations.
Rewrite works by making changes to Abstract Syntax Trees (AST) representing your source code and printing the modified trees back into source code. You can then review the changes in your code and commit. Modifications to the AST are performed in Visitors and visitors are aggregated into Recipes. Rewrite recipes make minimally invasive changes to your source code that honor the original formatting.
For example, if you want to consistently use static imports across all of your test files, rather than doing this manually, you could use the UseStaticImport visitor provided by Rewrite. Applied to the file below, you can see the changes this generates.
// Before Rewriteimport org.junit.Assert;...Assert.assertTrue(condition);
// After Rewriteimport static org.junit.Assert.assertTrue;...assertTrue(condition);
In Getting Started, we'll learn how to configure Maven/Gradle to add Rewrite as a build step and then use the tools to perform from transformations.