mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/next/linux-next.git
synced 2025-01-16 21:35:07 +00:00
checkpatch: add test for repeated const uses
Using 'const <type> const *' is generally meant to be written 'const <type> * const'. Add a test for the miswritten form. Signed-off-by: Joe Perches <joe@perches.com> Signed-off-by: Andrew Morton <akpm@linux-foundation.org> Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
This commit is contained in:
parent
f34e4a4f97
commit
ab7e23f344
@ -323,6 +323,7 @@ our $Operators = qr{
|
|||||||
|
|
||||||
our $c90_Keywords = qr{do|for|while|if|else|return|goto|continue|switch|default|case|break}x;
|
our $c90_Keywords = qr{do|for|while|if|else|return|goto|continue|switch|default|case|break}x;
|
||||||
|
|
||||||
|
our $BasicType;
|
||||||
our $NonptrType;
|
our $NonptrType;
|
||||||
our $NonptrTypeMisordered;
|
our $NonptrTypeMisordered;
|
||||||
our $NonptrTypeWithAttr;
|
our $NonptrTypeWithAttr;
|
||||||
@ -514,6 +515,11 @@ sub build_types {
|
|||||||
my $Misordered = "(?x: \n" . join("|\n ", @typeListMisordered) . "\n)";
|
my $Misordered = "(?x: \n" . join("|\n ", @typeListMisordered) . "\n)";
|
||||||
my $allWithAttr = "(?x: \n" . join("|\n ", @typeListWithAttr) . "\n)";
|
my $allWithAttr = "(?x: \n" . join("|\n ", @typeListWithAttr) . "\n)";
|
||||||
$Modifier = qr{(?:$Attribute|$Sparse|$mods)};
|
$Modifier = qr{(?:$Attribute|$Sparse|$mods)};
|
||||||
|
$BasicType = qr{
|
||||||
|
(?:$typeOtherOSTypedefs\b)|
|
||||||
|
(?:$typeTypedefs\b)|
|
||||||
|
(?:${all}\b)
|
||||||
|
}x;
|
||||||
$NonptrType = qr{
|
$NonptrType = qr{
|
||||||
(?:$Modifier\s+|const\s+)*
|
(?:$Modifier\s+|const\s+)*
|
||||||
(?:
|
(?:
|
||||||
@ -3192,6 +3198,18 @@ sub process {
|
|||||||
$herecurr);
|
$herecurr);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
# check for const <foo> const where <foo> is not a pointer or array type
|
||||||
|
if ($sline =~ /\bconst\s+($BasicType)\s+const\b/) {
|
||||||
|
my $found = $1;
|
||||||
|
if ($sline =~ /\bconst\s+\Q$found\E\s+const\b\s*\*/) {
|
||||||
|
WARN("CONST_CONST",
|
||||||
|
"'const $found const *' should probably be 'const $found * const'\n" . $herecurr);
|
||||||
|
} elsif ($sline !~ /\bconst\s+\Q$found\E\s+const\s+\w+\s*\[/) {
|
||||||
|
WARN("CONST_CONST",
|
||||||
|
"'const $found const' should probably be 'const $found'\n" . $herecurr);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
# check for non-global char *foo[] = {"bar", ...} declarations.
|
# check for non-global char *foo[] = {"bar", ...} declarations.
|
||||||
if ($line =~ /^.\s+(?:static\s+|const\s+)?char\s+\*\s*\w+\s*\[\s*\]\s*=\s*\{/) {
|
if ($line =~ /^.\s+(?:static\s+|const\s+)?char\s+\*\s*\w+\s*\[\s*\]\s*=\s*\{/) {
|
||||||
WARN("STATIC_CONST_CHAR_ARRAY",
|
WARN("STATIC_CONST_CHAR_ARRAY",
|
||||||
|
Loading…
x
Reference in New Issue
Block a user