File: //usr/share/perl5/Dpkg/Deps/Multiple.pm
# Copyright © 1998 Richard Braakman
# Copyright © 1999 Darren Benham
# Copyright © 2000 Sean 'Shaleh' Perry
# Copyright © 2004 Frank Lichtenheld
# Copyright © 2006 Russ Allbery
# Copyright © 2007-2009 Raphaël Hertzog <hertzog@debian.org>
# Copyright © 2008-2009, 2012-2014 Guillem Jover <guillem@debian.org>
#
# This program is free software; you may redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation; either version 2 of the License, or
# (at your option) any later version.
#
# This is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with this program. If not, see <https://www.gnu.org/licenses/>.
=encoding utf8
=head1 NAME
Dpkg::Deps::Multiple - base module to represent multiple dependencies
=head1 DESCRIPTION
The Dpkg::Deps::Multiple module provides objects implementing various types
of dependencies. It is the base class for Dpkg::Deps::{AND,OR,Union}.
=cut
package Dpkg::Deps::Multiple 1.02;
use strict;
use warnings;
use Carp;
use Dpkg::ErrorHandling;
use parent qw(Dpkg::Interface::Storable);
=head1 METHODS
=over 4
=item $dep = Dpkg::Deps::Multiple->new(%opts);
Creates a new object.
=cut
sub new {
my ($this, @deps) = @_;
my $class = ref($this) || $this;
my $self = { list => [ @deps ] };
bless $self, $class;
return $self;
}
=item $dep->reset()
Clears any dependency information stored in $dep so that $dep->is_empty()
returns true.
=cut
sub reset {
my $self = shift;
$self->{list} = [];
}
=item $dep->add(@deps)
Adds new dependency objects at the end of the list.
=cut
sub add {
my ($self, @deps) = @_;
push @{$self->{list}}, @deps;
}
=item $dep->get_deps()
Returns a list of sub-dependencies.
=cut
sub get_deps {
my $self = shift;
return grep { not $_->is_empty() } @{$self->{list}};
}
=item $dep->sort()
Sorts alphabetically the internal list of dependencies.
=cut
sub sort {
my $self = shift;
my @res = ();
@res = sort { Dpkg::Deps::deps_compare($a, $b) } @{$self->{list}};
$self->{list} = [ @res ];
}
=item $dep->arch_is_concerned($arch)
Returns true if at least one of the sub-dependencies apply to this
architecture.
=cut
sub arch_is_concerned {
my ($self, $host_arch) = @_;
my $res = 0;
foreach my $dep (@{$self->{list}}) {
$res = 1 if $dep->arch_is_concerned($host_arch);
}
return $res;
}
=item $dep->reduce_arch($arch)
Simplifies the dependencies to contain only information relevant to the
given architecture. The non-relevant sub-dependencies are simply removed.
This trims off the architecture restriction list of L<Dpkg::Deps::Simple>
objects.
=cut
sub reduce_arch {
my ($self, $host_arch) = @_;
my @new;
foreach my $dep (@{$self->{list}}) {
$dep->reduce_arch($host_arch);
push @new, $dep if $dep->arch_is_concerned($host_arch);
}
$self->{list} = [ @new ];
}
=item $dep->has_arch_restriction()
Returns the list of package names that have such a restriction.
=cut
sub has_arch_restriction {
my $self = shift;
my @res;
foreach my $dep (@{$self->{list}}) {
push @res, $dep->has_arch_restriction();
}
return @res;
}
=item $dep->profile_is_concerned()
Returns true if at least one of the sub-dependencies apply to this profile.
=cut
sub profile_is_concerned {
my ($self, $build_profiles) = @_;
my $res = 0;
foreach my $dep (@{$self->{list}}) {
$res = 1 if $dep->profile_is_concerned($build_profiles);
}
return $res;
}
=item $dep->reduce_profiles()
Simplifies the dependencies to contain only information relevant to the
given profile. The non-relevant sub-dependencies are simply removed.
This trims off the profile restriction list of L<Dpkg::Deps::Simple> objects.
=cut
sub reduce_profiles {
my ($self, $build_profiles) = @_;
my @new;
foreach my $dep (@{$self->{list}}) {
$dep->reduce_profiles($build_profiles);
push @new, $dep if $dep->profile_is_concerned($build_profiles);
}
$self->{list} = [ @new ];
}
=item $dep->is_empty()
Returns true if the dependency is empty and doesn't contain any useful
information. This is true when a (descendant of) L<Dpkg::Deps::Multiple>
contains an empty list of dependencies.
=cut
sub is_empty {
my $self = shift;
return scalar @{$self->{list}} == 0;
}
=item $dep->merge_union($other_dep)
This method is not meaningful for this object, and will always croak.
=cut
sub merge_union {
croak 'method merge_union() is only valid for Dpkg::Deps::Simple';
}
=back
=head1 CHANGES
=head2 Version 1.02 (dpkg 1.17.10)
New methods: Add $dep->profile_is_concerned() and $dep->reduce_profiles().
=head2 Version 1.01 (dpkg 1.16.1)
New method: Add $dep->reset().
=head2 Version 1.00 (dpkg 1.15.6)
Mark the module as public.
=cut
1;