如何使用 checkstyle 或 PMD 强制构造函数注入?
How to enforce constructor injection with checkstyle or PMD?
我想在使用 Guice 注释的 GWT 项目中强制执行构造函数注入 com.google.inject.Inject
,该注释要么放置在用于字段注入的字段上,要么放置在用于构造函数注入的构造函数上。
该项目已经使用了checkstyle和PMD。
Afaik 我可以通过禁止字段上的注释来简单地强制执行构造函数注入,但是我发现没有 checkstyle 模块或 PMD 规则可以执行此操作。我确信我遗漏了一些东西,因为它似乎是静态代码分析工具的日常任务。
这听起来很适合 Checkstyle 的 MatchXpath 检查。您可以像这样将两个模块添加到您的配置中:
<module name="MatchXpath">
<property name="query" value="//VARIABLE_DEF/MODIFIERS/ANNOTATION/IDENT[@text='Inject']"/>
<message key="matchxpath.match"
value="Inject annotation only allowed on constructors."/>
</module>
<module name="MatchXpath">
<property name="query" value="//METHOD_DEF/MODIFIERS/ANNOTATION[./IDENT[@text='Inject']]"/>
<message key="matchxpath.match"
value="Inject annotation only allowed on constructors."/>
</module>
示例 java 文件:
public class Communication {
@Inject @Named("SMSComms")
CommunicationMode smsComms;
@Inject
public void setEmailCommunicator(@Named("EmailComms") CommunicationMode emailComms) {
this.emailComms = emailComms;
}
@Inject
public Communication(@Named("IMComms") CommunicationMode imComms) {
this.imComms = imComms;
}
}
结果:
➜ src java -jar checkstyle-8.40-all.jar -c config.xml Communication.java
Starting audit...
[ERROR] src/Communication.java:2:6: Inject annotation only allowed on constructors. [MatchXpath]
[ERROR] src/Communication.java:5:5: Inject annotation only allowed on constructors. [MatchXpath]
Audit done.
Checkstyle ends with 2 errors.
我想在使用 Guice 注释的 GWT 项目中强制执行构造函数注入 com.google.inject.Inject
,该注释要么放置在用于字段注入的字段上,要么放置在用于构造函数注入的构造函数上。
该项目已经使用了checkstyle和PMD。
Afaik 我可以通过禁止字段上的注释来简单地强制执行构造函数注入,但是我发现没有 checkstyle 模块或 PMD 规则可以执行此操作。我确信我遗漏了一些东西,因为它似乎是静态代码分析工具的日常任务。
这听起来很适合 Checkstyle 的 MatchXpath 检查。您可以像这样将两个模块添加到您的配置中:
<module name="MatchXpath">
<property name="query" value="//VARIABLE_DEF/MODIFIERS/ANNOTATION/IDENT[@text='Inject']"/>
<message key="matchxpath.match"
value="Inject annotation only allowed on constructors."/>
</module>
<module name="MatchXpath">
<property name="query" value="//METHOD_DEF/MODIFIERS/ANNOTATION[./IDENT[@text='Inject']]"/>
<message key="matchxpath.match"
value="Inject annotation only allowed on constructors."/>
</module>
示例 java 文件:
public class Communication {
@Inject @Named("SMSComms")
CommunicationMode smsComms;
@Inject
public void setEmailCommunicator(@Named("EmailComms") CommunicationMode emailComms) {
this.emailComms = emailComms;
}
@Inject
public Communication(@Named("IMComms") CommunicationMode imComms) {
this.imComms = imComms;
}
}
结果:
➜ src java -jar checkstyle-8.40-all.jar -c config.xml Communication.java
Starting audit...
[ERROR] src/Communication.java:2:6: Inject annotation only allowed on constructors. [MatchXpath]
[ERROR] src/Communication.java:5:5: Inject annotation only allowed on constructors. [MatchXpath]
Audit done.
Checkstyle ends with 2 errors.