logo
Free, unlimited AI code reviews that run on commit
git-lrc git-lrc GitHub Install Now We'd appreciate a star git-lrc - Free, unlimited AI code reviews that run on commit | Product Hunt git-lrc - Free, unlimited AI code reviews that run on commit | Product Hunt

Moose::Meta::TypeCoercion - The Moose Type Coercion metaclass

Authors

       •   Stevan Little <stevan@cpan.org>

       •   Dave Rolsky <autarch@urth.org>

       •   Jesse Luehrs <doy@cpan.org>

       •   Shawn M Moore <sartak@cpan.org>

       •   יובל קוג'מן (Yuval Kogman) <nothingmuch@woobling.org>

       •   Karen Etheridge <ether@cpan.org>

       •   Florian Ragwitz <rafl@debian.org>

       •   Hans Dieter Pearcey <hdp@cpan.org>

       •   Chris Prather <chris@prather.org>

       •   Matt S Trout <mstrout@cpan.org>

Bugs

       See "BUGS" in Moose for details on reporting bugs.

Description

       A type coercion object is basically a mapping of one or more type constraints and the associated
       coercions subroutines.

       It's unlikely that you will need to instantiate an object of this class directly, as it's part of the
       deep internals of Moose.

Methods

Moose::Meta::TypeCoercion->new(%options)
       Creates a new type coercion object, based on the options provided.

       •   type_constraint

           This is the Moose::Meta::TypeConstraint object for the type that is being coerced to.

   $coercion->type_coercion_map
       This  returns  the  map  of  type constraints to coercions as an array reference. The values of the array
       alternate between type names and subroutine references which implement the coercion.

       The value is an array reference because coercions are tried in the order they are added.

   $coercion->type_constraint
       This returns the Moose::Meta::TypeConstraint that was passed to the constructor.

   $coercion->has_coercion_for_type($type_name)
       Returns true if the coercion can coerce the named type.

   $coercion->add_type_coercions($type_name=>$sub,...)
       This method takes a list of type names and subroutine references. If the coercion already has  a  mapping
       for a given type, it throws an exception.

       Coercions are actually

   $coercion->coerce($value)
       This method takes a value and applies the first valid coercion it finds.

       This  means  that  if the value could belong to more than type in the coercion object, the first coercion
       added is used.

   Moose::Meta::TypeCoercion->meta
       This will return a Class::MOP::Class instance for this class.

Name

       Moose::Meta::TypeCoercion - The Moose Type Coercion metaclass

Version

       version 2.2207

See Also