package Moose::Meta::TypeCoercion::Union; use strict; use warnings; use metaclass; use Scalar::Util 'blessed'; our $VERSION = '0.92'; $VERSION = eval $VERSION; our $AUTHORITY = 'cpan:STEVAN'; use base 'Moose::Meta::TypeCoercion'; sub compile_type_coercion { my $self = shift; my $type_constraint = $self->type_constraint; (blessed $type_constraint && $type_constraint->isa('Moose::Meta::TypeConstraint::Union')) || Moose->throw_error("You can only a Moose::Meta::TypeCoercion::Union for a " . "Moose::Meta::TypeConstraint::Union, not a $type_constraint"); $self->_compiled_type_coercion(sub { my $value = shift; # go through all the type constraints # in the union, and check em ... foreach my $type (@{$type_constraint->type_constraints}) { # if they have a coercion first if ($type->has_coercion) { # then try to coerce them ... my $temp = $type->coerce($value); # and if they get something # make sure it still fits within # the union type ... return $temp if $type_constraint->check($temp); } } return undef; }); } sub has_coercion_for_type { 0 } sub add_type_coercions { require Moose; Moose->throw_error("Cannot add additional type coercions to Union types"); } 1; __END__ =pod =head1 NAME Moose::Meta::TypeCoercion::Union - The Moose Type Coercion metaclass for Unions =head1 DESCRIPTION This is a subclass of L that is used for L objects. =head1 METHODS =over 4 =item B<< $coercion->has_coercion_for_type >> This method always returns false. =item B<< $coercion->add_type_coercions >> This method always throws an error. You cannot add coercions to a union type coercion. =item B<< $coercion->coerce($value) >> This method will coerce by trying the coercions for each type in the union. =back =head1 BUGS All complex software has bugs lurking in it, and this module is no exception. If you find a bug please either email me, or add the bug to cpan-RT. =head1 AUTHOR Stevan Little Estevan@iinteractive.comE =head1 COPYRIGHT AND LICENSE Copyright 2006-2009 by Infinity Interactive, Inc. L This library is free software; you can redistribute it and/or modify it under the same terms as Perl itself. =cut