2011-04-10 14:00:23 -04:00
|
|
|
# $OpenBSD: Var.pm,v 1.11 2011/04/10 18:01:13 jasper Exp $
|
2010-04-13 06:23:53 -04:00
|
|
|
#
|
|
|
|
# Copyright (c) 2006-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 a Template Method approach to store the variable values.
|
|
|
|
|
|
|
|
# rule: we store each value in the main table, after converting YesNo
|
|
|
|
# variables to undef/1. Then, in addition, we process specific variables
|
|
|
|
# to store them in secondary tables (because of one/many associations).
|
|
|
|
|
|
|
|
package AnyVar;
|
2010-04-17 05:33:18 -04:00
|
|
|
sub columntype() { 'OptTextColumn' }
|
|
|
|
sub table() { undef }
|
|
|
|
sub keyword_table() { undef }
|
|
|
|
|
2010-04-13 06:23:53 -04:00
|
|
|
sub new
|
|
|
|
{
|
2010-04-17 09:06:49 -04:00
|
|
|
my ($class, $var, $value, $arch) = @_;
|
|
|
|
print STDERR "$var-$arch\n" if defined $arch;
|
2010-04-13 06:23:53 -04:00
|
|
|
bless [$var, $value], $class;
|
|
|
|
}
|
|
|
|
|
|
|
|
sub var
|
|
|
|
{
|
|
|
|
return shift->[0];
|
|
|
|
}
|
|
|
|
|
|
|
|
sub value
|
|
|
|
{
|
|
|
|
return shift->[1];
|
|
|
|
}
|
|
|
|
|
2010-04-17 05:33:18 -04:00
|
|
|
sub words
|
|
|
|
{
|
|
|
|
my $self = shift;
|
|
|
|
my $v = $self->value;
|
|
|
|
$v =~ s/^\s+//;
|
|
|
|
$v =~ s/\s+$//;
|
|
|
|
return split(/\s+/, $v);
|
|
|
|
}
|
|
|
|
|
2010-04-13 06:23:53 -04:00
|
|
|
sub add
|
|
|
|
{
|
|
|
|
my ($self, $ins) = @_;
|
|
|
|
$ins->add_to_port($self->var, $self->value);
|
|
|
|
}
|
|
|
|
|
|
|
|
sub add_value
|
|
|
|
{
|
|
|
|
my ($self, $ins, $value) = @_;
|
|
|
|
$ins->add_to_port($self->var, $value);
|
|
|
|
}
|
|
|
|
|
|
|
|
sub column
|
|
|
|
{
|
|
|
|
my ($self, $name) = @_;
|
2010-04-13 06:56:42 -04:00
|
|
|
return $self->columntype->new($name)->set_vartype($self);
|
2010-04-13 06:23:53 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
sub keyword
|
|
|
|
{
|
|
|
|
my ($self, $ins, $value) = @_;
|
|
|
|
return $ins->find_keyword_id($value, $self->keyword_table);
|
|
|
|
}
|
|
|
|
|
|
|
|
sub create_keyword_table
|
|
|
|
{
|
|
|
|
my ($self, $inserter) = @_;
|
|
|
|
if (defined $self->keyword_table) {
|
|
|
|
$inserter->create_keyword_table($self->keyword_table);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
sub create_table
|
|
|
|
{
|
|
|
|
my ($self, $inserter) = @_;
|
|
|
|
$self->create_keyword_table($inserter);
|
|
|
|
}
|
|
|
|
|
|
|
|
sub insert
|
|
|
|
{
|
|
|
|
my $self = shift;
|
|
|
|
my $ins = shift;
|
|
|
|
$ins->insert($self->table, @_);
|
|
|
|
}
|
|
|
|
|
|
|
|
sub normal_insert
|
|
|
|
{
|
|
|
|
my $self = shift;
|
|
|
|
my $ins = shift;
|
|
|
|
$ins->insert($self->table, $ins->ref, @_);
|
|
|
|
}
|
|
|
|
|
|
|
|
package KeyVar;
|
2010-04-17 09:06:49 -04:00
|
|
|
our @ISA = qw(AnyVar);
|
2010-04-17 05:33:18 -04:00
|
|
|
sub columntype() { 'ValueColumn' }
|
|
|
|
|
2010-04-13 06:23:53 -04:00
|
|
|
sub add
|
|
|
|
{
|
|
|
|
my ($self, $ins) = @_;
|
|
|
|
$self->add_value($ins, $self->keyword($ins, $self->value));
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
package ArchKeyVar;
|
2010-04-17 09:06:49 -04:00
|
|
|
our @ISA = qw(KeyVar);
|
2010-04-17 05:33:18 -04:00
|
|
|
sub keyword_table() { 'Arch' }
|
2010-04-13 06:23:53 -04:00
|
|
|
|
|
|
|
package OptKeyVar;
|
2010-04-17 09:06:49 -04:00
|
|
|
our @ISA = qw(KeyVar);
|
2010-04-17 05:33:18 -04:00
|
|
|
sub columntype() { 'OptValueColumn' }
|
|
|
|
|
2010-04-13 06:23:53 -04:00
|
|
|
sub add
|
|
|
|
{
|
|
|
|
my ($self, $ins) = @_;
|
|
|
|
if ($self->value ne '') {
|
|
|
|
$self->SUPER::add($ins);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2010-04-17 09:06:49 -04:00
|
|
|
package ArchDependentVar;
|
|
|
|
our @ISA = qw(AnyVar);
|
|
|
|
sub keyword_table() { 'Arch' }
|
|
|
|
|
|
|
|
sub new
|
|
|
|
{
|
|
|
|
my ($class, $var, $value, $arch) = @_;
|
|
|
|
bless [$var, $value, $arch], $class;
|
|
|
|
}
|
|
|
|
|
|
|
|
sub arch
|
|
|
|
{
|
|
|
|
return shift->[2];
|
|
|
|
}
|
|
|
|
|
|
|
|
sub add
|
|
|
|
{
|
|
|
|
my ($self, $ins) = @_;
|
|
|
|
|
|
|
|
my $arch = $self->arch;
|
|
|
|
if (defined $arch) {
|
|
|
|
$arch = $self->keyword($ins, $arch);
|
|
|
|
} else {
|
|
|
|
$self->SUPER::add($ins);
|
|
|
|
}
|
|
|
|
$self->normal_insert($ins, $arch, $self->value);
|
|
|
|
}
|
|
|
|
|
|
|
|
sub create_table
|
|
|
|
{
|
|
|
|
my ($self, $inserter) = @_;
|
|
|
|
$self->create_keyword_table($inserter);
|
|
|
|
$inserter->make_table($self, 'UNIQUE(FULLPKGPATH, ARCH, VALUE)',
|
|
|
|
OptValueColumn->new("ARCH"),
|
|
|
|
TextColumn->new("VALUE"));
|
2010-04-26 06:20:50 -04:00
|
|
|
$inserter->prepare_normal_inserter($self->table,
|
2010-04-17 09:06:49 -04:00
|
|
|
"ARCH", "VALUE");
|
|
|
|
}
|
|
|
|
|
|
|
|
package BrokenVar;
|
|
|
|
our @ISA = qw(ArchDependentVar);
|
|
|
|
sub table() { 'Broken' }
|
|
|
|
|
2010-11-26 15:11:12 -05:00
|
|
|
package ValuedVar;
|
2010-04-17 09:06:49 -04:00
|
|
|
our @ISA = qw(AnyVar);
|
2010-04-17 05:33:18 -04:00
|
|
|
sub columntype() { 'OptIntegerColumn' }
|
2010-04-13 06:23:53 -04:00
|
|
|
|
2010-11-26 15:11:12 -05:00
|
|
|
sub find_value
|
2010-04-13 06:23:53 -04:00
|
|
|
{
|
|
|
|
my ($self, $ins) = @_;
|
|
|
|
|
2010-11-26 15:11:12 -05:00
|
|
|
my $key = $self->value;
|
|
|
|
my $h = $self->values;
|
|
|
|
while (my ($v, $k) = each %$h) {
|
|
|
|
if ($key =~ m/$v/i) {
|
|
|
|
return $k;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
$ins->add_error($self->var." has unknown value $key in ".$ins->{ref});
|
|
|
|
return undef;
|
|
|
|
}
|
2010-10-02 06:26:17 -04:00
|
|
|
|
|
|
|
sub add
|
|
|
|
{
|
|
|
|
my ($self, $ins) = @_;
|
2010-11-26 15:11:12 -05:00
|
|
|
if (defined $self->value) {
|
|
|
|
$self->add_value($ins, $self->find_value($ins));
|
|
|
|
} else {
|
|
|
|
$self->add_value($ins, undef);
|
|
|
|
}
|
2010-10-02 06:26:17 -04:00
|
|
|
}
|
|
|
|
|
2010-11-26 15:11:12 -05:00
|
|
|
package YesNoVar;
|
|
|
|
our @ISA = qw(ValuedVar);
|
|
|
|
sub values
|
|
|
|
{
|
|
|
|
return {
|
|
|
|
yes => 1,
|
|
|
|
no => undef
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
package YesNoGnuVar;
|
|
|
|
our @ISA = qw(ValuedVar);
|
|
|
|
|
|
|
|
sub values
|
|
|
|
{
|
|
|
|
return {
|
|
|
|
yes => 1,
|
|
|
|
gnu => 2,
|
|
|
|
no => undef
|
|
|
|
}
|
|
|
|
}
|
2010-10-02 06:26:17 -04:00
|
|
|
|
2010-04-13 06:23:53 -04:00
|
|
|
# variable is always defined, but we don't need to store empty values.
|
|
|
|
package DefinedVar;
|
2010-04-17 09:06:49 -04:00
|
|
|
our @ISA = qw(AnyVar);
|
2010-04-13 06:23:53 -04:00
|
|
|
|
|
|
|
sub add
|
|
|
|
{
|
|
|
|
my ($self, $ins) = @_;
|
|
|
|
return if $self->value eq '';
|
|
|
|
$self->SUPER::add($ins);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
# all the dependencies are converted into list. Stuff like LIB_DEPENDS will
|
|
|
|
# end up being treated as WANTLIB as well.
|
|
|
|
package DependsVar;
|
2010-04-17 09:06:49 -04:00
|
|
|
our @ISA = qw(AnyVar);
|
2010-04-17 05:33:18 -04:00
|
|
|
sub table() { 'Depends' }
|
|
|
|
|
2010-04-13 06:23:53 -04:00
|
|
|
sub add
|
|
|
|
{
|
|
|
|
my ($self, $ins) = @_;
|
|
|
|
$self->SUPER::add($ins);
|
2010-04-17 05:33:18 -04:00
|
|
|
for my $depends ($self->words) {
|
2010-11-14 03:42:00 -05:00
|
|
|
$depends =~ s/^\:+//;
|
|
|
|
my ($pkgspec, $pkgpath2, $rest) = split(/\:/, $depends);
|
|
|
|
if ($pkgspec =~ m/\//) {
|
|
|
|
($pkgspec, $pkgpath2, $rest) =
|
|
|
|
('', $pkgspec, $pkgpath2);
|
|
|
|
}
|
2010-04-13 06:23:53 -04:00
|
|
|
if (!defined $pkgpath2) {
|
|
|
|
print STDERR "Wrong depends $depends\n";
|
|
|
|
return;
|
|
|
|
}
|
2010-04-26 06:20:50 -04:00
|
|
|
$self->normal_insert($ins, $depends,
|
|
|
|
$ins->find_pathkey($pkgpath2),
|
|
|
|
$ins->convert_depends($self->depends_type),
|
2010-04-13 06:23:53 -04:00
|
|
|
$pkgspec, $rest);
|
2011-03-02 11:19:54 -05:00
|
|
|
$ins->add_todo($pkgpath2);
|
2010-04-13 06:23:53 -04:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
sub create_table
|
|
|
|
{
|
|
|
|
my ($self, $inserter) = @_;
|
2010-04-26 06:20:50 -04:00
|
|
|
$inserter->make_table($self, undef,
|
2010-04-13 06:23:53 -04:00
|
|
|
TextColumn->new("FULLDEPENDS"),
|
|
|
|
OptTextColumn->new("PKGSPEC"),
|
|
|
|
OptTextColumn->new("REST"),
|
|
|
|
PathColumn->new("DEPENDSPATH"),
|
|
|
|
TextColumn->new("TYPE"));
|
2010-04-26 06:20:50 -04:00
|
|
|
$inserter->prepare_normal_inserter($self->table,
|
2010-04-13 06:23:53 -04:00
|
|
|
"FULLDEPENDS", "DEPENDSPATH", "TYPE", "PKGSPEC", "REST");
|
|
|
|
}
|
|
|
|
|
|
|
|
package LibDependsVar;
|
2010-04-17 09:06:49 -04:00
|
|
|
our @ISA = qw(DependsVar);
|
2010-04-13 06:23:53 -04:00
|
|
|
sub depends_type() { 'Library' }
|
|
|
|
|
|
|
|
package RunDependsVar;
|
2010-04-17 09:06:49 -04:00
|
|
|
our @ISA = qw(DependsVar);
|
2010-04-13 06:23:53 -04:00
|
|
|
sub depends_type() { 'Run' }
|
|
|
|
|
|
|
|
package BuildDependsVar;
|
2010-04-17 09:06:49 -04:00
|
|
|
our @ISA = qw(DependsVar);
|
2010-04-13 06:23:53 -04:00
|
|
|
sub depends_type() { 'Build' }
|
|
|
|
|
|
|
|
package RegressDependsVar;
|
2010-04-17 09:06:49 -04:00
|
|
|
our @ISA = qw(DependsVar);
|
2010-04-13 06:23:53 -04:00
|
|
|
sub depends_type() { 'Regress' }
|
|
|
|
|
|
|
|
# Stuff that gets stored in another table
|
|
|
|
package SecondaryVar;
|
2010-04-17 09:06:49 -04:00
|
|
|
our @ISA = qw(KeyVar);
|
2010-04-17 05:33:18 -04:00
|
|
|
sub keyword_table() { undef }
|
|
|
|
|
2010-04-13 06:23:53 -04:00
|
|
|
sub add_value
|
|
|
|
{
|
|
|
|
my ($self, $ins, $value) = @_;
|
|
|
|
$self->normal_insert($ins, $value);
|
|
|
|
}
|
|
|
|
|
|
|
|
sub add_keyword
|
|
|
|
{
|
|
|
|
my ($self, $ins, $value) = @_;
|
|
|
|
$self->add_value($ins, $self->keyword($ins, $value));
|
|
|
|
}
|
|
|
|
|
|
|
|
sub create_table
|
|
|
|
{
|
|
|
|
my ($self, $inserter) = @_;
|
|
|
|
$self->create_keyword_table($inserter);
|
2010-04-26 06:20:50 -04:00
|
|
|
$inserter->make_table($self, "UNIQUE(FULLPKGPATH, VALUE)",
|
2010-04-13 06:23:53 -04:00
|
|
|
ValueColumn->new);
|
|
|
|
$inserter->prepare_normal_inserter($self->table, "VALUE");
|
|
|
|
}
|
|
|
|
|
|
|
|
package MasterSitesVar;
|
2010-04-17 09:06:49 -04:00
|
|
|
our @ISA = qw(OptKeyVar);
|
2010-04-17 05:33:18 -04:00
|
|
|
sub table() { 'MasterSites' }
|
|
|
|
|
2010-04-13 06:23:53 -04:00
|
|
|
sub add
|
|
|
|
{
|
|
|
|
my ($self, $ins) = @_;
|
|
|
|
|
|
|
|
my $n;
|
|
|
|
if ($self->var =~ m/^MASTER_SITES(\d)$/) {
|
|
|
|
$n = $1;
|
|
|
|
}
|
|
|
|
$self->normal_insert($ins, $n, $self->value);
|
|
|
|
}
|
|
|
|
|
|
|
|
sub create_table
|
|
|
|
{
|
|
|
|
my ($self, $inserter) = @_;
|
|
|
|
$self->create_keyword_table($inserter);
|
|
|
|
$inserter->make_table($self, "UNIQUE(FULLPKGPATH, N, VALUE)",
|
|
|
|
OptIntegerColumn->new("N"),
|
|
|
|
ValueColumn->new);
|
|
|
|
$inserter->prepare_normal_inserter($self->table, "N", "VALUE");
|
|
|
|
}
|
|
|
|
|
|
|
|
# Generic handling for any blank-separated list
|
|
|
|
package ListVar;
|
2010-04-17 09:06:49 -04:00
|
|
|
our @ISA = qw(SecondaryVar);
|
2010-04-17 05:33:18 -04:00
|
|
|
sub columntype() { 'OptTextColumn' }
|
2010-04-13 06:23:53 -04:00
|
|
|
|
|
|
|
sub add
|
|
|
|
{
|
|
|
|
my ($self, $ins) = @_;
|
|
|
|
$self->AnyVar::add($ins);
|
2010-04-17 05:33:18 -04:00
|
|
|
for my $d ($self->words) {
|
2010-04-13 06:23:53 -04:00
|
|
|
$self->add_value($ins, $d) if $d ne '';
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
package ListKeyVar;
|
2010-04-17 09:06:49 -04:00
|
|
|
our @ISA = qw(SecondaryVar);
|
2010-04-17 05:33:18 -04:00
|
|
|
sub keyword_table() { 'Keywords' }
|
2010-04-13 06:23:53 -04:00
|
|
|
|
|
|
|
sub add
|
|
|
|
{
|
|
|
|
my ($self, $ins) = @_;
|
|
|
|
$self->AnyVar::add($ins);
|
2010-04-17 05:33:18 -04:00
|
|
|
for my $d ($self->words) {
|
2010-04-13 06:23:53 -04:00
|
|
|
$self->add_keyword($ins, $d) if $d ne '';
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
package QuotedListVar;
|
2010-04-17 09:06:49 -04:00
|
|
|
our @ISA = qw(ListVar);
|
2010-04-13 06:23:53 -04:00
|
|
|
|
|
|
|
sub add
|
|
|
|
{
|
|
|
|
my ($self, $ins) = @_;
|
|
|
|
$self->AnyVar::add($ins);
|
2010-04-17 05:33:18 -04:00
|
|
|
my @l = ($self->words);
|
2010-04-13 06:23:53 -04:00
|
|
|
while (my $v = shift @l) {
|
|
|
|
while ($v =~ m/^[^']*\'[^']*$/ || $v =~m/^[^"]*\"[^"]*$/) {
|
|
|
|
$v.=' '.shift @l;
|
|
|
|
}
|
|
|
|
if ($v =~ m/^\"(.*)\"$/) {
|
|
|
|
$v = $1;
|
|
|
|
}
|
|
|
|
if ($v =~ m/^\'(.*)\'$/) {
|
|
|
|
$v = $1;
|
|
|
|
}
|
|
|
|
$self->add_value($ins, $v) if $v ne '';
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
package DefinedListKeyVar;
|
2010-04-17 09:06:49 -04:00
|
|
|
our @ISA = qw(ListKeyVar);
|
2010-04-17 05:33:18 -04:00
|
|
|
sub columntype() { 'OptValueColumn' }
|
|
|
|
|
2010-04-13 06:23:53 -04:00
|
|
|
sub add
|
|
|
|
{
|
|
|
|
my ($self, $ins) = @_;
|
|
|
|
return if $self->value eq '';
|
|
|
|
$self->SUPER::add($ins);
|
|
|
|
}
|
|
|
|
|
|
|
|
package FlavorsVar;
|
2010-04-17 09:06:49 -04:00
|
|
|
our @ISA = qw(DefinedListKeyVar);
|
2010-04-13 06:23:53 -04:00
|
|
|
sub table() { 'Flavors' }
|
|
|
|
|
|
|
|
package PseudoFlavorsVar;
|
2010-04-17 09:06:49 -04:00
|
|
|
our @ISA = qw(DefinedListKeyVar);
|
2010-04-13 06:23:53 -04:00
|
|
|
sub table() { 'PseudoFlavors' }
|
|
|
|
|
|
|
|
package ArchListVar;
|
2010-04-17 09:06:49 -04:00
|
|
|
our @ISA = qw(DefinedListKeyVar);
|
2010-04-13 06:23:53 -04:00
|
|
|
sub keyword_table() { 'Arch' }
|
|
|
|
|
|
|
|
package OnlyForArchListVar;
|
2010-04-17 09:06:49 -04:00
|
|
|
our @ISA = qw(ArchListVar);
|
2010-04-13 06:23:53 -04:00
|
|
|
sub table() { 'OnlyForArch' }
|
|
|
|
|
|
|
|
package NotForArchListVar;
|
2010-04-17 09:06:49 -04:00
|
|
|
our @ISA = qw(ArchListVar);
|
2010-04-13 06:23:53 -04:00
|
|
|
sub table() { 'NotForArch' }
|
|
|
|
|
|
|
|
package CategoriesVar;
|
2010-04-17 09:06:49 -04:00
|
|
|
our @ISA = qw(ListKeyVar);
|
2010-04-13 06:23:53 -04:00
|
|
|
sub table() { 'Categories' }
|
|
|
|
sub keyword_table() { 'CategoryKeys' }
|
|
|
|
|
2010-10-02 06:26:17 -04:00
|
|
|
package TargetsVar;
|
|
|
|
our @ISA = qw(ListKeyVar);
|
|
|
|
sub table() { 'Targets' }
|
|
|
|
sub keyword_table() { 'TargetKeys' }
|
|
|
|
|
2010-04-13 06:23:53 -04:00
|
|
|
package MultiVar;
|
2010-04-17 09:06:49 -04:00
|
|
|
our @ISA = qw(ListVar);
|
2010-04-13 06:23:53 -04:00
|
|
|
sub table() { 'Multi' }
|
|
|
|
|
|
|
|
sub add
|
|
|
|
{
|
|
|
|
my ($self, $ins) = @_;
|
|
|
|
return if $self->value eq '-';
|
|
|
|
$self->SUPER::add($ins);
|
|
|
|
}
|
|
|
|
|
|
|
|
package ModulesVar;
|
2010-04-17 09:06:49 -04:00
|
|
|
our @ISA = qw(DefinedListKeyVar);
|
2010-04-13 06:23:53 -04:00
|
|
|
sub table() { 'Modules' }
|
|
|
|
sub keyword_table() { 'ModuleKeys' }
|
|
|
|
|
|
|
|
package ConfigureVar;
|
2010-04-17 09:06:49 -04:00
|
|
|
our @ISA = qw(DefinedListKeyVar);
|
2010-04-13 06:23:53 -04:00
|
|
|
sub table() { 'Configure' }
|
|
|
|
sub keyword_table() { 'ConfigureKeys' }
|
|
|
|
|
|
|
|
package ConfigureArgsVar;
|
2010-04-17 09:06:49 -04:00
|
|
|
our @ISA = qw(QuotedListVar);
|
2010-04-13 06:23:53 -04:00
|
|
|
sub table() { 'ConfigureArgs' }
|
|
|
|
|
|
|
|
package WantlibVar;
|
2010-04-17 09:06:49 -04:00
|
|
|
our @ISA = qw(ListVar);
|
2010-04-13 06:23:53 -04:00
|
|
|
sub table() { 'Wantlib' }
|
2010-04-17 05:33:18 -04:00
|
|
|
sub keyword_table() { 'Library' }
|
|
|
|
|
2010-04-13 06:23:53 -04:00
|
|
|
sub _add
|
|
|
|
{
|
|
|
|
my ($self, $ins, $value, $extra) = @_;
|
|
|
|
$self->normal_insert($ins, $self->keyword($ins, $value), $extra);
|
|
|
|
}
|
|
|
|
|
|
|
|
sub add_value
|
|
|
|
{
|
|
|
|
my ($self, $ins, $value) = @_;
|
|
|
|
if ($value =~ m/^(.*)(\.\>?\=\d+\.\d+)$/) {
|
|
|
|
$self->_add($ins, $1, $2);
|
|
|
|
} elsif ($value =~ m/^(.*)(\.\>?\=\d+)$/) {
|
|
|
|
$self->_add($ins, $1, $2);
|
|
|
|
} else {
|
|
|
|
$self->_add($ins, $value, undef);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
sub create_table
|
|
|
|
{
|
|
|
|
my ($self, $inserter) = @_;
|
|
|
|
$self->create_keyword_table($inserter);
|
|
|
|
$inserter->make_table($self, "UNIQUE(FULLPKGPATH, VALUE)",
|
|
|
|
ValueColumn->new,
|
|
|
|
OptTextColumn->new("EXTRA"));
|
|
|
|
$inserter->prepare_normal_inserter($self->table, "VALUE", "EXTRA");
|
|
|
|
}
|
|
|
|
|
|
|
|
package OnlyForArchVar;
|
2010-04-17 09:06:49 -04:00
|
|
|
our @ISA = qw(DefinedListKeyVar);
|
2010-04-13 06:23:53 -04:00
|
|
|
sub table() { 'OnlyForArch' }
|
|
|
|
sub keyword_table() { 'Arches' }
|
|
|
|
|
|
|
|
package FileVar;
|
2010-04-17 09:06:49 -04:00
|
|
|
our @ISA = qw(SecondaryVar);
|
2010-04-17 05:33:18 -04:00
|
|
|
sub table() { 'Descr' }
|
2010-04-13 06:23:53 -04:00
|
|
|
|
|
|
|
sub add
|
|
|
|
{
|
|
|
|
my ($self, $ins) = @_;
|
|
|
|
$self->AnyVar::add($ins);
|
|
|
|
open my $file, '<', $self->value or return;
|
|
|
|
local $/ = undef;
|
|
|
|
$self->add_value($ins, <$file>);
|
|
|
|
}
|
|
|
|
|
|
|
|
package SharedLibsVar;
|
2010-04-17 09:06:49 -04:00
|
|
|
our @ISA = qw(KeyVar);
|
2010-04-17 05:33:18 -04:00
|
|
|
sub table() { 'Shared_Libs' }
|
|
|
|
sub keyword_table() { 'Library' }
|
2010-04-13 06:23:53 -04:00
|
|
|
|
|
|
|
sub add
|
|
|
|
{
|
|
|
|
my ($self, $ins) = @_;
|
|
|
|
$self->AnyVar::add($ins);
|
2010-04-17 05:33:18 -04:00
|
|
|
my %t = $self->words;
|
2010-04-13 06:23:53 -04:00
|
|
|
while (my ($k, $v) = each %t) {
|
|
|
|
$self->normal_insert($ins, $self->keyword($ins, $k), $v);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
sub create_table
|
|
|
|
{
|
|
|
|
my ($self, $inserter) = @_;
|
|
|
|
$self->create_keyword_table($inserter);
|
|
|
|
$inserter->make_table($self, "UNIQUE (FULLPKGPATH, LIBNAME)",
|
|
|
|
ValueColumn->new("LIBNAME"),
|
|
|
|
TextColumn->new("VERSION"));
|
|
|
|
$inserter->prepare_normal_inserter($self->table, "LIBNAME", "VERSION");
|
|
|
|
}
|
|
|
|
|
|
|
|
package EmailVar;
|
2010-04-17 09:06:49 -04:00
|
|
|
our @ISA = qw(KeyVar);
|
2010-04-17 05:33:18 -04:00
|
|
|
sub keyword_table() { 'Email' }
|
2010-04-13 06:23:53 -04:00
|
|
|
|
|
|
|
package YesKeyVar;
|
2010-04-17 09:06:49 -04:00
|
|
|
our @ISA = qw(KeyVar);
|
2010-04-17 05:33:18 -04:00
|
|
|
sub keyword_table() { 'Keywords2' }
|
2010-04-13 06:23:53 -04:00
|
|
|
|
|
|
|
package AutoVersionVar;
|
2010-04-17 09:06:49 -04:00
|
|
|
our @ISA = qw(OptKeyVar);
|
2010-04-17 05:33:18 -04:00
|
|
|
sub keyword_table() { 'AutoVersion' }
|
2010-04-13 06:23:53 -04:00
|
|
|
|
|
|
|
1;
|