Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

docs: config-cli-lint-mode.md: Grammar tweaks #2953

Merged
merged 4 commits into from
Sep 20, 2023
Merged
Changes from 1 commit
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
18 changes: 9 additions & 9 deletions docs/config-cli-lint-mode.md
Original file line number Diff line number Diff line change
Expand Up @@ -8,22 +8,22 @@ description: Cli lint mode can be list_of_files, project or files

# CLI lint mode

Each linter has a lint mode by default, visible in its MegaLinter documentation ([example](https://megalinter.io/latest/descriptors/repository_trivy/#how-the-linting-is-performed)):
Each linter is pre-configured to use a default lint mode, which are visible in the MegaLinter documentation ([example](https://megalinter.io/latest/descriptors/repository_trivy/#how-the-linting-is-performed)). The possible values are:

- `list_of_files`: All files are sent in single call to the linter
- `project`: The linter is called from the root of the project, without specifying any file name
- `file`: The linter is called once by file (so the performances may not be very good)
- `list_of_files`: The linter is called only once, and passed a list of all the files to be processed
- `project`: The linter is responsible to scan all the files in the repository, as no filenames are provided it
rasa marked this conversation as resolved.
Show resolved Hide resolved
- `file`: The linter is called once per file (which hurts performance)
rasa marked this conversation as resolved.
Show resolved Hide resolved

You can override the CLI_LINT_MODE by using configuration variable for each linter (see [linters documentation](https://megalinter.io/supported-linters/))
You can override the CLI_LINT_MODE by using a configuration variable for each linter (see [linters documentation](https://megalinter.io/supported-linters/)).

- Linters with `file` default lint mode can not be overridden to `list_of_files`
- Linters with `project` default lint mode can not be overridden to `list_of_files` or `file`
- Linters using the `file` lint mode cannot be overridden to use the `list_of_files` lint mode
- Linters using the `project` lint mode cannot be overridden to use either the `list_of_files` or `file` lint modes.
rasa marked this conversation as resolved.
Show resolved Hide resolved

Allowing `file` or `list_of_files` to be overridden to `project` is mostly for workarounds, for example with linters that have a problem to find their config file when the current folder isn't the repo root.
Allowing `file` or `list_of_files` to be overridden to `project` is mostly for a workaround. For example, with linters that have a problem finding their config file when the current folder isn't the repository's root folder.
rasa marked this conversation as resolved.
Show resolved Hide resolved

Special considerations:

- As list of files isn't sent to the linter command, linters using `project` lint mode don't take in account some variables like FILTER_REGEX_INCLUDE and FILTER_REGEX_EXCLUDE. For those linters, you must check their documentation to define ignore configuration as it's awaited by the linter (for example with a `.secretlintignore` file for secretlint)
- Linters that are configured to use `project` lint mode ignore variables like `FILTER_REGEX_INCLUDE` and `FILTER_REGEX_EXCLUDE`, as they are not passed a list of files to lint. For those linters, you must check their documentation to see if a linter can be configured to ignore specific files (for example, the secretlint linter ignores files listed in a `.secretlintignore` file, in the root of the repository).
rasa marked this conversation as resolved.
Show resolved Hide resolved


<!-- config-cli-lint-mode-section-end -->