summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorDaniel Friesel <derf@derf.homelinux.org>2010-05-09 10:09:04 +0200
committerDaniel Friesel <derf@derf.homelinux.org>2010-05-09 10:09:04 +0200
commitc1f6c1c189de5ea5b9395c0c259fef9a3c7829d9 (patch)
tree9d89ef21641223a4900254e26fa95c8fe61799ca
parentedb8a963113044270afa44e89f15cc51378ae0f9 (diff)
perltidy & perlcritic
-rwxr-xr-xbin/apt-why68
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>