openbsd-ports/infrastructure/lib/DPB/Grabber.pm
espie 234027bfe0 unfuck pkgpaths.
- instead of seen/unseen, have an actual constructor. Instead, mark pkgpath
for which we wantinfo/wantbuild.
- only mark EXTRA dependencies as wantinfo. So the devel/haddock,no_deps
temporary error should be gone.
- since we have FLAVOR and SUBPACKAGE available, construct as much info as
we can during vars scanning (see handle_equivalences). This avoids about 150
path rescans during a full bulk. Also, grab the timing and logsizes from
equivalent files, so that most stuff should know show % all the time.
- tweak subdirlist to be a hash, and correctly add pkgpath_and_flavors to it.
That way, we rescan avahi pseudo flavors just once, and not four or five times.
2011-10-10 18:56:50 +00:00

154 lines
3.2 KiB
Perl

# ex:ts=8 sw=4:
# $OpenBSD: Grabber.pm,v 1.15 2011/10/10 18:56:50 espie Exp $
#
# Copyright (c) 2010 Marc Espie <espie@openbsd.org>
#
# Permission to use, copy, modify, and distribute this software for any
# purpose with or without fee is hereby granted, provided that the above
# copyright notice and this permission notice appear in all copies.
#
# THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
# WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
# MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
# ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
# WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
# ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
# OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
use strict;
use warnings;
use DPB::Vars;
use DPB::Util;
package DPB::Grabber;
sub new
{
my ($class, $state, $endcode) = @_;
my $o = bless { ports => $state->ports, make => $state->make,
loglist => DPB::Util->make_hot($state->logger->open("vars")),
logger => $state->logger,
engine => $state->engine,
state => $state,
keep_going => 1,
endcode => $endcode
}, $class;
if ($state->opt('f')) {
require DPB::Fetch;
$o->{dpb} = "fetch";
$o->{fetch} = DPB::Fetch->new($state->distdir);
} else {
$o->{dpb} = "normal";
$o->{fetch} = DPB::FetchDummy->new;
}
return $o;
}
sub finish
{
my ($self, $h) = @_;
for my $v (values %$h) {
if ($v->{broken}) {
delete $v->{info};
delete $v->{broken};
$self->{engine}->add_fatal($v);
} elsif ($v->{wantbuild}) {
delete $v->{wantbuild};
$self->{engine}->new_path($v);
}
}
$self->{keepgoing} = &{$self->{endcode}};
}
sub ports
{
my $self = shift;
return $self->{ports};
}
sub make
{
my $self = shift;
return $self->{make};
}
sub logger
{
my $self = shift;
return $self->{logger};
}
sub grab_subdirs
{
my ($self, $core, $list) = @_;
DPB::Vars->grab_list($core, $self, $list,
$self->{loglist}, $self->{dpb},
sub {
my $h = shift;
for my $v (values %$h) {
$v->{wantbuild} = 1;
}
$self->finish($h);
});
}
sub grab_signature
{
my ($self, $core, $pkgpath) = @_;
return DPB::PortSignature->grab_signature($core, $self, $pkgpath);
}
sub clean_packages
{
my ($self, $core, $pkgpath) = @_;
return DPB::CleanPackages->clean($core, $self, $pkgpath);
}
sub complete_subdirs
{
my ($self, $core) = @_;
# more passes if necessary
while ($self->{keep_going}) {
my $subdirlist = {};
for my $v (DPB::PkgPath->seen) {
if (defined $v->{info}) {
if (defined $v->{wantbuild}) {
delete $v->{wantbuild};
$self->{engine}->new_path($v);
}
next;
}
next if defined $v->{category};
if (defined $v->{tried}) {
$self->{engine}->add_fatal($v)
if !defined $v->{errored};
$v->{errored} = 1;
} elsif ($v->{wantinfo} || $v->{wantbuild}) {
$v->add_to_subdirlist($subdirlist);
$v->{tried} = 1;
}
}
last if (keys %$subdirlist) == 0;
DPB::Vars->grab_list($core, $self, $subdirlist,
$self->{loglist}, $self->{dpb},
sub {
$self->finish(shift);
});
}
}
package DPB::FetchDummy;
sub new
{
my $class = shift;
bless {}, $class;
}
sub build_distinfo
{
}
1;