Common workflow language reference implementation
Project description
==================================================================
Common workflow language tool description reference implementation
==================================================================
CWL Conformance test: |Build Status|
This is the reference implementation of the Common Workflow Language. It is
intended to be feature complete and provide comprehensive validation of CWL
files as well as provide other tools related to working with CWL.
This is written and tested for Python 2.7.
The reference implementation consists of two packages. The "cwltool" package
is the primary Python module containing the reference implementation in the
"cwltool" module and console executable by the same name.
The "cwlref-runner" package is optional and provides an additional entry point
under the alias "cwl-runner", which is the implementation-agnostic name for the
default CWL interpreter installed on a host.
Install
-------
Installing the official package from PyPi (will install "cwltool" package as
well)::
pip install cwlref-runner
If installling alongside another CWL implementation then::
pip instal cwltool
To install from source::
git clone https://github.com/common-workflow-language/cwltool.git
cd cwltool && python setup.py install
cd cwlref-runner && python setup.py install # co-installing? skip this
Remember, if co-installing multiple CWL implementations then you need to
maintain which implementation ``cwl-runner`` points to via a symbolic file
system link or [another facility](https://wiki.debian.org/DebianAlternatives).
Run on the command line
-----------------------
Simple command::
cwl-runner [tool-or-workflow-description] [input-job-settings]
Or if you have multiple CWL implementations installed and you want to override
the default cwl-runner use::
cwltool [tool-or-workflow-description] [input-job-settings]
Import as a module
----------------
Add::
import cwltool
to your script.
Use with boot2docker
--------------------
boot2docker is running docker inside a virtual machine and it only mounts ``Users``
on it. The default behavoir of CWL is to create temporary directories under e.g.
``/Var`` which is not accessible to Docker containers.
To run CWL successfully with boot2docker you need to set the ``--tmpdir-prefix``
and ``--tmp-outdir-prefix`` to somewhere under ``/Users``::
$ cwl-runner --tmp-outdir-prefix=/Users/username/project --tmpdir-prefix=/Users/username/project wc-tool.cwl wc-job.json
.. |Build Status| image:: https://ci.commonwl.org/buildStatus/icon?job=cwltool-conformance
:target: https://ci.commonwl.org/job/cwltool-conformance/
Tool or workflow loading from remote or local locations
-------------------------------------------------------
``cwltool`` can run tool and workflow descriptions on both local and remote
systems via its support for HTTP[S] URLs.
Input job files and Workflow steps (via the `run` directive) can reference CWL
documents using absolute or relative local filesytem paths. If a relative path
is referenced and that document isn't found in the current directory then the
following locations will be searched:
http://www.commonwl.org/v1.0/CommandLineTool.html#Discovering_CWL_documents_on_a_local_filesystem
Common workflow language tool description reference implementation
==================================================================
CWL Conformance test: |Build Status|
This is the reference implementation of the Common Workflow Language. It is
intended to be feature complete and provide comprehensive validation of CWL
files as well as provide other tools related to working with CWL.
This is written and tested for Python 2.7.
The reference implementation consists of two packages. The "cwltool" package
is the primary Python module containing the reference implementation in the
"cwltool" module and console executable by the same name.
The "cwlref-runner" package is optional and provides an additional entry point
under the alias "cwl-runner", which is the implementation-agnostic name for the
default CWL interpreter installed on a host.
Install
-------
Installing the official package from PyPi (will install "cwltool" package as
well)::
pip install cwlref-runner
If installling alongside another CWL implementation then::
pip instal cwltool
To install from source::
git clone https://github.com/common-workflow-language/cwltool.git
cd cwltool && python setup.py install
cd cwlref-runner && python setup.py install # co-installing? skip this
Remember, if co-installing multiple CWL implementations then you need to
maintain which implementation ``cwl-runner`` points to via a symbolic file
system link or [another facility](https://wiki.debian.org/DebianAlternatives).
Run on the command line
-----------------------
Simple command::
cwl-runner [tool-or-workflow-description] [input-job-settings]
Or if you have multiple CWL implementations installed and you want to override
the default cwl-runner use::
cwltool [tool-or-workflow-description] [input-job-settings]
Import as a module
----------------
Add::
import cwltool
to your script.
Use with boot2docker
--------------------
boot2docker is running docker inside a virtual machine and it only mounts ``Users``
on it. The default behavoir of CWL is to create temporary directories under e.g.
``/Var`` which is not accessible to Docker containers.
To run CWL successfully with boot2docker you need to set the ``--tmpdir-prefix``
and ``--tmp-outdir-prefix`` to somewhere under ``/Users``::
$ cwl-runner --tmp-outdir-prefix=/Users/username/project --tmpdir-prefix=/Users/username/project wc-tool.cwl wc-job.json
.. |Build Status| image:: https://ci.commonwl.org/buildStatus/icon?job=cwltool-conformance
:target: https://ci.commonwl.org/job/cwltool-conformance/
Tool or workflow loading from remote or local locations
-------------------------------------------------------
``cwltool`` can run tool and workflow descriptions on both local and remote
systems via its support for HTTP[S] URLs.
Input job files and Workflow steps (via the `run` directive) can reference CWL
documents using absolute or relative local filesytem paths. If a relative path
is referenced and that document isn't found in the current directory then the
following locations will be searched:
http://www.commonwl.org/v1.0/CommandLineTool.html#Discovering_CWL_documents_on_a_local_filesystem
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
cwltool-1.0.20161115095848.tar.gz
(215.2 kB
view details)
Built Distribution
File details
Details for the file cwltool-1.0.20161115095848.tar.gz
.
File metadata
- Download URL: cwltool-1.0.20161115095848.tar.gz
- Upload date:
- Size: 215.2 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | db29f5965dc4b71bacab4ccaa923d9e2d10a62586e0f2e985147b5eec369b6b3 |
|
MD5 | 318d2ed1a9f07b5ccacbd443a1bb94fd |
|
BLAKE2b-256 | cf603431958310d45bb7d31d35694a24ed31c1c04561914ccef850234006e344 |
File details
Details for the file cwltool-1.0.20161115095848-py2-none-any.whl
.
File metadata
- Download URL: cwltool-1.0.20161115095848-py2-none-any.whl
- Upload date:
- Size: 262.6 kB
- Tags: Python 2
- Uploaded using Trusted Publishing? No
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | afe4398254d6b09ea2b8756162f918635d0f46f33e22a0bd8e632beb50ff526e |
|
MD5 | ea3febbb0298f6972391bda866c3f71b |
|
BLAKE2b-256 | b3feb518c99f63ff7849afece5642f3fae8ae85362d7edd6de586f64c32e7822 |