[<prev] [next>] [<thread-prev] [day] [month] [year] [list]
Message-ID: <CY4PR07MB31768353E8AE10181778F6D2F0C80@CY4PR07MB3176.namprd07.prod.outlook.com>
Date: Wed, 7 Jun 2017 15:49:15 +0000
From: "Kershner, David A" <David.Kershner@...sys.com>
To: Joe Perches <joe@...ches.com>,
Andrew Morton <akpm@...ux-foundation.org>,
Andy Whitcroft <apw@...onical.com>
CC: Greg KH <gregkh@...uxfoundation.org>,
"linux-kernel@...r.kernel.org" <linux-kernel@...r.kernel.org>
Subject: RE: [PATCH] checkpatch: Improve tests for multiple line function
definitions
> -----Original Message-----
> From: Joe Perches [mailto:joe@...ches.com]
> Sent: Wednesday, June 7, 2017 7:36 AM
> To: Andrew Morton <akpm@...ux-foundation.org>; Andy Whitcroft
> <apw@...onical.com>
> Cc: Greg KH <gregkh@...uxfoundation.org>; Kershner, David A
> <David.Kershner@...sys.com>; linux-kernel@...r.kernel.org
> 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@...ches.com>
Thanks for the quick turnaround! I tested it on our drivers and it showed the
errors.
Tested-by: David Kershner <david.kershner@...sys.com>
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
Powered by blists - more mailing lists