NAME
CGI::Application::Plugin::CaptureIO - Plug-in capture cache
VERSION
0.01
SYNOPSIS
use Your::App;
use CGI::Application::Plugin::CaptureIO;
DESCRIPTION
When all output contents are preserved in the cache, and the same next request is transmitted,
it is a plug-in that outputs contents preserved in the cache.
The effect is demonstrated as a load measures on the screen where the update is not very frequent
though there are a lot of requests.
METHOD
add_non_capture_runmodes
Runmode that doesn't preserve contents in the cache is set.
Example:
sub setup {
my $self = shift;
$self->run_modes(
mode => "mode1",
mode2 => "mode2",
non_capture => "non_capture",
non_capture2 => "non_capture2",
);
# Neither runmode non_capture nor non_capture2 cache contents.
$self->add_non_capture_runmodes(qw(non_capture non_capture2));
}
capture_init
It sets it in the early preserving capture.
Option:
capture_clear : The contents capture file and the directory not referred to whenever capture_init is executed when setting
it to "1" are deleted.
The file and the directory from which several or more are not accessed are deleted at
the second set with capture_ttl option.
defualt 0
capture_ttl : Contents are acquired, and output from the contents capture file in second when the
contents capture file specified that it preserves contents once survival time (The unit: second)
with capture_ttl number's passing.
default 60
capture_dir : Directory that preserves contents capture file. default /tmp/cgiapp-capture/
non_capture_rm : Runmode that doesn't preserve contents in the cache is set.
Example:
sub cgiapp_init {
my $self = shift;
$self->capture_init(
capture_clear => 0,
capture_ttl => 60,
capture_dir => "/home/akira/myapp/tmp",
non_capture_rm => [qw(non_capture1 non_capture2)],
);
}
current_url
Current URL is returned.
Example:
sub mode1 {
my $self = shift;
# when current url is http://www.hogehoge.hoge/app?mode=mode1, http://www.hogehoge.hoge/app?mode=mode1 is stored in $current_url
my $current_url = $self->current_url;
}
delete_non_capture_runmodes
Runmode that doesn't preserve the capture contents set with add_non_capture_runmodes and
capture_init is released.
Example:
$self->delete_non_capture_runmodes(qw(capture_mode1 capture_mode2));
TIPS
It preserves in the capture cash file in case of as it is runmode that it is runmode or is error_mode
specified with AUTOLOAD of $self->run_modes (Perhaps, when runmode that corresponds to the above-mentioned is called,
everybody : about contents it is to be sure not to have to preserve it by them),
and execute $self->add_non_capture_runmodes in AUTOLOAD and error_mode to make it not preserve,
please under the present situation.
# setup
sub setup {
my $self = shift;
$self->start_mode("mode1");
$self->mode_param("mode");
$self->error_mode("error");
$self->run_modes(
mode1 => "mode1",
mode2 => "mode2",
mode3 => "mode3",
mode4 => "mode4",
AUTOLOAD => "catch_exception",
);
}
# error mode
sub error {
my($self, $error) = @_;
# require!!
$self->add_non_capture_runmodes($self->get_current_runmode);
# process start...
}
# AUTOLOAD mode
sub catch_exception {
my($self, $intended_runmode) = @_;
# require!!
$self->add_non_capture_runmodes(intended_runmode);
# process start...
}
NOTES
This plug-in obtains a large hint from Sledge::Plugin::CacheContents of Sledge Web Application Flamework.
The function that Sledge and Sledge::Plugin::CacheContents are excellent can have been mounted as a plug-in of CGI::Application.
SEE ALSO
Carp CGI::Application Digest::SHA1 Exporter File::Find File::Path File::Spec File::stat Storable
AUTHOR
Akira Horimoto <emperor.kurt@gmail.com>
COPYRIGHT
Copyright (C) 2006 Akira Horimoto
This module is free software; you can redistribute it and/or modify it under the same terms as Perl itself.