summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorrillig <rillig@pkgsrc.org>2007-08-13 08:08:44 +0000
committerrillig <rillig@pkgsrc.org>2007-08-13 08:08:44 +0000
commit0505043778dd7ea14cb5f13aa34957a9611ac6cb (patch)
tree0c491996dfb15ad2b91ba162c9e4ad934a09edb3
parentc3cfa6c470bc762dd400c22dbabb2a08edd07abc (diff)
downloadpkgsrc-0505043778dd7ea14cb5f13aa34957a9611ac6cb.tar.gz
Documented expect() and prepared pkglint for the upcoming introduction
of category.mk.
-rw-r--r--pkgtools/pkglint/files/pkglint.pl26
1 files changed, 14 insertions, 12 deletions
diff --git a/pkgtools/pkglint/files/pkglint.pl b/pkgtools/pkglint/files/pkglint.pl
index 1791e6d4458..d5ced3567e7 100644
--- a/pkgtools/pkglint/files/pkglint.pl
+++ b/pkgtools/pkglint/files/pkglint.pl
@@ -1,5 +1,5 @@
#! @PERL@
-# $NetBSD: pkglint.pl,v 1.713 2007/07/15 22:13:46 rillig Exp $
+# $NetBSD: pkglint.pl,v 1.714 2007/08/13 08:08:44 rillig Exp $
#
# pkglint - static analyzer and checker for pkgsrc packages
@@ -3071,6 +3071,16 @@ sub lines_log_warning($$$) {
}
}
+# Checks if the current line ($lines->{${$lineno_ref}}) matches the
+# regular expression, and if it does, increments ${${lineno_ref}}.
+# @param $lines
+# The lines that are checked.
+# @param $lineno_ref
+# A reference to the line number, an integer variable.
+# @param $regex
+# The regular expression to be checked.
+# @return
+# The result of the regular expression match or false.
sub expect($$$) {
my ($lines, $lineno_ref, $regex) = @_;
my $lineno = ${$lineno_ref};
@@ -7767,20 +7777,12 @@ sub checkdir_category() {
}
}
- # Then we need an empty line
- if ($lineno <= $#{$lines} && $lines->[$lineno]->text eq "") {
- $lineno++;
- } else {
- $lines->[$lineno]->log_error("Empty line expected.");
- }
+ expect_empty_line($lines, \$lineno);
# And, last but not least, the .include line
my $final_line = ".include \"../mk/bsd.pkg.subdir.mk\"";
- if ($lineno <= $#{$lines} && $lines->[$lineno]->text eq $final_line) {
- $lineno++;
- } else {
- $lines->[$lineno]->log_error("Expected this: ${final_line}.");
- }
+ expect($lines, \$lineno, qr"\Q$final_line\E")
+ || expect_text($lines, \$lineno, ".include \"../mk/misc/category.mk\"");
if ($lineno <= $#{$lines}) {
$lines->[$lineno]->log_error("The file should end here.");