diff options
-rw-r--r-- | usr.sbin/pkg_add/OpenBSD/Update.pm | 24 | ||||
-rw-r--r-- | usr.sbin/pkg_add/pkg_add | 40 |
2 files changed, 10 insertions, 54 deletions
diff --git a/usr.sbin/pkg_add/OpenBSD/Update.pm b/usr.sbin/pkg_add/OpenBSD/Update.pm index 5ff19f64c7e..de00ae5d00a 100644 --- a/usr.sbin/pkg_add/OpenBSD/Update.pm +++ b/usr.sbin/pkg_add/OpenBSD/Update.pm @@ -1,5 +1,5 @@ # ex:ts=8 sw=4: -# $OpenBSD: Update.pm,v 1.85 2009/10/13 21:21:07 espie Exp $ +# $OpenBSD: Update.pm,v 1.86 2009/10/14 11:08:16 espie Exp $ # # Copyright (c) 2004-2006 Marc Espie <espie@openbsd.org> # @@ -103,7 +103,6 @@ sub process_handle push(@search, OpenBSD::Search::FilterLocation->keep_most_recent); } - my $l = OpenBSD::PackageLocator->match_locations(@search); if (@$l == 0) { return undef; @@ -124,25 +123,12 @@ sub process_handle } } - $state->progress->clear; - my %cnd = map {($_->name, $_)} @$l; - print "Candidates for updating $pkgname -> ", join(' ', keys %cnd), "\n"; + $state->progress->print("Candidates for updating $pkgname -> ", join(' ', map {$_->name} @$l), "\n"); - if (@$l == 1) { - $self->add_updateset($set, $h, $l->[0]); + my $r = $state->choose_location($pkgname, $l); + if (defined $r) { + $self->add_updateset($set, $h, $r); return 1; - } - my $result = OpenBSD::Interactive::choose1($pkgname, - $state->{interactive}, sort keys %cnd); - if (defined $result) { - if (defined $found && $found eq $result && - !$plist->uses_old_libs) { - print "No need to update $pkgname\n"; - return 0; - } else { - $self->add_updateset($set, $h, $cnd{$result}); - return 1; - } } else { $state->{issues} = 1; return undef; diff --git a/usr.sbin/pkg_add/pkg_add b/usr.sbin/pkg_add/pkg_add index 7307781dca9..66839b9f13c 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.347 2009/10/14 11:06:41 espie Exp $ +# $OpenBSD: pkg_add,v 1.348 2009/10/14 11:08:16 espie Exp $ # # Copyright (c) 2003-2009 Marc Espie <espie@openbsd.org> # @@ -626,23 +626,7 @@ sub stem2location if (@$l > 1 && !$state->{defines}->{allversions}) { $l = OpenBSD::Search::FilterLocation->keep_most_recent->filter_locations($l); } - if (@$l == 0) { - print "Can't resolve $name\n"; - return undef; - } elsif (@$l > 1) { - my %h = map {($_->name, $_)} @$l; - if ($state->{interactive}) { - $h{'<None>'} = undef; - my $result = OpenBSD::Interactive::ask_list("Ambiguous: choose package for $name", $state->{interactive}, sort keys %h); - return $h{$result}; - } else { - print "Ambiguous: $name could be ", - join(' ', keys %h), "\n"; - return undef; - } - } elsif (@$l == 1) { - return $l->[0]; - } + return $state->choose_location($name, $l); } @@ -770,7 +754,6 @@ lock_db($state->{not}) unless $state->{defines}->{nolock}; $state->setup_progressmeter($opt_x); $state->check_root; -my @todo = (); my @todo2 = (); if ($opt_l) { @@ -796,23 +779,10 @@ if ($opt_l || $opt_z) { $t =~ s/\-\d([^-]*)\-?/--/; $l = OpenBSD::PackageLocator->match_locations(OpenBSD::Search::Stem->new($t), $k); } - if (@$l == 0) { - $state->progress->clear; - print "Can't find $_\n"; - } elsif (@$l > 1) { - $state->progress->clear; - if ($state->{interactive}) { - my %cnd = map {($_->name, $_)} @$l; - my $result = OpenBSD::Interactive::choose1($_, - 1, sort keys %cnd); - push @todo, $cnd{$result} if defined $result; - } else { - print "Ambiguous: $_\n"; - } - } else { - push(@todo, $l->[0]); + my $r = $state->choose_location($_, $l); + if (defined $r) { + push(@todo2, OpenBSD::UpdateSet->from_location($r)); } - @todo2 = map { OpenBSD::UpdateSet->from_location($_) } @todo; } } elsif ($opt_u) { require OpenBSD::Update; |