diff options
author | rillig <rillig@pkgsrc.org> | 2007-02-20 10:14:55 +0000 |
---|---|---|
committer | rillig <rillig@pkgsrc.org> | 2007-02-20 10:14:55 +0000 |
commit | a9998c791b57b7821db88f7ac665001074d09183 (patch) | |
tree | 08a1e34f9b388ae4b34adf25db60d83d37885dcc /pkgtools/pkglint | |
parent | 79c6d231d01dd18378b90ff3fc236d834c1eb540 (diff) | |
download | pkgsrc-a9998c791b57b7821db88f7ac665001074d09183.tar.gz |
Fixed the detection of ": Avoid regenerating within pkgsrc".
Diffstat (limited to 'pkgtools/pkglint')
-rw-r--r-- | pkgtools/pkglint/files/pkglint.pl | 20 |
1 files changed, 13 insertions, 7 deletions
diff --git a/pkgtools/pkglint/files/pkglint.pl b/pkgtools/pkglint/files/pkglint.pl index f5caf3e5a52..2f65a714ce2 100644 --- a/pkgtools/pkglint/files/pkglint.pl +++ b/pkgtools/pkglint/files/pkglint.pl @@ -1,5 +1,5 @@ #! @PERL@ -# $NetBSD: pkglint.pl,v 1.698 2007/02/19 12:06:03 rillig Exp $ +# $NetBSD: pkglint.pl,v 1.699 2007/02/20 10:14:55 rillig Exp $ # # pkglint - static analyzer and checker for pkgsrc packages @@ -2780,7 +2780,8 @@ sub is_emptydir($) { # Guess the type of file based on the filename. This is used to select # the proper subroutine for detecting absolute pathnames. # -# Returns one of "source", "shell", "make", "text", "ignore", "unknown". +# Returns one of "source", "shell", "make", "text", "configure", +# "ignore", "unknown". # sub get_filetype($$) { my ($line, $fname) = @_; @@ -2796,10 +2797,11 @@ sub get_filetype($$) { return "make"; } - # Too many false positives. + # Too many false positives for shell scripts, so configure + # scripts get their own category. if ($basename =~ qr"^configure(?:|\.ac)$") { $opt_debug_unchecked and $line->log_debug("Skipped check for absolute pathnames."); - return "ignore"; + return "configure"; } if ($basename =~ qr"\.(?:sh|m4)$"i) { @@ -6872,15 +6874,17 @@ sub checkfile_patch($) { } checkline_mk_absolute_pathname($line, $shellword); } + + } elsif ($current_ftype eq "source") { + checkline_source_absolute_pathname($line, $text); + + } elsif ($current_ftype eq "configure") { if ($text =~ qr": Avoid regenerating within pkgsrc$") { $line->log_error("This code must not be included in patches."); $line->explain_error( "It is generated automatically by pkgsrc after the patch phase."); } - } elsif ($current_ftype eq "source") { - checkline_source_absolute_pathname($line, $text); - } elsif ($current_ftype eq "ignore") { # Ignore it. @@ -6988,6 +6992,7 @@ sub checkfile_patch($) { }], [PST_CFA, re_patch_cfa, PST_CH, sub() { $current_fname = $m->text(1); $current_ftype = get_filetype($line, $current_fname); + $opt_debug_patches and $line->log_debug("fname=$current_fname ftype=$current_ftype"); $patched_files++; $hunks = 0; }], [PST_CH, re_patch_ch, PST_CHD, sub() { @@ -7040,6 +7045,7 @@ sub checkfile_patch($) { }], [PST_UFA, re_patch_ufa, PST_UH, sub() { $current_fname = $m->text(1); $current_ftype = get_filetype($line, $current_fname); + $opt_debug_patches and $line->log_debug("fname=$current_fname ftype=$current_ftype"); $patched_files++; $hunks = 0; }], [PST_UH, re_patch_uh, PST_UL, sub() { |