From: Dave Mitchell Date: Mon, 10 Nov 2008 23:28:35 +0000 (+0000) Subject: add -t (tabular option) to Porting/corecpan.pl X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=commitdiff_plain;h=b78893c9935e40731b0134c5996886a293086d32;p=p5sagit%2Fp5-mst-13.2.git add -t (tabular option) to Porting/corecpan.pl This allows multiple source trees to be compared p4raw-id: //depot/perl@34814 --- diff --git a/Porting/corecpan.pl b/Porting/corecpan.pl index 0bf3913..df2a70a 100644 --- a/Porting/corecpan.pl +++ b/Porting/corecpan.pl @@ -1,6 +1,7 @@ #!perl # Reports, in a perl source tree, which dual-lived core modules have not the # same version than the corresponding module on CPAN. +# with -t option, can compare multiple source trees in tabular form. use 5.9.0; use strict; @@ -8,18 +9,26 @@ use Getopt::Std; use ExtUtils::MM_Unix; use lib 'Porting'; use Maintainers qw(get_module_files %Modules); +use Cwd; + +use List::Util qw(max); our $packagefile = '02packages.details.txt'; sub usage () { die <) { my ($p, $v) = split ' '; + next if 1../^\s*$/; # skip header $cpanversions{$p} = $v; } close $fh; -for my $dist (sort keys %Modules) { - next unless $Modules{$dist}{CPAN}; - print "Module $dist...\n"; - for my $file (get_module_files($dist)) { - next if $file !~ /\.pm\z/ or $file =~ m{^t/} or $file =~ m{/t/}; - my $vcore = MM->parse_version($file) // 'undef'; - my $module = $file; - $module =~ s/\.pm\z//; - # some heuristics to figure out the module name from the file name - $module =~ s{^(lib|ext)/}{} - and $1 eq 'ext' - and ( $module =~ s{^(.*)/lib/\1\b}{$1}, - $module =~ s{(\w+)/\1\b}{$1}, - $module =~ s{^Encode/encoding}{encoding}, - $module =~ s{^MIME/Base64/QuotedPrint}{MIME/QuotedPrint}, - $module =~ s{^List/Util/lib/Scalar}{Scalar}, - ); - $module =~ s{/}{::}g; - my $vcpan = $cpanversions{$module} // 'not found'; - if (our $opt_v or $vcore ne $vcpan) { - print " $file: core=$vcore, cpan=$vcpan\n"; +my %results; + +# scan source tree(s) and CPAN module list, and put results in %results + +foreach my $source (@sources) { + my ($srcdir, $label) = @$source; + my $olddir = getcwd(); + chdir $srcdir or die "chdir $srcdir: $!\n"; + + for my $dist (sort keys %Modules) { + next unless $Modules{$dist}{CPAN}; + for my $file (get_module_files($dist)) { + next if $file !~ /\.pm\z/ or $file =~ m{^t/} or $file =~ m{/t/}; + my $vcore = '!EXIST'; + $vcore = MM->parse_version($file) // 'undef' if -f $file; + my $module = $file; + $module =~ s/\.pm\z//; + # some heuristics to figure out the module name from the file name + $module =~ s{^(lib|ext)/}{} + and $1 eq 'ext' + and ( $module =~ s{^(.*)/lib/\1\b}{$1}, + $module =~ s{(\w+)/\1\b}{$1}, + $module =~ s{^Encode/encoding}{encoding}, + $module =~ s{^MIME/Base64/QuotedPrint}{MIME/QuotedPrint}, + $module =~ s{^List/Util/lib/Scalar}{Scalar}, + ); + $module =~ s{/}{::}g; + my $vcpan = $cpanversions{$module} // 'undef'; + $results{$dist}{$file}{$label} = $vcore; + $results{$dist}{$file}{CPAN} = $vcpan; + } + } + + chdir $olddir or die "chdir $olddir: $!\n"; +} + +# output %results in the requested format + +my @labels = ((map $_->[1], @sources), 'CPAN' ); + +if ($opt_t) { + my %changed; + my @fields; + for my $dist (sort keys %results) { + for my $file (sort keys %{$results{$dist}}) { + my @versions = @{$results{$dist}{$file}}{@labels}; + for (0..$#versions) { + $fields[$_] = max($fields[$_], + length $versions[$_], + length $labels[$_], + length '!EXIST' + ); + } + if (our $opt_v or grep $_ ne $versions[0], @versions) { + $changed{$dist} = 1; + } + } + } + printf "%*s ", $fields[$_], $labels[$_] for 0..$#labels; + print "\n"; + printf "%*s ", $fields[$_], '-' x length $labels[$_] for 0..$#labels; + print "\n"; + + my $field_total; + $field_total += $_ + 1 for @fields; + + for my $dist (sort keys %results) { + next unless $changed{$dist}; + print " " x $field_total, " $dist\n"; + for my $file (sort keys %{$results{$dist}}) { + my @versions = @{$results{$dist}{$file}}{@labels}; + for (0..$#versions) { + printf "%*s ", $fields[$_], $versions[$_]//'!EXIST' + } + print " $file\n"; + } + } +} +else { + for my $dist (sort keys %results) { + print "Module $dist...\n"; + for my $file (sort keys %{$results{$dist}}) { + my ($vcpan, $vcore) = @{$results{$dist}{$file}}{@labels}; + if (our $opt_v or $vcore ne $vcpan) { + print " $file: core=$vcore, cpan=$vcpan\n"; + } } } }