package MooseX::Storage::Deferred; # ABSTRACT: A role for indecisive programmers our $VERSION = '0.53'; use Moose::Role; with 'MooseX::Storage::Basic'; use Carp 'confess'; use namespace::autoclean; sub __get_method { my ( $self, $basename, $value, $method_name ) = @_; my $role = MooseX::Storage->_expand_role($basename => $value)->meta; my $method = $role->get_method($method_name)->body; } sub thaw { my ( $class, $packed, $type, @args ) = @_; (exists $type->{format}) || confess "You must specify a format type to thaw from"; my $code = $class->__get_method(Format => $type->{format} => 'thaw'); $class->$code($packed, @args); } sub freeze { my ( $self, $type, @args ) = @_; (exists $type->{format}) || confess "You must specify a format type to freeze into"; my $code = $self->__get_method(Format => $type->{format} => 'freeze'); $self->$code(@args); } sub load { my ( $class, $filename, $type, @args ) = @_; (exists $type->{io}) || confess "You must specify an I/O type to load with"; my $code = $class->__get_method(IO => $type->{io} => 'load'); $class->$code($filename, $type, @args); } sub store { my ( $self, $filename, $type, @args ) = @_; (exists $type->{io}) || confess "You must specify an I/O type to store with"; my $code = $self->__get_method(IO => $type->{io} => 'store'); $self->$code($filename, $type, @args); } 1; __END__ =pod =encoding UTF-8 =head1 NAME MooseX::Storage::Deferred - A role for indecisive programmers =head1 VERSION version 0.53 =head1 SYNOPSIS package Point; use Moose; use MooseX::Storage; with 'MooseX::Storage::Deferred'; has 'x' => (is => 'rw', isa => 'Int'); has 'y' => (is => 'rw', isa => 'Int'); 1; my $p = Point->new(x => 10, y => 10); ## methods to freeze/thaw into ## a specified serialization format ## (in this case JSON) # pack the class into a JSON string $p->freeze({ format => 'JSON' }); # { "__CLASS__" : "Point", "x" : 10, "y" : 10 } # pack the class into a JSON string using parameterized JSONpm role $p->freeze({ format => [ JSONpm => { json_opts => { pretty => 1 } } ] }); # unpack the JSON string into a class my $p2 = Point->thaw( '{ "__CLASS__" : "Point", "x" : 10, "y" : 10 }', { format => 'JSON' } ); =head1 DESCRIPTION This role is designed for those times when you need to serialize into many different formats or I/O options. It basically allows you to choose the format and IO options only when you actually use them (see the SYNOPSIS for more info) =head1 SUPPORTED FORMATS =over 4 =item I =for stopwords JSONpm =item I =item I =item I =back =head1 SUPPORTED I/O =over 4 =item I =item I =back B The B I/O option is not supported, this is because it does not mix well with options who also have a C and C methods like this. It is possible to probably work around this issue, but I don't currently have the need for it. If you need this supported, talk to me and I will see what I can do. =head1 METHODS =over 4 =item B =item B =item B =item B =back =head1 SUPPORT Bugs may be submitted through L (or L). There is also a mailing list available for users of this distribution, at L. There is also an irc channel available for users of this distribution, at L on C|irc://irc.perl.org/#moose>. =head1 AUTHORS =over 4 =item * Chris Prather =item * Stevan Little =item * יובל קוג'מן (Yuval Kogman) =back =head1 COPYRIGHT AND LICENSE This software is copyright (c) 2007 by Infinity Interactive, Inc. This is free software; you can redistribute it and/or modify it under the same terms as the Perl 5 programming language system itself. =cut