Class::Value::Contact::Name::Full - Contact-related value objects


Class-Value-Contact documentation Contained in the Class-Value-Contact distribution.

Index


Code Index:

NAME

Top

Class::Value::Contact::Name::Full - Contact-related value objects

VERSION

Top

version 1.100840

METHODS

Top

is_well_formed_value

FIXME

send_notify_value_invalid

FIXME

send_notify_value_not_wellformed

FIXME

INSTALLATION

Top

See perlmodinstall for information and options on installing Perl modules.

BUGS AND LIMITATIONS

Top

No bugs have been reported.

Please report any bugs or feature requests through the web interface at http://rt.cpan.org/Public/Dist/Display.html?Name=Class-Value-Contact.

AVAILABILITY

Top

The latest version of this module is available from the Comprehensive Perl Archive Network (CPAN). Visit http://www.perl.com/CPAN/ to find a CPAN site near you, or see http://search.cpan.org/dist/Class-Value-Contact/.

The development version lives at http://github.com/hanekomu/Class-Value-Contact/. Instead of sending patches, please fork this project using the standard git and github infrastructure.

AUTHOR

Top

  Marcel Gruenauer <marcel@cpan.org>

COPYRIGHT AND LICENSE

Top


Class-Value-Contact documentation Contained in the Class-Value-Contact distribution.

use 5.008;
use strict;
use warnings;

package Class::Value::Contact::Name::Full;
our $VERSION = '1.100840';
# ABSTRACT: Contact-related value objects
use parent 'Class::Value::Contact';

# A name is well-formed if it consists of 2-5 whitespace-separated words, at
# least two of which must contain at least two [A-Za-z] characters. This is
# rather arbitrary; if you allow different forms of names, subclass this
# class.
#
# Note that we don't check whether the string only consists of valid
# characters - that's handled by the charset handler mechanism in
# Class::Value::String (i.e., when checking for the validity of the value -
# here we check for well-formedness).
sub is_well_formed_value {
    my ($self, $value) = @_;
    return 1 unless defined($value) && length($value);
    return 0 unless $self->SUPER::is_well_formed_value($value);
    local $_ = $value;
    my @words = split /\s+/;
    return 0 if @words < 2 || @words > 5;
    my $valid_words = 0;
    for (@words) {
        $valid_words++ if 2 <= (() = /[A-Za-z]/g);
    }
    return $valid_words >= 2;
}

sub send_notify_value_not_wellformed {
    my ($self, $value) = @_;
    local $Error::Depth = $Error::Depth + 2;
    $self->exception_container->record(
        'Class::Value::Contact::Exception::Name::NotWellformed',
        name => $value,);
}

sub send_notify_value_invalid {
    my ($self, $value) = @_;
    local $Error::Depth = $Error::Depth + 2;
    $self->exception_container->record(
        'Class::Value::Contact::Exception::Name::Invalid',
        name => $value,);
}
1;


__END__