package MooseX::Storage::IO::AtomicFile; use Moose::Role; use MooseX::Storage::Engine::IO::AtomicFile; our $VERSION = '0.01'; our $AUTHORITY = 'cpan:STEVAN'; with 'MooseX::Storage::IO::File'; sub store { my ( $self, $filename, @args ) = @_; MooseX::Storage::Engine::IO::AtomicFile->new( file => $filename )->store( $self->freeze(@args) ); } 1; __END__ =pod =head1 NAME MooseX::Storage::IO::AtomicFile - An Atomic File I/O role =head1 SYNOPSIS package Point; use Moose; use MooseX::Storage; with Storage('format' => 'JSON', 'io' => 'AtomicFile'); has 'x' => (is => 'rw', isa => 'Int'); has 'y' => (is => 'rw', isa => 'Int'); 1; my $p = Point->new(x => 10, y => 10); ## methods to load/store a class ## on the file system $p->store('my_point.json'); my $p2 = Point->load('my_point.json'); =head1 METHODS =over 4 =item B =item B =back =head2 Introspection =over 4 =item B =back =head1 BUGS 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. =head1 AUTHOR Chris Prather Echris.prather@iinteractive.comE Stevan Little Estevan.little@iinteractive.comE =head1 COPYRIGHT AND LICENSE Copyright 2007-2008 by Infinity Interactive, Inc. L This library is free software; you can redistribute it and/or modify it under the same terms as Perl itself. =cut