NAME
Launcher::Cascade - a framework for launching processes that depend on one another
SYNOPSIS
use Launcher::Cascade::Simple;
use Launcher::Cascade::Container;
my $launcher1 = Launcher::Cascade::Simple->new(
-launch_hook => sub { ... }, # what to do to launch
-test_hook => sub { ... }, # what to do to test that it succeeded
);
my $launcher2 = Launcher::Cascade::Simple->new(
-launch_hook => sub { ... }, # what to do to launch
-test_hook => sub { ... }, # what to do to test that it succeeded
-dependencies => [ $launcher1 ], # second launcher depends on success of first
);
my $container = new Launcher::Cascade::Container
-launchers => [ $launcher1, $launcher2 ];
$container->run_session();
DESCRIPTION
This module provides a framework to launch processes, test whether they succeeded or not and report on that. Each process is modeled as an object and can depend on other processes to start, i.e., a process will not be started until all the processes it depends upon have successfully been started.
Process launchers must be implemented as Launcher::Cascade::Base
objects (or subclassses thereof). Their launch() method will actually launch the process, and their test() method will check whether it succeeded or not. Each launcher can be made to depend on one or more other launchers: it will then refuse to launch() until the others have been test()ed successfully.
All the launchers should be given to a Launcher::Cascade::Container
, which will run them in turn and test their status when applicable, until either all of the Launchers have succeeded or one of them has failed.
The distribution provides Launcher::Cascade::FileReader
to ease the launching of external (and possibly remote, by means of ssh) commands and the reading of files. FileReaders should be used in launch() or test() methods of Launchers.
This base class provides a constructor for its subclasses that accepts named arguments, as well as function to easily create attributes and their accessors. All the real functionality has to be implemented in subclasses.
Constructor
- new LIST
-
Creates and returns an instance. LIST should be a list of named parameters. The values will be passed to the accessors of the same name. Leading dashes will be removed from the names, and they will be converted to lowercase before invoking the accessor.
Functions
- make_accessors LIST
-
Make accessors in the caller's namespace.
LIST should contain names of accessors. make_accessors() will generate an accessor for each name in LIST, that will return the corresponding attribute's value when called without argument, and set the attribute's value when called with an argument (in that latter case, the former value is returned). Example:
package MyPackage; use Launcher::Cascade; our @ISA = qw/ Launcher::Cascade /; # inherits constructor Launcher::Cascade::make_accessors qw/ first_name last_name /; 1;
Meanwhile, in a nearby piece of code:
use MyPackage; my $object = new MyPackage -first_name => 'Zaphod'; print $object->first_name(); # Zaphod print $object->last_name('Beeblebrox'); # undef print $object->last_name(); # Beeblebrox
- read_default_file FILENAME
-
Reads a file containing the definition of default values for subclasses attributes. The file should contain name, value pairs, one by line, separated by an equal sign. Whitespace is ignored at the beginning or end of the line and on either side of the equal sign. Lines starting with a hash sign are ignored, as well as blank lines.
The name should be the fully qualified accessor method name, i.e., the package and name of the accessor separated by a double colon.
# This is an example MyPackage::first_name = Zaphod MyPackage::last_name = Beeblebrox
- make_accessors_with_defaults LIST
-
Does the same as make_accessors(), but elements in LIST should go in pairs, accessor names together with their default values. If the attribute's value has not explicitly been set, the accessor will return the default value as read from the defaults file (see read_default_file()) or the default value provided in LIST. The defaults file overrides the value from LIST.
package MyPackage; use Launcher::Cascade; our @ISA = qw/ Launcher::Cascade /; Launcher::Cascade::make_accessors_with_defaults( first_name => 'Zaphod', last_name => 'Beeblebrox', );
Meanwhile, in a nearby piece of code:
use MyPackage; my $o = new MyPackage; print $o->first_name(); # Zaphod
VERSION
0.02
SEE ALSO
AUTHOR
Cédric Bouvier <cbouvi@cpan.org>
COPYRIGHT & LICENSE
Copyright (C) 2006 Cédric Bouvier, All Rights Reserved.
This program is free software; you can redistribute it and/or modify it under the same terms as Perl itself.
1 POD Error
The following errors were encountered while parsing the POD:
- Around line 229:
Non-ASCII character seen before =encoding in 'Cédric'. Assuming CP1252