X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=lib%2FMooseX%2FStorage%2FBasic.pm;h=d661d078290ada22282dabaeb7b1b56983df75c6;hb=e44b5f5498b782752d2c91b6796698c86143a2f0;hp=a6bf51ee2c32b0e5c0d57fa42a68839e795b5065;hpb=7b428d1fd844e32dc3500a1fefc6cd794dc45fc8;p=gitmo%2FMooseX-Storage.git diff --git a/lib/MooseX/Storage/Basic.pm b/lib/MooseX/Storage/Basic.pm index a6bf51e..d661d07 100644 --- a/lib/MooseX/Storage/Basic.pm +++ b/lib/MooseX/Storage/Basic.pm @@ -1,23 +1,62 @@ - package MooseX::Storage::Basic; use Moose::Role; use MooseX::Storage::Engine; +use String::RewritePrefix; -our $VERSION = '0.01'; +our $VERSION = '0.32'; +our $AUTHORITY = 'cpan:STEVAN'; sub pack { - my $self = shift; - my $e = MooseX::Storage::Engine->new( object => $self ); - $e->collapse_object; + my ( $self, %args ) = @_; + my $e = $self->_storage_get_engine_class(%args)->new( object => $self ); + $e->collapse_object(%args); } sub unpack { - my ( $class, $data ) = @_; - my $e = MooseX::Storage::Engine->new( class => $class ); - $class->new( $e->expand_object($data) ); + my ($class, $data, %args) = @_; + my $e = $class->_storage_get_engine_class(%args)->new(class => $class); + + $class->_storage_construct_instance( + $e->expand_object($data, %args), + \%args + ); +} + +sub _storage_get_engine_class { + my ($self, %args) = @_; + + return 'MooseX::Storage::Engine' + unless ( + exists $args{engine_traits} + && ref($args{engine_traits}) eq 'ARRAY' + && scalar(@{$args{engine_traits}}) + ); + + my @roles = String::RewritePrefix->rewrite( + { + '' => 'MooseX::Storage::Engine::Trait::', + '+' => '', + }, + @{$args{engine_traits}} + ); + + Moose::Meta::Class->create_anon_class( + superclasses => ['MooseX::Storage::Engine'], + roles => [ @roles ], + cache => 1, + )->name; +} + +sub _storage_construct_instance { + my ($class, $args, $opts) = @_; + my %i = defined $opts->{'inject'} ? %{ $opts->{'inject'} } : (); + + $class->new( %$args, %i ); } +no Moose::Role; + 1; __END__ @@ -33,37 +72,52 @@ MooseX::Storage::Basic - The simplest level of serialization package Point; use Moose; use MooseX::Storage; - + + our $VERSION = '0.01'; + with Storage; - + has 'x' => (is => 'rw', isa => 'Int'); has 'y' => (is => 'rw', isa => 'Int'); - + 1; - + my $p = Point->new(x => 10, y => 10); - - ## methods to pack/unpack an + + ## methods to pack/unpack an ## object in perl data structures - + # pack the class into a hash - $p->pack(); # { __CLASS__ => 'Point', x => 10, y => 10 } - + $p->pack(); # { __CLASS__ => 'Point-0.01', x => 10, y => 10 } + # unpack the hash into a class - my $p2 = Point->unpack({ __CLASS__ => 'Point', x => 10, y => 10 }); + my $p2 = Point->unpack({ __CLASS__ => 'Point-0.01', x => 10, y => 10 }); + + # unpack the hash, with insertion of paramaters + my $p3 = Point->unpack( $p->pack, inject => { x => 11 } ); =head1 DESCRIPTION -This is the most basic form of serialization. This is used by default +This is the most basic form of serialization. This is used by default but the exported C function. =head1 METHODS =over 4 -=item B +=item B 1])> + +Providing the C argument disables checks for any cyclical +references. The current implementation for this check is rather naive, so if +you know what you are doing, you can bypass this check. + +This trait is applied on a perl-case basis. To set this flag for all objects +that inherit from this role, see L. + +=item B { key => val, ... } ] )> -=item B +Providing the C argument let's you supply additional arguments to +the class' C function, or override ones from the serialized data. =back @@ -77,7 +131,7 @@ but the exported C function. =head1 BUGS -All complex software has bugs lurking in it, and this module is no +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. @@ -89,7 +143,7 @@ Stevan Little Estevan.little@iinteractive.comE =head1 COPYRIGHT AND LICENSE -Copyright 2007 by Infinity Interactive, Inc. +Copyright 2007-2008 by Infinity Interactive, Inc. L