#----------------------------------------------------------------- # MOSES::MOBY::Data::String # Author: Edward Kawas , # Martin Senger # 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. Here just a list of them (additionally to the attributes from the parent classes) =over =item B A value of this datatype. Must be an integer. =item B 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__