| PerlBean documentation | Contained in the PerlBean distribution. |
PerlBean::Attribute::Multi::Unique::Associative - contains unique associative MULTI bean attribute information
use strict;
use PerlBean::Attribute::Multi::Unique::Associative;
my $attr = PerlBean::Attribute::Multi::Unique::Associative->new( {
method_factory_name => 'ssns_i_know_from_people',
short_description => 'all SSNs I know from people',
} );
Unique, associative MULTI bean attribute information
PerlBean::Attribute::Multi::Unique::Associative contains unique associative MULTI bean attribute information. It is a subclass of PerlBean::Attribute::Multi. The code generation and documentation methods from PerlBean::Attribute are implemented.
Creates a new PerlBean::Attribute::Multi::Unique::Associative object. OPT_HASH_REF is a hash reference used to pass initialization options. OPT_HASH_REF is mandatory. On error an exception Error::Simple is thrown.
Options for OPT_HASH_REF inherited through package PerlBean::Attribute may include:
default_valuePassed to set_default_value().
documentedPassed to set_documented(). Defaults to 1.
exception_classPassed to set_exception_class(). Defaults to 'Error::Simple'.
mandatoryPassed to set_mandatory(). Defaults to 0.
method_basePassed to set_method_base().
short_descriptionPassed to set_short_description().
Options for OPT_HASH_REF inherited through package PerlBean::Attribute::Single may include:
allow_emptyPassed to set_allow_empty(). Defaults to 1.
allow_isaPassed to set_allow_isa(). Must be an ARRAY reference.
allow_refPassed to set_allow_ref(). Must be an ARRAY reference.
allow_rxPassed to set_allow_rx(). Must be an ARRAY reference.
allow_valuePassed to set_allow_value(). Must be an ARRAY reference.
Options for OPT_HASH_REF inherited through package PerlBean::Method::Factory may include:
method_factory_namePassed to set_method_factory_name(). Mandatory option.
perl_beanPassed to set_perl_bean().
This method is inherited from package PerlBean::Attribute::Single. Add additional values on the list of allowed classes. ARRAY is the list value. The addition may not yield to multiple identical elements in the list. Hence, multiple occurrences of the same element cause the last occurrence to be inserted. On error an exception Error::Simple is thrown.
This method is inherited from package PerlBean::Attribute::Single. Add additional values on the list of allowed references. ARRAY is the list value. The addition may not yield to multiple identical elements in the list. Hence, multiple occurrences of the same element cause the last occurrence to be inserted. On error an exception Error::Simple is thrown.
This method is inherited from package PerlBean::Attribute::Single. Add additional values on the list of allow regular expressions. ARRAY is the list value. The addition may not yield to multiple identical elements in the list. Hence, multiple occurrences of the same element cause the last occurrence to be inserted. On error an exception Error::Simple is thrown.
This method is inherited from package PerlBean::Attribute::Single. Add additional values on allowed values. ARRAY is the list value. The addition may not yield to multiple identical elements in the list. Hence, multiple occurrences of the same element cause the last occurrence to be inserted. On error an exception Error::Simple is thrown.
This method is an implementation from package PerlBean::Attribute::Multi. Returns a list of PerlBean::Attribute::Method objects. Access methods are set..., add..., delete..., exists..., keys... and values....',
This method is inherited from package PerlBean::Attribute::Single. Delete elements from the list of allowed classes. Returns the number of deleted elements. On error an exception Error::Simple is thrown.
This method is inherited from package PerlBean::Attribute::Single. Delete elements from the list of allowed references. Returns the number of deleted elements. On error an exception Error::Simple is thrown.
This method is inherited from package PerlBean::Attribute::Single. Delete elements from the list of allow regular expressions. Returns the number of deleted elements. On error an exception Error::Simple is thrown.
This method is inherited from package PerlBean::Attribute::Single. Delete elements from allowed values. Returns the number of deleted elements. On error an exception Error::Simple is thrown.
This method is inherited from package PerlBean::Attribute::Single. Returns the count of items in ARRAY that are in the list of allowed classes.
This method is inherited from package PerlBean::Attribute::Single. Returns the count of items in ARRAY that are in the list of allowed references.
This method is inherited from package PerlBean::Attribute::Single. Returns the count of items in ARRAY that are in the list of allow regular expressions.
This method is inherited from package PerlBean::Attribute::Single. Returns the count of items in ARRAY that are in allowed values.
This method is inherited from package PerlBean::Attribute. Returns attribute default value.
This method is inherited from package PerlBean::Attribute. Returns the class to throw when an exception occurs.
This method is inherited from package PerlBean::Attribute. Returns the method base name.
This method is inherited from package PerlBean::Method::Factory. Returns method factory's name.
This method is inherited from package PerlBean::Attribute. Returns the package name. The package name is obtained from the PerlBean to which the PerlBean::Attribute belongs. Or, if the PerlBean::Attribute does not belong to a PerlBean, main is returned.
This method is inherited from package PerlBean::Attribute. Calls get_package() and replaces :+ with C <_>.
This method is inherited from package PerlBean::Method::Factory. Returns the PerlBean to which this method factory belongs.
This method is inherited from package PerlBean::Attribute. Returns the attribute description.
This method is inherited from package PerlBean::Attribute::Single. Returns whether the attribute is allowed to be empty or not.
This method is inherited from package PerlBean::Attribute. Returns whether the attribute is documented or not.
This method is inherited from package PerlBean::Attribute. Returns whether the attribute is mandatory for construction or not.
This method is inherited from package PerlBean::Attribute::Single. Returns a string containing the documentation for the clauses to which the contents the contents of the attribute must adhere.
This method is inherited from package PerlBean::Attribute::Single. State that the attribute is allowed to be empty. VALUE is the value. Default value at initialization is 1. On error an exception Error::Simple is thrown.
This method is inherited from package PerlBean::Attribute::Single. Set the list of allowed classes absolutely. ARRAY is the list value. Each element in the list is allowed to occur only once. Multiple occurrences of the same element yield in the last occurring element to be inserted and the rest to be ignored. On error an exception Error::Simple is thrown.
This method is inherited from package PerlBean::Attribute::Single. Set the list of allowed references absolutely. ARRAY is the list value. Each element in the list is allowed to occur only once. Multiple occurrences of the same element yield in the last occurring element to be inserted and the rest to be ignored. On error an exception Error::Simple is thrown.
This method is inherited from package PerlBean::Attribute::Single. Set the list of allow regular expressions absolutely. ARRAY is the list value. Each element in the list is allowed to occur only once. Multiple occurrences of the same element yield in the last occurring element to be inserted and the rest to be ignored. On error an exception Error::Simple is thrown.
This method is inherited from package PerlBean::Attribute::Single. Set allowed values absolutely. ARRAY is the list value. Each element in the list is allowed to occur only once. Multiple occurrences of the same element yield in the last occurring element to be inserted and the rest to be ignored. On error an exception Error::Simple is thrown.
This method is inherited from package PerlBean::Attribute. Set attribute default value. VALUE is the value. On error an exception Error::Simple is thrown.
This method is inherited from package PerlBean::Attribute. State that the attribute is documented. VALUE is the value. Default value at initialization is 1. On error an exception Error::Simple is thrown.
This method is inherited from package PerlBean::Attribute. Set the class to throw when an exception occurs. VALUE is the value. Default value at initialization is Error::Simple. VALUE may not be undef. On error an exception Error::Simple is thrown.
This method is inherited from package PerlBean::Attribute. State that the attribute is mandatory for construction. VALUE is the value. Default value at initialization is 0. On error an exception Error::Simple is thrown.
This method is inherited from package PerlBean::Attribute. Set the method base name. VALUE is the value. On error an exception Error::Simple is thrown.
This method is inherited from package PerlBean::Method::Factory. Set method factory's name. VALUE is the value. VALUE may not be undef. On error an exception Error::Simple is thrown.
This method is inherited from package PerlBean::Method::Factory. Set the PerlBean to which this method factory belongs. VALUE is the value. On error an exception Error::Simple is thrown.
This method is inherited from package PerlBean::Attribute. Set the attribute description. VALUE is the value. On error an exception Error::Simple is thrown.
This method is inherited from package PerlBean::Attribute. Determines and returns the type of the attribute. The type is either BOOLEAN, SINGLE or MULTI.
This method is inherited from package PerlBean::Attribute::Single. Returns an ARRAY containing all values of the list of allowed classes.
This method is inherited from package PerlBean::Attribute::Single. Returns an ARRAY containing all values of the list of allowed references.
This method is inherited from package PerlBean::Attribute::Single. Returns an ARRAY containing all values of the list of allow regular expressions.
This method is inherited from package PerlBean::Attribute::Single. Returns an ARRAY containing all values of allowed values.
This method is inherited from package PerlBean::Attribute::Multi. Writes constructor code for the attribute option.
This method is inherited from package PerlBean::Attribute::Multi. Writes constructor documentation for the attribute option.
This method is inherited from package PerlBean::Attribute::Multi. Returns a %DEFAULT_VALUE line string for the attribute.
PerlBean, PerlBean::Attribute, PerlBean::Attribute::Boolean, PerlBean::Attribute::Factory, PerlBean::Attribute::Multi, PerlBean::Attribute::Multi::Ordered, PerlBean::Attribute::Multi::Unique, PerlBean::Attribute::Multi::Unique::Associative::MethodKey, PerlBean::Attribute::Multi::Unique::Ordered, PerlBean::Attribute::Single, PerlBean::Collection, PerlBean::Dependency, PerlBean::Dependency::Import, PerlBean::Dependency::Require, PerlBean::Dependency::Use, PerlBean::Described, PerlBean::Described::ExportTag, PerlBean::Method, PerlBean::Method::Constructor, PerlBean::Method::Factory, PerlBean::Style, PerlBean::Symbol
None known (yet.)
First development: November 2002 Last update: September 2003
Vincenzo Zocca
Copyright 2002, 2003 by Vincenzo Zocca
This file is part of the PerlBean module hierarchy for Perl by
Vincenzo Zocca.
The PerlBean module hierarchy is free software; you can 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.
The PerlBean module hierarchy 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 the PerlBean module hierarchy; if not, write to the Free Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
| PerlBean documentation | Contained in the PerlBean distribution. |
package PerlBean::Attribute::Multi::Unique::Associative; use 5.005; use base qw( PerlBean::Attribute::Multi ); use strict; use warnings; use AutoLoader qw(AUTOLOAD); use Error qw(:try); use PerlBean::Style qw(:codegen); # Package version our ($VERSION) = '$Revision: 1.0 $' =~ /\$Revision:\s+([^\s]+)/; 1; __END__
sub create_method_add { my $self = shift; my $an = $self->get_method_factory_name(); my $an_esc = $self->_esc_apos($an); my $op = &{$MOF}('add'); my $mb = $self->get_method_base(); my $ec = $self->get_exception_class(); my $pkg = $self->get_package(); my $pkg_us = $self->get_package_us(); my $desc = defined( $self->get_short_description() ) ? $self->get_short_description() : 'not described option'; my $exc = ' On error an exception C<' . $self->get_exception_class() . '> is thrown.'; # Make body my $body = <<EOF; ${IND}my \$self${AO}=${AO}shift; EOF # Separate keys/values $body .= <<EOF; ${IND}# Separate keys/values ${IND}my \@key${AO}=${AO}(); ${IND}my \@value${AO}=${AO}(); ${IND}while${BCP}(${ACS}my \$key${AO}=${AO}shift${BFP}(\@_)${ACS})${PBOC[1]}{ ${IND}${IND}push${BFP}(${ACS}\@key,${AC}\$key${ACS}); ${IND}${IND}push${BFP}(${ACS}\@value,${AC}shift${BFP}(\@_)${ACS}); ${IND}} EOF # Check if isas/refs/rxs/values are allowed $body .= <<EOF; ${IND}# Check if isas/refs/rxs/values are allowed ${IND}\&_value_is_allowed${BFP}(${ACS}$an_esc,${AC}\@value${ACS})${AO}||${AO}throw $ec${BFP}("ERROR: ${pkg}::$op$mb, one or more specified value(s) '\@value' is/are not allowed."); EOF # Method tail $body .= <<EOF; ${IND}# Add keys/values ${IND}foreach my \$key (\@key)${PBOC[1]}{ ${IND}${IND}\$self->{$pkg_us}{$an}{\$key}${AO}=${AO}shift${BFP}(\@value); ${IND}} EOF # Make description my $description = <<EOF; Add additional keys/values on ${desc}. C<KEY, VALUE> are key/value pairs. The addition may not yield to multiple identical keys in the list. Hence, multiple occurrences of the same key cause the last occurrence to be inserted.${exc} EOF # Add clauses to the description my $clauses = $self->mk_doc_clauses(); if ($clauses) { $description .= "\n" . $clauses; } # Create and return the method return( PerlBean::Method->new( { method_name => "$op$mb", parameter_description => "${ACS}\[${ACS}KEY, VALUE ...${ACS}]${ACS}", documented => $self->is_documented(), volatile => 1, description => $description, body => $body, } ) ); } sub create_method_delete { my $self = shift; my $an = $self->get_method_factory_name(); my $an_esc = $self->_esc_apos($an); my $op = &{$MOF}('delete'); my $mb = $self->get_method_base(); my $ec = $self->get_exception_class(); my $pkg = $self->get_package(); my $pkg_us = $self->get_package_us(); my $desc = defined( $self->get_short_description() ) ? $self->get_short_description() : 'not described option'; my $empt = $self->is_allow_empty() ? '' : ' After deleting at least one element must remain.'; my $exc = ' On error an exception C<' . $self->get_exception_class() . '> is thrown.'; # Make body my $body = <<EOF; ${IND}my \$self${AO}=${AO}shift; EOF # Check if list value is allowed to be empty if ( ! $self->is_allow_empty() ) { $body .= <<EOF; ${IND}# List value for $an_esc is not allowed to be empty ${IND}my \%would_delete${AO}=${AO}(); ${IND}foreach my \$val (\@_)${PBOC[1]}{ ${IND}${IND}\$would_delete{\$val}${AO}=${AO}\$val if${BCP}(${ACS}exists${BFP}(${ACS}\$self->{$pkg_us}{$an}{\$val}${ACS})${ACS}) ${IND}} ${IND}(${ACS}scalar${BFP}(${ACS}keys${BFP}(${ACS}\%{${ACS}\$self->{$pkg_us}{$an}${ACS}}${ACS})${ACS})${AO}==${AO}scalar${BFP}(${ACS}keys${BFP}(${ACS}\%would_delete)${ACS})${ACS})${AO}&&${AO}throw $ec${BFP}("ERROR: ${pkg}::$op$mb, list value may not be empty."); EOF } # Method tail $body .= <<EOF; ${IND}# Delete values ${IND}my \$del${AO}=${AO}0; ${IND}foreach my \$val (\@_)${PBOC[1]}{ ${IND}${IND}exists${BFP}(${ACS}\$self->{$pkg_us}{$an}{\$val}${ACS})${AO}||${AO}next; ${IND}${IND}delete${BFP}(${ACS}\$self->{$pkg_us}{$an}{\$val}${ACS}); ${IND}${IND}\$del${AO}++; ${IND}} ${IND}return${BFP}(\$del); EOF # Create and return the method return( PerlBean::Method->new( { method_name => "$op$mb", parameter_description => 'ARRAY', documented => $self->is_documented(), volatile => 1, description => <<EOF, Delete elements from ${desc}.${empt} Returns the number of deleted elements.${exc} EOF body => $body, } ) ); } sub create_method_exists { my $self = shift; my $an = $self->get_method_factory_name(); my $op = &{$MOF}('exists'); my $mb = $self->get_method_base(); my $pkg_us = $self->get_package_us(); my $desc = defined( $self->get_short_description() ) ? $self->get_short_description() : 'not described option'; # Make body my $body = <<EOF; ${IND}my \$self${AO}=${AO}shift; ${IND}# Count occurrences ${IND}my \$count${AO}=${AO}0; ${IND}foreach my \$val (\@_)${PBOC[1]}{ ${IND}${IND}\$count${AO}+=${AO}exists${BFP}(${ACS}\$self->{$pkg_us}{$an}{\$val}${ACS}); ${IND}} ${IND}return${BFP}(\$count); EOF # Create and return the method return( PerlBean::Method->new( { method_name => "$op$mb", parameter_description => 'ARRAY', documented => $self->is_documented(), volatile => 1, description => <<EOF, Returns the count of items in C<ARRAY> that are in ${desc}. EOF body => $body, } ) ); } sub create_method_keys { my $self = shift; my $an = $self->get_method_factory_name(); my $op = &{$MOF}('keys'); my $mb = $self->get_method_base(); my $pkg_us = $self->get_package_us(); my $desc = defined( $self->get_short_description() ) ? $self->get_short_description() : 'not described option'; # Make body my $body = <<EOF; ${IND}my \$self${AO}=${AO}shift; ${IND}# Return all keys ${IND}return${BFP}(${ACS}keys${BFP}(${ACS}\%{${ACS}\$self->{$pkg_us}{$an}${ACS}}${ACS})${ACS}); EOF # Create and return the method return( PerlBean::Method->new( { method_name => "$op$mb", documented => $self->is_documented(), volatile => 1, description => <<EOF, Returns an C<ARRAY> containing the keys of ${desc}. EOF body => $body, } ) ); } sub create_method_set { my $self = shift; my $an = $self->get_method_factory_name(); my $an_esc = $self->_esc_apos($an); my $op = &{$MOF}('set'); my $mb = $self->get_method_base(); my $ec = $self->get_exception_class(); my $pkg = $self->get_package(); my $pkg_us = $self->get_package_us(); my $desc = defined( $self->get_short_description() ) ? $self->get_short_description() : 'not described option'; my $def = defined( $self->get_default_value() ) ? ' Default value at initialization is C<' . join( ', ', $self->_esc_aq ( @{ $self->get_default_value() } ) ) . '>.' : ''; my $empt = $self->is_allow_empty() ? '' : ' C<ARRAY> must at least have one element.'; my $exc = ' On error an exception C<' . $self->get_exception_class() . '> is thrown.'; my $attr_overl = $self->_get_overloaded_attribute(); my $overl = defined($attr_overl) ? " B<NOTE:> Methods B<C<*$mb ()>> are overloaded from package C<". $attr_overl->get_package() .'>.': ''; # Make body my $body = <<EOF; ${IND}my \$self${AO}=${AO}shift; EOF # Check if list value is allowed to be empty if ( ! $self->is_allow_empty() ) { $body .= <<EOF; ${IND}# List value for $an_esc is not allowed to be empty ${IND}scalar${BFP}(\@_)${AO}||${AO}throw $ec${BFP}("ERROR: ${pkg}::$op$mb, list value may not be empty."); EOF } # Separate keys/values $body .= <<EOF; ${IND}# Separate keys/values ${IND}my \@key${AO}=${AO}(); ${IND}my \@value${AO}=${AO}(); ${IND}while${BCP}(${ACS}my \$key${AO}=${AO}shift${BFP}(\@_)${ACS})${PBOC[1]}{ ${IND}${IND}push${BFP}(${ACS}\@key,${AC}\$key${ACS}); ${IND}${IND}push${BFP}(${ACS}\@value,${AC}shift${BFP}(\@_)${ACS}); ${IND}} EOF # Check if isas/refs/rxs/values are allowed $body .= <<EOF; ${IND}# Check if isas/refs/rxs/values are allowed ${IND}\&_value_is_allowed${BFP}(${ACS}$an_esc,${AC}\@value${ACS})${AO}||${AO}throw $ec${BFP}("ERROR: ${pkg}::$op$mb, one or more specified value(s) '\@value' is/are not allowed."); EOF # Method tail $body .= <<EOF; ${IND}# Empty list ${IND}\$self->{$pkg_us}{$an}${AO}=${AO}\{}; ${IND}# Add keys/values ${IND}foreach my \$key (\@key)${PBOC[1]}{ ${IND}${IND}\$self->{$pkg_us}{$an}{\$key}${AO}=${AO}shift${BFP}(\@value); ${IND}} EOF # Make description my $description = <<EOF; Set ${desc} absolutely using keys/values. C<KEY, VALUE> are key/value pairs. 0 or more of these pairs may be supplied. Each key in is allowed to occur only once. Multiple occurrences of the same key yield in the last occurring key to be inserted and the rest to be ignored.${def}${empt}${exc}${overl} EOF # Add clauses to the description my $clauses = $self->mk_doc_clauses(); if ($clauses) { $description .= "\n" . $clauses; } # Create and return the method return( PerlBean::Method->new( { method_name => "$op$mb", parameter_description => "${ACS}\[${ACS}KEY, VALUE ...${ACS}]${ACS}", documented => $self->is_documented(), volatile => 1, description => $description, body => $body, } ) ); } sub create_method_values { my $self = shift; my $an = $self->get_method_factory_name(); my $op = &{$MOF}('values'); my $mb = $self->get_method_base(); my $pkg_us = $self->get_package_us(); my $desc = defined( $self->get_short_description() ) ? $self->get_short_description() : 'not described option'; # Make body my $body = <<EOF; ${IND}my \$self${AO}=${AO}shift; ${IND}if${BCP}(${ACS}scalar${BFP}(\@_)${ACS})${PBOC[1]}{ ${IND}${IND}my \@ret${AO}=${AO}(); ${IND}${IND}foreach my \$key (\@_)${PBOC[2]}{ ${IND}${IND}${IND}exists${BFP}(${ACS}\$self->{$pkg_us}{$an}{\$key}${ACS})${AO}&&${AO}push${BFP}(${ACS}\@ret,${AC}\$self->{$pkg_us}{$an}{\$key}${ACS}); ${IND}${IND}} ${IND}${IND}return${BFP}(\@ret); ${IND}}${PBCC[1]}else${PBOC[1]}{ ${IND}${IND}# Return all values ${IND}${IND}return${BFP}(${ACS}values${BFP}(${ACS}\%{${ACS}\$self->{$pkg_us}{$an}${ACS}}${ACS})${ACS}); ${IND}} EOF # Create and return the method return( PerlBean::Method->new( { method_name => "$op$mb", parameter_description => "${ACS}\[${ACS}KEY_ARRAY${ACS}]${ACS}", documented => $self->is_documented(), volatile => 1, description => <<EOF, Returns an C<ARRAY> containing the values of ${desc}. If C<KEY_ARRAY> contains one or more C<KEY>s the values related to the C<KEY>s are returned. If no C<KEY>s specified all values are returned. EOF body => $body, } ) ); } sub create_methods { my $self = shift; return( $self->create_method_add(), $self->create_method_delete(), $self->create_method_exists(), $self->create_method_keys(), $self->create_method_set(), $self->create_method_values(), ); }