diff options
author | Daniel Friesel <derf@derf.homelinux.org> | 2010-05-09 10:09:04 +0200 |
---|---|---|
committer | Daniel Friesel <derf@derf.homelinux.org> | 2010-05-09 10:09:04 +0200 |
commit | c1f6c1c189de5ea5b9395c0c259fef9a3c7829d9 (patch) | |
tree | 9d89ef21641223a4900254e26fa95c8fe61799ca | |
parent | edb8a963113044270afa44e89f15cc51378ae0f9 (diff) |
perltidy & perlcritic
-rwxr-xr-x | bin/apt-why | 68 |
1 files changed, 45 insertions, 23 deletions
diff --git a/bin/apt-why b/bin/apt-why index 75413e4..fcf2486 100755 --- a/bin/apt-why +++ b/bin/apt-why @@ -7,45 +7,48 @@ use 5.010; use AptPkg::Cache; use Getopt::Long; -my $cache = AptPkg::Cache->new; +my $cache = AptPkg::Cache->new; my $max_depth = 5; -my $all = 0; -my $tabsign = "\t"; -my @deptypes = qw/Depends Recommends Suggests/; +my $all = 0; +my $tabsign = "\t"; +my @deptypes = qw/Depends Recommends Suggests/; my @known; sub revdeps { - my $name = shift; + my $name = shift; my $package = $cache->{$name}; my @return; my $rdeps = $package->{RevDependsList}; - foreach my $dependency (@{$rdeps}) { + foreach my $dependency ( @{$rdeps} ) { if ( not $dependency->{ParentPkg}{Name} ~~ @known - and ($all or $cache->{ $dependency->{ParentPkg}{Name} }->{CurrentState} eq 'Installed') - and "$dependency->{DepType}" ~~ @deptypes ) + and ( $all + or $cache->{ $dependency->{ParentPkg}{Name} }->{CurrentState} eq + 'Installed' ) + and "$dependency->{DepType}" ~~ @deptypes + ) { - push(@return, $dependency->{ParentPkg}{Name}); + push( @return, $dependency->{ParentPkg}{Name} ); } } - push(@known, @return); - return(@return); + push( @known, @return ); + return (@return); } sub recurse { - my $name = shift; + my $name = shift; my $depth = (shift) + 1; - printf("%s%s\n", $tabsign x ($depth-1), $name); + printf( "%s%s\n", $tabsign x ( $depth - 1 ), $name ); - if ($depth >= $max_depth) { + if ( $depth >= $max_depth ) { return; } - foreach (revdeps($name)) { - recurse($_, $depth); + foreach ( revdeps($name) ) { + recurse( $_, $depth ); } return; @@ -53,23 +56,25 @@ sub recurse { GetOptions( 'all!' => \$all, - 'deptype=s' => sub { @deptypes = split(/,/, $_[1]) }, + 'deptype=s' => sub { @deptypes = split( /,/, $_[1] ) }, 'depth=i' => \$max_depth, - 'tabwidth=i' => sub { $tabsign = ' ' x $_[1] }, - 'h|?|help' => sub { exec('perldoc', '-F', $0) or die("See perldoc -F $0\n") }, + 'tabwidth=i' => sub { $tabsign = q{ } x $_[1] }, + 'h|?|help' => + sub { exec( 'perldoc', '-F', $0 ) or die("See perldoc -F $0\n") }, ); -my $packagename = shift or die("Usage: $0 [options] <package>; see $0 --help\n"); +my $packagename = shift + or die("Usage: $0 [options] <package>; see $0 --help\n"); -if (not defined $cache->{$packagename}) { +if ( not defined $cache->{$packagename} ) { die("No such package: $packagename\n"); } -if ($cache->{$packagename}->{Flags} =~ /Essential/) { +if ( $cache->{$packagename}->{Flags} =~ /Essential/ ) { print "Essential: Yes\n"; } -recurse($packagename, 0); +recurse( $packagename, 0 ); __END__ @@ -109,6 +114,23 @@ Indent each recursion level with I<i> spaces (by default: one tab) =back +=head1 EXIT STATUS + +Zero on success, non-zero on error (i.e. no such package). + +=head1 CONFIGURATION + +None. + +=head1 DEPENDENCIES + +This program requires the perl module B<AptPkg::Cache>. On Debian, it is +available via the package B<libapt-pkg-perl>. + +=head1 BUGS AND LIMITATIONS + +There may be problems with virtual packages and "Provides: " stuff. + =head1 AUTHOR Daniel Friesel E<lt>derf@derf.homelinux.orgE<gt> |