This is a command line for the Apache Taverna Language, an API for the Apache Taverna workflows.
usage: tavlang <command> [<args>] The most commonly used tavlang commands are: convert Convert the given workflow help Display help information about Taverna inspect Inspect the given workflow and show the results on the terminal validate Validate the given workflow version Show version informantion See 'tavlang help <command>' for more information on a specific command.
The Taverna language command line tool is for accessing the features of the Taverna language modules. The tool has the following functions:
$tavlang <command> <options> [arguments and parameters]
Each command has its own set of options.
###Commands and Options The tool has the following major commands:
Convert the given workflow file/s into a specified output format.
Usage:
tavlang convert (--output_fomat) ([[options] [arguments]]|files...)
Supported output formats are,
Options:
*The tool can only convert into one format at a time
There are two methods for using the conversion command.
Usage:
$tavlang convert (--output_format) [options] [arguments]
####### Example 1: Without specifying any options
$tavlang convert --structure /helloworld.t2flow
Output:
/converted/helloworld.structure is created
Convert the helloworld.t2flow into helloworld.structure format and store in the /converted directory
$tavlang convert --json /helloworld.t2flow /hello.t2flow
Output:
/converted/helloworld.json is created /converted/hello.json is created
Convert both workflow files and store them in /converted directory
$tavlang convert --wfbundle /helloworld.t2flow -o /output/workflows
Output:
/output/workflows/helloworld.wfbundle is created
Convert the workflow file/s and store them in the specified output directory
If there are many workflows in a directory, which are needed to be converted into one single format use this method.
Usage:
$tavlang convert -r (--output_format) -i workflow_src_dir <options> [arguments]
$tavlang convert -r --json -i /home/user/workflows
Convert all the workflows in the input directory into the specified format and store them in the “/home/user/workflows/converted” directory.
Output: Suppose that there are 2 workflow files in the dir 1.t2flow and 2.t2flow
/home/workflows/converted/1.json is created /home/workflows/converted/2.json is created
$tavlang convert -r --json -i /home/workflows -o /home/final
Convert all the workflows in the input directory and store them in /home/final directory
Output:
/home/final/1.json is created /home/final/2.json is created
Inspect the given workflow file/s and give the inspection report. Supported workflow bundle formats: .wfbundle, .t2flow
Usage:-
$tavlang inspect (--inspection_options) <-other-options> [arguments] workflow_undles_to_be_inspected
Inspection options:
Other Options:
Inspection result for Service types
$tavlang inspect --servicetypes helloworld.wfbundle Service types used in helloworld.wfbundle :
http://ns.taverna.org.uk/2010/activity/constant
inspection result for Processor names
$tavlang inspect --processornames helloworld.wfbundle Processor tree of helloworld.wfbundle
The output is the same but the results will be saved in the given file.
$tavlang inspect --processornames helloworld.wfbundle -l results.txt Processor tree of helloworld.wfbundle + Hello_World - hello
The output will be saved in results.txt in the same format.
Validates the given workflow file or files and gives the validation report. Validate tool checks for the following problematic conditions.
Usage:-
$tavlang validate [options][arguments] input_files
Options:-
Supported workflow bundle formats: .t2flow and .wfbundle
Validate one workflow bundle
$tavlang validate helloworld.t2flow
Output:
Validation started.... Validating helloworld.t2flow The workflow helloworld.t2flow has no errors. Validation completed.......
Validate more than one workflow bundles
$tavlang validate ../../workflow2.t2flow ../../workflow3.wfbundle Validation started.... Validating ../../workflow2.t2flow The workflow workflow2.t2flow has no errors. Validating ../../workflow3.wfbundle The workflow workflow3.t2flow has no errors. Validation completed.......
The report is more explanatory.
$tavlang validate -v ../../workflow2.t2flow Validation started.... Validating ../../workflow2.t2flow The workflow workflow2.t2flow has no errors. The validation report for defaultActivitiesTaverna2.wfbundle...... -------------------------------------------------------------------------------- -->NegativeValueProblems:- null -->EmptyIterationStrategyTopNodeProblems:- null -->MismatchConfigurableTypeProblems:- null -->NonAbsoluteURIProblems:- null -->NullFieldProblems:- null -->OutOfScopeValueProblems:- null -->PortMentionedTwiceProblems:- null -->PortMissingFromIterationStrategyStackProblems:- null -->WrongParentProblems:- null -->IncompatibleGranularDepthProblems:- null ---------------------------------------------------------------------------------
$tavlang validate workflow2.t2flow -l log2.txt Validation started.... Validating workflow2.t2flow The workflow helloworld.wfbundle has no errors. Validation completed....... Results were saved into log2.txt
A workflow contains several resources.
The stats command gives a report of the resources used in the workflow.
Usage:-
$tavlang stats <options>[arguments] input_files...
Options:-
Supported workflow bundle formats:- .t2flow, .wfbundle
$tavlang helloworld.wfbundle >>> Statistics of the workflow bundle: helloworld.wfbundle <<< Name of the workflow = Hello_World |--> Number of Processors = 1 |--> Number of Data Links = 1 |--> Number of Control Links = 0 |--> Number of Input ports = 0 |--> Number of Output Ports = 1
$tavlang -v ../../../helloworld.wfbundle >>> Statistics of the workflow bundle: helloworld.wfbundle <<< Name of the workflow = Hello_World |--> Number of Processors = 1 | |--> Processors: | |--> hello | |--> Number of Data Links = 1 | |--> Data Links | |--> DataLink value=>greeting | |--> Number of Control Links = 0 |--> Number of Input ports = 0 |--> Number of Output Ports = 1 | |--> Output Ports | |--> OutputWorkflowPort "greeting"
$tavlang -l ../../results.txt ../../../helloworld.wfbundle >>> Statistics of the workflow bundle: helloworld.wfbundle <<< Name of the workflow = Hello_World |--> Number of Processors = 1 |--> Number of Data Links = 1 |--> Number of Control Links = 0 |--> Number of Input ports = 0 |--> Number of Output Ports = 1 Results were saved into ../../results.txt