Re: [PATCH v5] checkpatch: get default codespell dictionary path from package location

From: Joe Perches
Date: Tue Oct 12 2021 - 09:57:49 EST


On Tue, 2021-10-12 at 14:29 +0300, Peter Ujfalusi wrote:
> The standard location of dictionary.txt is under codespell's package, on
> my machine atm (codespell 2.1, Artix Linux):
> /usr/lib/python3.9/site-packages/codespell_lib/data/dictionary.txt
>
> Since we enable the codespell by default for SOF I have constant:
> No codespell typos will be found - \
> file '/usr/share/codespell/dictionary.txt': No such file or directory
>
> The patch proposes to try to fix up the path following the recommendation
> found here:
> https://github.com/codespell-project/codespell/issues/1540

trivia:

> @@ -325,9 +326,31 @@ GetOptions(
>   'kconfig-prefix=s' => \${CONFIG_},
>   'h|help' => \$help,
>   'version' => \$help
> -) or help(1);
> +) or $help = 2;
> +
> +my $python_codespell_dict = << "EOF";

Because you add a semicolon after "EOF"

> +import os.path as op
> +import codespell_lib
> +codespell_dir = op.dirname(codespell_lib.__file__)
> +codespell_file = op.join(codespell_dir, 'data', 'dictionary.txt')
> +print(codespell_file, end='')
> +EOF
> +;

this is an extra semicolon

> +if ($user_codespellfile) {
> + # Use the user provided codespell file unconditionally
> + $codespellfile = $user_codespellfile;
> +} else {
> + # Try to find the codespell install location to use it as default path
> + if (($codespell || $help) && which("codespell") ne "" && which("python") ne "") {

and I would keep the my $python_codespell_dict definition local to this block.

> + my $codespell_dict = `python3 -c "$python_codespell_dict" 2> /dev/null`;
> + $codespellfile = $codespell_dict if (-e $codespell_dict);
> + }
> +}

It's wrong to check which("python") and then exec `python3 ...`