| MooseX-Storage documentation | Contained in the MooseX-Storage distribution. |
MooseX::Storage::IO::AtomicFile - An Atomic File I/O role
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');
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.
Chris Prather <chris.prather@iinteractive.com>
Stevan Little <stevan.little@iinteractive.com>
Copyright 2007-2008 by Infinity Interactive, Inc.
This library is free software; you can redistribute it and/or modify it under the same terms as Perl itself.
| MooseX-Storage documentation | Contained in the MooseX-Storage distribution. |
package MooseX::Storage::IO::AtomicFile; use Moose::Role; use MooseX::Storage::Engine::IO::AtomicFile; our $VERSION = '0.30'; 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) ); } no Moose::Role; 1; __END__