From 785a228713db38802d6ce2c4418c4fe93e7e7eb7 Mon Sep 17 00:00:00 2001 From: Marc Espie Date: Mon, 7 Jun 2010 10:02:28 +0000 Subject: check reverse dependencies as well --- usr.sbin/pkg_add/OpenBSD/PkgCheck.pm | 47 ++++++++++++++++++++++++++++++++++-- 1 file changed, 45 insertions(+), 2 deletions(-) (limited to 'usr.sbin/pkg_add/OpenBSD') diff --git a/usr.sbin/pkg_add/OpenBSD/PkgCheck.pm b/usr.sbin/pkg_add/OpenBSD/PkgCheck.pm index bd212fd6e0a..d07a1279fa8 100644 --- a/usr.sbin/pkg_add/OpenBSD/PkgCheck.pm +++ b/usr.sbin/pkg_add/OpenBSD/PkgCheck.pm @@ -1,7 +1,7 @@ #! /usr/bin/perl # ex:ts=8 sw=4: -# $OpenBSD: PkgCheck.pm,v 1.6 2010/06/07 09:54:28 espie Exp $ +# $OpenBSD: PkgCheck.pm,v 1.7 2010/06/07 10:02:27 espie Exp $ # # Copyright (c) 2003-2010 Marc Espie # @@ -387,7 +387,6 @@ sub dependencies_check { my ($self, $state, $l) = @_; OpenBSD::SharedLibs::add_libs_from_system($state->{destdir}); - my $i = 0; $self->for_all_packages($state, $l, "Dependencies", sub { my $name = shift; my $plist = OpenBSD::PackingList->from_installation($name, @@ -419,6 +418,48 @@ sub dependencies_check join(' ', @todo)); $self->ask_add_deps($state, $name, \@todo, $req); } + for my $dep ($req->list) { + push(@{$state->{reverse}{$dep}}, $name); + } + }); +} + +sub reverse_dependencies_check +{ + my ($self, $state, $l) = @_; + $self->for_all_packages($state, $l, "Reverse dependencies", sub { + my $name = shift; + my $req = OpenBSD::RequiredBy->new($name); + my @known = $req->list; + my %not_yet = (); + my %possible = (); + my %other = (); + for my $pkg (@known) { + $not_yet{$pkg} = 1; + if ($state->{exists}{$pkg}) { + $possible{$pkg} = 1; + } else { + $state->errsay("$name: bogus reverse dependency $pkg"); + } + } + for my $i (@{$state->{reverse}{$name}}) { + if ($possible{$i}) { + delete $not_yet{$i}; + } else { + $other{$i} = 1; + } + } + if (keys %not_yet > 0) { + my @todo = sort keys %not_yet; + $state->errsay("$name is having too many dependencies: ", join(' ', @todo)); + $self->ask_delete_deps($state, $name, \@todo, $req); + } + if (keys %other > 0) { + my @todo = sort keys %other; + $state->errsay("$name is missing dependencies: ", + join(' ', @todo)); + $self->ask_add_deps($state, $name, \@todo, $req); + } }); } @@ -475,6 +516,8 @@ sub run $self->sanity_check($state, \@list); $self->dependencies_check($state, \@list); $state->log->dump; + $self->reverse_dependencies_check($state, \@list); + $state->log->dump; $self->package_files_check($state, \@list); $state->log->dump; $self->localbase_check($state); -- cgit v1.2.3