Re: [PATCH] checkpatch: Minimize checkpatch induced patches...

From: Christian Borntraeger
Date: Wed Sep 14 2016 - 13:57:13 EST


On 09/14/2016 07:51 PM, Joe Perches wrote:
> checkpatch can be a useful tool for patches.
>
> It can be a much more controversial tool when used on files with the
> -f option for style and whitespace changes for code that is relatively
> stable, obsolete, or for maintained by specific individuals.
>
> o By default, allow checkpatch to be used with the -f|--file option
> for files in drivers/staging/
> o Add an undocumented --force command line option to be used together
> with the -f|--file option to scan any file
>
> Signed-off-by: Joe Perches <joe@xxxxxxxxxxx>
> cc: Greg KH <greg@xxxxxxxxx>
> cc: Jonathan Corbet <corbet@xxxxxxx>
> cc: Josh Triplett <josh@xxxxxxxxxxxxxxxx>
> cc: Christian Borntraeger <borntraeger@xxxxxxxxxx>
> cc: Theodore Ts'o <tytso@xxxxxxx>

This will certainly help to reduce the noise. On the other hand I remember Linus
saying something along the line that he does not like the -f parameter (and he
prefers to set this automatically). So while I like the approach I am not happy
enough to ack right now - still looking for a better alternative :-/
> ---
> scripts/checkpatch.pl | 6 ++++++
> 1 file changed, 6 insertions(+)
>
> diff --git a/scripts/checkpatch.pl b/scripts/checkpatch.pl
> index 0ef3d83..d998a61 100755
> --- a/scripts/checkpatch.pl
> +++ b/scripts/checkpatch.pl
> @@ -27,6 +27,7 @@ my $emacs = 0;
> my $terse = 0;
> my $showfile = 0;
> my $file = 0;
> +my $force = 0;
> my $git = 0;
> my %git_commits = ();
> my $check = 0;
> @@ -188,6 +189,7 @@ GetOptions(
> 'terse!' => \$terse,
> 'showfile!' => \$showfile,
> 'f|file!' => \$file,
> + 'force!' => \$force,
> 'g|git!' => \$git,
> 'subjective!' => \$check,
> 'strict!' => \$check,
> @@ -893,6 +895,10 @@ if ($git) {
> my $vname;
> for my $filename (@ARGV) {
> my $FILE;
> + if (!$force && $file && $filename !~ m@^drivers/staging/@) {
> + warn "$P: checking '$filename' is not supported\n";
> + next;
> + }
> if ($git) {
> open($FILE, '-|', "git format-patch -M --stdout -1 $filename") ||
> die "$P: $filename: git format-patch failed - $!\n";
>