summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMarc Espie <espie@cvs.openbsd.org>2007-06-19 10:47:29 +0000
committerMarc Espie <espie@cvs.openbsd.org>2007-06-19 10:47:29 +0000
commit814ff9650e7027e275065ec1fdb45615a2c97506 (patch)
tree3d0bdac433afdd6e37c107933449d9c0635bb889
parent62fe1f8b08101ab9914ba2c3c7bf13f236017211 (diff)
first draft of a tag solver, needs more flesh to be useful (especially:
transform the lib cache into a tags/lib cache)
-rw-r--r--usr.sbin/pkg_add/OpenBSD/Dependencies.pm60
-rw-r--r--usr.sbin/pkg_add/OpenBSD/PackingList.pm8
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));