前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Maven插件方式执行CheckStyle并自定义风格文件

Maven插件方式执行CheckStyle并自定义风格文件

作者头像
张云飞Vir
发布2023-01-04 08:34:17
1.6K0
发布2023-01-04 08:34:17
举报
文章被收录于专栏:写代码和思考写代码和思考

一、写在前面

代码风格包含了变量的命名,缩进,注释等内容,在团队开发中,多人协同开发要避免各种风格混合带来的混乱,统一的代码风格是必须的。在开发过程中,我们可以使用一些工具来改进这一状况,比如 checkStyle 工具。

二、开始

Checkstyle 是一种用于检查 Java 源代码是否遵守代码标准或验证规则集(最佳实践)的工具。

它由这些组成:

  • 执行程序:即 checkStyle 的执行程序,它可以再 IDEA 编辑器中启动,也可以在 Maven 插件方式启动,也可以二进制方式启动。
  • 代码风格描述规则:以 XML 方式描述的代码风格的规则,比如sun_checks.xml 这个文件。
  • 相关的配置文件:比如在使用Maven插件时,插件的配置文件需要配置。

checkStyle 可以通过多种方式使用

我个人更喜欢在 Maven 插件 的方式使用,代码编写完执行一次,需要更改地方会在执行结果中告诉我,然后再修正遇到的问题。

我这里推荐 作者blinkfox 修改的代码风格规则文件,作者很用心,根据google的风格进行了修改,比如缩进(谷歌是2个空格缩进,而我也习惯了4个空格缩进),同时编写了中文的风格说明,非常赞。 更多请参考: blinkfox-checks.md

Maven 插件方式使用CheckStyle

(1) 下载 一个 规则文件

在这里下载 一个 google_checks.xml 文件 下载地址:https://github.com/blinkfox/java-style/tree/master/docs/styles

(2) 配置Maven插件

代码语言:javascript
复制
    <properties>
        <checkstyle.skip>true</checkstyle.skip>
    </properties>

    <build>
        <plugins>
            <plugin>
                <groupId>org.apache.maven.plugins</groupId>
                <artifactId>maven-checkstyle-plugin</artifactId>
                <version>3.1.2</version>
                <dependencies>
                    <dependency>
                        <groupId>com.puppycrawl.tools</groupId>
                        <artifactId>checkstyle</artifactId>
                        <version>9.3</version>
                    </dependency>
                </dependencies>
                <configuration>
                    <skip>${checkstyle.skip}</skip>
<!--                    <configLocation>style/my_sun_checks.xml</configLocation>-->
                    <configLocation>style/blinkfox-checks.xml</configLocation>
                    <encoding>UTF-8</encoding>
                    <consoleOutput>true</consoleOutput>
                    <failsOnError>true</failsOnError>
                    <linkXRef>false</linkXRef>
                    <includeTestSourceDirectory>false</includeTestSourceDirectory>
                </configuration>
                <executions>
                    <execution>
                        <id>validate</id>
                        <phase>validate</phase>
                        <goals>
                            <goal>check</goal>
                        </goals>
                    </execution>
                </executions>
            </plugin>
        </plugins>
    </build>

疑问:我这里添加了自定义属性 checkstyle.skip,为什么呢? 解答:配置了checkstyle后,它会在 maven 构建的 验证阶段执行,如果失败,会导致编译失败。我这里不想让它默认执行,仅在 希望执行的时候执行,因此默认是不执行的,只有 ${checkstyle.skip} 是 true 的时候执行,通过 -Dcheckstyle.skip=false 进行传参。

(3) 执行 CheckStyle

代码语言:javascript
复制
mvn checkstyle:check -Dcheckstyle.skip=false

三、扩展

3.1 跳过代码检查

mvn install 时可以跳过代码检查,使用 用 checkstyle.skip 来做:

代码语言:javascript
复制
mvn clean install -Dcheckstyle.skip -Dmaven.test.skip

3.2 CheckStyle 配置详解

请参考:https://www.pudn.com/news/6306d065f8728f1f6c829ae9.html

四、参考

Blinkfox Java 编程风格指南,且包含 CheckStyle 和 IDEA 格式化文件,作者很用心 https://github.com/blinkfox/java-style

https://juejin.cn/post/7178683426852044858?share_token=8408902a-f460-4642-b312-e7e661a9878d

谷歌开发指南,英文: https://google.github.io/styleguide/javaguide.html

https://juejin.cn/post/7178683426852044858?share_token=8408902a-f460-4642-b312-e7e661a9878d

下载google_checks.xml 文件 https://github.com/checkstyle/checkstyle/blob/master/src/main/resources/google_checks.xml

Google 开源项目风格指南——中文版 https://zh-google-styleguide.readthedocs.io/en/latest/google-javascript-styleguide/javascript_language_rules/#var

https://zh-google-styleguide.readthedocs.io/en/latest/google-javascript-styleguide/javascript_language_rules/#var

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2023-01-03,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 一、写在前面
  • 二、开始
    • Maven 插件方式使用CheckStyle
      • (1) 下载 一个 规则文件
      • (2) 配置Maven插件
      • (3) 执行 CheckStyle
  • 三、扩展
    • 3.1 跳过代码检查
      • 3.2 CheckStyle 配置详解
      • 四、参考
      相关产品与服务
      腾讯云代码分析
      腾讯云代码分析(内部代号CodeDog)是集众多代码分析工具的云原生、分布式、高性能的代码综合分析跟踪管理平台,其主要功能是持续跟踪分析代码,观测项目代码质量,支撑团队传承代码文化。
      领券
      问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档