| <?xml version="1.0"?> |
| <!-- |
| * Licensed to the Apache Software Foundation (ASF) under one or more |
| * contributor license agreements. See the NOTICE file distributed with |
| * this work for additional information regarding copyright ownership. |
| * The ASF licenses this file to You under the Apache License, Version 2.0 |
| * (the "License"); you may not use this file except in compliance with |
| * the License. You may obtain a copy of the License at |
| * |
| * http://www.apache.org/licenses/LICENSE-2.0 |
| * |
| * Unless required by applicable law or agreed to in writing, software |
| * distributed under the License is distributed on an "AS IS" BASIS, |
| * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
| * See the License for the specific language governing permissions and |
| * limitations under the License. |
| --> |
| <!DOCTYPE module PUBLIC |
| "-//Puppy Crawl//DTD Check Configuration 1.2//EN" |
| "http://www.puppycrawl.com/dtds/configuration_1_2.dtd"> |
| <!-- |
| |
| Checkstyle configuration that checks the sun coding conventions from: |
| |
| - the Java Language Specification at |
| http://java.sun.com/docs/books/jls/second_edition/html/index.html |
| |
| - the Sun Code Conventions at http://java.sun.com/docs/codeconv/ |
| |
| - the Javadoc guidelines at |
| http://java.sun.com/j2se/javadoc/writingdoccomments/index.html |
| |
| - the JDK Api documentation http://java.sun.com/j2se/docs/api/index.html |
| |
| - some best practices |
| |
| Checkstyle is very configurable. Be sure to read the documentation at |
| http://checkstyle.sf.net (or in your downloaded distribution). |
| |
| Most Checks are configurable, be sure to consult the documentation. |
| |
| To completely disable a check, just comment it out or delete it from the file. |
| |
| Finally, it is worth reading the documentation. |
| |
| --> |
| <!-- |
| |
| This ruleset is customized for Apache Commons SCXML. |
| |
| For changes to the defaults sun checks, search for string "Commons SCXML" |
| |
| --> |
| <module name="Checker"> |
| |
| <!-- Checks that a package.html file exists for each package. --> |
| <!-- See http://checkstyle.sourceforge.net/config_javadoc.html#JavadocPackage --> |
| <module name="JavadocPackage"> |
| <property name="allowLegacy" value="true" /> |
| </module> |
| |
| <!-- Checks whether files end with a new line. --> |
| <!-- See http://checkstyle.sf.net/config_misc.html#NewlineAtEndOfFile --> |
| <module name="NewlineAtEndOfFile" /> |
| |
| <!-- Checks that property files contain the same keys. --> |
| <!-- See http://checkstyle.sf.net/config_misc.html#Translation --> |
| <module name="Translation" /> |
| |
| <!-- Checks for Headers --> |
| <!-- See http://checkstyle.sf.net/config_header.html --> |
| <module name="Header"> |
| <!-- The follow property value demonstrates the ability --> |
| <!-- to have access to ANT properties. In this case it uses --> |
| <!-- the ${basedir} property to allow Checkstyle to be run --> |
| <!-- from any directory within a project. See property --> |
| <!-- expansion, --> |
| <!-- http://checkstyle.sf.net/config.html#properties --> |
| <!-- <property --> |
| <!-- name="headerFile" --> |
| <!-- value="${basedir}/java.header"/> --> |
| <property name="headerFile" value="${checkstyle.header.file}" /> |
| <property name="fileExtensions" value="java" /> |
| </module> |
| |
| <!-- Checks for File length Violations. --> |
| <!-- See http://checkstyle.sf.net/config_sizes.html --> |
| <module name="FileLength" /> |
| |
| <!-- See: http://checkstyle.sourceforge.net/config_whitespace.html#FileTabCharacter --> |
| <module name="FileTabCharacter"> |
| <property name="fileExtensions" value="java" /> |
| </module> |
| |
| <!-- See: http://checkstyle.sourceforge.net/config_regexp.html#RegexpSingleline --> |
| <module name="RegexpSingleline"> |
| <property name="format" value="\s+$" /> |
| <property name="message" value="Line has trailing spaces." /> |
| </module> |
| |
| <module name="LineLength"> |
| <property name="max" value="160" /> |
| </module> |
| |
| <module name="TreeWalker"> |
| |
| <module name="ExplicitInitializationCheck" /> |
| |
| <!-- Checks for Javadoc comments. --> |
| <!-- See http://checkstyle.sf.net/config_javadoc.html --> |
| <module name="JavadocMethod" /> |
| <module name="JavadocType" /> |
| <module name="JavadocVariable" /> |
| <module name="JavadocStyle" /> |
| |
| <!-- Checks for Naming Conventions. --> |
| <!-- See http://checkstyle.sf.net/config_naming.html --> |
| <module name="ConstantName" /> |
| <module name="LocalFinalVariableName" /> |
| <module name="LocalVariableName" /> |
| <module name="MemberName" /> |
| <module name="MethodName" /> |
| <module name="PackageName" /> |
| <module name="ParameterName" /> |
| <module name="StaticVariableName" /> |
| <module name="TypeName" /> |
| |
| <!-- Checks for imports --> |
| <!-- See http://checkstyle.sf.net/config_import.html --> |
| <module name="AvoidStarImport" /> |
| <module name="IllegalImport" /> <!-- defaults to sun.* packages --> |
| <module name="RedundantImport" /> |
| <module name="UnusedImports" /> |
| |
| <!-- Checks for Size Violations. --> |
| <!-- See http://checkstyle.sf.net/config_sizes.html --> |
| <module name="MethodLength" /> |
| <!--module name="ParameterNumber"/ --> |
| |
| <!-- Checks for whitespace --> |
| <!-- See http://checkstyle.sf.net/config_whitespace.html --> |
| <module name="EmptyForIteratorPad" /> |
| <module name="NoWhitespaceAfter" /> |
| <module name="NoWhitespaceBefore" /> |
| <module name="OperatorWrap" /> |
| <module name="ParenPad" /> |
| <module name="TypecastParenPad" /> |
| <module name="WhitespaceAfter" /> |
| <module name="WhitespaceAround" /> |
| |
| <!-- Modifier Checks --> |
| <!-- See http://checkstyle.sf.net/config_modifiers.html --> |
| <module name="ModifierOrder" /> |
| <module name="RedundantModifier" /> |
| |
| <!-- Checks for blocks. You know, those {}'s --> |
| <!-- See http://checkstyle.sf.net/config_blocks.html --> |
| <module name="AvoidNestedBlocks" /> |
| <module name="EmptyBlock" /> |
| <module name="LeftCurly" /> |
| <module name="NeedBraces" /> |
| <module name="RightCurly" /> |
| |
| |
| <!-- Checks for common coding problems --> |
| <!-- See http://checkstyle.sf.net/config_coding.html --> |
| <module name="AvoidInlineConditionals" /> |
| <module name="EmptyStatement" /> |
| <module name="EqualsHashCode" /> |
| <!-- Commons SCXML change # 2 : Turn off the hidden field check based on discussion on dev AT commons.apache.org The code uses same names for arguments in side-effect |
| free setters. --> |
| <!--module name="HiddenField"/ --> |
| <module name="IllegalInstantiation" /> |
| <module name="InnerAssignment" /> |
| <module name="MagicNumber" /> |
| <module name="MissingSwitchDefault" /> |
| <module name="SimplifyBooleanExpression" /> |
| <module name="SimplifyBooleanReturn" /> |
| |
| <!-- Checks for class design --> |
| <!-- See http://checkstyle.sf.net/config_design.html --> |
| <!-- Commons SCXML change # 3 : Turn off the design for extension check based on discussion on dev AT commons.apache.org --> |
| <!--module name="DesignForExtension"/ --> |
| <!--module name="FinalClass"/ --> |
| <module name="HideUtilityClassConstructor" /> |
| <module name="InterfaceIsType" /> |
| <module name="VisibilityModifier" /> |
| |
| <!-- Miscellaneous other checks. --> |
| <!-- See http://checkstyle.sf.net/config_misc.html --> |
| <module name="ArrayTypeStyle" /> |
| <module name="FinalParameters" /> |
| <module name="TodoComment" /> |
| <module name="UpperEll" /> |
| <module name="ImportOrder"> |
| <property name="option" value="top"/> |
| <property name="groups" value="java,javax,org"/> |
| <property name="ordered" value="true"/> |
| <property name="separated" value="true"/> |
| </module> |
| |
| </module> |
| <!-- @author tags are deprecated --> |
| <module name="RegexpSingleline"> |
| <property name="format" value="^\s+\*\s+@author\s" /> |
| <property name="message" value="Deprecated @author tag" /> |
| <property name="fileExtensions" value="java" /> |
| <property name="severity" value="warning" /> |
| </module> |
| </module> |