forked from mirrors/linux
		
	checkpatch: add checks for question mark and colon spacing
Add checks for the question mark colon operator spacing, and also check the other uses of colon. Colon means a number of things: - it introduces the else part of the ?: operator, - it terminates a goto label, - it terminates the case value, - it separates the identifier from the bit size on bit fields, and - it is used to introduce option types in asm(). Signed-off-by: Andy Whitcroft <apw@shadowen.org> Signed-off-by: Andrew Morton <akpm@linux-foundation.org> Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
This commit is contained in:
		
							parent
							
								
									d250658658
								
							
						
					
					
						commit
						1f65f947a6
					
				
					 1 changed files with 72 additions and 9 deletions
				
			
		| 
						 | 
					@ -689,17 +689,20 @@ sub cat_vet {
 | 
				
			||||||
my $av_preprocessor = 0;
 | 
					my $av_preprocessor = 0;
 | 
				
			||||||
my $av_pending;
 | 
					my $av_pending;
 | 
				
			||||||
my @av_paren_type;
 | 
					my @av_paren_type;
 | 
				
			||||||
 | 
					my $av_pend_colon;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
sub annotate_reset {
 | 
					sub annotate_reset {
 | 
				
			||||||
	$av_preprocessor = 0;
 | 
						$av_preprocessor = 0;
 | 
				
			||||||
	$av_pending = '_';
 | 
						$av_pending = '_';
 | 
				
			||||||
	@av_paren_type = ('E');
 | 
						@av_paren_type = ('E');
 | 
				
			||||||
 | 
						$av_pend_colon = 'O';
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
sub annotate_values {
 | 
					sub annotate_values {
 | 
				
			||||||
	my ($stream, $type) = @_;
 | 
						my ($stream, $type) = @_;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	my $res;
 | 
						my $res;
 | 
				
			||||||
 | 
						my $var = '_' x length($stream);
 | 
				
			||||||
	my $cur = $stream;
 | 
						my $cur = $stream;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	print "$stream\n" if ($dbg_values > 1);
 | 
						print "$stream\n" if ($dbg_values > 1);
 | 
				
			||||||
| 
						 | 
					@ -784,7 +787,12 @@ sub annotate_values {
 | 
				
			||||||
			$av_pending = 'N';
 | 
								$av_pending = 'N';
 | 
				
			||||||
			$type = 'N';
 | 
								$type = 'N';
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		} elsif ($cur =~/^(return|case|else|goto)/o) {
 | 
							} elsif ($cur =~/^(case)/o) {
 | 
				
			||||||
 | 
								print "CASE($1)\n" if ($dbg_values > 1);
 | 
				
			||||||
 | 
								$av_pend_colon = 'C';
 | 
				
			||||||
 | 
								$type = 'N';
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							} elsif ($cur =~/^(return|else|goto)/o) {
 | 
				
			||||||
			print "KEYWORD($1)\n" if ($dbg_values > 1);
 | 
								print "KEYWORD($1)\n" if ($dbg_values > 1);
 | 
				
			||||||
			$type = 'N';
 | 
								$type = 'N';
 | 
				
			||||||
 | 
					
 | 
				
			||||||
| 
						 | 
					@ -809,6 +817,15 @@ sub annotate_values {
 | 
				
			||||||
			$type = 'V';
 | 
								$type = 'V';
 | 
				
			||||||
			$av_pending = 'V';
 | 
								$av_pending = 'V';
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							} elsif ($cur =~ /^($Ident\s*):/) {
 | 
				
			||||||
 | 
								if ($type eq 'E') {
 | 
				
			||||||
 | 
									$av_pend_colon = 'L';
 | 
				
			||||||
 | 
								} elsif ($type eq 'T') {
 | 
				
			||||||
 | 
									$av_pend_colon = 'B';
 | 
				
			||||||
 | 
								}
 | 
				
			||||||
 | 
								print "IDENT_COLON($1,$type>$av_pend_colon)\n" if ($dbg_values > 1);
 | 
				
			||||||
 | 
								$type = 'V';
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		} elsif ($cur =~ /^($Ident|$Constant)/o) {
 | 
							} elsif ($cur =~ /^($Ident|$Constant)/o) {
 | 
				
			||||||
			print "IDENT($1)\n" if ($dbg_values > 1);
 | 
								print "IDENT($1)\n" if ($dbg_values > 1);
 | 
				
			||||||
			$type = 'V';
 | 
								$type = 'V';
 | 
				
			||||||
| 
						 | 
					@ -820,8 +837,24 @@ sub annotate_values {
 | 
				
			||||||
		} elsif ($cur =~/^(;|{|})/) {
 | 
							} elsif ($cur =~/^(;|{|})/) {
 | 
				
			||||||
			print "END($1)\n" if ($dbg_values > 1);
 | 
								print "END($1)\n" if ($dbg_values > 1);
 | 
				
			||||||
			$type = 'E';
 | 
								$type = 'E';
 | 
				
			||||||
 | 
								$av_pend_colon = 'O';
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		} elsif ($cur =~ /^(;|\?|:|\[)/o) {
 | 
							} elsif ($cur =~ /^(\?)/o) {
 | 
				
			||||||
 | 
								print "QUESTION($1)\n" if ($dbg_values > 1);
 | 
				
			||||||
 | 
								$type = 'N';
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							} elsif ($cur =~ /^(:)/o) {
 | 
				
			||||||
 | 
								print "COLON($1,$av_pend_colon)\n" if ($dbg_values > 1);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
								substr($var, length($res), 1, $av_pend_colon);
 | 
				
			||||||
 | 
								if ($av_pend_colon eq 'C' || $av_pend_colon eq 'L') {
 | 
				
			||||||
 | 
									$type = 'E';
 | 
				
			||||||
 | 
								} else {
 | 
				
			||||||
 | 
									$type = 'N';
 | 
				
			||||||
 | 
								}
 | 
				
			||||||
 | 
								$av_pend_colon = 'O';
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							} elsif ($cur =~ /^(;|\[)/o) {
 | 
				
			||||||
			print "CLOSE($1)\n" if ($dbg_values > 1);
 | 
								print "CLOSE($1)\n" if ($dbg_values > 1);
 | 
				
			||||||
			$type = 'N';
 | 
								$type = 'N';
 | 
				
			||||||
 | 
					
 | 
				
			||||||
| 
						 | 
					@ -840,7 +873,7 @@ sub annotate_values {
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	return $res;
 | 
						return ($res, $var);
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
sub possible {
 | 
					sub possible {
 | 
				
			||||||
| 
						 | 
					@ -1294,12 +1327,14 @@ sub process {
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		# Track the 'values' across context and added lines.
 | 
							# Track the 'values' across context and added lines.
 | 
				
			||||||
		my $opline = $line; $opline =~ s/^./ /;
 | 
							my $opline = $line; $opline =~ s/^./ /;
 | 
				
			||||||
		my $curr_values = annotate_values($opline . "\n", $prev_values);
 | 
							my ($curr_values, $curr_vars) =
 | 
				
			||||||
 | 
									annotate_values($opline . "\n", $prev_values);
 | 
				
			||||||
		$curr_values = $prev_values . $curr_values;
 | 
							$curr_values = $prev_values . $curr_values;
 | 
				
			||||||
		if ($dbg_values) {
 | 
							if ($dbg_values) {
 | 
				
			||||||
			my $outline = $opline; $outline =~ s/\t/ /g;
 | 
								my $outline = $opline; $outline =~ s/\t/ /g;
 | 
				
			||||||
			print "$linenr > .$outline\n";
 | 
								print "$linenr > .$outline\n";
 | 
				
			||||||
			print "$linenr > $curr_values\n";
 | 
								print "$linenr > $curr_values\n";
 | 
				
			||||||
 | 
								print "$linenr >  $curr_vars\n";
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
		$prev_values = substr($curr_values, -1);
 | 
							$prev_values = substr($curr_values, -1);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
| 
						 | 
					@ -1490,7 +1525,8 @@ sub process {
 | 
				
			||||||
				<<=|>>=|<=|>=|==|!=|
 | 
									<<=|>>=|<=|>=|==|!=|
 | 
				
			||||||
				\+=|-=|\*=|\/=|%=|\^=|\|=|&=|
 | 
									\+=|-=|\*=|\/=|%=|\^=|\|=|&=|
 | 
				
			||||||
				=>|->|<<|>>|<|>|=|!|~|
 | 
									=>|->|<<|>>|<|>|=|!|~|
 | 
				
			||||||
				&&|\|\||,|\^|\+\+|--|&|\||\+|-|\*|\/|%
 | 
									&&|\|\||,|\^|\+\+|--|&|\||\+|-|\*|\/|%|
 | 
				
			||||||
 | 
									\?|:
 | 
				
			||||||
			}x;
 | 
								}x;
 | 
				
			||||||
			my @elements = split(/($ops|;)/, $opline);
 | 
								my @elements = split(/($ops|;)/, $opline);
 | 
				
			||||||
			my $off = 0;
 | 
								my $off = 0;
 | 
				
			||||||
| 
						 | 
					@ -1554,6 +1590,9 @@ sub process {
 | 
				
			||||||
				#	print "UNARY: <$op_left$op_type $is_unary $a:$op:$c> <$ca:$op:$cc> <$unary_ctx>\n";
 | 
									#	print "UNARY: <$op_left$op_type $is_unary $a:$op:$c> <$ca:$op:$cc> <$unary_ctx>\n";
 | 
				
			||||||
				#}
 | 
									#}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
									# Get the full operator variant.
 | 
				
			||||||
 | 
									my $opv = $op . substr($curr_vars, $off, 1);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
				# Ignore operators passed as parameters.
 | 
									# Ignore operators passed as parameters.
 | 
				
			||||||
				if ($op_type ne 'V' &&
 | 
									if ($op_type ne 'V' &&
 | 
				
			||||||
				    $ca =~ /\s$/ && $cc =~ /^\s*,/) {
 | 
									    $ca =~ /\s$/ && $cc =~ /^\s*,/) {
 | 
				
			||||||
| 
						 | 
					@ -1571,8 +1610,10 @@ sub process {
 | 
				
			||||||
				# // is a comment
 | 
									# // is a comment
 | 
				
			||||||
				} elsif ($op eq '//') {
 | 
									} elsif ($op eq '//') {
 | 
				
			||||||
 | 
					
 | 
				
			||||||
				# -> should have no spaces
 | 
									# No spaces for:
 | 
				
			||||||
				} elsif ($op eq '->') {
 | 
									#   ->
 | 
				
			||||||
 | 
									#   :   when part of a bitfield
 | 
				
			||||||
 | 
									} elsif ($op eq '->' || $opv eq ':B') {
 | 
				
			||||||
					if ($ctx =~ /Wx.|.xW/) {
 | 
										if ($ctx =~ /Wx.|.xW/) {
 | 
				
			||||||
						ERROR("spaces prohibited around that '$op' $at\n" . $hereptr);
 | 
											ERROR("spaces prohibited around that '$op' $at\n" . $hereptr);
 | 
				
			||||||
					}
 | 
										}
 | 
				
			||||||
| 
						 | 
					@ -1628,11 +1669,33 @@ sub process {
 | 
				
			||||||
							$hereptr);
 | 
												$hereptr);
 | 
				
			||||||
					}
 | 
										}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
									# A colon needs no spaces before when it is
 | 
				
			||||||
 | 
									# terminating a case value or a label.
 | 
				
			||||||
 | 
									} elsif ($opv eq ':C' || $opv eq ':L') {
 | 
				
			||||||
 | 
										if ($ctx =~ /Wx./) {
 | 
				
			||||||
 | 
											ERROR("space prohibited before that '$op' $at\n" . $hereptr);
 | 
				
			||||||
 | 
										}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
				# All the others need spaces both sides.
 | 
									# All the others need spaces both sides.
 | 
				
			||||||
				} elsif ($ctx !~ /[EWC]x[CWE]/) {
 | 
									} elsif ($ctx !~ /[EWC]x[CWE]/) {
 | 
				
			||||||
 | 
										my $ok = 0;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
					# Ignore email addresses <foo@bar>
 | 
										# Ignore email addresses <foo@bar>
 | 
				
			||||||
					if (!($op eq '<' && $cb =~ /$;\S+\@\S+>/) &&
 | 
										if (($op eq '<' &&
 | 
				
			||||||
					    !($op eq '>' && $cb =~ /<\S+\@\S+$;/)) {
 | 
										     $cc =~ /^\S+\@\S+>/) ||
 | 
				
			||||||
 | 
										    ($op eq '>' &&
 | 
				
			||||||
 | 
										     $ca =~ /<\S+\@\S+$/))
 | 
				
			||||||
 | 
										{
 | 
				
			||||||
 | 
										    	$ok = 1;
 | 
				
			||||||
 | 
										}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
										# Ignore ?:
 | 
				
			||||||
 | 
										if (($opv eq ':O' && $ca =~ /\?$/) ||
 | 
				
			||||||
 | 
										    ($op eq '?' && $cc =~ /^:/)) {
 | 
				
			||||||
 | 
										    	$ok = 1;
 | 
				
			||||||
 | 
										}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
										if ($ok == 0) {
 | 
				
			||||||
						ERROR("spaces required around that '$op' $at\n" . $hereptr);
 | 
											ERROR("spaces required around that '$op' $at\n" . $hereptr);
 | 
				
			||||||
					}
 | 
										}
 | 
				
			||||||
				}
 | 
									}
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
		Loading…
	
		Reference in a new issue