- What?
- Quickstart
- Installation
- Usage
- Configuration
- Excluding
- Docker
- Continuous Integration
- Support
- Contributing
- Semantic Versioning Policy
This is a tool to check if your files consider your .editorconfig rules.
Most tools—like linters, for example—only test one filetype and need an extra configuration.
This tool only needs your .editorconfig to check all files.
If you don't know about editorconfig already you can read about it here: editorconfig.org.
Currently, implemented editorconfig features are:
- end_of_line
- insert_final_newline
- trim_trailing_whitespace
- indent_style
- indent_size
- max_line_length
Unsupported features are:
- charset
VERSION="v3.4.1"
OS="linux"
ARCH="amd64"
curl -O -L -C - https://github.com/editorconfig-checker/editorconfig-checker/releases/download/$VERSION/ec-$OS-$ARCH.tar.gz && \
tar xzf ec-$OS-$ARCH.tar.gz && \
./bin/ec-$OS-$ARCHGrab a binary from the release page.
If you have go installed you can run go get github.com/editorconfig-checker/editorconfig-checker/v3 
and run make build inside the project folder.
This will place a binary called ec into the bin directory.
If you are using Arch Linux, you can use pacman to install from extra repository:
pacman -S editorconfig-checkerAlso, development (VCS) package is available in the AUR:
# <favourite-aur-helper> <install-command> editorconfig-checker-git
# i.e.
paru -S editorconfig-checker-gitIf Go 1.16 or greater is installed, you can also install it globally via go install:
go install github.com/editorconfig-checker/editorconfig-checker/v3/cmd/editorconfig-checker@latestUSAGE:
  -config string
        config
  -debug
        print debugging information
  -disable-end-of-line
        disables the trailing whitespace check
  -disable-indent-size
        disables only the indent-size check
  -disable-indentation
        disables the indentation check
  -disable-insert-final-newline
        disables the final newline check
  -disable-trim-trailing-whitespace
        disables the trailing whitespace check
  -dry-run
        show which files would be checked
  -exclude string
        a regex which files should be excluded from checking - needs to be a valid regular expression
  -format
        specifies the output format, see "Formats" below for more information
  -h    print the help
  -help
        print the help
  -ignore-defaults
        ignore default excludes
  -init
        creates an initial configuration
  -no-color
        disables printing color
  -color
        enables printing color
  -v    print debugging information
  -verbose
        print debugging information
  -version
        print the version numberIf you run this tool from a repository root it will check all files which are added to the git repository and are text files. If the tool isn't able to determine a file type it will be added to be checked too.
If you run this tool from a normal directory it will check all files which are text files. If the tool isn't able to determine a file type it will be added to be checked too.
The following output formats are supported:
- default: Plain text, human readable output.
 <file>: <startingLine>-<endLine>: <message>
- gcc: GCC compatible output. Useful for editors that support compiling and showing syntax errors. 
 <file>:<line>:<column>: <type>: <message>
- github-actions: The format used by GitHub Actions 
 ::error file=<file>,line=<startingLine>,endLine=<endingLine>::<message>
- codeclimate: The Code Climate json format used for custom quality reports in GitLab CI
[ { "check_name": "editorconfig-checker", "description": "Wrong indent style found (tabs instead of spaces)", "fingerprint": "e87a958a3960d60a11d4b49c563cccd2", "severity": "minor", "location": { "path": ".vscode/extensions.json", "lines": { "begin": 2, "end": 2 } } } ]
The configuration is done via arguments or it will take the first config file found with the following file names:
- .editorconfig-checker.json
- .ecrc(deprecated filename, soon unsupported)
A sample configuration file can look like this and will be used from your current working directory if not specified via the --config argument:
{
  "Verbose": false,
  "Debug": false,
  "IgnoreDefaults": false,
  "SpacesAfterTabs": false,
  "NoColor": false,
  "Exclude": [],
  "AllowedContentTypes": [],
  "PassedFiles": [],
  "Disable": {
    "EndOfLine": false,
    "Indentation": false,
    "IndentSize": false,
    "InsertFinalNewline": false,
    "TrimTrailingWhitespace": false,
    "MaxLineLength": false
  }
}You can set any of the options under the "Disable" section to true to disable those particular checks.
You could also specify command line arguments, and they will get merged with the configuration file. The command line arguments have a higher precedence than the configuration.
You can create a configuration with the init-flag. If you specify a config-path it will be created there.
By default, the allowed_content_types are:
- text/(matches- text/plain,- text/html, etc.)
- application/ecmascript
- application/json
- application/x-ndjson
- application/xml
- +json(matches- application/geo+json, etc.)
- +xml(matches- application/rss+xml, etc.)
- application/octet-stream
application/octet-stream is needed as a fallback when no content type could be determined. You can add additional accepted content types with the allowed_content_types key. But the default ones don't get removed.
You can exclude single lines inline. To do that you need a comment on that line that says: editorconfig-checker-disable-line.
const myTemplateString = `
  first line
     wrongly indented line because it needs to be` // editorconfig-checker-disable-lineAlternatively, you can use editorconfig-checker-disable-next-line to skip the line that comes after this comment.
