Perl data types
package MyApp::Thingy; use strict; use Class::Meta; use Class::Meta::Types::Perl; # OR... # use Class::Meta::Types::Perl 'affordance'; # OR... # use Class::Meta::Types::Perl 'semi-affordance'; BEGIN { # Create a Class::Meta object for this class. my $cm = Class::Meta->new( key => 'thingy' ); # Add an integer attribute. $cm->add_attribute( name => 'my_hash', type => 'hash' ); $cm->build; }
This module provides Perl data types for use with Class::Meta attributes. Simply load it, then pass the name of one of its types to the \*(C`add_attribute()\*(C' method of a Class::Meta object. See Class::Meta::Type for more information on using and creating data types.
The validation checks for Class::Meta::Types::Perl are provided by the Class::Meta::Type's support for object type validation, since Perl data types are understood by \*(C`UNIVERSAL::isa()\*(C'.
The data types created by Class::Meta::Types::Perl are:
A simple scalar value. This can be anything, and has no validation checks.
A scalar reference. \*(C`UNIVERSAL::isa()\*(C' must return '\s-1SCALAR\s0'.
A array reference. \*(C`UNIVERSAL::isa()\*(C' must return '\s-1ARRAY\s0'.
A hash reference. \*(C`UNIVERSAL::isa()\*(C' must return '\s-1HASH\s0'.
A code reference. Also known as a closure. \*(C`UNIVERSAL::isa()\*(C' must return '\s-1CODE\s0'.
This module is stored in an open GitHub repository <http://github.com/theory/class-meta/>. Feel free to fork and contribute!
Please file bug reports via GitHub Issues <http://github.com/theory/class-meta/issues/> or by sending mail to [email protected] <mailto:[email protected]>.
David E. Wheeler <[email protected]>
Other classes of interest within the Class::Meta distribution include:
This class contains most of the documentation you need to get started with Class::Meta.
This class manages the creation of data types.
This class manages Class::Meta class attributes, all of which are based on data types.
Other data type modules:
Copyright (c) 2002-2011, David E. Wheeler. Some Rights Reserved.
This module is free software; you can redistribute it and/or modify it under the same terms as Perl itself.