From ee39a674b487e765657673d5ef4bab899a58e8a9 Mon Sep 17 00:00:00 2001 From: Marc Espie Date: Sun, 24 Jan 2010 15:13:16 +0000 Subject: use libspecs, report problem will be terser for now. --- usr.sbin/pkg_add/OpenBSD/Dependencies.pm | 10 +-- usr.sbin/pkg_add/OpenBSD/SharedLibs.pm | 101 +++++-------------------------- 2 files changed, 21 insertions(+), 90 deletions(-) (limited to 'usr.sbin/pkg_add/OpenBSD') diff --git a/usr.sbin/pkg_add/OpenBSD/Dependencies.pm b/usr.sbin/pkg_add/OpenBSD/Dependencies.pm index 8d7d6bf65a9..f4068c26e5f 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.121 2010/01/24 15:00:26 espie Exp $ +# $OpenBSD: Dependencies.pm,v 1.122 2010/01/24 15:13:15 espie Exp $ # # Copyright (c) 2005-2010 Marc Espie # @@ -652,10 +652,10 @@ 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}) { - return $candidate; + my $r = OpenBSD::SharedLibs::lookup_libspec($base, $spec); + for my $candidate (@$r) { + if ($dependencies->{$candidate->origin}) { + return $candidate->origin; } } return; diff --git a/usr.sbin/pkg_add/OpenBSD/SharedLibs.pm b/usr.sbin/pkg_add/OpenBSD/SharedLibs.pm index aa0f241a803..f3e02f442b7 100644 --- a/usr.sbin/pkg_add/OpenBSD/SharedLibs.pm +++ b/usr.sbin/pkg_add/OpenBSD/SharedLibs.pm @@ -1,5 +1,5 @@ # ex:ts=8 sw=4: -# $OpenBSD: SharedLibs.pm,v 1.45 2010/01/24 15:00:26 espie Exp $ +# $OpenBSD: SharedLibs.pm,v 1.46 2010/01/24 15:13:15 espie Exp $ # # Copyright (c) 2003-2010 Marc Espie # @@ -19,6 +19,8 @@ use strict; use warnings; use OpenBSD::Paths; +use OpenBSD::LibSpec; + package OpenBSD::PackingElement; sub mark_available_lib @@ -84,16 +86,14 @@ sub ensure_ldconfig $OpenBSD::PackingElement::Lib::todo = 0; } -our $registered_libs = {}; +our $repo = OpenBSD::LibRepo->new; sub register_lib { my ($name, $pkgname) = @_; - my ($stem, $major, $minor, $dir) = - OpenBSD::PackingElement::Lib->parse($name); - if (defined $stem) { - push(@{$registered_libs->{$stem}->{$dir}->{$major}}, - [$minor, $pkgname]); + my $lib = OpenBSD::Library->from_string($name); + if ($lib->is_valid) { + $repo->register($lib, $pkgname); } else { print STDERR "Bogus library in $pkgname: $name\n" unless $pkgname eq 'system'; @@ -144,97 +144,28 @@ sub add_libs_from_plist $plist->mark_available_lib($pkgname); } -sub normalize_dir_and_spec -{ - my ($base, $libspec) = @_; - if ($libspec =~ m/^(.*)\/([^\/]+)$/o) { - return ("$base/$1", $2); - } else { - return ("$base/lib", $libspec); - } -} - -sub parse_spec -{ - my $spec = shift; - if ($spec =~ m/^(.*)\.(\d+)\.(\d+)$/o) { - return ($1, $2, $3); - } else { - return undef; - } -} - sub lookup_libspec { - my ($dir, $spec) = normalize_dir_and_spec($_[0], $_[1]->to_string); - my @r = (); - my ($libname, $major, $minor) = parse_spec($spec); - if (defined $libname) { - my $exists = $registered_libs->{$libname}->{$dir}->{$major}; - if (defined $exists) { - for my $e (@$exists) { - if ($e->[0] >= $minor) { - push(@r, $e->[1]); - } - } - } - } - return @r; -} - -sub entry_string -{ - my ($stem, $M, $m) = @_; - return "lib$stem.so.$M.$m"; -} - -sub why_is_this_bad -{ - my ($base, $name, $d1, $d2, $M1, $M2, $m1, $m2, $pkgname) = @_; - if ($d1 ne $d2 && !($pkgname eq 'system' && $d1 eq "$base/lib")) { - return "bad directory"; - } - if ($M1 != $M2) { - return "bad major"; - } - if ($m1 > $m2) { - return "minor not large enough"; - } - return "$pkgname not reachable"; + my ($base, $spec) = @_; + return $spec->lookup($repo, $base); } my $printed = {}; sub report_problem { - my ($state, $p) = @_; + my ($state, $spec) = @_; + my $name = $spec->to_string; my $base = $state->{localbase}; - my ($dir, $name) = normalize_dir_and_spec($base, $p->to_string); - my ($stem, $major, $minor) = parse_spec($name); + my $approx = $spec->lookup_stem($repo); my $r = ""; - if (!defined $stem) { + if (!$spec->is_valid) { $r = "| bad library specification\n"; - } elsif (!defined $registered_libs->{$stem}) { - $r = "| not found anywhere\n"; + } elsif (!defined $approx) { + $r = "| not found anywhere\n"; } else { - while (my ($d, $v) = each %{$registered_libs->{$stem}}) { - my @l = (); - while (my ($M, $w) = each %$v) { - for my $e (@$w) { - push(@l, - entry_string($stem, $M, $e->[0]). - " (". - why_is_this_bad($base, $name, $dir, - $d, $major, $M, $minor, - $e->[0], $e->[1]). - ")"); - } - } - if (@l > 0) { - $r .= "| in $d: ". join(", ", sort @l). "\n"; - } - } + $r .= join(',', sort map {$_->to_string} @$approx)."\n"; } if (!defined $printed->{$name} || $printed->{$name} ne $r) { $printed->{$name} = $r; -- cgit v1.2.3