X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=lib%2FMooseX%2FStorage%2FBasic.pm;h=a803e7432d1370619958978a76a6980f824f6918;hb=a473d69d41c77bb4ba2d94dfd731bdcf6e7a8d63;hp=686772bbd53e2b2f52c59327038861e0bafb89a1;hpb=c21a034f8b360ad6cbf51ae1dab269fc6ef5a6b3;p=gitmo%2FMooseX-Storage.git diff --git a/lib/MooseX/Storage/Basic.pm b/lib/MooseX/Storage/Basic.pm index 686772b..a803e74 100644 --- a/lib/MooseX/Storage/Basic.pm +++ b/lib/MooseX/Storage/Basic.pm @@ -7,14 +7,14 @@ our $VERSION = '0.18'; our $AUTHORITY = 'cpan:STEVAN'; sub pack { - my ( $self, @args ) = @_; - my $e = $self->_storage_get_engine( object => $self ); - $e->collapse_object(@args); + my ( $self, %args ) = @_; + my $e = $self->_storage_get_engine_class(%args)->new( object => $self ); + $e->collapse_object(%args); } sub unpack { my ($class, $data, %args) = @_; - my $e = $class->_storage_get_engine(class => $class); + my $e = $class->_storage_get_engine_class(%args)->new(class => $class); $class->_storage_construct_instance( $e->expand_object($data, %args), @@ -22,9 +22,26 @@ sub unpack { ); } -sub _storage_get_engine { - my $self = shift; - MooseX::Storage::Engine->new( @_ ); +sub _storage_get_engine_class { + my ($self, %args) = @_; + + my $default = 'MooseX::Storage::Engine'; + + return $default + unless ( + exists $args{engine_traits} + && ref($args{engine_traits}) eq 'ARRAY' + && scalar(@{$args{engine_traits}}) + ); + + my @roles = map { sprintf("%s::Trait::%s", $default, $_) } + @{$args{engine_traits}}; + + Moose::Meta::Class->create_anon_class( + superclasses => [$default], + roles => [ @roles ], + cache => 1, + )->name; } sub _storage_construct_instance { @@ -82,7 +99,14 @@ but the exported C function. =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, ... } ] )>