summaryrefslogtreecommitdiffstats
path: root/chromium/third_party/cygwin/lib/perl5/5.10/Memoize/Expire.pm
diff options
context:
space:
mode:
Diffstat (limited to 'chromium/third_party/cygwin/lib/perl5/5.10/Memoize/Expire.pm')
-rw-r--r--chromium/third_party/cygwin/lib/perl5/5.10/Memoize/Expire.pm365
1 files changed, 0 insertions, 365 deletions
diff --git a/chromium/third_party/cygwin/lib/perl5/5.10/Memoize/Expire.pm b/chromium/third_party/cygwin/lib/perl5/5.10/Memoize/Expire.pm
deleted file mode 100644
index 97e1aa44208..00000000000
--- a/chromium/third_party/cygwin/lib/perl5/5.10/Memoize/Expire.pm
+++ /dev/null
@@ -1,365 +0,0 @@
-
-package Memoize::Expire;
-# require 5.00556;
-use Carp;
-$DEBUG = 0;
-$VERSION = '1.00';
-
-# This package will implement expiration by prepending a fixed-length header
-# to the font of the cached data. The format of the header will be:
-# (4-byte number of last-access-time) (For LRU when I implement it)
-# (4-byte expiration time: unsigned seconds-since-unix-epoch)
-# (2-byte number-of-uses-before-expire)
-
-sub _header_fmt () { "N N n" }
-sub _header_size () { length(_header_fmt) }
-
-# Usage: memoize func
-# TIE => [Memoize::Expire, LIFETIME => sec, NUM_USES => n,
-# TIE => [...] ]
-
-BEGIN {
- eval {require Time::HiRes};
- unless ($@) {
- Time::HiRes->import('time');
- }
-}
-
-sub TIEHASH {
- my ($package, %args) = @_;
- my %cache;
- if ($args{TIE}) {
- my ($module, @opts) = @{$args{TIE}};
- my $modulefile = $module . '.pm';
- $modulefile =~ s{::}{/}g;
- eval { require $modulefile };
- if ($@) {
- croak "Memoize::Expire: Couldn't load hash tie module `$module': $@; aborting";
- }
- my $rc = (tie %cache => $module, @opts);
- unless ($rc) {
- croak "Memoize::Expire: Couldn't tie hash to `$module': $@; aborting";
- }
- }
- $args{LIFETIME} ||= 0;
- $args{NUM_USES} ||= 0;
- $args{C} = \%cache;
- bless \%args => $package;
-}
-
-sub STORE {
- $DEBUG and print STDERR " >> Store $_[1] $_[2]\n";
- my ($self, $key, $value) = @_;
- my $expire_time = $self->{LIFETIME} > 0 ? $self->{LIFETIME} + time : 0;
- # The call that results in a value to store into the cache is the
- # first of the NUM_USES allowed calls.
- my $header = _make_header(time, $expire_time, $self->{NUM_USES}-1);
- $self->{C}{$key} = $header . $value;
- $value;
-}
-
-sub FETCH {
- $DEBUG and print STDERR " >> Fetch cached value for $_[1]\n";
- my ($data, $last_access, $expire_time, $num_uses_left) = _get_item($_[0]{C}{$_[1]});
- $DEBUG and print STDERR " >> (ttl: ", ($expire_time-time()), ", nuses: $num_uses_left)\n";
- $num_uses_left--;
- $last_access = time;
- _set_header(@_, $data, $last_access, $expire_time, $num_uses_left);
- $data;
-}
-
-sub EXISTS {
- $DEBUG and print STDERR " >> Exists $_[1]\n";
- unless (exists $_[0]{C}{$_[1]}) {
- $DEBUG and print STDERR " Not in underlying hash at all.\n";
- return 0;
- }
- my $item = $_[0]{C}{$_[1]};
- my ($last_access, $expire_time, $num_uses_left) = _get_header($item);
- my $ttl = $expire_time - time;
- if ($DEBUG) {
- $_[0]{LIFETIME} and print STDERR " Time to live for this item: $ttl\n";
- $_[0]{NUM_USES} and print STDERR " Uses remaining: $num_uses_left\n";
- }
- if ( (! $_[0]{LIFETIME} || $expire_time > time)
- && (! $_[0]{NUM_USES} || $num_uses_left > 0 )) {
- $DEBUG and print STDERR " (Still good)\n";
- return 1;
- } else {
- $DEBUG and print STDERR " (Expired)\n";
- return 0;
- }
-}
-
-# Arguments: last access time, expire time, number of uses remaining
-sub _make_header {
- pack "N N n", @_;
-}
-
-sub _strip_header {
- substr($_[0], 10);
-}
-
-# Arguments: last access time, expire time, number of uses remaining
-sub _set_header {
- my ($self, $key, $data, @header) = @_;
- $self->{C}{$key} = _make_header(@header) . $data;
-}
-
-sub _get_item {
- my $data = substr($_[0], 10);
- my @header = unpack "N N n", substr($_[0], 0, 10);
-# print STDERR " >> _get_item: $data => $data @header\n";
- ($data, @header);
-}
-
-# Return last access time, expire time, number of uses remaining
-sub _get_header {
- unpack "N N n", substr($_[0], 0, 10);
-}
-
-1;
-
-=head1 NAME
-
-Memoize::Expire - Plug-in module for automatic expiration of memoized values
-
-=head1 SYNOPSIS
-
- use Memoize;
- use Memoize::Expire;
- tie my %cache => 'Memoize::Expire',
- LIFETIME => $lifetime, # In seconds
- NUM_USES => $n_uses;
-
- memoize 'function', SCALAR_CACHE => [HASH => \%cache ];
-
-=head1 DESCRIPTION
-
-Memoize::Expire is a plug-in module for Memoize. It allows the cached
-values for memoized functions to expire automatically. This manual
-assumes you are already familiar with the Memoize module. If not, you
-should study that manual carefully first, paying particular attention
-to the HASH feature.
-
-Memoize::Expire is a layer of software that you can insert in between
-Memoize itself and whatever underlying package implements the cache.
-The layer presents a hash variable whose values expire whenever they
-get too old, have been used too often, or both. You tell C<Memoize> to
-use this forgetful hash as its cache instead of the default, which is
-an ordinary hash.
-
-To specify a real-time timeout, supply the C<LIFETIME> option with a
-numeric value. Cached data will expire after this many seconds, and
-will be looked up afresh when it expires. When a data item is looked
-up afresh, its lifetime is reset.
-
-If you specify C<NUM_USES> with an argument of I<n>, then each cached
-data item will be discarded and looked up afresh after the I<n>th time
-you access it. When a data item is looked up afresh, its number of
-uses is reset.
-
-If you specify both arguments, data will be discarded from the cache
-when either expiration condition holds.
-
-Memoize::Expire uses a real hash internally to store the cached data.
-You can use the C<HASH> option to Memoize::Expire to supply a tied
-hash in place of the ordinary hash that Memoize::Expire will normally
-use. You can use this feature to add Memoize::Expire as a layer in
-between a persistent disk hash and Memoize. If you do this, you get a
-persistent disk cache whose entries expire automatically. For
-example:
-
- # Memoize
- # |
- # Memoize::Expire enforces data expiration policy
- # |
- # DB_File implements persistence of data in a disk file
- # |
- # Disk file
-
- use Memoize;
- use Memoize::Expire;
- use DB_File;
-
- # Set up persistence
- tie my %disk_cache => 'DB_File', $filename, O_CREAT|O_RDWR, 0666];
-
- # Set up expiration policy, supplying persistent hash as a target
- tie my %cache => 'Memoize::Expire',
- LIFETIME => $lifetime, # In seconds
- NUM_USES => $n_uses,
- HASH => \%disk_cache;
-
- # Set up memoization, supplying expiring persistent hash for cache
- memoize 'function', SCALAR_CACHE => [ HASH => \%cache ];
-
-=head1 INTERFACE
-
-There is nothing special about Memoize::Expire. It is just an
-example. If you don't like the policy that it implements, you are
-free to write your own expiration policy module that implements
-whatever policy you desire. Here is how to do that. Let us suppose
-that your module will be named MyExpirePolicy.
-
-Short summary: You need to create a package that defines four methods:
-
-=over 4
-
-=item
-TIEHASH
-
-Construct and return cache object.
-
-=item
-EXISTS
-
-Given a function argument, is the corresponding function value in the
-cache, and if so, is it fresh enough to use?
-
-=item
-FETCH
-
-Given a function argument, look up the corresponding function value in
-the cache and return it.
-
-=item
-STORE
-
-Given a function argument and the corresponding function value, store
-them into the cache.
-
-=item
-CLEAR
-
-(Optional.) Flush the cache completely.
-
-=back
-
-The user who wants the memoization cache to be expired according to
-your policy will say so by writing
-
- tie my %cache => 'MyExpirePolicy', args...;
- memoize 'function', SCALAR_CACHE => [HASH => \%cache];
-
-This will invoke C<< MyExpirePolicy->TIEHASH(args) >>.
-MyExpirePolicy::TIEHASH should do whatever is appropriate to set up
-the cache, and it should return the cache object to the caller.
-
-For example, MyExpirePolicy::TIEHASH might create an object that
-contains a regular Perl hash (which it will to store the cached
-values) and some extra information about the arguments and how old the
-data is and things like that. Let us call this object `C'.
-
-When Memoize needs to check to see if an entry is in the cache
-already, it will invoke C<< C->EXISTS(key) >>. C<key> is the normalized
-function argument. MyExpirePolicy::EXISTS should return 0 if the key
-is not in the cache, or if it has expired, and 1 if an unexpired value
-is in the cache. It should I<not> return C<undef>, because there is a
-bug in some versions of Perl that will cause a spurious FETCH if the
-EXISTS method returns C<undef>.
-
-If your EXISTS function returns true, Memoize will try to fetch the
-cached value by invoking C<< C->FETCH(key) >>. MyExpirePolicy::FETCH should
-return the cached value. Otherwise, Memoize will call the memoized
-function to compute the appropriate value, and will store it into the
-cache by calling C<< C->STORE(key, value) >>.
-
-Here is a very brief example of a policy module that expires each
-cache item after ten seconds.
-
- package Memoize::TenSecondExpire;
-
- sub TIEHASH {
- my ($package, %args) = @_;
- my $cache = $args{HASH} || {};
- bless $cache => $package;
- }
-
- sub EXISTS {
- my ($cache, $key) = @_;
- if (exists $cache->{$key} &&
- $cache->{$key}{EXPIRE_TIME} > time) {
- return 1
- } else {
- return 0; # Do NOT return `undef' here.
- }
- }
-
- sub FETCH {
- my ($cache, $key) = @_;
- return $cache->{$key}{VALUE};
- }
-
- sub STORE {
- my ($cache, $key, $newvalue) = @_;
- $cache->{$key}{VALUE} = $newvalue;
- $cache->{$key}{EXPIRE_TIME} = time + 10;
- }
-
-To use this expiration policy, the user would say
-
- use Memoize;
- tie my %cache10sec => 'Memoize::TenSecondExpire';
- memoize 'function', SCALAR_CACHE => [HASH => \%cache10sec];
-
-Memoize would then call C<function> whenever a cached value was
-entirely absent or was older than ten seconds.
-
-You should always support a C<HASH> argument to C<TIEHASH> that ties
-the underlying cache so that the user can specify that the cache is
-also persistent or that it has some other interesting semantics. The
-example above demonstrates how to do this, as does C<Memoize::Expire>.
-
-=head1 ALTERNATIVES
-
-Brent Powers has a C<Memoize::ExpireLRU> module that was designed to
-work with Memoize and provides expiration of least-recently-used data.
-The cache is held at a fixed number of entries, and when new data
-comes in, the least-recently used data is expired. See
-L<http://search.cpan.org/search?mode=module&query=ExpireLRU>.
-
-Joshua Chamas's Tie::Cache module may be useful as an expiration
-manager. (If you try this, let me know how it works out.)
-
-If you develop any useful expiration managers that you think should be
-distributed with Memoize, please let me know.
-
-=head1 CAVEATS
-
-This module is experimental, and may contain bugs. Please report bugs
-to the address below.
-
-Number-of-uses is stored as a 16-bit unsigned integer, so can't exceed
-65535.
-
-Because of clock granularity, expiration times may occur up to one
-second sooner than you expect. For example, suppose you store a value
-with a lifetime of ten seconds, and you store it at 12:00:00.998 on a
-certain day. Memoize will look at the clock and see 12:00:00. Then
-9.01 seconds later, at 12:00:10.008 you try to read it back. Memoize
-will look at the clock and see 12:00:10 and conclude that the value
-has expired. This will probably not occur if you have
-C<Time::HiRes> installed.
-
-=head1 AUTHOR
-
-Mark-Jason Dominus (mjd-perl-memoize+@plover.com)
-
-Mike Cariaso provided valuable insight into the best way to solve this
-problem.
-
-=head1 SEE ALSO
-
-perl(1)
-
-The Memoize man page.
-
-http://www.plover.com/~mjd/perl/Memoize/ (for news and updates)
-
-I maintain a mailing list on which I occasionally announce new
-versions of Memoize. The list is for announcements only, not
-discussion. To join, send an empty message to
-mjd-perl-memoize-request@Plover.com.
-
-=cut