X-Git-Url: http://git.rot13.org/?a=blobdiff_plain;f=koha_perl_deps.pl;h=cf686324fade0fcd5c56c87f095c6f516f205b11;hb=d05a7e4a73066a546d7ebcfc5af215a0549ae1fb;hp=934dea58e63bf62d01fbfe4b20b21145e3974c99;hpb=e08d35bdc32b4dfada80d0018f66457846e6b298;p=koha.git diff --git a/koha_perl_deps.pl b/koha_perl_deps.pl index 934dea58e6..cf686324fa 100755 --- a/koha_perl_deps.pl +++ b/koha_perl_deps.pl @@ -9,8 +9,7 @@ use lib $FindBin::Bin; use C4::Installer::PerlModules; -use strict; -use warnings; +use Modern::Perl; my $help = 0; my $missing = 0; @@ -18,6 +17,8 @@ my $installed = 0; my $upgrade = 0; my $all = 0; my $color = 0; +my $brief = 0; +my $req = 0; GetOptions( 'h|help|?' => \$help, @@ -25,13 +26,15 @@ GetOptions( 'i|installed' => \$installed, 'u|upgrade' => \$upgrade, 'a|all' => \$all, + 'b|brief' => \$brief, + 'r|required' => \$req, 'c|color' => \$color, ); pod2usage(1) if $help || (!$missing && !$installed && !$upgrade && !$all); my $koha_pm = C4::Installer::PerlModules->new; -$koha_pm->version_info(all => 1); +$koha_pm->versions_info; my @pm = (); @@ -39,11 +42,14 @@ push @pm, 'missing_pm' if $missing || $all; push @pm, 'upgrade_pm' if $upgrade || $all; push @pm, 'current_pm' if $installed || $all; -print color 'bold white' if $color; -print" -Module Name Current Version Required Version Module Required --------------------------------------------------------------------------------------------------------------------------- +if (!$brief) { + print color 'bold blue' if $color; + print" + Installed Required Module is +Module Name Version Version Required +-------------------------------------------------------------------------------------------- "; +} my $count = 0; foreach my $type (@pm) { @@ -55,31 +61,45 @@ foreach my $type (@pm) { print color 'yellow' if $type eq 'upgrade_pm' && $color; print color 'red' if $type eq 'missing_pm' && $color; print color 'green' if $type eq 'current_pm' && $color; - $count++; my $required = ($_->{$pm}->{'required'}?'Yes':'No'); my $current_version = ($color ? $_->{$pm}->{'cur_ver'} : $type eq 'missing_pm' || $type eq 'upgrade_pm' ? $_->{$pm}->{'cur_ver'}." *" : $_->{$pm}->{'cur_ver'}); + if (!$brief) { + if (($req && $required eq 'Yes') || !$req) { format = -@<<<<<<<<<<<<<<<<<<<<<<<<< @<<<<<<<<<< @<<<<<<<<<< @<<<<< -$pm, $current_version, $_->{$pm}->{'min_ver'}, $required +@<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<< @<<<<<<<<<<<<<<<< @<<<<<<<<<<<<<<<< @<<<<< +$pm, $current_version, $_->{$pm}->{'min_ver'}, $required . write; + $count++; + } + } + else { + if (($req && $required eq 'Yes') || !$req) { + print "$pm\n"; + $count++; + } + } } } } -print color 'bold white' if $color; -my $footer = " --------------------------------------------------------------------------------------------------------------------------- -Total modules reported: $count "; -if ($color) { - $footer .= "\n\n"; -} -else { - $footer .= "* Module is missing or requires an upgrade.\n\n"; -} +if (!$brief) { + print color 'bold blue' if $color; + my $footer = " +-------------------------------------------------------------------------------------------- +Total modules reported: $count "; -print $footer; + if ($color) { + $footer .= "\n\n"; + } + else { + $footer .= "* Module is missing or requires an upgrade.\n\n"; + } + + print $footer; + print color 'reset' if $color; +} 1; @@ -91,7 +111,12 @@ koha_perl_deps.pl =head1 SYNOPSIS -./koha_perl_deps.pl -m + At least one of -a, -m, -i, or -u flags must specified to not trigger help. + ./koha_perl_deps.pl -m [-b] [-r] [-c] + ./koha_perl_deps.pl -u [-b] [-r] [-c] + ./koha_perl_deps.pl -i [-b] [-r] [-c] + ./koha_perl_deps.pl -a [-b] [-r] [-c] + ./koha_perl_deps.pl [-[h?]] =head1 OPTIONS @@ -111,7 +136,16 @@ lists all perl modules needing to be upgraded relative to Koha =item B<-a|--all> -lists all koha perl dependencies + lists all koha perl dependencies + This is equivalent to '-m -i -u'. + +=item B<-b|--brief> + +lists only the perl dependency name. + +=item B<-r|--required> + +filters list to only required perl dependencies. =item B<-c|--color>