The Perl Toolchain Summit needs more sponsors. If your company depends on Perl, please support this very important event.

NAME

XML::Pastor::Builtin::List - Ancestor of all classes that correspond to whitespace separated list W3C simple types.

WARNING

This module is used internally by XML::Pastor. You do not normally know much about this module to actually use XML::Pastor. It is documented here for completeness and for XML::Pastor developers. Do not count on the interface of this module. It may change in any of the subsequent releases. You have been warned.

ISA

This class descends from XML::Pastor::Builtin::SimpleType.

DESCRIPTION

This class is used for grouping the builtin classes that have whitespace separated list content. Some utility methods are defined for easing the use of such content.

Some builtin W3C types have a list nature on their own, such as NMTOKENS (whitespace seperated NMTOKEN values) or IDREFS.

In W3C schemas it is also possible to define a simple type to be a list of another atomic simple type.

METHODS

INHERITED METHODS

This class inherits many methods from its ancestors. Please see XML::Pastor::Builtin::SimpleType for more methods.

CONSTRUCTORS

fromList()

  my $object = XML::Pastor::Builtin::List->fromList('hello', 'world');

Creates a new object and sets its value by joining the values passed as the parameter list with a space seperator.

OTHER METHODS

setFromList()

  $object->setFromList('hello', 'world');

Sets the object's value by joining the values passed as the parameter list with a space seperator.

toList()

  @list = $object->toList();

Splits the object's value on whitespace and returns the resulting list.

xml_validate()

  $object->xml_validate();

OBJECT METHOD overriden from XML::Pastor::SimpleType.

Normaly the xml_validate method checks an atomic value. However, list types are aggregate values made up of items whose type is known via itemType and itemClass properties (see XML::Pastor::Schema::SimpleType).

This method will first split the object's value into a list and then run xml_validate on each item by instantiating an simple type object on their own and invoking the xml_validate method on each of them. If all those invocations return TRUE, this method will return TRUE. Otherwise, it would have died along the way before even returning FALSE.

BUGS & CAVEATS

There no known bugs at this time, but this doesn't mean there are aren't any. Note that, although some testing was done prior to releasing the module, this should still be considered alpha code. So use it at your own risk.

Note that there may be other bugs or limitations that the author is not aware of.

AUTHOR

Ayhan Ulusoy <dev(at)ulusoy(dot)name>

COPYRIGHT

  Copyright (C) 2006-2007 Ayhan Ulusoy. All Rights Reserved.

This module is free software; you can redistribute it and/or modify it under the same terms as Perl itself.

SEE ALSO

See also XML::Pastor, XML::Pastor::ComplexType, XML::Pastor::SimpleType, XML::Pastor::Builtin

If you are curious about the implementation, see XML::Pastor::Schema::Parser, XML::Pastor::Schema::Model, XML::Pastor::Generator.