summaryrefslogtreecommitdiff
path: root/usr.sbin/pkg_add
diff options
context:
space:
mode:
Diffstat (limited to 'usr.sbin/pkg_add')
-rw-r--r--usr.sbin/pkg_add/OpenBSD/Update.pm8
-rw-r--r--usr.sbin/pkg_add/pkg_add25
2 files changed, 22 insertions, 11 deletions
diff --git a/usr.sbin/pkg_add/OpenBSD/Update.pm b/usr.sbin/pkg_add/OpenBSD/Update.pm
index de00ae5d00a..73df87d02f2 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.86 2009/10/14 11:08:16 espie Exp $
+# $OpenBSD: Update.pm,v 1.87 2009/10/14 13:46:25 espie Exp $
#
# Copyright (c) 2004-2006 Marc Espie <espie@openbsd.org>
#
@@ -34,7 +34,7 @@ sub new
sub add_updateset
{
my ($self, $set, $handle, $location) = @_;
-
+
my $n = OpenBSD::Handle->from_location($location);
$set->add_newer($n);
}
@@ -48,7 +48,7 @@ sub process_handle
print "Update to $pkgname already found\n";
return 0;
}
-
+
if ($pkgname =~ m/^(?:\.libs\d*|partial)\-/o) {
$state->progress->clear;
print "Not updating $pkgname, remember to clean it\n";
@@ -114,7 +114,7 @@ sub process_handle
$self->add_updateset($set, $h, $l->[0]);
return 1;
}
- if (defined $found && $found eq $l->[0] &&
+ if (defined $found && $found eq $l->[0] &&
!$plist->uses_old_libs && !$state->{defines}->{installed}) {
my $msg = "No need to update $pkgname";
$state->progress->message($msg);
diff --git a/usr.sbin/pkg_add/pkg_add b/usr.sbin/pkg_add/pkg_add
index f7e3ba2bc86..f9f6461896a 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.349 2009/10/14 11:16:15 espie Exp $
+# $OpenBSD: pkg_add,v 1.350 2009/10/14 13:46:25 espie Exp $
#
# Copyright (c) 2003-2009 Marc Espie <espie@openbsd.org>
#
@@ -555,8 +555,7 @@ sub install_set
return ();
}
if ($handle->has_error) {
- if ((!$state->{defines}->{kitchensink} ||
- $handle->has_error(OpenBSD::Handle::BAD_PACKAGE)) &&
+ if ($handle->has_error(OpenBSD::Handle::BAD_PACKAGE) &&
!$handle->{tweaked}) {
$state->set_name_from_handle($handle);
$state->fatal("Fatal error");
@@ -754,6 +753,9 @@ lock_db($state->{not}) unless $state->{defines}->{nolock};
$state->setup_progressmeter($opt_x);
$state->check_root;
+# Here we create the list of packages to install
+# actually, an updateset list (@todo2), and we hope to do this lazily
+# later for the most part...
my @todo2 = ();
if ($opt_l) {
@@ -766,6 +768,8 @@ if ($opt_l) {
}
}
+# three cases:
+# 1/ match fuzzily against a list
if ($opt_l || $opt_z) {
my $k = OpenBSD::Search::FilterLocation->keep_most_recent;
$state->progress->set_header("Looking for packages");
@@ -784,6 +788,7 @@ if ($opt_l || $opt_z) {
push(@todo2, OpenBSD::UpdateSet->from_location($r));
}
}
+# 2/ update existing stuff
} elsif ($opt_u) {
require OpenBSD::Update;
require OpenBSD::PackageRepository::Installed;
@@ -846,6 +851,7 @@ if ($opt_l || $opt_z) {
}
print "Running update ", join(',', map {$_->short_print} @todo2), "\n";
} else {
+# 3/ actual names
find_truelocations(\@ARGV, \@todo2, $state);
OpenBSD::Add::tag_user_packages(@todo2);
}
@@ -854,19 +860,25 @@ if ($bad) {
exit(1);
}
+
+
+# This is the actual very small loop that adds all packages
eval {
while (my $set = shift @todo2) {
unshift(@todo2, install_set($set, $state, @todo2));
}
};
-
+# Note how well we performed. We need to clean up BEFORE we exit anyways.
my $dielater = $@;
+# cleanup various things
$state->{recorder}->cleanup($state);
OpenBSD::PackingElement::Fontdir::finish_fontdirs($state);
OpenBSD::Add::manpages_index($state);
OpenBSD::PackingElement::Lib::ensure_ldconfig($state);
+
+# and display delayed thingies.
if ($state->{packages_with_sig}) {
print "Packages with signatures: ", $state->{packages_with_sig};
if ($state->{packages_without_sig}) {
@@ -883,9 +895,8 @@ if (defined $state->{updatedepends} && %{$state->{updatedepends}}) {
join(' ', sort(keys %{$state->{updatedepends}})),
" may remain\n";
}
-if (defined $state->{defines}->{kitchensink}) {
- print "Added:\n", (map { "\t$_\n" } sort $state->installed), "\n";
-}
+
+# show any error, and show why we died...
rethrow $dielater;
} catch {
print STDERR "$0: $_\n";