diff options
author | Marc Espie <espie@cvs.openbsd.org> | 2007-06-18 18:34:01 +0000 |
---|---|---|
committer | Marc Espie <espie@cvs.openbsd.org> | 2007-06-18 18:34:01 +0000 |
commit | 4cc96c5e59459805ecad7cae3ec2dc4da7a91101 (patch) | |
tree | 68dea7bf8bde6b78b9fbcffcab04185022eeb409 /usr.sbin | |
parent | 29d74df164cd030b9a3c2a56257b7cf1d1e9ad1e (diff) |
reorganize lookup_library so I can reuse the exact same algorithm to
look up different things (in particular, the incremental lookup through
dependencies).
Diffstat (limited to 'usr.sbin')
-rw-r--r-- | usr.sbin/pkg_add/OpenBSD/Dependencies.pm | 118 |
1 files changed, 112 insertions, 6 deletions
diff --git a/usr.sbin/pkg_add/OpenBSD/Dependencies.pm b/usr.sbin/pkg_add/OpenBSD/Dependencies.pm index 4d1dde165dc..583968846f5 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.54 2007/06/18 18:06:28 espie Exp $ +# $OpenBSD: Dependencies.pm,v 1.55 2007/06/18 18:34:00 espie Exp $ # # Copyright (c) 2005-2007 Marc Espie <espie@openbsd.org> # @@ -18,6 +18,112 @@ use strict; use warnings; +package OpenBSD::lookup; + +sub lookup +{ + my ($self, $solver, $state, $obj) = @_; + + my $dependencies = $solver->{to_register}; + my $known = $solver->{known}; + if (my $r = $self->find_in_already_done($solver, $state, $obj)) { + $dependencies->{$r} = 1; + return 1; + } + if ($self->find_in_extra_sources($solver, $state, $obj)) { + return 1; + } + # lookup through the rest of the tree... + my $done = $solver->{done}; + while (my $dep = pop @{$solver->{todo}}) { + require OpenBSD::RequiredBy; + + next if $done->{$dep}; + $done->{$dep} = 1; + for my $dep2 (OpenBSD::Requiring->new($dep)->list) { + push(@{$solver->{todo}}, $dep2) unless $done->{$dep2}; + } + $known->{$dep} = 1; + if ($self->find_in_new_source($solver, $state, $obj, $dep)) { + $dependencies->{$dep} = 1; + return 1; + } + } + if (my $r = $self->find_elsewhere($solver, $state, $obj)) { + $dependencies->{$r} = 1; + return 1; + } + + $self->dependency_not_found($state, $obj); + return 0; +} + +package OpenBSD::lookup::library; +our @ISA=qw(OpenBSD::lookup); + +sub find_in_already_done +{ + my ($self, $solver, $state, $obj) = @_; + + + my $r = $solver->check_lib_spec($solver->{plist}->localbase, $obj, + $solver->{known}); + if ($r) { + print "found libspec $obj in package $r\n" if $state->{verbose}; + return $r; + } else { + return undef; + } +} + +sub find_in_extra_sources +{ + my ($self, $solver, $state, $obj) = @_; + return undef if $obj =~ m/\//; + + OpenBSD::SharedLibs::add_libs_from_system($state->{destdir}); + for my $dir (OpenBSD::SharedLibs::system_dirs()) { + if ($solver->check_lib_spec($dir, $obj, {system => 1})) { + print "found libspec $obj in $dir/lib\n" if $state->{verbose}; + return 'system'; + } + } + return undef; +} + +sub find_in_new_source +{ + my ($self, $solver, $state, $obj, $dep) = @_; + OpenBSD::SharedLibs::add_libs_from_installed_package($dep); + if ($solver->check_lib_spec($solver->{plist}->localbase, $obj, + {$dep => 1})) { + print "found libspec $obj in package $dep\n" if $state->{verbose}; + return $dep; + } + return undef; +} + +sub find_elsewhere +{ + my ($self, $state, $solver, $obj) = @_; + + for my $dep (@{$solver->{plist}->{depend}}) { + my $r = $solver->find_old_lib($state, + $solver->{plist}->localbase, $dep->{pattern}, $obj); + if ($r) { + print "found libspec $obj in old package $r\n" if $state->{verbose}; + return $r; + } + } + return undef; +} + +sub dependency_not_found +{ + my ($self, $state, $obj) = @_; + print "libspec $obj not found\n" if $state->{very_verbose}; +} + package OpenBSD::Dependencies::Solver; use OpenBSD::PackageInfo; @@ -257,7 +363,7 @@ sub check_lib_spec sub find_old_lib { - my ($self, $state, $base, $pattern, $lib, $dependencies) = @_; + my ($self, $state, $base, $pattern, $lib) = @_; require OpenBSD::Search; require OpenBSD::PackageRepository::Installed; @@ -265,11 +371,10 @@ sub find_old_lib for my $try (OpenBSD::PackageRepository::Installed->new->match(OpenBSD::Search::PkgSpec->new(".libs-".$pattern))) { OpenBSD::SharedLibs::add_libs_from_installed_package($try); if ($self->check_lib_spec($base, $lib, {$try => 1})) { - $dependencies->{$try} = 1; - return "$try($lib)"; + return $try; } } - return; + return undef; } sub lookup_library @@ -333,7 +438,8 @@ sub solve_wantlibs for my $h ($solver->{set}->newer) { for my $lib (@{$h->{plist}->{wantlib}}) { - if (!$solver->lookup_library($state, $lib->{name})) { + if (!OpenBSD::lookup::library->lookup($solver, + $state, $lib->{name})) { OpenBSD::Error::Warn "Can't install ", $h->{pkgname}, ": lib not found ", $lib->{name}, "\n"; |