NAME
Type::Library - tiny, yet Moo(se)-compatible type libraries
SYNOPSIS
package MyTypes {
use Scalar::Util qw(looks_like_number);
use Type::Library -base;
use Type::Tiny;
my $NUM = "Type::Tiny"->new(
name => "Number",
constraint => sub { looks_like_number($_) },
message => sub { "$_ ain't a number" },
);
__PACKAGE__->meta->add_type($NUM);
}
package Ermintrude {
use Moo;
use MyTypes qw(Number);
has favourite_number => (is => "ro", isa => Number);
}
# Note the "-moose" flag when importing!
package Bullwinkle {
use Moose;
use MyTypes -moose, qw(Number);
has favourite_number => (is => "ro", isa => Number);
}
# Note the "-mouse" flag when importing!
package Maisy {
use Mouse;
use MyTypes -mouse, qw(Number);
has favourite_number => (is => "ro", isa => Number);
}
DESCRIPTION
Type::Library is a tiny class for creating MooseX::Types-like type libraries which are compatible with Moo and Moose.
If you're reading this because you want to create a type library, then you're probably better off reading Type::Tiny::Intro.
Methods
A type library is a singleton class. Use the meta
method to get a blessed object which other methods can get called on. For example:
MyTypes->meta->add_type($foo);
add_type($type)
oradd_type(%opts)
-
Add a type to the library. If
%opts
is given, then this method callsType::Tiny->new(%opts)
first, and adds the resultant type.Adding a type named "Foo" to the library will automatically define four functions in the library's namespace:
get_type($name)
-
Gets the
Type::Tiny
object corresponding to the name. has_type($name)
-
Boolean; returns true if the type exists in the library.
type_names
-
List all types defined by the library.
import(@args)
-
Type::Library-based libraries are exporters.
Export
Type libraries are exporters. For the purposes of the following examples, assume that the MyTypes
library defines types Number
and String
.
# Exports nothing.
#
use MyTypes;
# Exports a function "String" which is a constant returning
# the String type constraint.
#
use MyTypes qw( String );
# Exports both String and Number as above.
#
use MyTypes qw( String Number );
# Same.
#
use MyTypes qw( :types );
# Exports a sub "is_String" so that "is_String($foo)" is equivalent
# to "String->check($foo)".
#
use MyTypes qw( is_String );
# Exports "is_String" and "is_Number".
#
use MyTypes qw( :is );
# Exports a sub "assert_String" so that "assert_String($foo)" is
# equivalent to "String->assert_valid($foo)".
#
use MyTypes qw( assert_String );
# Exports "assert_String" and "assert_Number".
#
use MyTypes qw( :assert );
# Exports a sub "to_String" so that "to_String($foo)" is equivalent
# to "String->coerce($foo)".
#
use MyTypes qw( to_String );
# Exports "to_String" and "to_Number".
#
use MyTypes qw( :to );
# Exports "String", "is_String", "assert_String" and "coerce_String".
#
use MyTypes qw( +String );
# Exports everything.
#
use MyTypes qw( :all );
Adding -mouse
or -moose
to the export list ensures that all the type constraints exported are Mouse or Moose compatible respectively.
BUGS
Please report any bugs to http://rt.cpan.org/Dist/Display.html?Queue=Type-Tiny.
SEE ALSO
Type::Tiny, Type::Utils, Type::Standard, Type::Coercion.
Moose::Util::TypeConstraints, Mouse::Util::TypeConstraints.
AUTHOR
Toby Inkster <tobyink@cpan.org>.
COPYRIGHT AND LICENCE
This software is copyright (c) 2013 by Toby Inkster.
This is free software; you can redistribute it and/or modify it under the same terms as the Perl 5 programming language system itself.
DISCLAIMER OF WARRANTIES
THIS PACKAGE IS PROVIDED "AS IS" AND WITHOUT ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, WITHOUT LIMITATION, THE IMPLIED WARRANTIES OF MERCHANTIBILITY AND FITNESS FOR A PARTICULAR PURPOSE.