Skip to content

Commit

Permalink
typos: fix unexpected behaviour
Browse files Browse the repository at this point in the history
Use excludes from .typos.toml when running `pre-commit run typos --all-files`.

Since we don't set "pass_filenames = false" for typos (see
upstream discussions [0]), we must ensure that pre-commit never
passes the files specified as excludes in `.typos.toml` to
`typos` as argument, if possible. Otherwise,
`$ pre-commit run typos --all-files` has another behaviour than
`$ typos .`, which is confusing and wrong.

To not break anything, and to be compliant with the existing
API, we encourage users to provide the `.typos.toml` as Nix
path, so the excludes can be read via evaluation time.

The `configAsFile` variable is the path where the configuration
file can be found by the `typos` utility when it executes in the
user environment. Not necessarily in Nix store.

[0]: #387 (comment)
  • Loading branch information
phip1611 committed Mar 12, 2024
1 parent 5df5a70 commit 7756e23
Showing 1 changed file with 68 additions and 6 deletions.
74 changes: 68 additions & 6 deletions modules/hooks.nix
Original file line number Diff line number Diff line change
Expand Up @@ -1115,10 +1115,24 @@ in
extend-glob = []
'';
};
# Recommended way to specifcy a config, as this way, exludes can be
# taken into account by pre-commit when running
# `$ pre-commit run --all-files`.
# We provide configFile and configPath for API compatibility with
# previous versions and coherence with other hooks defined here.
configFile =
mkOption {
type = types.path;
description = lib.mdDoc "Path to a typos config file (in Nix store).";
default = null;
example = "./.typos.toml";
};
# It is recommended to use configFile instead, as it provides more
# flexibility and a more correct/expected behaviour.
configPath =
mkOption {
type = types.str;
description = lib.mdDoc "Path to a custom config file.";
description = lib.mdDoc "Path to a typos config file (relative to the PWD where pre-commit runs).";
default = "";
example = ".typos.toml";
};
Expand Down Expand Up @@ -2456,21 +2470,68 @@ in
entry = "${settings.treefmt.package}/bin/treefmt --fail-on-change";
};
typos =
let
# Since we don't set "pass_filenames = false" for typos (see
# upstream discussions [0]), we must ensure that pre-commit never
# passes the files specified as excludes in `.typos.toml` to
# `typos` as argument, if possible. Otherwise,
# `$ pre-commit run typos --all-files` has another behaviour than
# `$ typos .`, which is confusing and wrong.
#
# To not break anything, and to be compliant with the existing
# API, we encourage users to provide the `.typos.toml` as Nix
# path, so the excludes can be read via evaluation time.
#
# The `configAsFile` variable is the path where the configuration
# file can be found by the `typos` utility when it executes in the
# user environment. Not necessarily in Nix store.
#
# [0]: https://github.com/cachix/pre-commit-hooks.nix/pull/387#issuecomment-1893600631
configAsFile =
# Highest precedence.
if settings.typos.configFile != null
then (toString settings.typos.configFile)
# Secondary precedence.
else if settings.typos.configPath != ""
then settings.typos.configPath
# Lowest precedence.
else
builtins.toFile "config.toml"
# Concatenate config in config file with section for ignoring words
# generated from list of words to ignore
("${settings.typos.config}" +
lib.strings.optionalString (settings.typos.ignored-words != [ ]) "\n\[default.extend-words\]" +
lib.strings.concatMapStrings (x: "\n${x} = \"${x}\"") settings.typos.ignored-words
)
;
# If the config file path is passed as Nix string and not as Nix
# Path, we can't read it from Nix, unfortunately.
excludesFromConfig =
if settings.typos.configPath == "" # passed directly or as Path
then
(
let
toml = builtins.fromTOML (builtins.readFile configAsFile);
in
# The "files.extend-exclude" key comes from
# https://github.com/crate-ci/typos/blob/master/docs/reference.md
(toml.files or { }).extend-exclude or [ ]
)
else
[ ];
in
{
name = "typos";
description = "Source code spell checker";
entry =
let
# Concatenate config in config file with section for ignoring words generated from list of words to ignore
config = "${settings.typos.config}" + lib.strings.optionalString (settings.typos.ignored-words != [ ]) "\n\[default.extend-words\]" + lib.strings.concatMapStrings (x: "\n${x} = \"${x}\"") settings.typos.ignored-words;
configFile = builtins.toFile "typos-config.toml" config;
cmdArgs =
mkCmdArgs
(with settings.typos; [
# Config file always exists.
[ true "--config ${configAsFile}" ]
[ binary "--binary" ]
[ (color != "auto") "--color ${color}" ]
[ (config != "") "--config ${configFile}" ]
[ (configPath != "" && config == "") "--config ${configPath}" ]
[ diff "--diff" ]
[ (exclude != "") "--exclude ${exclude} --force-exclude" ]
[ (format != "long") "--format ${format}" ]
Expand All @@ -2486,6 +2547,7 @@ in
in
"${tools.typos}/bin/typos ${cmdArgs}";
types = [ "text" ];
excludes = excludesFromConfig;
};
typstfmt = {
name = "typstfmt";
Expand Down

0 comments on commit 7756e23

Please sign in to comment.