Commit 91bfe484 authored by Joe Perches's avatar Joe Perches Committed by Linus Torvalds

checkpatch: add --types option to report only specific message types

Add a --types convenience option to show only specific message types.
Combined with the --fix option, this can produce specific suggested
formatting patches to files.
Signed-off-by: default avatarJoe Perches <joe@perches.com>
Signed-off-by: default avatarAndrew Morton <akpm@linux-foundation.org>
Signed-off-by: default avatarLinus Torvalds <torvalds@linux-foundation.org>
parent 61135e96
...@@ -31,8 +31,10 @@ my $show_types = 0; ...@@ -31,8 +31,10 @@ my $show_types = 0;
my $fix = 0; my $fix = 0;
my $root; my $root;
my %debug; my %debug;
my %ignore_type = ();
my %camelcase = (); my %camelcase = ();
my %use_type = ();
my @use = ();
my %ignore_type = ();
my @ignore = (); my @ignore = ();
my $help = 0; my $help = 0;
my $configuration_file = ".checkpatch.conf"; my $configuration_file = ".checkpatch.conf";
...@@ -56,6 +58,7 @@ Options: ...@@ -56,6 +58,7 @@ Options:
--terse one line per report --terse one line per report
-f, --file treat FILE as regular source file -f, --file treat FILE as regular source file
--subjective, --strict enable more subjective tests --subjective, --strict enable more subjective tests
--types TYPE(,TYPE2...) show only these comma separated message types
--ignore TYPE(,TYPE2...) ignore various comma separated message types --ignore TYPE(,TYPE2...) ignore various comma separated message types
--max-line-length=n set the maximum line length, if exceeded, warn --max-line-length=n set the maximum line length, if exceeded, warn
--show-types show the message "types" in the output --show-types show the message "types" in the output
...@@ -120,6 +123,7 @@ GetOptions( ...@@ -120,6 +123,7 @@ GetOptions(
'subjective!' => \$check, 'subjective!' => \$check,
'strict!' => \$check, 'strict!' => \$check,
'ignore=s' => \@ignore, 'ignore=s' => \@ignore,
'types=s' => \@use,
'show-types!' => \$show_types, 'show-types!' => \$show_types,
'max-line-length=i' => \$max_line_length, 'max-line-length=i' => \$max_line_length,
'root=s' => \$root, 'root=s' => \$root,
...@@ -150,8 +154,11 @@ if ($#ARGV < 0) { ...@@ -150,8 +154,11 @@ if ($#ARGV < 0) {
exit(1); exit(1);
} }
@ignore = split(/,/, join(',',@ignore)); sub hash_save_array_words {
foreach my $word (@ignore) { my ($hashRef, $arrayRef) = @_;
my @array = split(/,/, join(',', @$arrayRef));
foreach my $word (@array) {
$word =~ s/\s*\n?$//g; $word =~ s/\s*\n?$//g;
$word =~ s/^\s*//g; $word =~ s/^\s*//g;
$word =~ s/\s+/ /g; $word =~ s/\s+/ /g;
...@@ -160,9 +167,25 @@ foreach my $word (@ignore) { ...@@ -160,9 +167,25 @@ foreach my $word (@ignore) {
next if ($word =~ m/^\s*#/); next if ($word =~ m/^\s*#/);
next if ($word =~ m/^\s*$/); next if ($word =~ m/^\s*$/);
$ignore_type{$word}++; $hashRef->{$word}++;
}
} }
sub hash_show_words {
my ($hashRef, $prefix) = @_;
if ($quiet == 0 && keys $hashRef) {
print "NOTE: $prefix message types:";
foreach my $word (sort keys $hashRef) {
print " $word";
}
print "\n\n";
}
}
hash_save_array_words(\%ignore_type, \@ignore);
hash_save_array_words(\%use_type, \@use);
my $dbg_values = 0; my $dbg_values = 0;
my $dbg_possible = 0; my $dbg_possible = 0;
my $dbg_type = 0; my $dbg_type = 0;
...@@ -1367,6 +1390,8 @@ sub possible { ...@@ -1367,6 +1390,8 @@ sub possible {
my $prefix = ''; my $prefix = '';
sub show_type { sub show_type {
return defined $use_type{$_[0]} if (scalar keys %use_type > 0);
return !defined $ignore_type{$_[0]}; return !defined $ignore_type{$_[0]};
} }
...@@ -4190,13 +4215,8 @@ sub process { ...@@ -4190,13 +4215,8 @@ sub process {
} }
} }
if ($quiet == 0 && keys %ignore_type) { hash_show_words(\%use_type, "Used");
print "NOTE: Ignored message types:"; hash_show_words(\%ignore_type, "Ignored");
foreach my $ignore (sort keys %ignore_type) {
print " $ignore";
}
print "\n\n";
}
if ($clean == 0 && $fix && "@rawlines" ne "@fixed") { if ($clean == 0 && $fix && "@rawlines" ne "@fixed") {
my $newfile = $filename . ".EXPERIMENTAL-checkpatch-fixes"; my $newfile = $filename . ".EXPERIMENTAL-checkpatch-fixes";
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment