RegexpOnFilename
Since Checkstyle 6.15
Description
When customizing the check, the properties are applied in a specific order. The fileExtensions property first picks only files that match any of the specific extensions supplied. Once files are matched against the fileExtensions, the match property is then used in conjunction with the patterns to determine if the check is looking for a match or mismatch on those files. If the fileNamePattern is supplied, the matching is only applied to the fileNamePattern and not the folderPattern. If no fileNamePattern is supplied, then matching is applied to the folderPattern only and will result in all files in a folder to be reported on violations. If no folderPattern is supplied, then all folders that checkstyle finds are examined for violations. The ignoreFileNameExtensions property drops the file extension and applies the fileNamePattern only to the rest of file name. For example, if the file is named 'test.java' and this property is turned on, the pattern is only applied to 'test'.
If this check is configured with no properties, then the default behavior of this check is to report file names with spaces in them. When at least one pattern property is supplied, the entire check is under the user's control to allow them to fully customize the behavior.
It is recommended that if you create your own pattern, to also specify a custom violation message. This allows the violation message printed to be clear what the violation is, especially if multiple RegexpOnFilename checks are used. Argument 0 for the message populates the check's folderPattern. Argument 1 for the message populates the check's fileNamePattern. The file name is not passed as an argument since it is part of CheckStyle's default violation messages.
Properties
| name | description | type | default value | since | 
|---|---|---|---|---|
| fileExtensions | Specify the file extensions of the files to process. | String[] | all files | 6.15 | 
| fileNamePattern | Specify the regular expression to match the file name against. | Pattern | null | 6.15 | 
| folderPattern | Specify the regular expression to match the folder path against. | Pattern | null | 6.15 | 
| ignoreFileNameExtensions | Control whether to ignore the file extension for the file name match. | boolean | false | 6.15 | 
| match | Control whether to look for a match or mismatch on the file name, if the fileNamePattern is supplied, otherwise it is applied on the folderPattern. | boolean | true | 6.15 | 
Examples
To configure the check to report file names that contain a space:
<module name="Checker">
  <module name="RegexpOnFilename"/>
</module>
Example1:
.../checkstyle.xml
.../Test Example1.xml // violation, 'File match folder pattern '' and file pattern '\s'.'
.../TestExample2.xml
.../TestExample3.md
.../TestExample4.xml
To configure the check to forbid 'xml' files in folders:
<module name="Checker">
  <module name="RegexpOnFilename">
    <property name="fileNamePattern" value="^TestExample\d+\.xml$"/>
    <message key="regexp.filename.match"
      value="xml files should not match ''{1}''"/>
  </module>
</module>
Example2:
.../checkstyle.xml
.../Test Example1.xml
.../TestExample2.xml // violation, 'xml files should not match '^TestExample\d+\.xml$''
.../TestExample3.md
.../TestExample4.xml // violation, 'xml files should not match '^TestExample\d+\.xml$''
To configure the check to forbid 'md' files except 'README.md file' in folders, with custom message:
<module name="Checker">
  <module name="RegexpOnFilename">
    <property name="fileNamePattern" value="README"/>
    <property name="fileExtensions" value="md"/>
    <property name="match" value="false"/>
    <message key="regexp.filename.mismatch"
      value="No *.md files other than README.md"/>
  </module>
</module>
Example3:
.../checkstyle.xml
.../Test Example1.xml
.../TestExample2.xml
.../TestExample3.md  // violation, 'No *.md files other than README.md'
.../TestExample4.xml
To configure the check to only allow property and xml files to be located in the resource folder:
<module name="Checker">
  <module name="RegexpOnFilename">
    <property name="fileNamePattern" value=".*\.(properties|xml)$"/>
    <property name="match" value="false"/>
    <message key="regexp.filename.mismatch"
      value="Only property and xml files to be located in the resource folder"/>
  </module>
</module>
Example4:
.../checkstyle.xml
.../Test Example1.xml
.../TestExample2.xml
.../TestExample3.md  // violation, 'Only property and xml files to be located in the resource folder'
.../TestExample4.xml
To configure the check to only allow only camelcase
<module name="Checker">
  <module name="RegexpOnFilename">
    <property name="fileNamePattern" value="^([A-Z][a-z0-9]+\.?)+$"/>
    <property name="match" value="false"/>
    <property name="ignoreFileNameExtensions" value="true"/>
    <message key="regexp.filename.mismatch"
      value="only filenames in camelcase is allowed"/>
  </module>
</module>
Example5:
.../checkstyle.xml    // violation, 'only filenames in camelcase is allowed'
.../Test Example1.xml // violation, 'only filenames in camelcase is allowed'
.../TestExample2.xml
.../TestExample3.md
.../TestExample4.xml
Example of Usage
Violation Messages
All messages can be customized if the default message doesn't suit you. Please see the documentation to learn how to.
Package
com.puppycrawl.tools.checkstyle.checks.regexp






