diff options
author | rillig <rillig@pkgsrc.org> | 2006-02-07 09:20:17 +0000 |
---|---|---|
committer | rillig <rillig@pkgsrc.org> | 2006-02-07 09:20:17 +0000 |
commit | 675546c4b7275be38d793ab753e6c21a2e99cc25 (patch) | |
tree | 9cb36043272bf74193d266960497b062856f587b | |
parent | 6561c363741477e961fb9dbaa3875dad56591291 (diff) | |
download | pkgsrc-675546c4b7275be38d793ab753e6c21a2e99cc25.tar.gz |
- Not only check for the definition of deprecated variables, but also for
using them.
- The :Q operator should not be used in double quotes.
-rw-r--r-- | pkgtools/pkglint/files/pkglint.pl | 32 |
1 files changed, 21 insertions, 11 deletions
diff --git a/pkgtools/pkglint/files/pkglint.pl b/pkgtools/pkglint/files/pkglint.pl index 4b8b9cfa444..66a590ac43f 100644 --- a/pkgtools/pkglint/files/pkglint.pl +++ b/pkgtools/pkglint/files/pkglint.pl @@ -1,5 +1,5 @@ #! @PERL@ -# $NetBSD: pkglint.pl,v 1.501 2006/02/06 10:07:23 rillig Exp $ +# $NetBSD: pkglint.pl,v 1.502 2006/02/07 09:20:17 rillig Exp $ # # pkglint - static analyzer and checker for pkgsrc packages @@ -2202,7 +2202,7 @@ sub checkline_cpp_macro_names($$) { sub checkline_mk_text($$) { my ($line, $text) = @_; - my ($rest, $state, $vartools); + my ($rest, $state, $vartools, $depr_map); if ($text =~ qr"^(?:[^#]*[^\$])?\$(\w+)") { my ($varname) = ($1); @@ -2220,11 +2220,17 @@ sub checkline_mk_text($$) { } $rest = $text; - while ($rest =~ s/(?:^|[^\$])\$\{([-A-Z0-9a-z_]+)(?::[^\}]+)?\}//) { - my ($varname) = ($1); + $depr_map = get_deprecated_map(); + while ($rest =~ s/(?:^|[^\$])\$\{([-A-Z0-9a-z_]+)(\.[\-0-9A-Z_a-z]+)?(?::[^\}]+)?\}//) { + my ($varbase, $varext) = ($1, $2); + my $varname = $varbase . (defined($varext) ? $varext : ""); + my $instead = + (exists($depr_map->{$varname})) ? $depr_map->{$varname} + : (exists($depr_map->{$varbase})) ? $depr_map->{$varbase} + : undef; - if (exists(get_deprecated_map()->{$varname})) { - $line->log_warning("Use of ${varname} is deprecated. ".get_deprecated_map()->{$varname}); + if (defined($instead)) { + $line->log_warning("Use of ${varname} is deprecated. ${instead}"); } } @@ -2301,16 +2307,19 @@ sub checkline_mk_shellword($$$) { || $rest =~ s/^\$\((${regex_varname})(:[^\)]+)?\)//) { my ($varname, $mod) = ($1, $2); - if (!$opt_warn_quoting) { - # Skip the following checks. - - } elsif ($state == SWST_PLAIN && defined($mod) && $mod =~ qr":Q$") { + if ($state == SWST_PLAIN && defined($mod) && $mod =~ qr":Q$") { # Fine. } elsif ($state == SWST_SQUOT && $varname =~ qr"(?:DIRS?|FILES?|PATH|^PREFIX|^LOCALBASE|^PKGNAME)$") { # Fine, too. - } else { + } elsif ($state == SWST_DQUOT && defined($mod) && $mod =~ qr":Q$") { + $line->log_warning("Please don't use the :Q operator in double quotes."); + $line->explain( + "Either remove the :Q or the double quotes. In most cases, it is more", + "appropriate to remove the double quotes."); + + } elsif ($opt_warn_quoting) { $line->log_warning("Possibly misquoted make variable ${varname} in " . user_statename->[$state] . "."); if ($state == SWST_PLAIN && !defined($mod)) { $line->replace("\${${varname}}", "\${${varname}:Q}"); @@ -3143,6 +3152,7 @@ sub checkline_mk_varassign($$$$$) { } } + checkline_mk_text($line, $value); checkline_mk_vartype($line, $varname, $op, $value, $comment); if (!$is_internal && $varname =~ qr"^_") { |