NAME

MooseX::Storage::Base::SerializedClass - Deserialize according to the serialized __CLASS__

VERSION

version 0.2.0

SYNOPSIS

package ThirdDimension;
use Moose::Role;

has 'z' => (is => 'rw', isa => 'Int');

package Point;
use Moose;
use MooseX::Storage;

with Storage( base => 'SerializedClass', traits => [ 'WithRoles' ] );

has 'x' => (is => 'rw', isa => 'Int');
has 'y' => (is => 'rw', isa => 'Int');

1;

use Moose::Util qw/ with_traits /;

my $p = with_traits( 'Point', 'ThirdDimension' )->new(x => 10, y => 10, z => 10);

my $packed = $p->pack(); 
# { __CLASS__ => 'Point', '__ROLES__' => [ 'ThirdDimension' ], x => 10, y => 10, z => 10 }

# unpack the hash into a class
my $p2 = Point->unpack($packed);

print $p2->z;

DESCRIPTION

Behaves like MooseX::Storage::Basic, with the exception that the unpacking will reinflate the object into the class and roles as provided in the serialized data. It is means to be used in conjuncture with MooseX::Storage::Traits::WithRoles.

EXPORTED FUNCTIONS

The function moosex_unpack can be exported. The function unpacks a serialized object based on its __CLASS__ and __ROLES__ attributes.

use MooseX::Storage::Base::SerializedClass qw/ moosex_unpack /;

my $object = moosex_unpack( $struct );

AUTHOR

Yanick Champoux <yanick@babyl.dyndns.org>

COPYRIGHT AND LICENSE

This software is copyright (c) 2015 by Yanick Champoux.

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