diff options
Diffstat (limited to 'usr.sbin')
-rw-r--r-- | usr.sbin/pkg_add/OpenBSD/Dependencies.pm | 414 |
1 files changed, 207 insertions, 207 deletions
diff --git a/usr.sbin/pkg_add/OpenBSD/Dependencies.pm b/usr.sbin/pkg_add/OpenBSD/Dependencies.pm index 854e9ad44b4..8de8db798a8 100644 --- a/usr.sbin/pkg_add/OpenBSD/Dependencies.pm +++ b/usr.sbin/pkg_add/OpenBSD/Dependencies.pm @@ -1,5 +1,5 @@ # ex:ts=8 sw=4: -# $OpenBSD: Dependencies.pm,v 1.141 2010/12/20 09:10:51 espie Exp $ +# $OpenBSD: Dependencies.pm,v 1.142 2010/12/20 09:23:23 espie Exp $ # # Copyright (c) 2005-2010 Marc Espie <espie@openbsd.org> # @@ -17,6 +17,8 @@ use strict; use warnings; +use OpenBSD::SharedLibs; + # generic dependencies lookup class: walk the dependency tree as far # as necessary to resolve dependencies package OpenBSD::lookup; @@ -307,18 +309,219 @@ sub clone } package OpenBSD::Dependencies::Solver; -our @ISA = (qw(OpenBSD::Cloner)); - -use OpenBSD::PackageInfo; +our @ISA = qw(OpenBSD::Cloner); my $global_cache = {}; +sub cached +{ + my ($self, $dep) = @_; + return $global_cache->{$dep->{pattern}} || + $self->{cache}{$dep->{pattern}}; +} + +sub set_cache +{ + my ($self, $dep, $value) = @_; + $self->{cache}{$dep->{pattern}} = $value; +} + +sub set_global +{ + my ($self, $dep, $value) = @_; + $global_cache->{$dep->{pattern}} = $value; +} + +sub find_candidate +{ + my ($self, $dep, @list) = @_; + my @candidates = $dep->spec->filter(@list); + if (@candidates >= 1) { + return $candidates[0]; + } else { + return undef; + } +} + +sub solve_dependency +{ + my ($self, $state, $dep, $package) = @_; + + my $v; + + if (defined $self->cached($dep)) { + if ($state->defines('stat_cache')) { + if (defined $global_cache->{$dep->{pattern}}) { + $state->print("Global "); + } + $state->say("Cache hit on #1: #2", $dep->{pattern}, + $self->cached($dep)->pretty); + } + $v = $self->cached($dep)->do($self, $state, $dep, $package); + return $v if $v; + } + if ($state->defines('stat_cache')) { + $state->say("No cache hit on #1", $dep->{pattern}); + } + + if ($state->{allow_replacing}) { + + $v = $self->find_dep_in_self($state, $dep); + if ($v) { + $self->set_cache($dep, _cache::self->new($v)); + push(@{$package->{before}}, $v); + return $v; + } + $v = $self->find_candidate($dep, $self->{set}->older_names); + if ($v) { + push(@{$self->{bad}}, $dep->{pattern}); + return $v; + } + $v = $self->find_dep_in_stuff_to_install($state, $dep); + return $v if $v; + } + + $v = $self->find_candidate($dep, @{$self->installed_list}); + if ($v) { + if ($state->{newupdates}) { + if ($state->tracker->is_known($v)) { + return $v; + } + my $set = $state->updateset->add_older(OpenBSD::Handle->create_old($v, $state)); + $set->merge_paths($self->{set}); + $self->add_dep($set); + $self->set_cache($dep, _cache::to_update->new($v)); + $state->tracker->todo($set); + } + return $v; + } + if (!$state->{allow_replacing}) { + $v = $self->find_dep_in_stuff_to_install($state, $dep); + return $v if $v; + } + + $v = $self->find_dep_in_repositories($state, $dep); + + my $s; + if ($v) { + $s = $state->updateset_from_location($v); + $v = $v->name; + } else { + # resort to default if nothing else + $v = $dep->{def}; + $s = $state->updateset_with_new($v); + } + + $s->merge_paths($self->{set}); + $state->tracker->todo($s); + $self->add_dep($s); + $self->set_cache($dep, _cache::to_install->new($v)); + return $v; +} + +sub solve_depends +{ + my ($self, $state) = @_; + + $self->{all_dependencies} = {}; + $self->{to_register} = {}; + $self->{deplist} = {}; + delete $self->{installed}; + + for my $package ($self->{set}->newer, $self->{set}->kept) { + $package->{before} = []; + for my $dep (@{$package->{plist}->{depend}}) { + my $v = $self->solve_dependency($state, $dep, $package); + $self->{all_dependencies}->{$v} = $dep; + $self->{to_register}->{$package}->{$v} = $dep; + } + } + + return values %{$self->{deplist}}; +} + +sub solve_wantlibs +{ + my ($solver, $state) = @_; + my $okay = 1; + + my $lib_finder = OpenBSD::lookup::library->new($solver); + for my $h ($solver->{set}->newer) { + for my $lib (@{$h->{plist}->{wantlib}}) { + $solver->{localbase} = $h->{plist}->localbase; + next if $lib_finder->lookup($solver, + $solver->{to_register}->{$h}, $state, + $lib->spec); + if ($okay) { + $state->errsay("Can't install #1 because of libraries", $h->pkgname); + } + $okay = 0; + OpenBSD::SharedLibs::report_problem($state, + $lib->spec); + } + } + if (!$okay) { + $solver->dump($state); + $lib_finder->dump($state); + } + return $okay; +} + +sub dump +{ + my ($self, $state) = @_; + if ($self->dependencies) { + $state->print("Direct dependencies for #1 resolve to #2", + $self->{set}->print, join(' ', $self->dependencies)); + $state->print(" (todo: #1)", + join(' ', (map {$_->print} values %{$self->{deplist}}))) + if %{$self->{deplist}}; + $state->print("\n"); + } +} + +sub dependencies +{ + my $self = shift; + if (wantarray) { + return keys %{$self->{all_dependencies}}; + } else { + return scalar(%{$self->{all_dependencies}}); + } +} + +sub check_lib_spec +{ + my ($self, $base, $spec, $dependencies) = @_; + my $r = OpenBSD::SharedLibs::lookup_libspec($base, $spec); + for my $candidate (@$r) { + if ($dependencies->{$candidate->origin}) { + return $candidate->origin; + } + } + return; +} + sub add_dep { my ($self, $d) = @_; $self->{deplist}{$d} = $d; } +use OpenBSD::PackageInfo; +OpenBSD::Auto::cache(installed_list, + sub { + my $self = shift; + + my @l = installed_packages(); + for my $o ($self->{set}->older_names) { + @l = grep {$_ ne $o} @l; + } + return \@l; + } +); + + sub merge { my ($solver, @extra) = @_; @@ -326,17 +529,6 @@ sub merge $solver->clone('cache', @extra); } -sub find_candidate -{ - my ($self, $dep, @list) = @_; - my @candidates = $dep->spec->filter(@list); - if (@candidates >= 1) { - return $candidates[0]; - } else { - return undef; - } -} - sub new { my ($class, $set) = @_; @@ -388,16 +580,6 @@ sub check_for_loops } } -sub dependencies -{ - my $self = shift; - if (wantarray) { - return keys %{$self->{all_dependencies}}; - } else { - return scalar(%{$self->{all_dependencies}}); - } -} - sub find_dep_in_repositories { my ($self, $state, $dep) = @_; @@ -470,134 +652,6 @@ sub find_dep_in_stuff_to_install return $v; } -sub cached -{ - my ($self, $dep) = @_; - return $global_cache->{$dep->{pattern}} || - $self->{cache}{$dep->{pattern}}; -} - -sub set_cache -{ - my ($self, $dep, $value) = @_; - $self->{cache}{$dep->{pattern}} = $value; -} - -sub set_global -{ - my ($self, $dep, $value) = @_; - $global_cache->{$dep->{pattern}} = $value; -} - -OpenBSD::Auto::cache(installed_list, - sub { - my $self = shift; - - my @l = installed_packages(); - for my $o ($self->{set}->older_names) { - @l = grep {$_ ne $o} @l; - } - return \@l; - } -); - -sub solve_dependency -{ - my ($self, $state, $dep, $package) = @_; - - my $v; - - if (defined $self->cached($dep)) { - if ($state->defines('stat_cache')) { - if (defined $global_cache->{$dep->{pattern}}) { - $state->print("Global "); - } - $state->say("Cache hit on #1: #2", $dep->{pattern}, - $self->cached($dep)->pretty); - } - $v = $self->cached($dep)->do($self, $state, $dep, $package); - return $v if $v; - } - if ($state->defines('stat_cache')) { - $state->say("No cache hit on #1", $dep->{pattern}); - } - - if ($state->{allow_replacing}) { - - $v = $self->find_dep_in_self($state, $dep); - if ($v) { - $self->set_cache($dep, _cache::self->new($v)); - push(@{$package->{before}}, $v); - return $v; - } - $v = $self->find_candidate($dep, $self->{set}->older_names); - if ($v) { - push(@{$self->{bad}}, $dep->{pattern}); - return $v; - } - $v = $self->find_dep_in_stuff_to_install($state, $dep); - return $v if $v; - } - - $v = $self->find_candidate($dep, @{$self->installed_list}); - if ($v) { - if ($state->{newupdates}) { - if ($state->tracker->is_known($v)) { - return $v; - } - my $set = $state->updateset->add_older(OpenBSD::Handle->create_old($v, $state)); - $set->merge_paths($self->{set}); - $self->add_dep($set); - $self->set_cache($dep, _cache::to_update->new($v)); - $state->tracker->todo($set); - } - return $v; - } - if (!$state->{allow_replacing}) { - $v = $self->find_dep_in_stuff_to_install($state, $dep); - return $v if $v; - } - - $v = $self->find_dep_in_repositories($state, $dep); - - my $s; - if ($v) { - $s = $state->updateset_from_location($v); - $v = $v->name; - } else { - # resort to default if nothing else - $v = $dep->{def}; - $s = $state->updateset_with_new($v); - } - - $s->merge_paths($self->{set}); - $state->tracker->todo($s); - $self->add_dep($s); - $self->set_cache($dep, _cache::to_install->new($v)); - return $v; -} - -sub solve_depends -{ - my ($self, $state) = @_; - - $self->{all_dependencies} = {}; - $self->{to_register} = {}; - $self->{deplist} = {}; - delete $self->{installed}; - - for my $package ($self->{set}->newer, $self->{set}->kept) { - $package->{before} = []; - for my $dep (@{$package->{plist}->{depend}}) { - my $v = $self->solve_dependency($state, $dep, $package); - $self->{all_dependencies}->{$v} = $dep; - $self->{to_register}->{$package}->{$v} = $dep; - } - } - - return values %{$self->{deplist}}; -} - sub check_depends { my $self = shift; @@ -610,19 +664,6 @@ sub check_depends return $self->{bad}; } -sub dump -{ - my ($self, $state) = @_; - if ($self->dependencies) { - $state->print("Direct dependencies for #1 resolve to #2", - $self->{set}->print, join(' ', $self->dependencies)); - $state->print(" (todo: #1)", - join(' ', (map {$_->print} values %{$self->{deplist}}))) - if %{$self->{deplist}}; - $state->print("\n"); - } -} - sub register_dependencies { my ($self, $state) = @_; @@ -652,20 +693,6 @@ sub repair_dependencies } } -use OpenBSD::SharedLibs; - -sub check_lib_spec -{ - my ($self, $base, $spec, $dependencies) = @_; - my $r = OpenBSD::SharedLibs::lookup_libspec($base, $spec); - for my $candidate (@$r) { - if ($dependencies->{$candidate->origin}) { - return $candidate->origin; - } - } - return; -} - sub find_old_lib { my ($self, $state, $base, $pattern, $lib) = @_; @@ -682,33 +709,6 @@ sub find_old_lib return undef; } -sub solve_wantlibs -{ - my ($solver, $state) = @_; - my $okay = 1; - - my $lib_finder = OpenBSD::lookup::library->new($solver); - for my $h ($solver->{set}->newer) { - for my $lib (@{$h->{plist}->{wantlib}}) { - $solver->{localbase} = $h->{plist}->localbase; - next if $lib_finder->lookup($solver, - $solver->{to_register}->{$h}, $state, - $lib->spec); - if ($okay) { - $state->errsay("Can't install #1 because of libraries", $h->pkgname); - } - $okay = 0; - OpenBSD::SharedLibs::report_problem($state, - $lib->spec); - } - } - if (!$okay) { - $solver->dump($state); - $lib_finder->dump($state); - } - return $okay; -} - sub solve_tags { my ($solver, $state) = @_; |