NAME
Bio::Tools::Run::PiseJob - A class to manage Pise jobs.
SYNOPSIS
use Bio::Tools::Run::AnalysisFactory::Pise;
# Build a Pise factory
my $factory = new Bio::Tools::Run::AnalysisFactory::Pise();
# Then create an application object (Pise::Run::Tools::PiseApplication):
my $program = $factory->program('genscan');
# Set parameters
$program->seq($ARGV[0]);
# Next, run the program
# (notice that you can set some parameters at run time)
my $job = $program->run(-parameter_file => "Arabidopsis.smat");
my $job = $program->run(-seq => $ARGV[0]);
# Test for submission errors:
if ($job->error) {
print "Job submission error (",$job->jobid,"):\n";
print $job->error_message,"\n";
exit;
}
# Get results
print STDERR $job->content('genscan.out');
# or:
my $result_file = $job->save('genscan.out');
DESCRIPTION
Bio::Tools::Run::PiseJob class handles a specific job state and results. A Bio::Tools::Run::PiseJob instance should be created by a subclass of Bio::Tools::Run::PiseApplication class, e.g Bio::Tools::Run::PiseApplication::genscan or Bio::Tools::Run::PiseApplication::dnapars, ... (see Bio::Tools::Run::PiseApplication class) :
my $job = Bio::Tools::Run::PiseJob->new($self, $self->{VERBOSE});
This class may also be used as a mean to get informations about a running job, or to get results after a long computation:
my $job = Bio::Factory::Pise->job($url);
print $job->content('infile.aln');
Once the job is created, you can get results:
foreach my $result ($job->get_results) {
print $job->content($result);
$job->save($result, "myfile"); # $job->save($result) keeps the name
print $job->stdout; # print job standard output
print $job->stderr; # print job standard error
}
You can feed a result file as a filehandle to a bioperl parser :
my $parser = Bio::Tools:Genscan->new (-fh => $job->fh('genscan.out'));
my $parser = Bio::Tools:BPlite->new (-fh => $job->fh('blast2.txt'));
... or to another pise job:
my $neighbor = $factory->program ('neighbor',
-infile => $job->fh('outfile'));
You can lookup up for a type of result that could be piped to another Pise program:
my $matrix = $job->lookup_piped_file('phylip_dist');
returns the url of the just calculated Phylip distances matrix file, produced by e.g DNADIST or PROTDIST.
All the available pipe types may be obtained by:
$job->lookup_piped_files;
FEEDBACK
Mailing Lists
User feedback is an integral part of the evolution of this and other Bioperl modules. Send your comments and suggestions preferably to the Bioperl mailing list. Your participation is much appreciated.
bioperl-l@bioperl.org - General discussion
http://bioperl.org/wiki/Mailing_lists - About the mailing lists
Reporting Bugs
Report bugs to the Bioperl bug tracking system to help us keep track of the bugs and their resolution. Bug reports can be submitted via the web:
http://bugzilla.open-bio.org/
AUTHOR
Catherine Letondal (letondal@pasteur.fr)
COPYRIGHT
Copyright (C) 2003 Institut Pasteur & Catherine Letondal. All Rights Reserved.
This module is free software; you can redistribute it and/or modify it under the same terms as Perl itself.
DISCLAIMER
This software is provided "as is" without warranty of any kind.
SEE ALSO
Bio::Tools::Run::AnalysisFactory::Pise Bio::Tools::Run::PiseApplication
new
Title : new()
Usage : $job = Bio::Tools::Run::PiseJob->new($application, $verbose);
Function: Creates a Bio::Tools::Run::PiseJob object.
This is normally called by an application object
- i.e a subclass of the Bio::Tools::Run::PiseApplication class,
for submitting a job.
This method actually submit the job and parse results.
Example :
Returns : An instance of Bio::Tools::Run::PiseJob.
verbose
Title : verbose()
Usage : $program->verbose(1);
Function: Ask the object to tells more.
Example :
Returns :
job
Title : job()
Usage : $job = Bio::Tools::Run::PiseJob->job(url);
Function: Creates a Bio::Tools::Run::PiseJob object from an already
run job by giving the url of the job result page.
May also be called through Bio::Factory::Pise->job(url);
Example :
Returns : An instance of Bio::Tools::Run::PiseJob.
jobid
Title : jobid()
Usage : $job->jobid();
Function: Returns the url of the job result page.
Example :
Returns :
error
Title : error()
Usage : $job->error();
Function: Tells if the job has been successfully run. This is the case
when the job has been submitted, but the Pise server has
detected user errors (missing mandatory parameter, unallowed
value,...). This also happen when the user provided an
invalid url, or the http request could not be submitted.
See method error_message().
Example :
Returns : TRUE/FALSE
error_message
Title : error_message()
Usage : $job->error_message();
Function: Returns the error message.
Example :
Returns : A string.
get_results
Title : get_results()
Usage : $job->get_results();
Function: Provides the urls of the result files.
Example :
Returns : A list of urls.
get_pipes
Title : get_pipes()
Usage : $job->get_pipes($result);
Function: Provides the names of the programs that can use this type of
result. $result is an url, that can be provided through the
get_results method.
Example :
Returns : A list of program names.
piped_file_type
Title : piped_file_type()
Usage : $job->piped_file_type($result);
Function: Provides the Pise type of $result. $result is an url,
that can be provided through the get_results method.
Example :
Returns : A Pise pipetype name.
lookup_piped_files
Title : lookup_piped_files()
Usage : $pipe_types = $job->lookup_piped_files();
Function: Returns the pipe types produced by the job
(e.g: phylip_tree, seqsfile, readseq_ok_alig, ...).
You have to call lookup_piped_file($type) to get the actual
correponding result file.
Example :
Returns : A string.
lookup_piped_file
Title : lookup_piped_file(type)
Usage : $result = $job->lookup_piped_file($type);
Function: Returns the name of the result file of pipe type $type
(e.g: phylip_tree, seqsfile, readseq_ok_alig, ...). $result
is an url.
Example :
Returns : A string (an url).
terminated
Title : terminated()
Usage : $job->terminated();
Function: Tells whether the job has terminated.
Example :
Returns : TRUE/FALSE.
save
Title : save()
Usage : $filename = $job->save($result);
$filename = $job->save($result, $name);
Function: Save the result in a file. $result is an url,
that can be provided through the get_results method. You can
provide your own filename. By default, the file name will be
the same as the result name.
Example :
Returns : A file name.
content
Title : content()
Usage : $s = $job->content($result);
Function: Provides the content of $result. $result is an url,
that can be provided through the get_results method.
By default, $result is the standard output.
Example :
Returns : A string.
stdout
Title : stdout()
Usage : print $job->stdout();
Function: Provides the content of the job standard output.
Example :
Returns : A string.
stderr
Title : stderr()
Usage : print $job->stderr();
Function: Provides the content of the job standard error.
Example :
Returns : A string.
fh
Title : fh()
Usage : $fh = $job->fh($result);
Function: Provides a filhandle for a result.
$result is an url, that can be provided through the
get_results method.
Be aware that you must re-ask for it for a subsequent use. For
instance, if you first use it for an input parameter:
my $program = Pise::program->new ( ...,
file => $previous_job->fh('..'),
);
my $job = $program->run;
A subsequent run of the same object: will need a re-initialization:
$program->file($previous_job->fh('..'));
my $job2 = $program->run;
Example :
Returns : A filehandle.
results_type
Title : results_type()
Usage : $job->results_type($type);
Function: Enables to change result delivery from one email per file
to url notification or attached files. $type is either: url,
attachment, email.
Example :
Returns : 1 if success, 0 if job already terminated.
value
Title : value(param)
Usage : $job->value(param);
Function:
Example :
Returns : value of parameter param, if available.
_init
Title : _init()
Usage : $self->_init;
Function: Internal. Initializes parameters. Called by new.
Example :
Returns :
_submit
Title : _submit()
Usage : $self->_submit();
Function: Internal. Sends the http request on a Pise server. Called by new.
Example :
Returns : -1 if an error has occured
jobid else
Exceptions: when the job has already been submitted.
_parse
Title : _parse()
Usage : $self->_parse();
Function: Internal. Parses Pise XHTML results page and fills data structures.
Called by frmoUrl or by _submit.
Example :
Returns :
READLINE
Title : READLINE()
Usage :
Function: Internal - see perltie.
Example :
Returns : A string.
TIEHANDLE
Title : TIEHANDLE()
Usage :
Function: Internal - see perltie.
Example :
Returns :
CLOSE()
Title : CLOSE()
Usage :
Function: Internal - see perltie.
Example :
Returns :
_clean_content
Title : _clean_content()
Usage : my $content = $self->_clean_content($content);
Function: Internal. Useful to call before XML parsing.
Example :
Returns :