This modifier is present to improve readability, or because your sometimes have no other choice because of your own/language constraints.
// editorconfig-checker-disable-next-line used because blah blah blah what ever the reason blah
const myTemplateString = `a line that is (...) longer (...) than ... usual` // or with a very long inline commentPlease note that using editorconfig-checker-disable-next-line has only an effect on the next line, so it will report if the line where you added the modifier doesn't comply.
To temporarily disable all checks, add a comment containing editorconfig-checker-disable. Re-enable with a comment containing editorconfig-checker-enable
// editorconfig-checker-disable
const myTemplateString = `
  first line
     wrongly indented line because it needs to be
`
// editorconfig-checker-enableYou can exclude paths from being checked in several ways:
- ignoring a file by documenting it inside the to-be-excluded file
- adding a regex matching the path to the configuration file
- passing a regex matching the path as argument to --exclude
All these excludes are used in addition to the default excludes, unless you opt out of them.
If you want to see which files would be checked without checking them you can pass the --dry-run flag.
Note that while --dry-run might output absolute paths, the regular expression you write must match the filenames using relative paths from where editorconfig-checker is used. This becomes especially relevant if you need to anchor your regular expression in order to only match files in the top level your checked directory.
Additionally, paths will be normalized to Unix style before matching against the regex list happens. As a result you don't have to write [\\/] to account for Windows and Unix path styles but can just use / instead.
If you want to exclude a file inline you need a comment on the first line of the file that contains: editorconfig-checker-disable-file
-- editorconfig-checker-disable-file
add :: Int -> Int -> Int
add x y =
  let result = x + y -- falsy indentation would not report
  in result -- falsy indentation would not reportIf you choose to ignore them, these paths are excluded automatically:
