NAME

Type::Constraint::Parameterizable - A class which represents parameterizable constraints

VERSION

version 0.02

SYNOPSIS

my $arrayref = t('ArrayRef');

my $arrayref_of_int = $arrayref->parameterize( of => t('Int') );

DESCRIPTION

This class implements the API for parameterizable types like ArrayRef and Maybe.

API

This class implements the same API as Type::Constraint::Simple, with a few additions.

Type::Constraint::Parameterizable->new(...)

This class's constructor accepts two additional parameters:

  • parameterized_constraint_generator

    This is a subroutine that generates a new constraint subroutine when the type is parameterized.

    It will be called as a method on the type and will be passed a single argument, the type object for the type parameter.

    This parameter is mutually exclusive with the parameterized_inline_generator parameter.

  • parameterized_inline_generator

    This is a subroutine that generates a new inline generator subroutine when the type is parameterized.

    It will be called as a method on the Type::Constraint::Parameterized object when that object needs to generate inline constraint. It will receive the type parameter as the first argument and the variable name as a string as the second.

    This probably seems fairly confusing, so looking at the examples in the Type::Library::Builtins code may be helpful.

    This parameter is mutually exclusive with the parameterized_inline_generator parameter.

$type->parameterize(...)

This method takes two arguments. The of argument should be an object which does the Type::Constraint::Role::Interface role, and is required.

The other argument, declared_at, is optional. If it is not given, then a new Type::DeclaredAt object is creating using a call stack depth of 1.

This method returns a new Type::Constraint::Parameterized object.

AUTHOR

Dave Rolsky <autarch@urth.org>

COPYRIGHT AND LICENSE

This software is Copyright (c) 2012 by Dave Rolsky.

This is free software, licensed under:

The Artistic License 2.0 (GPL Compatible)