/Data-Fetch

Fetch data that you've hinted you'll be wanting

Primary LanguagePerlGNU General Public License v2.0GPL-2.0

Actions Status Travis Status Appveyor Status Appveyor status Coveralls Status CPAN Kritika Analysis Status Kwalitee

NAME

Data::Fetch - give advance warning that you'll be needing a value

VERSION

Version 0.06

SYNOPSIS

Sometimes we know in advance that we'll be needing a value which is going to take a long time to compute or determine. This module fetches the value in the background so that you don't need to wait so long when you need the value.

use CalculatePi;
use Data::Fetch;
my $fetcher = Data::Fetch->new();
my $pi = CalculatePi->new(places => 1000000);
$fetcher->prime(object => $pi, message => 'as_string');     # Warn we'll run $pi->as_string() in the future
# Do other things
print $fetcher->get(object => $pi, message => 'as_string'), "\n";   # Runs $pi->as_string()

SUBROUTINES/METHODS

new

Creates a Data::Fetch object. Takes no argument.

prime

Say what is is you'll be needing later. Call in an array context if get() is to be used in an array context.

Takes two mandatory parameters:

object - the object you'll be sending the message to
message - the message you'll be sending

Takes one optional parameter:

arg - passes this argument to the message

get

Retrieve get a value you've primed. Call in an array context only works if prime() was called in an array context, or the value wasn't primed

Takes two mandatory parameters:

object - the object you'll be sending the message to
message - the message you'll be sending

Takes one optional parameter:

arg - passes this argument to the message

If you don't prime it will still work and store the value for subsequent calls, but in this scenerio you gain nothing over using CHI to cache your values.

AUTHOR

Nigel Horne, <njh at bandsman.co.uk>

BUGS

Can't pass more than one argument to the message.

I would not advise using this to call messages that change values in the object.

Changing a value between prime and get will not necessarily get you the data you want. That's the way it works and isn't going to change.

If you change a value between two calls of get(), the earlier value is always used. This is definitely a feature not a bug.

Please report any bugs or feature requests to bug-data-fetch at rt.cpan.org, or through the web interface at http://rt.cpan.org/NoAuth/ReportBug.html?Queue=Data-Fetch. I will be notified, and then you'll automatically be notified of progress on your bug as I make changes.

See http://www.cpantesters.org/cpan/report/116390147. This code could produce the "attempt to prime twice" if you're unlucky and Perl assigns the same address to the new object as the old object.

my $fetch = Data::Fetch->new();
my $data = Class::Simple->new();
$fetch->prime(object => $data, message => 'get');
$fetch->get(object => $data, message => 'get');
$data = Class::Simple->new();       # Possibly the address of $data isn't changed
$fetch->prime(object => $data, message => 'get');   # <<<< This could produce the error

Perhaps the use of

SEE ALSO

SUPPORT

You can find documentation for this module with the perldoc command.

perldoc Data::Fetch

You can also look for information at:

LICENSE AND COPYRIGHT

Copyright 2010-2020 Nigel Horne.

This program is released under the following licence: GPL2