// source control related files and folders
"\\.git/",
"\\.jj/",
// package manager, generated, & lock files
// Cargo (Rust)
"Cargo\\.lock$",
// Composer (PHP)
"composer\\.lock$",
// RubyGems (Ruby)
"Gemfile\\.lock$",
// Go Modules (Go)
"go\\.(mod|sum|work|work\\.sum)$",
// Gradle (Java)
"gradle/wrapper/gradle-wrapper\\.properties$",
"gradlew(\\.bat)?$",
"(buildscript-)?gradle\\.lockfile?$",
// Maven (Java)
"\\.mvn/wrapper/maven-wrapper\\.properties$",
"\\.mvn/wrapper/MavenWrapperDownloader\\.java$",
"mvnw(\\.cmd)?$",
// NodeJS
"/node_modules/",
// npm (NodeJS)
"npm-shrinkwrap\\.json$",
"package-lock\\.json$",
// pip (Python)
"Pipfile\\.lock$",
// Poetry (Python)
"poetry\\.lock$",
// pnpm (NodeJS)
"pnpm-lock\\.yaml$",
// Terraform & OpenTofu
"\\.terraform\\.lock\\.hcl$",
// uv (Python)
"uv\\.lock$",
// yarn (NodeJS)
"\\.pnp\\.c?js$",
"\\.pnp\\.loader\\.mjs$",
"\\.yarn/",
"yarn\\.lock$",
// font files
"\\.eot$",
"\\.otf$",
"\\.ttf$",
"\\.woff2?$",
// image & video formats
"\\.avif$",
"\\.gif$",
"\\.ico$",
"\\.jpe?g$",
"\\.mp4$",
"\\.p[bgnp]m$",
"\\.png$",
"\\.svg$",
"\\.tiff?$",
"\\.webp$",
"\\.wmv$",
// other binary or container formats
"\\.bak$",
"\\.bin$",
"\\.docx?$",
"\\.exe$",
"\\.pdf$",
"\\.snap$",
"\\.xlsx?$",
// archive formats
"\\.7z$",
"\\.bz2$",
"\\.gz$",
"\\.jar$",
"\\.tar$",
"\\.tgz$",
"\\.war$",
"\\.zip$",
// log & (git) patch files
"\\.log$",
"\\.patch$",
// generated or minified CSS and JavaScript files
"\\.(css|js)\\.map$",
"min\\.(css|js)$",If you either set IgnoreDefaults to true or pass the -ignore-defaults commandline switch, the default excludes will be ignored entirely.
In your configuration file you can exclude files with the "exclude" key which takes an array of regular expressions.
This will get merged with the default excludes (if not ignored). You should remember to escape your regular expressions correctly.
A configuration file which would ignore all test files and all Markdown files can look like this:
{
  "Verbose": false,
  "IgnoreDefaults": false,
  "Exclude": ["testfiles", "\\.md$"],
  "SpacesAfterTabs": false,
  "Disable": {
    "EndOfLine": false,
    "Indentation": false,
    "IndentSize": false,
    "InsertFinalNewline": false,
    "TrimTrailingWhitespace": false,
    "MaxLineLength": false
  }
}If you want to play around how the tool would behave you can also pass the --exclude argument to the binary. This will accept a regular expression as well. The argument given will be added to the excludes as defined by your configuration file (respecting both its Exclude and IgnoreDefaults settings).
For example: ec --exclude node_modules
You are able to run this tool inside a Docker container.
To do this you need to have Docker installed and run this command in your repository root which you want to check:
docker run --rm --volume=$PWD:/check mstruebing/editorconfig-checker
Docker Hub: mstruebing/editorconfig-checker
Instead of installing and configuring editorconfig-checker and all other linters in your project CI workflows (GitHub Actions & others), you can use Mega-Linter which does all that for you with a single assisted installation.
Mega-Linter embeds editorconfig-checker by default in all its flavors, meaning that it will be run at each commit or Pull Request to detect any issue related to .editorconfig.
If you want to use only editorconfig-checker and not the 70+ other linters, you can use the following .mega-linter.yml configuration file:
ENABLE:
  - EDITORCONFIGThe ss-open/ci/recipes project offers a ready to use lint job integrating editorconfig-checker.
- Main documentation: https://gitlab.com/ss-open/ci/recipes/-/blob/main/README.md
- Editorconfig job specific documentation: https://gitlab.com/ss-open/ci/recipes/-/blob/main/stages/lint/editorconfig/README.md
If you have any questions, suggestions, need a wrapper for a programming language or just want to chat join #editorconfig-checker on freenode(IRC). If you don't have an IRC-client set up you can use the freenode webchat.
Anyone can help to improve the project, submit a Feature Request, a bug report or even correct a spelling mistake.
The steps to contribute can be found in the CONTRIBUTING.md file.
editorconfig-checker adheres to Semantic Versioning for releases.
However, as it is a code quality tool, it's not always clear when a minor or major version bump occurs. The following rules are used to determine the version bump:
- Patch release (1.0.x -> 1.0.y)
- Updates to output formats (error messages, logs, ...).
- Performance improvements which doesn't affect behavior.
- Build process changes (e.g., updating dependencies, updating Dockerfile, ...).
- Reverts (reverting a previous commit).
- Bug fixes which result in editorconfig-checker reporting less linting errors (removing "false-positive" linting errors).
 
- Minor release (1.x.0 -> 1.y.0)
- Adding new configuration options, including new CLI flags.
- Adding new path to exclude by default.
- Adding new output formats.
- Supporting a new editorconfig property (e.g: insert_final_newline,indent_size, ...).
- Any new feature which doesn't break existing behavior.
 
- Major release (x.0.0 -> y.0.0)
- Removal of a configuration option.
- Removal of an output format.
- Removal of a path to exclude by default.
- Removal of support for an editorconfig property.
- Bug fixes, which result in editorconfig-checker reporting more linting errors, because the previous behavior was incorrect according to the editorconfig specification.