| Net-ACL documentation | Contained in the Net-ACL distribution. |
Net::ACL::Set::Union - Class updating array references doing unions
use Net::ACL::Set::Union;
# Construction
my $set = new Net::ACL::Set::Union(1,[42,45]);
# Accessor Methods
@data = $set->set(@data);
This module is a list manipulator, which can replace a list with the union of the list and another list. It is used with Net::ACL::Rule.
my $set = new Net::ACL::Set::Union(1,[42,45]);
This is the constructor for Net::ACL::Set::Scalar objects. It returns a reference to the newly created object.
It takes one argument. If the argument is an array reference with one element, the element will be placed instead of the first argument to the set method.
If an array reference has more then one element, the second element should be the argument number to be replaced in the set method.
Otherwise, the value will directly be used instead of the first argument of the set method.
This function modifies the arguments according to the arguments of the constructor and returns them.
Net::ACL::Set, Net::ACL::Rule, Net::ACL
Martin Lorensen <bgp@martin.lorensen.dk>
| Net-ACL documentation | Contained in the Net-ACL distribution. |
#!/usr/bin/perl # $Id: Union.pm,v 1.7 2003/06/06 18:45:02 unimlo Exp $ package Net::ACL::Set::Union; use strict; use vars qw( $VERSION @ISA ); ## Inheritance and Versioning ## @ISA = qw( Net::ACL::Set::Scalar ); $VERSION = '0.07'; ## Module Imports ## use Net::ACL::Set::Scalar; use Carp; ## Public Object Methods ## sub set { my $this = shift; my @data = @_; my $data = $data[$this->{_index}]; croak __PACKAGE__ . "->set needs to operate on an array reference!" unless ref $data eq 'ARRAY'; my %res; foreach my $elem ( @{$data}, @{$this->{_value}} ) { $res{$elem} = 1; }; $data[$this->{_index}] = [ sort keys %res ]; return @data; } sub value { my $this = shift; $this->{_value} = @_ ? shift : $this->{_value}; return $this->{_value}; } ## POD ##
## End Package Net::ACL::Set::Scalar ## 1;