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/PackingElement.pm12
-rw-r--r--usr.sbin/pkg_add/pkg_add26
2 files changed, 35 insertions, 3 deletions
diff --git a/usr.sbin/pkg_add/OpenBSD/PackingElement.pm b/usr.sbin/pkg_add/OpenBSD/PackingElement.pm
index 2f9fa4b56d7..f1af78e8389 100644
--- a/usr.sbin/pkg_add/OpenBSD/PackingElement.pm
+++ b/usr.sbin/pkg_add/OpenBSD/PackingElement.pm
@@ -1,5 +1,5 @@
# ex:ts=8 sw=4:
-# $OpenBSD: PackingElement.pm,v 1.139 2007/06/17 09:50:02 espie Exp $
+# $OpenBSD: PackingElement.pm,v 1.140 2007/06/17 10:44:01 espie Exp $
#
# Copyright (c) 2003-2007 Marc Espie <espie@openbsd.org>
#
@@ -586,10 +586,18 @@ sub add
if ($args eq 'no checksum') {
$plist->{state}->{lastfile}->{nochecksum} = 1;
} else {
- die "Unknown tag $args";
+ my $object = $plist->{state}->{lastfileobject};
+ $object->{tags}->{$args} = 1;
+ push(@{$plist->{tags}->{$args}}, $object);
}
}
+package OpenBSD::PackingElement::DefineTag;
+our @ISA=qw(OpenBSD::PackingElement::Meta);
+
+sub keyword() { 'define-tag' }
+__PACKAGE__->register_with_factory;
+
package OpenBSD::PackingElement::symlink;
our @ISA=qw(OpenBSD::PackingElement::Annotation);
diff --git a/usr.sbin/pkg_add/pkg_add b/usr.sbin/pkg_add/pkg_add
index d4699b37d25..2be184135c7 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.324 2007/06/16 11:50:48 espie Exp $
+# $OpenBSD: pkg_add,v 1.325 2007/06/17 10:44:01 espie Exp $
#
# Copyright (c) 2003-2007 Marc Espie <espie@openbsd.org>
#
@@ -141,6 +141,30 @@ sub complete
}
}
+sub reorder_old
+{
+ my ($set, $state) = @_;
+ # no need to sort things if there is one package to replace
+ # return if $set->older <= 1;
+
+ my $resolved;
+ my @l = ();
+ my %todo = map {($_->{pkgname}, $_)} $set->older;
+ do {
+ $resolved = 0;
+BIGLOOP: while (my ($pkg, $h) = each %todo) {
+ for my $name (OpenBSD::RequiredBy->new($pkg)->list) {
+ next BIGLOOP if defined $todo{$name};
+ }
+ push(@l, $h);
+ delete $todo{$pkg};
+ $resolved++;
+ }
+ } while ($resolved);
+ push(@l, values %todo);
+ $set->{older} = \@l;
+}
+
sub can_install
{
my ($set, $state) = @_;