Gungho::Provider::Simple - An In-Memory, Simple Provider


Gungho documentation Contained in the Gungho distribution.

Index


Code Index:

NAME

Top

Gungho::Provider::Simple - An In-Memory, Simple Provider

SYNOPSIS

Top

  use Gungho::Provider::Simple;
  my $g = Gungho::Provider::Simple->new;
  $g->add_request(Gungho::Request->new(GET => 'http://...'));

METHODS

Top

new()

Creates a new instance.

setup($c)

Sets up the provider.

add_request($request)

Adds a new request to the provider.

pushback_request($c, $request)

dispatch()

dispatches the requests


Gungho documentation Contained in the Gungho distribution.

# $Id: /mirror/gungho/lib/Gungho/Provider/Simple.pm 4037 2007-10-25T14:20:48.994833Z lestrrat  $
#
# Copyright (c) 2007 Daisuke Maki <daisuke@endeworks.jp>
# All rights reserved.

package Gungho::Provider::Simple;
use strict;
use warnings;
use base qw(Gungho::Provider);
use Gungho::Request;

__PACKAGE__->mk_accessors($_) for qw(requests);

sub new
{
    my $class = shift;
    my $self  = $class->next::method(@_);
    $self->requests([]);
    $self;
}

sub setup
{
    my $self = shift;
    my $url = $self->config->{url};
    if ($url && ! ref($url) ) {
        $url = [ $url ];
    }

    foreach my $u (@$url) {
        $self->add_request(
            Gungho::Request->new(GET => $u)
        );
    }
    $self->next::method(@_);
}

sub add_request
{
    my ($self, $req) = @_;

    my $list = $self->requests;
    push @$list, $req;
    $self->has_requests(1);
}

sub pushback_request
{
    my ($self, $c, $request) = @_;
    $c->is_running(1);
    $self->add_request($request);
}

sub dispatch
{
    my ($self, $c) = @_;

    my $requests = $self->requests;

    $self->requests([]);
    while (@$requests) {
        $self->dispatch_request($c, shift @$requests);
    }

    if (scalar @{ $self->requests } <= 0) {
        $self->has_requests(0);
        $c->is_running(0);
    }
}

1;

__END__