package MooseX::Storage::Format::Storable; # ABSTRACT: A Storable serialization role our $VERSION = '0.53'; use Moose::Role; use Storable (); use namespace::autoclean; requires 'pack'; requires 'unpack'; sub thaw { my ( $class, $stored, @args ) = @_; $class->unpack( Storable::thaw($stored), @args ); } sub freeze { my ( $self, @args ) = @_; Storable::nfreeze( $self->pack(@args) ); } 1; __END__ =pod =encoding UTF-8 =head1 NAME MooseX::Storage::Format::Storable - A Storable serialization role =head1 VERSION version 0.53 =head1 SYNOPSIS package Point; use Moose; use MooseX::Storage; with Storage('format' => 'Storable'); 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 # pack the class with Storable my $storable_data = $p->freeze(); # unpack the storable data into the class my $p2 = Point->thaw($storable_data); =head1 DESCRIPTION =for stopwords IPC This module will C and C Moose classes using Storable. It uses C by default so that it can be easily used in IPC scenarios across machines or just locally. =for stopwords Storable's One important thing to note is that this module does not mix well with the IO modules. The structures that C and C deal with are Storable's memory representation, and (as far as I know) that is not easily just written onto a file. If you want file based serialization with Storable, the please look at the L role instead. =head1 METHODS =over 4 =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