From 814ff9650e7027e275065ec1fdb45615a2c97506 Mon Sep 17 00:00:00 2001 From: Marc Espie Date: Tue, 19 Jun 2007 10:47:29 +0000 Subject: first draft of a tag solver, needs more flesh to be useful (especially: transform the lib cache into a tags/lib cache) --- usr.sbin/pkg_add/OpenBSD/Dependencies.pm | 60 +++++++++++++++++++++++++++++++- 1 file changed, 59 insertions(+), 1 deletion(-) (limited to 'usr.sbin/pkg_add/OpenBSD/Dependencies.pm') 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 # @@ -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; -- cgit v1.2.3