openrewrite Maven plugin configuration

1goal

1.1mvn rewrite:run

1.1.1Run the configured recipes and apply the changes locally.

1.2mvn rewrite:runNoFork

1.2.1运行run命令但不改变maven 的life cycle,因此更方便用于多个maven goal 一起运行

1.3mvn rewrite:dryRun

1.3.1不修改原文件,而是在target/rewrite目录下生成一个diff格式的 rewrite.patch 文件

1.4mvn rewrite:dryRunNoFork

1.4.1运行dryRun命令但不改变maven 的life cycle,因此更方便用于多个maven goal 一起运行

1.5mvn rewrite:discover

1.5.1列出所有recipe,注意style也是一种recipe

2-D 参数

2.1-D 参数比配置文件优先级高,即-D会替换配置文件内的配置

2.1.1-Drewrite.activeRecipes=org.example.R1, org.example.R2

2.1.2-Drewrite.activeStyles=org.example.Style

2.1.3-Drewrite.recipeArtifactCoordinates=org.example:your-recipe:1.0

指定recipe 对应的maven artifact

3Plugin configuration

3.1activeRecipes

3.2activeStyles

3.2.1代码风格

3.3checkstyleDetectionEnabled

3.3.1默认会侦测maven Checkstyle plugin 并使用对应style

xml 复制代码
<artifactId>maven-checkstyle-plugin</artifactId>
				<version>3.3.1</version>
				<executions>
					<execution>
						<id>verify-style</id>
						<phase>process-classes</phase>
						<goals>
							<goal>check</goal>
						</goals>
					</execution>
				</executions>

3.4configLocation

3.4.1rewrite.yml 文件所在目录

3.5dependencies

3.5.1依赖 artificial,一般用于非官方recipes

3.6failOnDryRunResults

3.6.1DryRun发现内容需要修改时候返回fail

3.6.2默认false,不返回

3.7exclusions

3.7.1排除内容

3.8plainTextMasks

3.8.1指出那些文件为plaintext格式

3.8.2默认内容

xml 复制代码
**/META-INF/services/**
**/META-INF/spring.factories
**/META-INF/spring/**
**/*.bash
**/*.bat
**/CODEOWNERS
**/*.config
**/Dockerfile
**/.gitattributes
**/.gitignore
**/.java-version
**/*.jsp
**/*.ksh
**/*.md
**/*.qute.java
**/.sdkmanrc
**/*.sh
**/*.sql
**/*.txt

3.9pomCacheDirectory

3.9.1pom.xml文件cache目录

3.9.2默认为 ~/.rewrite-cache

3.10pomCacheEnabled

3.10.1default is true

3.11sizeThresholdMb

3.11.1非java 资源被忽略分析的上限大小

3.11.2The default threshold is 10Mb.

3.12skipMavenParsing

3.12.1跳过pom文件分析,默认为false

3.13 exportDatatables

3.13.1 export the data tables generated by the active recipes.

3.13.2The default is false.

3.13.3The resulting files can be found in the directory <build directory>/reports/rewrite/datatables/<timestamp>.

files

  • org.openrewrite.table.RecipeRunStats.csv
  • org.openrewrite.table.SourcesFileResults.csv

注意在运行目录下,使用maven cli的时候要注意不一定在 修改的project 目录下

3.13.4 核心代码

java 复制代码
 protected List<Result> runRecipe(Recipe recipe, LargeSourceSet sourceSet, ExecutionContext ctx) {
        getLog().info("Running recipe(s)...");
        RecipeRun recipeRun = recipe.run(sourceSet, ctx);

        if (exportDatatables) {
            String timestamp = LocalDateTime.now().format(DateTimeFormatter.ofPattern("yyyy-MM-dd_HH-mm-ss-SSS"));
            Path datatableDirectoryPath = Paths.get("target", "rewrite", "datatables", timestamp);
            getLog().info(String.format("Printing available datatables to: %s", datatableDirectoryPath));
            recipeRun.exportDatatablesToCsv(datatableDirectoryPath, ctx);
        }

        return recipeRun.getChangeset().getAllResults().stream().filter(source -> {
            // Remove ASTs originating from generated files
            if (source.getBefore() != null) {
                return !source.getBefore().getMarkers().findFirst(Generated.class).isPresent();
            }
            return true
        }).collect(toList());
    }

  public void exportDatatablesToCsv(Path filePath, ExecutionContext ctx) {
        try {
            Files.createDirectories(filePath);
        } catch (IOException e) {
            ctx.getOnError().accept(e);
        }
        for (Map.Entry<DataTable<?>, List<?>> entry : dataTables.entrySet()) {
            DataTable<?> dataTable = entry.getKey();
            List<?> rows = entry.getValue();
            File csv = filePath.resolve(dataTable.getName() + ".csv").toFile();
            try (PrintWriter printWriter = new PrintWriter(new FileOutputStream(csv, false))) {
                exportCsv(ctx, dataTable, printWriter::println, rows);
            } catch (FileNotFoundException e) {
                ctx.getOnError().accept(e);
            }
        }
    }
相关推荐
小刘|9 分钟前
Spring WebFlux + AI 流式输出深度解析:Spring AI 与 LangChain4j 效果差异溯源
java·后端·spring
Arvin.Angela14 分钟前
Maven 的基本配置操作
java·maven
夕除15 分钟前
Spring Security 配置类(SecurityConfig)
java·后端·spring
weixin1997010801618 分钟前
[特殊字符] 1688开放平台API Sign签名算法详解(Java / Python / PHP 实现)
java·python·算法
武子康23 分钟前
Java-22 深入浅出 MyBatis - 手写ORM框架3 手写SqlSession、Executor 工作原理
java·后端
未若君雅裁30 分钟前
JVM 垃圾回收算法与分代回收机制
java·jvm·算法
摇滚侠1 小时前
SpringMVC 入门到实战 简介和入门案例 01-13
java·后端·spring·intellij-idea
未若君雅裁1 小时前
JVM 垃圾回收器全景与G1深度解析
java·开发语言·jvm
霸道流氓气质1 小时前
Java 大数据量异步处理方案:线程池 vs 消息队列
java·开发语言
devilnumber1 小时前
想真正吃透 + 灵活运用 Java 代理模式
java·开发语言·代理模式