更改与模式匹配的文件的Checkstyle规则的严重性



我有一个检查样式文件,如下所示:

<?xml version="1.0"?>
  <!DOCTYPE module PUBLIC
    "-//Puppy Crawl//DTD Check Configuration 1.2//EN"
    "http://www.puppycrawl.com/dtds/configuration_1_2.dtd">
<module name="Checker">
  <module name="SuppressionFilter">
    <property name="file" value="./suppressions.xml"/>
  </module>
  <module name="FileTabCharacter">
    <property name="eachLine" value="true"/>
  </module>
  <module name="TreeWalker">
  ...
    <module name="JavadocMethod"/>
    <module name="JavadocType"/>
    <module name="JavadocVariable"/>
  ...
  </module>
</module>

还有一个看起来像这样的suppressions.xml:

<suppressions>
  <suppress checks="JavadocMethod" files="[/\]src[/\]test[/\]java[/\]"/>
  <suppress checks="JavadocType" files="[/\]src[/\]test[/\]java[/\]"/>
  <suppress checks="JavadocVariable" files="[/\]src[/\]test[/\]java[/\]"/>
</suppressions>

这在过去工作得很好,禁用了Javadoc检查测试目录中的任何文件。

然而,现在我们希望在测试文件缺少javadoc时显示一个警告,而不是完全忽略它,但对于不在测试目录中的文件,我们希望仍然具有错误严重性。

我试了一次,但没有成功。有办法做到这一点吗?

是的,您可以更改不同文件组的严重性。(Javadoc问题的错误严重性对我来说似乎相当苛刻,但很好。)

基本思想是将Checkstyle配置为同时生成两个严重性,然后抑制不需要的严重性。为了做到这一点,给您的支票一个id(为了简洁起见,仅适用于JavadocMethod):

<module name="JavadocMethod">
    <property name="id" value="jmwarn"/>
    <property name="severity" value="warning"/>
</module>
<module name="JavadocMethod">
    <property name="id" value="jmerr"/>
    <property name="severity" value="error"/>
</module>

然后,在您的抑制文件中,您可以控制哪些文件获得哪个严重性:

<!DOCTYPE suppressions PUBLIC "-//Puppy Crawl//DTD Suppressions 1.1//EN"
    "http://www.puppycrawl.com/dtds/suppressions_1_1.dtd">
<suppressions>
    <suppress files="[/\]src[/\]test[/\]" id="jmerr" />
    <suppress files="[\/]src[\/]main[\/]" id="jmwarn" />
</suppressions>

最新更新