diff options
Diffstat (limited to 'usr.sbin/pkg_add/OpenBSD')
-rw-r--r-- | usr.sbin/pkg_add/OpenBSD/Dependencies.pm | 60 | ||||
-rw-r--r-- | usr.sbin/pkg_add/OpenBSD/PackingList.pm | 8 |
2 files changed, 63 insertions, 5 deletions
diff --git a/usr.sbin/pkg_add/OpenBSD/Dependencies.pm b/usr.sbin/pkg_add/OpenBSD/Dependencies.pm index 65ee4e7afa2..ffb4896e976 100644 --- a/usr.sbin/pkg_add/OpenBSD/Dependencies.pm +++ b/usr.sbin/pkg_add/OpenBSD/Dependencies.pm @@ -1,5 +1,5 @@ # ex:ts=8 sw=4: -# $OpenBSD: Dependencies.pm,v 1.57 2007/06/19 10:25:35 espie Exp $ +# $OpenBSD: Dependencies.pm,v 1.58 2007/06/19 10:47:28 espie Exp $ # # Copyright (c) 2005-2007 Marc Espie <espie@openbsd.org> # @@ -142,6 +142,42 @@ sub dependency_not_found print "libspec $obj not found\n" if $state->{very_verbose}; } +package OpenBSD::lookup::tag; +our @ISA=qw(OpenBSD::lookup); +sub find_in_extra_sources +{ +} + +sub find_elsewhere +{ +} + +sub find_in_already_done +{ + my ($self, $solver, $state, $obj) = @_; + my $r = $self->{known_tags}->{$obj}; + if (defined $r) { + print "Found tag $obj in $r\n" if $state->{verbose}; + } + return $r; +} + +sub find_in_new_source +{ + my ($self, $solver, $state, $obj, $dep) = @_; + my $plist = OpenBSD::PackingList->from_installation($dep, + \&OpenBSD::PackingList::DependsOnly); + if (!defined $plist) { + print STDERR "Can't read plist for $dep\n"; + } + if ($plist->has('define-tag')) { + for my $t (@{$plist->{'define-tag'}}) { + $self->{known_tags}->{$t} = $dep; + } + } + return $self->find_in_already_dony($solver, $state, $obj); +} + package OpenBSD::Dependencies::Solver; use OpenBSD::PackageInfo; @@ -413,4 +449,26 @@ sub solve_wantlibs return $okay; } +sub solve_tags +{ + my ($solver, $state) = @_; + my $okay = 1; + + my $tag_finder = OpenBSD::lookup::tag->new($solver); + for my $h ($solver->{set}->newer) { + for my $tag (keys %{$h->{plist}->{tags}}) { + next if $tag_finder->lookup($solver, $state, $tag); + OpenBSD::Error::Warn "Can't install ", + $h->{pkgname}, ": tag definition not found ", + $tag, "\n"; + if ($okay) { + $solver->dump; + $tag_finder->dump; + $okay = 0; + } + } + } + return $okay; +} + 1; diff --git a/usr.sbin/pkg_add/OpenBSD/PackingList.pm b/usr.sbin/pkg_add/OpenBSD/PackingList.pm index e4d29a8ce06..8ed4d30ae91 100644 --- a/usr.sbin/pkg_add/OpenBSD/PackingList.pm +++ b/usr.sbin/pkg_add/OpenBSD/PackingList.pm @@ -1,5 +1,5 @@ # ex:ts=8 sw=4: -# $OpenBSD: PackingList.pm,v 1.78 2007/06/12 09:53:36 espie Exp $ +# $OpenBSD: PackingList.pm,v 1.79 2007/06/19 10:47:28 espie Exp $ # # Copyright (c) 2003-2007 Marc Espie <espie@openbsd.org> # @@ -164,7 +164,7 @@ sub DependOnly # XXX optimization if (m/^\@arch\b/o) { while (<$fh>) { - if (m/^\@(?:depend|wantlib)\b/o) { + if (m/^\@(?:depend|wantlib|define-tag)\b/o) { &$cont($_); } elsif (m/^\@(?:groups|users|cwd)\b/o) { last; @@ -172,7 +172,7 @@ sub DependOnly } return; } - next unless m/^\@(?:depend|wantlib)\b/o; + next unless m/^\@(?:depend|wantlib|define-tag)\b/o; &$cont($_); } } @@ -374,7 +374,7 @@ our @unique_categories = our @list_categories = (qw(conflict pkgpath incompatibility updateset depend - wantlib groups users items)); + wantlib define-tag groups users items)); our @cache_categories = (qw(depend wantlib)); |