diff options
author | Marc Espie <espie@cvs.openbsd.org> | 2011-12-03 16:15:06 +0000 |
---|---|---|
committer | Marc Espie <espie@cvs.openbsd.org> | 2011-12-03 16:15:06 +0000 |
commit | bba335689980b5b93df5b0aebc94968c8cb4cc94 (patch) | |
tree | ae6324442e4b3e1070d632548c32aa2bef88c911 | |
parent | 5eb8aa22c6f93ddd9e7244db815763d310a3f578 (diff) |
In a collision, retrofit storage for 2nd pkgname.
(in large updatesets, it may not be obvious where the 2nd copy comes from,
as exemplified by ajacoutot@).
-rw-r--r-- | usr.sbin/pkg_add/OpenBSD/Add.pm | 3 | ||||
-rw-r--r-- | usr.sbin/pkg_add/OpenBSD/CollisionReport.pm | 10 |
2 files changed, 10 insertions, 3 deletions
diff --git a/usr.sbin/pkg_add/OpenBSD/Add.pm b/usr.sbin/pkg_add/OpenBSD/Add.pm index 0a9315bd53d..03116760dd2 100644 --- a/usr.sbin/pkg_add/OpenBSD/Add.pm +++ b/usr.sbin/pkg_add/OpenBSD/Add.pm @@ -1,5 +1,5 @@ # ex:ts=8 sw=4: -# $OpenBSD: Add.pm,v 1.126 2011/09/17 15:33:56 schwarze Exp $ +# $OpenBSD: Add.pm,v 1.127 2011/12/03 16:15:05 espie Exp $ # # Copyright (c) 2003-2007 Marc Espie <espie@openbsd.org> # @@ -356,6 +356,7 @@ sub prepare_for_addition # check for collisions with existing stuff if ($state->vstat->exists($fname)) { push(@{$state->{colliding}}, $self); + $self->{newly_found} = $pkgname; $state->{problems}++; return; } diff --git a/usr.sbin/pkg_add/OpenBSD/CollisionReport.pm b/usr.sbin/pkg_add/OpenBSD/CollisionReport.pm index 7ed65c52792..3144225d7a8 100644 --- a/usr.sbin/pkg_add/OpenBSD/CollisionReport.pm +++ b/usr.sbin/pkg_add/OpenBSD/CollisionReport.pm @@ -1,5 +1,5 @@ # ex:ts=8 sw=4: -# $OpenBSD: CollisionReport.pm,v 1.41 2011/01/02 14:26:17 espie Exp $ +# $OpenBSD: CollisionReport.pm,v 1.42 2011/12/03 16:15:05 espie Exp $ # # Copyright (c) 2003-2006 Marc Espie <espie@openbsd.org> # @@ -79,6 +79,7 @@ sub collision_report return; } my %todo = map {($_->fullname, $_->{d})} @$list; + my %extra = map {($_->fullname, $_->{newly_found})} @$list; my $clueless_bat; my $clueless_bat2; my $found = 0; @@ -90,7 +91,12 @@ sub collision_report for my $pkg (sort keys %$bypkg) { for my $item (sort @{$bypkg->{$pkg}}) { $found++; - $state->errsay("\t#1 (#2)", $item, $pkg); + if ($extra{$item}) { + $state->errsay("\t#1 (#2 and #3)", $item, + $pkg, $extra{$item}); + } else { + $state->errsay("\t#1 (#2)", $item, $pkg); + } } if ($pkg =~ m/^(?:partial\-|borked\.\d+$)/o) { $clueless_bat = $pkg; |