checkstyle.xml 18 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361
  1. <?xml version="1.0"?>
  2. <!DOCTYPE module PUBLIC "-//Checkstyle//DTD Checkstyle Configuration 1.3//EN" "https://checkstyle.org/dtds/configuration_1_3.dtd">
  3. <!--
  4. Checkstyle configuration that checks the Google coding conventions from Google Java Style
  5. that can be found at https://google.github.io/styleguide/javaguide.html.
  6. Based on google_checks.xml found in the checkstyle repository:
  7. https://github.com/checkstyle/checkstyle/blob/master/src/main/resources/google_checks.xml
  8. Adapted for changes by the jMonkeyEngine contribution guidelines document.
  9. -->
  10. <module name="Checker">
  11. <property name="charset" value="UTF-8" />
  12. <property name="severity" value="warning" />
  13. <property name="fileExtensions" value="java, properties, xml" />
  14. <!-- Excludes all 'module-info.java' files -->
  15. <!-- See https://checkstyle.org/filefilters/index.html -->
  16. <module name="BeforeExecutionExclusionFileFilter">
  17. <property name="fileNamePattern" value="module\-info\.java$" />
  18. </module>
  19. <!-- https://checkstyle.org/filters/suppressionfilter.html -->
  20. <module name="SuppressionFilter">
  21. <property name="file" value="config/checkstyle/checkstyle-suppressions.xml"/>
  22. <property name="optional" value="true" />
  23. </module>
  24. <!-- Checks for whitespace -->
  25. <!-- See https://checkstyle.org/checks/whitespace/index.html -->
  26. <module name="FileTabCharacter">
  27. <property name="eachLine" value="false" />
  28. </module>
  29. <module name="LineLength">
  30. <property name="fileExtensions" value="java" />
  31. <property name="max" value="110" />
  32. <property name="ignorePattern"
  33. value="^package.*|^import.*|a href|href|http://|https://|ftp://" />
  34. </module>
  35. <module name="TreeWalker">
  36. <module name="OuterTypeFilename" />
  37. <module name="IllegalTokenText">
  38. <property name="tokens" value="STRING_LITERAL, CHAR_LITERAL" />
  39. <property name="format"
  40. value="\\u00(09|0(a|A)|0(c|C)|0(d|D)|22|27|5(C|c))|\\(0(10|11|12|14|15|42|47)|134)" />
  41. <property name="message"
  42. value="Consider using special escape sequence instead of octal value or Unicode escaped value." />
  43. </module>
  44. <module name="AvoidEscapedUnicodeCharacters">
  45. <property name="allowEscapesForControlCharacters" value="true" />
  46. <property name="allowByTailComment" value="true" />
  47. <property name="allowNonPrintableEscapes" value="true" />
  48. </module>
  49. <module name="AvoidStarImport"/>
  50. <module name="OneTopLevelClass" />
  51. <module name="NoLineWrap">
  52. <property name="tokens" value="PACKAGE_DEF, IMPORT, STATIC_IMPORT" />
  53. </module>
  54. <module name="EmptyBlock">
  55. <property name="option" value="TEXT" />
  56. <property name="tokens"
  57. value="LITERAL_TRY, LITERAL_FINALLY, LITERAL_IF, LITERAL_ELSE, LITERAL_SWITCH" />
  58. </module>
  59. <module name="NeedBraces">
  60. <property name="tokens"
  61. value="LITERAL_DO, LITERAL_ELSE, LITERAL_FOR, LITERAL_IF, LITERAL_WHILE" />
  62. </module>
  63. <module name="LeftCurly">
  64. <property name="tokens"
  65. value="ANNOTATION_DEF, CLASS_DEF, CTOR_DEF, ENUM_CONSTANT_DEF, ENUM_DEF,
  66. INTERFACE_DEF, LAMBDA, LITERAL_CASE, LITERAL_CATCH, LITERAL_DEFAULT,
  67. LITERAL_DO, LITERAL_ELSE, LITERAL_FINALLY, LITERAL_FOR, LITERAL_IF,
  68. LITERAL_SWITCH, LITERAL_SYNCHRONIZED, LITERAL_TRY, LITERAL_WHILE, METHOD_DEF,
  69. OBJBLOCK, STATIC_INIT, RECORD_DEF, COMPACT_CTOR_DEF" />
  70. </module>
  71. <module name="RightCurly">
  72. <property name="id" value="RightCurlySame" />
  73. <property name="tokens"
  74. value="LITERAL_TRY, LITERAL_CATCH, LITERAL_FINALLY, LITERAL_IF, LITERAL_ELSE,
  75. LITERAL_DO" />
  76. </module>
  77. <module name="RightCurly">
  78. <property name="id" value="RightCurlyAlone" />
  79. <property name="option" value="alone" />
  80. <property name="tokens"
  81. value="CLASS_DEF, METHOD_DEF, CTOR_DEF, LITERAL_FOR, LITERAL_WHILE, STATIC_INIT,
  82. INSTANCE_INIT, ANNOTATION_DEF, ENUM_DEF, INTERFACE_DEF, RECORD_DEF,
  83. COMPACT_CTOR_DEF" />
  84. </module>
  85. <module name="SuppressionXpathSingleFilter">
  86. <!-- suppresion is required till https://github.com/checkstyle/checkstyle/issues/7541 -->
  87. <property name="id" value="RightCurlyAlone" />
  88. <property name="query"
  89. value="//RCURLY[parent::SLIST[count(./*)=1]
  90. or preceding-sibling::*[last()][self::LCURLY]]" />
  91. </module>
  92. <module name="WhitespaceAfter">
  93. <property name="tokens"
  94. value="COMMA, SEMI, TYPECAST, LITERAL_IF, LITERAL_ELSE,
  95. LITERAL_WHILE, LITERAL_DO, LITERAL_FOR, DO_WHILE" />
  96. </module>
  97. <module name="WhitespaceAround">
  98. <property name="allowEmptyConstructors" value="true" />
  99. <property name="allowEmptyLambdas" value="true" />
  100. <property name="allowEmptyMethods" value="true" />
  101. <property name="allowEmptyTypes" value="true" />
  102. <property name="allowEmptyLoops" value="true" />
  103. <property name="ignoreEnhancedForColon" value="false" />
  104. <property name="tokens"
  105. value="ASSIGN, BAND, BAND_ASSIGN, BOR, BOR_ASSIGN, BSR, BSR_ASSIGN, BXOR,
  106. BXOR_ASSIGN, COLON, DIV, DIV_ASSIGN, DO_WHILE, EQUAL, GE, GT, LAMBDA, LAND,
  107. LCURLY, LE, LITERAL_CATCH, LITERAL_DO, LITERAL_ELSE, LITERAL_FINALLY,
  108. LITERAL_FOR, LITERAL_IF, LITERAL_RETURN, LITERAL_SWITCH, LITERAL_SYNCHRONIZED,
  109. LITERAL_TRY, LITERAL_WHILE, LOR, LT, MINUS, MINUS_ASSIGN, MOD, MOD_ASSIGN,
  110. NOT_EQUAL, PLUS, PLUS_ASSIGN, QUESTION, RCURLY, SL, SLIST, SL_ASSIGN, SR,
  111. SR_ASSIGN, STAR, STAR_ASSIGN, LITERAL_ASSERT, TYPE_EXTENSION_AND" />
  112. <message key="ws.notFollowed"
  113. value="WhitespaceAround: ''{0}'' is not followed by whitespace. Empty blocks may only be represented as '{}' when not part of a multi-block statement (4.1.3)" />
  114. <message key="ws.notPreceded"
  115. value="WhitespaceAround: ''{0}'' is not preceded with whitespace." />
  116. </module>
  117. <module name="OneStatementPerLine" />
  118. <module name="MultipleVariableDeclarations" />
  119. <module name="ArrayTypeStyle" />
  120. <module name="MissingSwitchDefault" />
  121. <module name="FallThrough" />
  122. <module name="UpperEll" />
  123. <module name="ModifierOrder" />
  124. <module name="EmptyLineSeparator">
  125. <property name="tokens"
  126. value="IMPORT, STATIC_IMPORT, CLASS_DEF, INTERFACE_DEF, ENUM_DEF,
  127. STATIC_INIT, INSTANCE_INIT, METHOD_DEF, CTOR_DEF, VARIABLE_DEF, RECORD_DEF,
  128. COMPACT_CTOR_DEF" />
  129. <property name="allowNoEmptyLineBetweenFields" value="true" />
  130. </module>
  131. <module name="SeparatorWrap">
  132. <property name="id" value="SeparatorWrapDot" />
  133. <property name="tokens" value="DOT" />
  134. <property name="option" value="nl" />
  135. </module>
  136. <module name="SeparatorWrap">
  137. <property name="id" value="SeparatorWrapComma" />
  138. <property name="tokens" value="COMMA" />
  139. <property name="option" value="EOL" />
  140. </module>
  141. <module name="SeparatorWrap">
  142. <!-- ELLIPSIS is EOL until https://github.com/google/styleguide/issues/259 -->
  143. <property name="id" value="SeparatorWrapEllipsis" />
  144. <property name="tokens" value="ELLIPSIS" />
  145. <property name="option" value="EOL" />
  146. </module>
  147. <module name="SeparatorWrap">
  148. <!-- ARRAY_DECLARATOR is EOL until https://github.com/google/styleguide/issues/258 -->
  149. <property name="id" value="SeparatorWrapArrayDeclarator" />
  150. <property name="tokens" value="ARRAY_DECLARATOR" />
  151. <property name="option" value="EOL" />
  152. </module>
  153. <module name="SeparatorWrap">
  154. <property name="id" value="SeparatorWrapMethodRef" />
  155. <property name="tokens" value="METHOD_REF" />
  156. <property name="option" value="nl" />
  157. </module>
  158. <module name="PackageName">
  159. <property name="format" value="^[a-z]+(\.[a-z][a-z0-9]*)*$" />
  160. <message key="name.invalidPattern"
  161. value="Package name ''{0}'' must match pattern ''{1}''." />
  162. </module>
  163. <module name="TypeName">
  164. <property name="tokens"
  165. value="CLASS_DEF, INTERFACE_DEF, ENUM_DEF,
  166. ANNOTATION_DEF, RECORD_DEF" />
  167. <message key="name.invalidPattern"
  168. value="Type name ''{0}'' must match pattern ''{1}''." />
  169. </module>
  170. <module name="MemberName">
  171. <property name="format" value="^[a-z][a-z0-9][a-zA-Z0-9]*$" />
  172. <message key="name.invalidPattern"
  173. value="Member name ''{0}'' must match pattern ''{1}''." />
  174. </module>
  175. <module name="ParameterName">
  176. <property name="format" value="^[a-z]([a-z0-9][a-zA-Z0-9]*)?$" />
  177. <message key="name.invalidPattern"
  178. value="Parameter name ''{0}'' must match pattern ''{1}''." />
  179. </module>
  180. <module name="LambdaParameterName">
  181. <property name="format" value="^[a-z]([a-z0-9][a-zA-Z0-9]*)?$" />
  182. <message key="name.invalidPattern"
  183. value="Lambda parameter name ''{0}'' must match pattern ''{1}''." />
  184. </module>
  185. <module name="CatchParameterName">
  186. <property name="format" value="^[a-z]([a-z0-9][a-zA-Z0-9]*)?$" />
  187. <message key="name.invalidPattern"
  188. value="Catch parameter name ''{0}'' must match pattern ''{1}''." />
  189. </module>
  190. <module name="LocalVariableName">
  191. <property name="format" value="^[a-z]([a-zA-Z0-9]*)?$" />
  192. <message key="name.invalidPattern"
  193. value="Local variable name ''{0}'' must match pattern ''{1}''." />
  194. </module>
  195. <module name="PatternVariableName">
  196. <property name="format" value="^[a-z]([a-z0-9][a-zA-Z0-9]*)?$" />
  197. <message key="name.invalidPattern"
  198. value="Pattern variable name ''{0}'' must match pattern ''{1}''." />
  199. </module>
  200. <module name="ClassTypeParameterName">
  201. <property name="format" value="(^[A-Z][0-9]?)$|([A-Z][a-zA-Z0-9]*[T]$)" />
  202. <message key="name.invalidPattern"
  203. value="Class type name ''{0}'' must match pattern ''{1}''." />
  204. </module>
  205. <module name="RecordComponentName">
  206. <property name="format" value="^[a-z]([a-z0-9][a-zA-Z0-9]*)?$" />
  207. <message key="name.invalidPattern"
  208. value="Record component name ''{0}'' must match pattern ''{1}''." />
  209. </module>
  210. <module name="RecordTypeParameterName">
  211. <property name="format" value="(^[A-Z][0-9]?)$|([A-Z][a-zA-Z0-9]*[T]$)" />
  212. <message key="name.invalidPattern"
  213. value="Record type name ''{0}'' must match pattern ''{1}''." />
  214. </module>
  215. <module name="MethodTypeParameterName">
  216. <property name="format" value="(^[A-Z][0-9]?)$|([A-Z][a-zA-Z0-9]*[T]$)" />
  217. <message key="name.invalidPattern"
  218. value="Method type name ''{0}'' must match pattern ''{1}''." />
  219. </module>
  220. <module name="InterfaceTypeParameterName">
  221. <property name="format" value="(^[A-Z][0-9]?)$|([A-Z][a-zA-Z0-9]*[T]$)" />
  222. <message key="name.invalidPattern"
  223. value="Interface type name ''{0}'' must match pattern ''{1}''." />
  224. </module>
  225. <module name="NoFinalizer" />
  226. <module name="GenericWhitespace">
  227. <message key="ws.followed"
  228. value="GenericWhitespace ''{0}'' is followed by whitespace." />
  229. <message key="ws.preceded"
  230. value="GenericWhitespace ''{0}'' is preceded with whitespace." />
  231. <message key="ws.illegalFollow"
  232. value="GenericWhitespace ''{0}'' should followed by whitespace." />
  233. <message key="ws.notPreceded"
  234. value="GenericWhitespace ''{0}'' is not preceded with whitespace." />
  235. </module>
  236. <module name="Indentation">
  237. <property name="basicOffset" value="4" />
  238. <property name="braceAdjustment" value="4" />
  239. <property name="caseIndent" value="4" />
  240. <property name="throwsIndent" value="4" />
  241. <property name="lineWrappingIndentation" value="8" />
  242. <property name="arrayInitIndent" value="4" />
  243. </module>
  244. <module name="AbbreviationAsWordInName">
  245. <property name="ignoreFinal" value="false" />
  246. <property name="allowedAbbreviationLength" value="1" />
  247. <property name="tokens"
  248. value="CLASS_DEF, INTERFACE_DEF, ENUM_DEF, ANNOTATION_DEF, ANNOTATION_FIELD_DEF,
  249. PARAMETER_DEF, VARIABLE_DEF, METHOD_DEF, PATTERN_VARIABLE_DEF, RECORD_DEF,
  250. RECORD_COMPONENT_DEF" />
  251. </module>
  252. <module name="NoWhitespaceBeforeCaseDefaultColon" />
  253. <module name="VariableDeclarationUsageDistance" />
  254. <module name="CustomImportOrder">
  255. <property name="sortImportsInGroupAlphabetically" value="true" />
  256. <property name="separateLineBetweenGroups" value="true" />
  257. <property name="customImportOrderRules" value="STATIC###THIRD_PARTY_PACKAGE" />
  258. <property name="tokens" value="IMPORT, STATIC_IMPORT, PACKAGE_DEF" />
  259. </module>
  260. <module name="MethodParamPad">
  261. <property name="tokens"
  262. value="CTOR_DEF, LITERAL_NEW, METHOD_CALL, METHOD_DEF,
  263. SUPER_CTOR_CALL, ENUM_CONSTANT_DEF, RECORD_DEF" />
  264. </module>
  265. <module name="NoWhitespaceBefore">
  266. <property name="tokens"
  267. value="COMMA, SEMI, POST_INC, POST_DEC, DOT,
  268. LABELED_STAT, METHOD_REF" />
  269. <property name="allowLineBreaks" value="true" />
  270. </module>
  271. <module name="ParenPad">
  272. <property name="tokens"
  273. value="ANNOTATION, ANNOTATION_FIELD_DEF, CTOR_CALL, CTOR_DEF, DOT, ENUM_CONSTANT_DEF,
  274. EXPR, LITERAL_CATCH, LITERAL_DO, LITERAL_FOR, LITERAL_IF, LITERAL_NEW,
  275. LITERAL_SWITCH, LITERAL_SYNCHRONIZED, LITERAL_WHILE, METHOD_CALL,
  276. METHOD_DEF, QUESTION, RESOURCE_SPECIFICATION, SUPER_CTOR_CALL, LAMBDA,
  277. RECORD_DEF" />
  278. </module>
  279. <module name="OperatorWrap">
  280. <property name="option" value="NL" />
  281. <property name="tokens"
  282. value="BAND, BOR, BSR, BXOR, DIV, EQUAL, GE, GT, LAND, LE, LITERAL_INSTANCEOF, LOR,
  283. LT, MINUS, MOD, NOT_EQUAL, PLUS, QUESTION, SL, SR, STAR, METHOD_REF,
  284. TYPE_EXTENSION_AND " />
  285. </module>
  286. <module name="AnnotationLocation">
  287. <property name="id" value="AnnotationLocationMostCases" />
  288. <property name="tokens"
  289. value="CLASS_DEF, INTERFACE_DEF, ENUM_DEF, METHOD_DEF, CTOR_DEF,
  290. RECORD_DEF, COMPACT_CTOR_DEF" />
  291. </module>
  292. <module name="AnnotationLocation">
  293. <property name="id" value="AnnotationLocationVariables" />
  294. <property name="tokens" value="VARIABLE_DEF" />
  295. <property name="allowSamelineMultipleAnnotations" value="true" />
  296. </module>
  297. <module name="NonEmptyAtclauseDescription" />
  298. <!--
  299. Commented out javadoc checks, these produce a lot (4k in jme3-core) of warnings so for now, might
  300. be too noisy
  301. <module name="InvalidJavadocPosition" />
  302. <module name="JavadocTagContinuationIndentation" />
  303. <module name="SummaryJavadoc">
  304. <property name="forbiddenSummaryFragments"
  305. value="^@return the *|^This method returns |^A [{]@code [a-zA-Z0-9]+[}]( is a )" />
  306. </module>
  307. <module name="JavadocParagraph" />
  308. <module name="RequireEmptyLineBeforeBlockTagGroup" />
  309. <module name="AtclauseOrder">
  310. <property name="tagOrder" value="@param, @return, @throws, @deprecated" />
  311. <property name="target"
  312. value="CLASS_DEF, INTERFACE_DEF, ENUM_DEF, METHOD_DEF, CTOR_DEF, VARIABLE_DEF" />
  313. </module>
  314. <module name="JavadocMethod">
  315. <property name="accessModifiers" value="public" />
  316. <property name="allowMissingParamTags" value="true" />
  317. <property name="allowMissingReturnTag" value="true" />
  318. <property name="allowedAnnotations" value="Override, Test" />
  319. <property name="tokens"
  320. value="METHOD_DEF, CTOR_DEF, ANNOTATION_FIELD_DEF, COMPACT_CTOR_DEF" />
  321. </module>
  322. <module name="MissingJavadocMethod">
  323. <property name="scope" value="public" />
  324. <property name="minLineCount" value="2" />
  325. <property name="allowedAnnotations" value="Override, Test" />
  326. <property name="tokens"
  327. value="METHOD_DEF, CTOR_DEF, ANNOTATION_FIELD_DEF,
  328. COMPACT_CTOR_DEF" />
  329. </module>
  330. <module name="MissingJavadocType">
  331. <property name="scope" value="protected" />
  332. <property name="tokens"
  333. value="CLASS_DEF, INTERFACE_DEF, ENUM_DEF,
  334. RECORD_DEF, ANNOTATION_DEF" />
  335. <property name="excludeScope" value="nothing" />
  336. </module>
  337. <module name="MethodName">
  338. <property name="format" value="^[a-z][a-z0-9][a-zA-Z0-9_]*$" />
  339. <message key="name.invalidPattern"
  340. value="Method name ''{0}'' must match pattern ''{1}''." />
  341. </module>
  342. <module name="SingleLineJavadoc" />
  343. -->
  344. <module name="EmptyCatchBlock">
  345. <property name="exceptionVariableName" value="expected" />
  346. </module>
  347. </module>
  348. </module>