From a711a8a80c6c373aaba94b4704464f6715ca663a Mon Sep 17 00:00:00 2001 From: Marc Espie Date: Fri, 1 Jun 2007 21:50:48 +0000 Subject: don't store stuff in the plist, use the handle which is there for that. so loop directly over $set->older for replacements. --- usr.sbin/pkg_add/OpenBSD/Replace.pm | 9 +++--- usr.sbin/pkg_add/pkg_add | 59 ++++++++++++++++++------------------- 2 files changed, 34 insertions(+), 34 deletions(-) (limited to 'usr.sbin/pkg_add') diff --git a/usr.sbin/pkg_add/OpenBSD/Replace.pm b/usr.sbin/pkg_add/OpenBSD/Replace.pm index 1344612b02b..afc79f80c7e 100644 --- a/usr.sbin/pkg_add/OpenBSD/Replace.pm +++ b/usr.sbin/pkg_add/OpenBSD/Replace.pm @@ -1,5 +1,5 @@ # ex:ts=8 sw=4: -# $OpenBSD: Replace.pm,v 1.27 2007/06/01 14:58:29 espie Exp $ +# $OpenBSD: Replace.pm,v 1.28 2007/06/01 21:50:47 espie Exp $ # # Copyright (c) 2004-2006 Marc Espie # @@ -388,8 +388,10 @@ sub save_old_libraries { my ($set, $state) = @_; - for my $old_plist ($set->actual_replacements) { + for my $o ($set->older) { + my $old_plist = $o->{plist}; + my $oldname = $o->{pkgname}; my $libs = {}; my $p = {}; @@ -414,7 +416,6 @@ sub save_old_libraries require OpenBSD::md5; mkdir($dest); - my $oldname = $old_plist->pkgname; open my $descr, '>', $dest.DESC; print $descr "Stub libraries for $oldname\n"; close $descr; @@ -429,7 +430,7 @@ sub save_old_libraries require OpenBSD::PkgCfl; OpenBSD::PkgCfl::register($stub_list, $state); - walk_depends_closure($old_plist->pkgname, $stub_list, $state); + walk_depends_closure($oldname, $stub_list, $state); } else { print "No libraries to keep\n" if $state->{beverbose}; } diff --git a/usr.sbin/pkg_add/pkg_add b/usr.sbin/pkg_add/pkg_add index aa7039309f2..b9b15e4da5b 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.301 2007/06/01 21:37:56 espie Exp $ +# $OpenBSD: pkg_add,v 1.302 2007/06/01 21:50:46 espie Exp $ # # Copyright (c) 2003-2007 Marc Espie # @@ -92,15 +92,15 @@ sub installed return keys %{$state->{installed}}; } +sub set_name_from_handle +{ + my ($state, $h) = @_; + $state->set_pkgname($h->{pkgname}); +} + package OpenBSD::UpdateSet; use OpenBSD::PackageInfo; -sub actual_replacements -{ - my $set = shift; - return map {$_->{plist}} $set->older; -} - sub setup_header { my ($set, $state) = @_; @@ -108,9 +108,8 @@ sub setup_header my $pkgname = $set->handle->{pkgname}; my $header = $state->deptree_header($pkgname).$pkgname; - my @toreplace = $set->older; - if (@toreplace) { - $header.=" (replacing ". join(', ', (map {$_->{pkgname}} @toreplace)). ")"; + if ($set->older) { + $header.=" (replacing ". join(', ', (map {$_->{pkgname}} $set->older)). ")"; } if (!$state->progress->set_header($header)) { print $state->{not} ? "Pretending to add " : "Adding "; @@ -339,16 +338,15 @@ sub really_add my $plist = $handle->{plist}; my $pkgname = $handle->{pkgname}; my $errors = 0; - $state->set_pkgname($pkgname); + $state->set_name_from_handle($handle); $set->setup_header($state); # XXX in `combined' updates, some dependencies may remove extra # packages, so we do a double-take on the list of packages we # are actually replacing. - my @toreplace = $set->actual_replacements; my $replacing = 0; - if (@toreplace) { + if ($set->older) { $replacing = 1; } # if (defined $plist->{old_libs}) { @@ -388,35 +386,36 @@ sub really_add $set, $state); } - for my $op (@toreplace) { - $state->progress->set_header($op->pkgname." (deleting)"); - $state->set_pkgname($op->pkgname); + for my $o ($set->older) { + my $oldname = $o->{pkgname}; + $state->progress->set_header($oldname." (deleting)"); + $state->set_name_from_handle($o); require OpenBSD::Search; - if (OpenBSD::Search::PkgSpec->new("mozilla-thunderbird-<=1.0.2p0")->filter($op->pkgname)) { + if (OpenBSD::Search::PkgSpec->new("mozilla-thunderbird-<=1.0.2p0")->filter($oldname)) { thunderbird_special_case($plist); } require OpenBSD::Delete; require OpenBSD::RequiredBy; - my @wantlist = OpenBSD::RequiredBy->new($op->pkgname)->list; - $op->{wantlist} = \@wantlist; + my @wantlist = OpenBSD::RequiredBy->new($oldname)->list; + $o->{wantlist} = \@wantlist; try { - OpenBSD::Delete::delete_plist($op, $state); + OpenBSD::Delete::delete_plist($o->{plist}, $state); } catchall { Warn $_; Fatal partial_install( - "Deinstallation of ".$op->pkgname." failed", + "Deinstallation of ".$oldname." failed", $set, $state); }; if (defined $state->{updatedepends}) { - delete $state->{updatedepends}->{$op->pkgname}; + delete $state->{updatedepends}->{$oldname}; } - OpenBSD::PkgCfl::unregister($op, $state); + OpenBSD::PkgCfl::unregister($o->{plist}, $state); } # Here there should be code to handle old libs $state->progress->set_header("$pkgname (installing)"); - $state->set_pkgname($pkgname); + $state->set_name_from_handle($handle); } try { @@ -448,21 +447,21 @@ sub really_add $plist->get(DISPLAY)->prepare($state); } # and add dependencies corresponding to the replacement - for my $op (@toreplace) { + for my $o ($set->older) { require OpenBSD::Replace; - my $opkgname = $op->pkgname; + my $oldname = $o->{pkgname}; - print "Adjusting dependencies for $pkgname/$opkgname\n" + print "Adjusting dependencies for $pkgname/$oldname\n" if $state->{beverbose}; my $d = OpenBSD::RequiredBy->new($pkgname); - for my $dep (@{$op->{wantlist}}) { + for my $dep (@{$o->{wantlist}}) { if (defined $set->{skipupdatedeps}->{$dep}) { print "\tskipping $dep\n" if $state->{beverbose}; next; } print "\t$dep\n" if $state->{beverbose}; $d->add($dep); - OpenBSD::Replace::adjust_dependency($dep, $opkgname, $pkgname); + OpenBSD::Replace::adjust_dependency($dep, $oldname, $pkgname); } } } @@ -484,7 +483,7 @@ sub install_package if ($handle->has_error) { if (!$state->{forced}->{kitchensink} || $handle->has_error(OpenBSD::Handle::BAD_PACKAGE)) { - $state->set_pkgname($pkg); + $state->set_name_from_handle($handle); $state->fatal("Fatal error"); } else { return (); -- cgit v1.2.3