The Perl Toolchain Summit needs more sponsors. If your company depends on Perl, please support this very important event.

NAME

MooseX::LazyCoercion - Coercion deferred to attribute call time

VERSION

version 0.002

SYNOPSIS

    #
    # with built-in type constraints
    #
    package My::Foo;
    use MooseX::LazyCoercion;
    subtype 'My::DateTime' => as 'DateTime';
    coerce 'My::DateTime' => from 'Int', via { DateTime->from_epoch( epoch => $_ ) };
    has_lazily_coerced dt => (
        is => 'ro',
        isa => 'My::DateTime',
    );
    package main;
    my $foo = My::Foo->new( dt => time() );
    my $dt = $foo->{dt}     # uncoerced, returns undef
    my $dt = $foo->dt       # coerced, returns DateTime object

    #
    # with MooseX::Types type constraints
    #
    package My::Foo;
    use MooseX::Types::DateTime qw(DateTime);
    has_lazily_coerced dt => (
        is => 'ro',
        isa => DateTime,
    );
    package main;
    my $foo = My::Foo->new( dt => time() )
    my $dt = $foo->{dt}     # uncoerced, returns undef
    my $dt = $foo->dt       # coerced, returns DateTime object

DESCRIPTION

Moose has the feature of lazy attribute creation, that is: The value of an attribute is created only at the moment when it is first called. Moose has another cool feature, type coercions, which allows one to define rules on how to derive the type of value specified in the "isa" parameter to "has" from different data structures. Unfortunately, this breaks the laziness of attribute creation, since all coercions are performed at BUILD time.

This module allows one to defer the coercion of an attribute to the time when it is first called. It does so by shadowing the value passed to the init_arg of the attribute to a temporary attribute and coercing that when the original attribute is called.

MooseX::LazyCoercion can introspect both native typeconstraints and the type decorators used by MooseX::Types to determine if a value passed to the shadow attribute can be coerced. This way, you have the benefit of type checking without the overhead of type coercion performed at build time.

NAME

MooseX::LazyCoercion - Lazy coercions for Moose TypeConstraints

METHODS

has_lazily_coerced

AUTHOR

Konstantin Baierer <kba@cpan.org>

COPYRIGHT AND LICENSE

This software is copyright (c) 2012 by Konstantin Baierer.

This is free software; you can redistribute it and/or modify it under the same terms as the Perl 5 programming language system itself.