RE: [PATCH] checkpatch: Improve tests for multiple line function definitions

From: Kershner, David A
Date: Wed Jun 07 2017 - 11:49:27 EST




> -----Original Message-----
> From: Joe Perches [mailto:joe@xxxxxxxxxxx]
> Sent: Wednesday, June 7, 2017 7:36 AM
> To: Andrew Morton <akpm@xxxxxxxxxxxxxxxxxxxx>; Andy Whitcroft
> <apw@xxxxxxxxxxxxx>
> Cc: Greg KH <gregkh@xxxxxxxxxxxxxxxxxxx>; Kershner, David A
> <David.Kershner@xxxxxxxxxx>; linux-kernel@xxxxxxxxxxxxxxx
> Subject: [PATCH] checkpatch: Improve tests for multiple line function
> definitions
>
> Add a block that identifies multiple line function definitions.
>
> Save the function name into $context_function to improve the embedded
> function name test.
>
> Look for misplaced open brace on the function definition.
> Emit an OPEN_BRACE error when the function definition is similar to
>
> void foo(int arg1,
> int arg2) {
>
> Miscellanea:
>
> o Remove the $realfile test in function declaration w/o named arguments
> test
> o Comment the function declaration w/o named arguments test
>
> Signed-off-by: Joe Perches <joe@xxxxxxxxxxx>

Thanks for the quick turnaround! I tested it on our drivers and it showed the
errors.

Tested-by: David Kershner <david.kershner@xxxxxxxxxx>

David Kershner


> ---
> scripts/checkpatch.pl | 26 +++++++++++++++++++++++++-
> 1 file changed, 25 insertions(+), 1 deletion(-)
>
> diff --git a/scripts/checkpatch.pl b/scripts/checkpatch.pl
> index 7fcaf5ca997b..3643d390eb1a 100755
> --- a/scripts/checkpatch.pl
> +++ b/scripts/checkpatch.pl
> @@ -5897,7 +5897,8 @@ sub process {
> "externs should be avoided in .c files\n" .
> $herecurr);
> }
>
> - if ($realfile =~ /\.[ch]$/ && defined $stat &&
> +# check for function declarations that have arguments without identifier
> names
> + if (defined $stat &&
> $stat =~
> /^.\s*(?:extern\s+)?$Type\s*$Ident\s*\(\s*([^{]+)\s*\)\s*;/s &&
> $1 ne "void") {
> my $args = trim($1);
> @@ -5910,6 +5911,29 @@ sub process {
> }
> }
>
> +# check for function definitions
> + if ($^V && $^V ge 5.10.0 &&
> + defined $stat &&
> + $stat =~
> /^.\s*(?:$Storage\s+)?$Type\s*($Ident)\s*$balanced_parens\s*{/s) {
> + $context_function = $1;
> +
> +# check for multiline function definition with misplaced open brace
> + my $ok = 0;
> + my $cnt = statement_rawlines($stat);
> + my $herectx = $here . "\n";
> + for (my $n = 0; $n < $cnt; $n++) {
> + my $rl = raw_line($linenr, $n);
> + $herectx .= $rl . "\n";
> + $ok = 1 if ($rl =~ /^[ \+]\{/);
> + $ok = 1 if ($rl =~ /\{/ && $n == 0);
> + last if $rl =~ /^[ \+].*\{/;
> + }
> + if (!$ok) {
> + ERROR("OPEN_BRACE",
> + "open brace '{' following function
> definitions go on the next line\n" . $herectx);
> + }
> + }
> +
> # checks for new __setup's
> if ($rawline =~ /\b__setup\("([^"]*)"/) {
> my $name = $1;
> --
> 2.10.0.rc2.1.g053435c