summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--usr.sbin/pkg_add/OpenBSD/Delete.pm26
-rw-r--r--usr.sbin/pkg_add/pkg_add64
2 files changed, 44 insertions, 46 deletions
diff --git a/usr.sbin/pkg_add/OpenBSD/Delete.pm b/usr.sbin/pkg_add/OpenBSD/Delete.pm
index e7c918cd601..ce6a7fcd8af 100644
--- a/usr.sbin/pkg_add/OpenBSD/Delete.pm
+++ b/usr.sbin/pkg_add/OpenBSD/Delete.pm
@@ -1,5 +1,5 @@
# ex:ts=8 sw=4:
-# $OpenBSD: Delete.pm,v 1.10 2004/11/14 19:25:45 espie Exp $
+# $OpenBSD: Delete.pm,v 1.11 2004/11/21 13:32:18 espie Exp $
#
# Copyright (c) 2003-2004 Marc Espie <espie@openbsd.org>
#
@@ -126,10 +126,12 @@ sub delete_plist
# guard against duplicate pkgdep
my $removed = {};
- for my $item (@{$plist->{pkgdep}}) {
- my $name = $item->{name};
- next if defined $removed->{$name};
- print "remove dependency in $name\n"
+
+ my $zap_dependency = sub {
+ my $name = shift;
+
+ return if defined $removed->{$name};
+ print "remove dependency on $name\n"
if $state->{very_verbose} or $state->{not};
local $@;
eval { OpenBSD::RequiredBy->new($name)->delete($pkgname) unless $state->{not}; };
@@ -137,17 +139,13 @@ sub delete_plist
print STDERR "$@\n";
}
$removed->{$name} = 1;
+ };
+
+ for my $item (@{$plist->{pkgdep}}) {
+ &$zap_dependency($item->{name});
}
for my $name (OpenBSD::Requiring->new($pkgname)->list()) {
- next if defined $removed->{$name};
- print "remove dependency in $name\n"
- if $state->{very_verbose} or $state->{not};
- local $@;
- eval { OpenBSD::RequiredBy->new($name)->delete($pkgname) unless $state->{not}; };
- if ($@) {
- print STDERR "$@\n";
- }
- $removed->{$name} = 1;
+ &$zap_dependency($name);
}
remove_packing_info($dir) unless $state->{not};
diff --git a/usr.sbin/pkg_add/pkg_add b/usr.sbin/pkg_add/pkg_add
index 67131140264..aea6d0e0069 100644
--- a/usr.sbin/pkg_add/pkg_add
+++ b/usr.sbin/pkg_add/pkg_add
@@ -1,7 +1,7 @@
#! /usr/bin/perl
# ex:ts=8 sw=4:
-# $OpenBSD: pkg_add,v 1.125 2004/11/21 13:24:41 espie Exp $
+# $OpenBSD: pkg_add,v 1.126 2004/11/21 13:32:18 espie Exp $
#
# Copyright (c) 2003-2004 Marc Espie <espie@openbsd.org>
#
@@ -242,32 +242,30 @@ sub solve_dependencies
return @deps;
}
-sub check_lib_specs
+sub check_lib_spec
{
- my ($verbose, $base, $specs, $available) = @_;
+ my ($verbose, $base, $spec, $available) = @_;
my $dir;
- for my $spec (split(/,/, $specs)) {
- print "checking libspec $spec " if $verbose;
- if ($spec =~ m|(.*)/|) {
- $dir = "$base/$1";
- $spec = $';
- } else {
- $dir = "$base/lib";
- }
- if ($spec =~ m/^(.*)\.(\d+)\.(\d+)$/) {
- my ($libname, $major, $minor) = ($1, $2, $3);
- my $exists = $available->{"$dir/lib$libname.so.$major"};
- if ((defined $exists) && $exists->[0] >= $minor) {
- my ($m, $where) = @$exists;
- print "found $dir/lib$libname.so.$major.$m in $where\n" if $verbose;
- } else {
- print "not found\n" if $verbose;
- return undef;
- }
+ print "checking libspec $spec " if $verbose;
+ if ($spec =~ m|(.*)/|) {
+ $dir = "$base/$1";
+ $spec = $';
+ } else {
+ $dir = "$base/lib";
+ }
+ if ($spec =~ m/^(.*)\.(\d+)\.(\d+)$/) {
+ my ($libname, $major, $minor) = ($1, $2, $3);
+ my $exists = $available->{"$dir/lib$libname.so.$major"};
+ if ((defined $exists) && $exists->[0] >= $minor) {
+ my ($m, $where) = @$exists;
+ print "found $dir/lib$libname.so.$major.$m in $where\n" if $verbose;
} else {
- print "bad spec\n" if $verbose;
+ print "not found\n" if $verbose;
return undef;
}
+ } else {
+ print "bad spec\n" if $verbose;
+ return undef;
}
return 1;
}
@@ -478,7 +476,7 @@ sub find_old_lib
\&OpenBSD::PackingList::LibraryOnly);
my $available = {};
$plist->visit('available_lib', $available, $try);
- if (check_lib_specs($state->{very_verbose},
+ if (check_lib_spec($state->{very_verbose},
$state->{destdir}.$plist->pkgbase(), $lib, $available)) {
Warn "Found library ", $lib, " in old package $try\n";
$plist->visit('available_lib', $global_avail, $try);
@@ -495,7 +493,7 @@ sub add_system_libs
{
my ($destdir, $avail) = @_;
for my $dirname ("/usr/lib", "/usr/X11R6/lib") {
- opendir(my $dir, $destdir.$dirname);
+ opendir(my $dir, $destdir.$dirname) or next;
while (my $d = readdir($dir)) {
next unless $d =~ m/^(.*\.so\.\d+)\.(\d+)$/;
my ($stem, $minor) = ($1, $2);
@@ -512,7 +510,7 @@ sub lookup_library
{
my ($state, $lib, $available, $plist, $dependencies, $harder) = @_;
- if (check_lib_specs($state->{very_verbose},
+ if (check_lib_spec($state->{very_verbose},
$state->{destdir}.$plist->pkgbase(), $lib, $available)) {
return 1;
}
@@ -521,11 +519,11 @@ sub lookup_library
$syst_avail = {};
add_system_libs($state->{destdir}, $syst_avail);
}
- if (check_lib_specs($state->{very_verbose},
+ if (check_lib_spec($state->{very_verbose},
$state->{destdir}."/usr", $lib, $syst_avail)) {
return 1;
}
- if (check_lib_specs($state->{very_verbose},
+ if (check_lib_spec($state->{very_verbose},
$state->{destdir}."/usr/X11R6", $lib, $syst_avail)) {
return 1;
}
@@ -553,7 +551,7 @@ sub lookup_library
\&OpenBSD::PackingList::LibraryOnly);
my $avail2 = {};
$plist->visit('available_lib', $avail2, $dep);
- if (check_lib_specs($state->{very_verbose},
+ if (check_lib_spec($state->{very_verbose},
$state->{destdir}.$plist->pkgbase(), $lib, $avail2)) {
Warn "Found library ", $lib, " in dependent package $dep\n";
$plist->visit('available_lib', $available, $dep);
@@ -617,10 +615,12 @@ sub install_package
}
for my $dep (@{$plist->{libdepend}}) {
return () if defined $dep->{name} and $dep->{name} ne $plist->pkgname();
- if (!lookup_library($state, $dep->{libspec}, $available,
- $plist, $handle->{solved_dependencies}, 0)) {
- Warn "Can't install $pkg: lib not found ", $dep->{libspec}, "\n";
- return () unless $forced{libdepends};
+ for my $spec (split(/,/, $dep->{libspec})) {
+ if (!lookup_library($state, $spec, $available,
+ $plist, $handle->{solved_dependencies}, 0)) {
+ Warn "Can't install $pkg: lib not found spec\n";
+ return () unless $forced{libdepends};
+ }
}
}
# add_system_libs($state->{destdir}, $available);