summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorDavid Mitchell <davem@iabyn.com>2009-05-17 00:31:43 +0100
committerDavid Mitchell <davem@iabyn.com>2009-05-17 01:43:21 +0100
commitda92fd6071387be2a444dac8cdba07b4488e05e0 (patch)
tree5fcd30c79835178bbb22639f4d812474e87fe765
parent2a570317cfc4bd5eea92957f4973877418392dbe (diff)
downloadperl-da92fd6071387be2a444dac8cdba07b4488e05e0.tar.gz
add reload_manifest() function to Porting/maintainers.pm
to allow the MANIFEST file to be read more than once. Also be more liberal in parsing the MANIFEST file (it now handles lines with no second column), and warn on bad lines .
-rw-r--r--Porting/Maintainers.pm31
1 files changed, 22 insertions, 9 deletions
diff --git a/Porting/Maintainers.pm b/Porting/Maintainers.pm
index 666e4516db..7929352e68 100644
--- a/Porting/Maintainers.pm
+++ b/Porting/Maintainers.pm
@@ -18,25 +18,38 @@ use vars qw(@ISA @EXPORT_OK $VERSION);
@ISA = qw(Exporter);
@EXPORT_OK = qw(%Modules %Maintainers
get_module_files get_module_pat
- show_results process_options files_to_modules);
-$VERSION = 0.02;
+ show_results process_options files_to_modules
+ reload_manifest);
+$VERSION = 0.03;
require Exporter;
use File::Find;
use Getopt::Long;
my %MANIFEST;
-if (open(MANIFEST, "MANIFEST")) {
- while (<MANIFEST>) {
- if (/^(\S+)\t+(.+)$/) {
- $MANIFEST{$1}++;
+
+# (re)read the MANIFEST file, blowing away any previous effort
+
+sub reload_manifest {
+ %MANIFEST = ();
+ if (open(MANIFEST, "MANIFEST")) {
+ while (<MANIFEST>) {
+ if (/^(\S+)/) {
+ $MANIFEST{$1}++;
+ }
+ else {
+ warn "MANIFEST:$.: malformed line: $_\n";
+ }
}
+ close MANIFEST;
+ } else {
+ die "$0: Failed to open MANIFEST for reading: $!\n";
}
- close MANIFEST;
-} else {
- die "$0: Failed to open MANIFEST for reading: $!\n";
}
+reload_manifest;
+
+
sub get_module_pat {
my $m = shift;
split ' ', $Modules{$m}{FILES};