93 lines
		
	
	
	
		
			1.7 KiB
		
	
	
	
		
			Perl
		
	
	
	
	
	
			
		
		
	
	
			93 lines
		
	
	
	
		
			1.7 KiB
		
	
	
	
		
			Perl
		
	
	
	
	
	
package Git::SVN::Memoize::YAML;
 | 
						|
use warnings;
 | 
						|
use strict;
 | 
						|
use YAML::Any ();
 | 
						|
 | 
						|
# based on Memoize::Storable.
 | 
						|
 | 
						|
sub TIEHASH {
 | 
						|
	my $package = shift;
 | 
						|
	my $filename = shift;
 | 
						|
	my $truehash = (-e $filename) ? YAML::Any::LoadFile($filename) : {};
 | 
						|
	my $self = {FILENAME => $filename, H => $truehash};
 | 
						|
	bless $self => $package;
 | 
						|
}
 | 
						|
 | 
						|
sub STORE {
 | 
						|
	my $self = shift;
 | 
						|
	$self->{H}{$_[0]} = $_[1];
 | 
						|
}
 | 
						|
 | 
						|
sub FETCH {
 | 
						|
	my $self = shift;
 | 
						|
	$self->{H}{$_[0]};
 | 
						|
}
 | 
						|
 | 
						|
sub EXISTS {
 | 
						|
	my $self = shift;
 | 
						|
	exists $self->{H}{$_[0]};
 | 
						|
}
 | 
						|
 | 
						|
sub DESTROY {
 | 
						|
	my $self = shift;
 | 
						|
	YAML::Any::DumpFile($self->{FILENAME}, $self->{H});
 | 
						|
}
 | 
						|
 | 
						|
sub SCALAR {
 | 
						|
	my $self = shift;
 | 
						|
	scalar(%{$self->{H}});
 | 
						|
}
 | 
						|
 | 
						|
sub FIRSTKEY {
 | 
						|
	'Fake hash from Git::SVN::Memoize::YAML';
 | 
						|
}
 | 
						|
 | 
						|
sub NEXTKEY {
 | 
						|
	undef;
 | 
						|
}
 | 
						|
 | 
						|
1;
 | 
						|
__END__
 | 
						|
 | 
						|
=head1 NAME
 | 
						|
 | 
						|
Git::SVN::Memoize::YAML - store Memoized data in YAML format
 | 
						|
 | 
						|
=head1 SYNOPSIS
 | 
						|
 | 
						|
    use Memoize;
 | 
						|
    use Git::SVN::Memoize::YAML;
 | 
						|
 | 
						|
    tie my %cache => 'Git::SVN::Memoize::YAML', $filename;
 | 
						|
    memoize('slow_function', SCALAR_CACHE => [HASH => \%cache]);
 | 
						|
    slow_function(arguments);
 | 
						|
 | 
						|
=head1 DESCRIPTION
 | 
						|
 | 
						|
This module provides a class that can be used to tie a hash to a
 | 
						|
YAML file.  The file is read when the hash is initialized and
 | 
						|
rewritten when the hash is destroyed.
 | 
						|
 | 
						|
The intent is to allow L<Memoize> to back its cache with a file in
 | 
						|
YAML format, just like L<Memoize::Storable> allows L<Memoize> to
 | 
						|
back its cache with a file in Storable format.  Unlike the Storable
 | 
						|
format, the YAML format is platform-independent and fairly stable.
 | 
						|
 | 
						|
Carps on error.
 | 
						|
 | 
						|
=head1 DIAGNOSTICS
 | 
						|
 | 
						|
See L<YAML::Any>.
 | 
						|
 | 
						|
=head1 DEPENDENCIES
 | 
						|
 | 
						|
L<YAML::Any> from CPAN.
 | 
						|
 | 
						|
=head1 INCOMPATIBILITIES
 | 
						|
 | 
						|
None reported.
 | 
						|
 | 
						|
=head1 BUGS
 | 
						|
 | 
						|
The entire cache is read into a Perl hash when loading the file,
 | 
						|
so this is not very scalable.
 |