summaryrefslogtreecommitdiff
path: root/pkgtools
diff options
context:
space:
mode:
Diffstat (limited to 'pkgtools')
-rw-r--r--pkgtools/pkglint/files/pkglint.pl24
1 files changed, 17 insertions, 7 deletions
diff --git a/pkgtools/pkglint/files/pkglint.pl b/pkgtools/pkglint/files/pkglint.pl
index eee68cb4ea7..1791e6d4458 100644
--- a/pkgtools/pkglint/files/pkglint.pl
+++ b/pkgtools/pkglint/files/pkglint.pl
@@ -1,5 +1,5 @@
#! @PERL@
-# $NetBSD: pkglint.pl,v 1.712 2007/07/10 15:27:57 joerg Exp $
+# $NetBSD: pkglint.pl,v 1.713 2007/07/15 22:13:46 rillig Exp $
#
# pkglint - static analyzer and checker for pkgsrc packages
@@ -1294,7 +1294,7 @@ use enum qw(:SUBST_ ID CLASS STAGE MESSAGE FILES SED VARS FILTER_CMD);
sub new($) {
my ($class) = @_;
- my ($self) = ([undef, undef, undef, undef, [], [], undef, undef]);
+ my ($self) = ([undef, undef, undef, undef, [], [], [], undef]);
bless($self, $class);
return $self;
}
@@ -1304,19 +1304,21 @@ sub subst_stage($) { return shift(@_)->[SUBST_STAGE]; }
sub subst_message($) { return shift(@_)->[SUBST_MESSAGE]; }
sub subst_files($) { return shift(@_)->[SUBST_FILES]; }
sub subst_sed($) { return shift(@_)->[SUBST_SED]; }
+sub subst_vars($) { return shift(@_)->[SUBST_VARS]; }
sub subst_filter_cmd($) { return shift(@_)->[SUBST_FILTER_CMD]; }
sub subst_id($) { return shift(@_)->[SUBST_ID]; }
sub init($) {
my ($self) = @_;
+ $self->[SUBST_ID] = undef;
$self->[SUBST_CLASS] = undef;
$self->[SUBST_STAGE] = undef;
$self->[SUBST_MESSAGE] = undef;
$self->[SUBST_FILES] = [];
$self->[SUBST_SED] = [];
+ $self->[SUBST_VARS] = [];
$self->[SUBST_FILTER_CMD] = undef;
- $self->[SUBST_ID] = undef;
}
sub check_end($$) {
@@ -1333,8 +1335,8 @@ sub check_end($$) {
if (@{$self->subst_files} == 0) {
$line->log_warning("Incomplete SUBST block: SUBST_FILES missing.");
}
- if (@{$self->subst_sed} == 0 && !defined($self->subst_filter_cmd)) {
- $line->log_warning("Incomplete SUBST block: SUBST_SED missing.");
+ if (@{$self->subst_sed} == 0 && @{$self->subst_vars} == 0 && !defined($self->subst_filter_cmd)) {
+ $line->log_warning("Incomplete SUBST block: SUBST_SED or SUBST_VARS missing.");
}
$self->init();
}
@@ -1345,7 +1347,7 @@ sub is_complete($) {
return false unless defined($self->subst_id);
return false unless defined($self->subst_class);
return false unless defined($self->subst_files);
- return false unless defined($self->subst_sed);
+ return false if @{$self->subst_sed} == 0 && @{$self->subst_vars} == 0;
return true;
}
@@ -1372,7 +1374,7 @@ sub check_varassign($$$$$) {
$id = $self->subst_id;
- if ($varname =~ qr"^(SUBST_(?:STAGE|MESSAGE|FILES|SED|FILTER_CMD))\.([\-\w_]+)$") {
+ if ($varname =~ qr"^(SUBST_(?:STAGE|MESSAGE|FILES|SED|VARS|FILTER_CMD))\.([\-\w_]+)$") {
($varbase, $varparam) = ($1, $2);
if (!defined($id)) {
@@ -1441,6 +1443,14 @@ sub check_varassign($$$$$) {
$self->[SUBST_FILTER_CMD] = $value;
}
+ } elsif ($varbase eq "SUBST_VARS") {
+ if (@{$self->subst_vars} > 0) {
+ if ($op ne "+=") {
+ $line->log_warning("All but the first SUBST_VARS line should use the \"+=\" operator.");
+ }
+ }
+ push(@{$self->subst_vars}, $value);
+
} else {
$line->log_warning("Foreign variable in SUBST block.");
}