For the latest updates and improvements, see the latest Cloud documentation instead.
Codacy configuration file¶
Codacy supports configuring certain advanced features through a configuration file:
-
Ignoring files globally, for duplication, or a specific tool
-
Configuring a specific repository directory on which to start the analysis
-
Adding custom extensions to languages, keeping in mind that some tools might not work out of the box with those extensions
Note
- If a Codacy configuration file exists in your repository, the Ignored Files settings in the Codacy UI don't apply.
- To disable a tool you must use the Code Patterns page instead.
To use a Codacy configuration file:
-
Create a text file with the name
.codacy.yml
or.codacy.yaml
on the root of your repository. -
Add your settings to the configuration file based on the example template below.
Important
The configuration file must start with a line containing a triple dash (
---
).--- engines: rubocop: exclude_paths: - "config/test.yml" base_sub_dir: "test/baseDir" duplication: exclude_paths: - "config/test.yml" config: languages: - "ruby" languages: css: extensions: - "-css.resource" exclude_paths: - ".bundle/**" - "spec/**/*" - "benchmarks/**/*" - "**.min.js" - "**/tests/**"
-
Optionally, validate the syntax of your configuration file with the Codacy Analysis CLI by running the following command in the same folder as the Codacy configuration file:
codacy-analysis-cli validate-configuration --directory `pwd`
Syntax for excluding files¶
To ignore files, you must use the Java glob syntax to define one or more exclude_paths
patterns. For example:
Example pattern | Ignored files |
---|---|
test/README.md |
The file test/README.md |
test/* |
All files in the root of test |
test/** |
All files and directories inside test |
test/**/* |
All files inside sub-directories of test |
**.resource |
All .resource files across all your repository |
**/*.resource |
All .resource files in all directories and sub-directories |
Which tools can be configured and which name should I use?¶
You can configure all tools supported by Codacy using the configuration file.
The following are the tool names that must be used in the Codacy configuration file:
ameba
bandit
brakeman
bundleraudit
checkstyle
codacy-scalameta-pro
codenarc
coffeelint
cppcheck
credo
csslint
detekt
eslint
findbugs
findbugssec
flawfinder
golint
govet
hadolint
jacksonlinter
jshint
nsp
phpcs
phpmd
pmd-legacy
pmd
prospector
psscriptanalyzer
pylint
pylintpython3
remark-int
rubocop
scalastyle
scsslint
shellcheck
sonarscharp
spotbugs
SQLint
stylelint
swiftlint
tailor
tslint
tsqllint
If you have questions about the Codacy configuration file please contact us at support@codacy.com.
Share your feedback 📢
Did this page help you?
Thanks for the feedback! Is there anything else you'd like to tell us about this page?
255 characters left
We're sorry to hear that. Please let us know what we can improve:
255 characters left
Alternatively, you can create a more detailed issue on our GitHub repository.
Thanks for helping improve the Codacy documentation.
If you have a question or need help please contact support@codacy.com.