[SCM] Git repository for devscripts branch, master, updated. v2.12.4-43-g227b8b8

Benjamin Drung bdrung at debian.org
Thu Oct 25 20:17:07 UTC 2012


The following commit has been merged in the master branch:
commit 66e25e4e82f183bc4c7631a73c4110829d135e0c
Author: Raphael Geissert <geissert at debian.org>
Date:   Sun Oct 21 23:14:57 2012 -0500

    checkbashisms: check for incorrect args. to 'exit' (Closes: #687450)
    
    Signed-off-by: Benjamin Drung <bdrung at debian.org>

diff --git a/scripts/checkbashisms.pl b/scripts/checkbashisms.pl
index 8f9b19c..11767ce 100755
--- a/scripts/checkbashisms.pl
+++ b/scripts/checkbashisms.pl
@@ -430,6 +430,13 @@ foreach my $filename (@ARGV) {
 		    output_explanation($display_filename, $orig_line, $explanation);
 		}
 	    }
+	    # This check requires the value to be compared, which could
+	    # be done in the regex itself but requires "use re 'eval'".
+	    # So it's better done in its own
+	    if ($line =~ m/$LEADIN(exit\s+(\d{3,}))/ && $2 > 255) {
+		$explanation = 'exit status code greater than 255';
+		output_explanation($display_filename, $orig_line, $explanation);
+	    }
 
 	    # Only look for the beginning of a heredoc here, after we've
 	    # stripped out quoted material, to avoid false positives.
@@ -609,6 +616,8 @@ sub init_hashes {
 	$LEADIN . qr'command\s+-[^p]\s' =>  q<'command' with option other than -p>,
 	$LEADIN . qr'setvar\s' =>  q<setvar 'foo' 'bar' should be eval 'foo="'"$bar"'"'>,
 	$LEADIN . qr'trap\s+["\']?.*["\']?\s+.*(?:ERR|DEBUG|RETURN)' => q<trap with ERR|DEBUG|RETURN>,
+	$LEADIN . qr'exit\s+-\d' => q<exit with negative status code>,
+	$LEADIN . qr'exit\s+--' => q<'exit --' should be 'exit'>,
     );
 
     %string_bashisms = (

-- 
Git repository for devscripts



More information about the devscripts-devel mailing list