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

一、写在前面

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

    <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

mvn checkstyle:check -Dcheckstyle.skip=false
# 或者指定子模块
mvn checkstyle:check -Dcheckstyle.skip=false -pl pvdms-svc

针对哪些文件哪些规则进行过滤的规则

通过配置一个 checkstyle-suppressions.xml 过滤配置文件来指定针对哪些文件哪些规则进行过滤。

示例:


# 在pom里对应的配置项指定 check_style_suppressions.xml 的位置
<suppressionsLocation>${session.executionRootDirectory}/1_doc/style/check_style_suppressions.xml</suppressionsLocation>

check_style_suppressions.xml 的内容如下:
# 注意设置的 项 是 正则表达式
# 比如过滤 SparrowLoggerImpl.java 的 RegexpSingleline 规则
# 比如过滤 MyBatisPlusGenerator.java 的 全部规则

<suppressions>
    <suppress checks="RegexpSingleline"
              files="SparrowLoggerImpl.java"
              lines="400-410"/>

    <suppress checks="[a-zA-Z]"
              files="MyBatisPlusGenerator.java"
              lines="1-1000"/>

</suppressions>

参考:
https://maven.apache.org/plugins-archives/maven-checkstyle-plugin-3.0.0/examples/suppressions-filter.html

三、扩展

3.1 跳过代码检查

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

mvn clean install -Dcheckstyle.skip -Dmaven.test.skip

3.2 CheckStyle 配置详解

请参考:
https://maven.apache.org/plugins/maven-checkstyle-plugin/checkstyle-mojo.html

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

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 160,504评论 4 365
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 67,898评论 1 300
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 110,218评论 0 248
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 44,322评论 0 214
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 52,693评论 3 290
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 40,812评论 1 223
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 32,010评论 2 315
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 30,747评论 0 204
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 34,476评论 1 246
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 30,700评论 2 251
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 32,190评论 1 262
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 28,541评论 3 258
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 33,206评论 3 240
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 26,129评论 0 8
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,903评论 0 199
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 35,894评论 2 283
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 35,748评论 2 274

推荐阅读更多精彩内容