Event::ExecFlow::Scheduler - Abstract class for parallel scheduling


Event-ExecFlow documentation Contained in the Event-ExecFlow distribution.

Index


Code Index:

NAME

Top

Event::ExecFlow::Scheduler - Abstract class for parallel scheduling

SYNOPSIS

Top

  #-- Create a new Scheduler object
  my $scheduler = Event::ExecFlow::Scheduler::XYZ->new ( ... );

  #-- Attach scheduler to a group job with parallel execution
  $group_job->set_parallel(1);
  $group_job->set_scheduler($scheduler);

  #-- The following methods gets called by Event::ExecFlow
  #-- at runtime
  $scheduler->schedule_job($job);
  $scheduler->job_finished($job);

DESCRIPTION

Top

This abstract base class represents just an interface which needs to be implemented by custom schedulers for controlling the execution of jobs in a Event::ExecFlow::Group which has the parallel option set.

Event::ExecFlow ships a very simple example for a scheduler which just limits the maximum number of parallel executed jobs: Event::ExecFlow::Scheduler::SimpleMax.

OBJECT HIERARCHY

Top

  Event::ExecFlow

  Event::ExecFlow::Job
  +--- Event::ExecFlow::Job::Group
  +--- Event::ExecFlow::Job::Command
  +--- Event::ExecFlow::Job::Code

  Event::ExecFlow::Frontend
  Event::ExecFlow::Callbacks
  Event::ExecFlow::Scheduler
  +--- Event::ExecFlow::Scheduler::SimpleMax

METHODS

Top

[ FIXME: describe all methods in detail ]

AUTHORS

Top

 Jörn Reder <joern at zyn dot de>

COPYRIGHT AND LICENSE

Top


Event-ExecFlow documentation Contained in the Event-ExecFlow distribution.

package Event::ExecFlow::Scheduler;

use strict;

sub is_exclusive { 0 }

sub schedule_job { die ref(shift)." missing schedule_job() implementation" }
sub job_finished { die ref(shift)." missing job_finished() implementation" }

1;

__END__