-
Notifications
You must be signed in to change notification settings - Fork 54
/
Copy pathcheckStyle.xml
238 lines (189 loc) · 10.6 KB
/
checkStyle.xml
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE module PUBLIC "-//Puppy Crawl//DTD Check Configuration 1.2//EN" "http://www.puppycrawl.com/dtds/configuration_1_2.dtd">
<!-- sumavision代码格式检查 -->
<module name="Checker">
<property name="charset" value="UTF-8" />
<property name="severity" value="warning" />
<module name="TreeWalker">
<!-- Checks for imports -->
<!-- 必须导入类的完整路径,即不能使用*导入所需的类 -->
<!--<module name="AvoidStarImport" />-->
<!-- 检查是否从非法的包中导入了类 illegalPkgs: 定义非法的包名称 -->
<module name="IllegalImport" /> <!-- defaults to sun.* packages -->
<!-- 检查是否导入了不必显示导入的类 -->
<module name="RedundantImport" />
<!-- 检查是否导入的包没有使用 -->
<module name="UnusedImports" />
<!-- Checks for Naming Conventions. 命名规范 -->
<!-- local, final variables, including catch parameters -->
<module name="LocalFinalVariableName" />
<!-- local, non-final variables, including catch parameters -->
<module name="LocalVariableName" />
<!-- static, non-final fields -->
<module name="StaticVariableName">
<property name="format" value="(^[A-Za-z0-9_]{0,32}$)" />
</module>
<!-- packages -->
<module name="PackageName">
<property name="format" value="^[a-z]+(\.[a-z][a-z0-9]*)*$" />
</module>
<!-- classes and interfaces -->
<module name="TypeName">
<property name="format" value="(^[A-Z][a-zA-Z0-9]{0,31}$)" />
</module>
<!-- methods -->
<module name="MethodName">
<property name="format" value="(^[a-z][a-zA-Z0-9]{0,38}$)" />
</module>
<!-- non-static fields -->
<!-- 对应的接口已定 参数先不做修改
<module name="MemberName">
<property name="format" value="(^[a-z][a-z0-9][a-zA-Z0-9]{0,30}$)" />
</module> -->
<module name="MemberName">
<property name="format" value="(^[a-z][a-zA-Z0-9]{0,31}$)" />
</module>
<!-- parameters -->
<module name="ParameterName">
<property name="format" value="(^[a-z][a-zA-Z0-9_]{0,31}$)" />
</module>
<!-- constants (static, final fields) -->
<module name="ConstantName">
<property name="format" value="(^[A-Z0-9_]{0,38}$)" />
</module>
<!--option: 定义左大括号'{'显示位置,eol在同一行显示,nl在下一行显示 maxLineLength: 大括号'{'所在行行最多容纳的字符数
tokens: 该属性适用的类型,例:CLASS_DEF,INTERFACE_DEF,METHOD_DEF,CTOR_DEF -->
<module name="LeftCurly">
<property name="option" value="eol" />
</module>
<!-- Checks the placement of right curly braces ('}') for else, try, and
catch tokens. The policy to verify is specified using property option. option:
右大括号是否单独一行显示 tokens: 定义检查的类型-->
<!--<module name="RightCurly">-->
<!--<property name="option" value="alone" />-->
<!--<property name="tokens" value="LITERAL_IF, LITERAL_FOR, LITERAL_WHILE, LITERAL_FINALLY"/>-->
<!--<!– <property name="tokens" value="LITERAL_ELSE,LITERAL_IF, LITERAL_FOR, LITERAL_WHILE, LITERAL_FINALLY"/> –>-->
<!--</module>-->
<!-- NeedBraces 检查是否应该使用括号的地方没有加括号 tokens: 定义检查的类型 -->
<module name="NeedBraces" />
<!-- 代码缩进 -->
<module name="Indentation" >
<property name="arrayInitIndent" value="4"/>
</module>
<!-- 每一行只能定义一个变量 -->
<module name="MultipleVariableDeclarations" />
<!-- Checks the style of array type definitions. Some like Java-style:
public static void main(String[] args) and some like C-style: public static
void main(String args[]) 检查再定义数组时,采用java风格还是c风格,例如:int[] num是java风格,int num[]是c风格。默认是java风格 -->
<module name="ArrayTypeStyle" />
<!-- Checks that switch statement has "default" clause. 检查switch语句是否有‘default’从句
Rationale: It's usually a good idea to introduce a default case in every
switch statement. Even if the developer is sure that all currently possible
cases are covered, this should be expressed in the default branch, e.g. by
using an assertion. This way the code is protected aginst later changes,
e.g. introduction of new types in an enumeration type. -->
<module name="MissingSwitchDefault" />
<!--检查switch中case后是否加入了跳出语句,例如:return、break、throw、continue -->
<module name="FallThrough" />
<!--检查default是否在语句的最后 -->
<module name="DefaultComesLast">
<property name="severity" value="warning"/>
</module>
<!-- ModifierOrder 检查修饰符的顺序,默认是 public,protected,private,abstract,static,final,transient,volatile,synchronized,native -->
<module name="ModifierOrder" />
<!-- 每行字符数为150 -->
<module name="LineLength">
<property name="max" value="150" />
</module>
<!-- 不允许使用魔法数
<module name="MagicNumber" />-->
<!-- 禁用Finalizers -->
<module name="NoFinalizer" />
<!-- 每行一条语句 -->
<module name="OneStatementPerLine" />
<!-- 检查是否跨越分支 在有跨越分支的case分支代码中添加“fallthru”、“fall through”、“fallthrough”、
“falls through”、“fallsthrough”等注释(区分大小写)时,便可抑制警告。-->
<module name="FallThrough" />
<!-- 检查所有的重载放在一起 -->
<module name="OverloadMethodsDeclarationOrder"/>
<!-- 检查是否有多余的修饰符,例如:接口中的方法不必使用public、abstract修饰 -->
<module name="RedundantModifier" />
<!-- 检查方法的javadoc的注释 scope: 可以检查的方法的范围,例如:public只能检查public修饰的方法,private可以检查所有的方法
allowMissingParamTags: 是否忽略对参数注释的检查 allowMissingThrowsTags: 是否忽略对throws注释的检查
allowMissingReturnTag: 是否忽略对return注释的检查 -->
<module name="JavadocMethod">
<property name="scope" value="private" />
<property name="allowMissingParamTags" value="true" />
<property name="allowMissingThrowsTags" value="true" />
<property name="allowMissingReturnTag" value="true" />
<property name="tokens" value="METHOD_DEF" />
<property name="allowUndeclaredRTE" value="true" />
<property name="allowThrowsTagsForSubclasses" value="true" />
<!-- 允许get set 方法没有注释 -->
<property name="allowMissingPropertyJavadoc" value="true" />
</module>
<!-- 检查在重写了equals方法后是否重写了hashCode方法 -->
<module name="EqualsHashCode" />
<!-- Checks for overly complicated boolean expressions. Currently finds
code like if (b == true), b || true, !false, etc. 检查boolean值是否冗余的地方 Rationale:
Complex boolean logic makes code hard to understand and maintain. -->
<module name="SimplifyBooleanExpression" />
<!-- Checks for overly complicated boolean return statements. For example
the following code 检查是否存在过度复杂的boolean返回值 if (valid()) return false; else
return true; could be written as return !valid(); The Idea for this Check
has been shamelessly stolen from the equivalent PMD rule. -->
<module name="SimplifyBooleanReturn" />
<!-- Checks that a class which has only private constructors is declared
as final.只有私有构造器的类必须声明为final -->
<module name="FinalClass" />
<!-- Make sure that utility classes (classes that contain only static methods
or fields in their API) do not have a public constructor. 确保Utils类(只提供static方法和属性的类)没有public构造器。
Rationale: Instantiating utility classes does not make sense. Hence the constructors
should either be private or (if you want to allow subclassing) protected.
A common mistake is forgetting to hide the default constructor. If you make
the constructor protected you may want to consider the following constructor
implementation technique to disallow instantiating subclasses: public class
StringUtils // not final to allow subclassing { protected StringUtils() {
throw new UnsupportedOperationException(); // prevents calls from subclass
} public static int count(char c, String s) { // ... } } -->
<module name="HideUtilityClassConstructor" />
<!-- Checks visibility of class members. Only static final members may
be public; other class members must be private unless property protectedAllowed
or packageAllowed is set. 检查class成员属性可见性。只有static final 修饰的成员是可以public的。其他的成员属性必需是private的,除非属性protectedAllowed或者packageAllowed设置了true.
Public members are not flagged if the name matches the public member regular
expression (contains "^serialVersionUID$" by default). Note: Checkstyle 2
used to include "^f[A-Z][a-zA-Z0-9]*$" in the default pattern to allow CMP
for EJB 1.1 with the default settings. With EJB 2.0 it is not longer necessary
to have public access for persistent fields, hence the default has been changed.
Rationale: Enforce encapsulation. 强制封装 -->
<module name="VisibilityModifier" />
<!-- Checks that long constants are defined with an upper ell. That is
' L' and not 'l'. This is in accordance to the Java Language Specification,
Section 3.10.1. 检查是否在long类型是否定义了大写的L.字母小写l和数字1(一)很相似。 looks a lot like 1. -->
<module name="UpperEll" />
<!-- Checks the number of parameters of a method or constructor. max default 7个. -->
<module name="ParameterNumber" >
<property name="max" value="8"/>
</module>
<!-- Checks for long methods and constructors. max default 150行. max=300 设置长度300 -->
<module name="MethodLength">
<property name="max" value="300" />
</module>
<!--- 字符串比较必须使用 equals() -->
<module name="StringLiteralEquality">
</module>
<!-- if-else嵌套语句个数 最多4层 -->
<module name="NestedIfDepth">
<property name="max" value="4" />
</module>
<!-- try-catch 嵌套语句个数 最多2层 -->
<module name="NestedTryDepth">
<property name="max" value="2" />
</module>
<!-- 返回个数
<module name="ReturnCount">
<property name="max" value="10" />
<property name="format" value="^$" />
</module>-->
</module>
</module>