MOSES-MOBY
view release on metacpan or search on metacpan
lib/MOSES/MOBY/Data/String.pm view on Meta::CPAN
#-----------------------------------------------------------------
# MOSES::MOBY::Data::String
# Author: Edward Kawas <edward.kawas@gmail.com>,
# Martin Senger <martin.senger@gmail.com>
# For copyright and disclaimer see below.
#
# $Id: String.pm,v 1.4 2008/04/29 19:35:57 kawas Exp $
#-----------------------------------------------------------------
package MOSES::MOBY::Data::String;
use base ("MOSES::MOBY::Data::Object");
use strict;
# add versioning to this module
use vars qw /$VERSION/;
$VERSION = sprintf "%d.%02d", q$Revision: 1.4 $ =~ /: (\d+)\.(\d+)/;
=head1 NAME
MOSES::MOBY::Data::String - A primite Moby data type for strings
=head1 SYNOPSIS
use MOSES::MOBY::Data::String;
# create a Moby String with initial value of 'eddie'
my $data = MOSES::MOBY::Data::String->new (value => 'eddie');
my $data = MOSES::MOBY::Data::String->new ('eddie');
# later change the value of this data object
$data->value ('tulak');
print $data->value();
# indicate that the value should be treated as CDATA
$data->cdata (1);
print $data->toXML->toString;
=head1 DESCRIPTION
An object representing a String, a Moby primitive data type.
=head1 AUTHORS
Edward Kawas (edward.kawas [at] gmail [dot] com)
Martin Senger (martin.senger [at] gmail [dot] com)
=cut
#-----------------------------------------------------------------
# A list of allowed attribute names. See MOSES::MOBY::Base for details.
#-----------------------------------------------------------------
=head1 ACCESSIBLE ATTRIBUTES
Details are in L<MOSES::MOBY::Base>. Here just a list of them (additionally
to the attributes from the parent classes)
=over
=item B<value>
A value of this datatype. Must be an integer.
=item B<cdata>
Boolean. If set to true the value will be wrapped as CDATA in the XML
representing this object.
=back
=cut
{
my %_allowed =
(
value => {type => MOSES::MOBY::Base->STRING},
cdata => {type => MOSES::MOBY::Base->BOOLEAN},
);
sub _accessible {
my ($self, $attr) = @_;
exists $_allowed{$attr} or $self->SUPER::_accessible ($attr);
}
sub _attr_prop {
my ($self, $attr_name, $prop_name) = @_;
my $attr = $_allowed {$attr_name};
return ref ($attr) ? $attr->{$prop_name} : $attr if $attr;
return $self->SUPER::_attr_prop ($attr_name, $prop_name);
}
}
#-----------------------------------------------------------------
# init
#-----------------------------------------------------------------
sub init {
my ($self) = shift;
$self->SUPER::init();
$self->primitive ('yes');
$self->cdata ('no');
}
1;
__END__
( run in 1.110 second using v1.01-cache-2.11-cpan-d8267643d1d )