argparse2tool
transparently build CWL and Galaxy XML tool definitions for any script that uses argparse
Science Score: 23.0%
This score indicates how likely this project is to be science-related based on various indicators:
-
○CITATION.cff file
-
✓codemeta.json file
Found codemeta.json file -
○.zenodo.json file
-
○DOI references
-
○Academic publication links
-
✓Committers with academic emails
1 of 10 committers (10.0%) from academic institutions -
○Institutional organization owner
-
○JOSS paper metadata
-
○Scientific vocabulary similarity
Low similarity (12.0%) to scientific vocabulary
Keywords
bioinformatics
python
usegalaxy
Keywords from Contributors
dna
genomics
ngs
sequencing
workflow-engine
common-workflow-language
commonwl
cwl
sciworkflows
workflows
Last synced: 6 months ago
·
JSON representation
Repository
transparently build CWL and Galaxy XML tool definitions for any script that uses argparse
Basic Info
Statistics
- Stars: 27
- Watchers: 7
- Forks: 9
- Open Issues: 23
- Releases: 3
Topics
bioinformatics
python
usegalaxy
Created about 11 years ago
· Last pushed over 1 year ago
Metadata Files
Readme
License
README.rst
argparse2tool
=============
|PyPI|
This project aims to provide a drop-in replacement for argparse which allows
generating Galaxy XML and CWL Tools.
It is quite literally a drop-in replacement. You (or the upstream tool
author) can use argparse completely as normal
.. code:: python
import argparse
When this package is installed and PYTHONPATH=$(argparse2tool) is set the
dropin replacement of argparse is used ahead of the
system argparse, ``argparse2tool`` will capture all argparse function
calls, and process them specially.
This information captured in this process is used to produce `Galaxy
Tool XML `__ when it's requested
with the ``--generate_galaxy_xml`` flag, or `CWL
Tools `__ when
requested with the ``--generate_cwl_tool`` flag.
For our `example python script <./examples/example.py>`__ you can see
the generated `Galaxy XML <./examples/example.xml>`__ and `CWL
Tools <./examples/example.cwl>`__.
Running
-------
To generate XML or CWL, run your tool with the appropriate command line
flag
.. code:: console
$ PYTHONPATH=$(argparse2tool) --generate_galaxy_xml > tool.xml
$ PYTHONPATH=$(argparse2tool) --generate_cwl_tool > tool.cwl
The project includes a sample ``example.py`` file which uses as many
argparse features as possible. CWL and Galaxy XML support different
portions feature sets which will be visible in the generated outputs.
.. code:: console
$ PYTHONPATH=$(argparse2tool) python example.py --generate_galaxy_xml
$ PYTHONPATH=$(argparse2tool) python example.py --generate_cwl_tool
CWL Specific Functionality
~~~~~~~~~~~~~~~~~~~~~~~~~~
Example for `CNVkit `__ toolkit
.. code:: console
$ cnvkit.py batch --generate_cwl_tool -d ~/cnvkit-tools/ --generate_outputs
If there are subcommands in the provided command, all possible tools
will be generated, for instance, for CNVkit
.. code:: console
$ cnvkit.py --generate_cwl_tool
will produce CWL tool descriptions for ``cnvkit.py batch``,
``cnvkit.py access``, ``cnvkit.py export bed``, ``cnvkit.py export cdt``
and all other subcommands.
Other options (which work only with ``--generate_cwl_tool`` provided,
except for help message) are:
- ``-o FILENAME``, ``--output_section FILENAME``: File with manually
filled output section which is put to a formed CWL tool.
``argparse2tool`` is not very good at generating outputs, it
recognizes output files only if they have type
``argparse.FileType('w')``, so output section is often blank and
should be filled manually.
- ``-go``, ``--generate_outputs``: flag for generating outputs not only
from arguments that are instances of ``argparse.FileType('w')``, but
also from every argument which contains ``output`` keyword in its
name. For instance, argument ``--output-file`` with no type will also
be placed to output section. However, '--output-directory' argument
will also be treated like File, so generated tools must be checked
carefully if when this option is selected.
- ``-b``, ``basecommand``: command which appears in ``basecommand``
field in a resulting tool. It is handy to use this option when you
run tool with shebang, but want ``python`` to be in ``basecommand``
field and the file amidst arguments. Example:
``$ .search.py --generate_cwl_tool -b python``.
Basecommand of the formed tool will be ``['python']``, and ``search``
will be a positional argument on position 0.
- ``-d``, ``--directory``: directory for storing tool descriptions.
- ``--help_arg2cwl``: prints this help message.
How it works
------------
Internally, ``argparse2tool``, masquerading as ``argparse`` attempts to
find and import the **real** argparse. It then stores a reference to the
code module for the system argparse, and presents the user with all of
the functions that stdlib's argparse provides. Every function call is
passed through the system argparse. However, argparse2tool captures the
details of those calls and when Tool XML or CWL is requested, it builds
up the tool definition and prints it out to standard output.
Examples
--------
You can see the ``example.py`` file for an example with numerous types
of arguments and options that you might see in real tools. Accordingly
there is an ``example.xml`` file with the output.
It doesn't work!!
-----------------
If you are not able to use the
``--generate_galaxy_xml``/``--generate_cwl_tool`` flags after
installing, it is probably because of module load order.
``argparse2tool`` must precede ``argparse`` in the path.
To easily correct this, run the tool ``argparse2tool`` which
is installed as part of this package. Correctly functioning paths will
produce the following:
.. code:: console
$ argparse2tool
PATH_TO_THE_DROPINS
while incorrectly ordered paths will produce a helpful error message:
.. code:: console
$ argparse2tool
no dropins dir...
This is intended to be used inline:
.. code:: console
user@host:$ PYTHONPATH=$(argparse2tool) python my_script.py --generate_galaxy_xml
Limitations
-----------
This code doesn't cover the entirety of the ``argparse`` API yet, and
there are some bugs to work out on the XML generation side:
- argparse
- groups not supported (in galaxy, everything should still work in
argparse)
- some features like templating of the version string (please submit
bugs)
- galaxyxml
- bugs in conditionals/whens (probably)
- argparse2tool Galaxy XML Output
- support declaring output files in an ``argparse``-esque manner
- argparse2tool CWL Output
- Some of argparse features can not be ported to CWL.
1. ``nargs=N``. Number of arguments can not be specified in CWL
(yet).
2. ``const`` argument of ``add_argument()``. All constants must be
specified in job files.
3. Custom types and custom actions are not supported.
4. Argument groups don't work in CWL as arguments are sorted with
a `special
algorithm `__
5. Mutual exclusion is not supported.
License
-------
Apache License, v2
.. |PyPI| image:: https://img.shields.io/pypi/v/argparse2tool.svg
:target: https://pypi.python.org/pypi/argparse2tool
Owner
- Name: Helena
- Login: hexylena
- Kind: user
- Location: ::1
- Company: Erasmus Medical Center
- Website: https://hexylena.galaxians.org/
- Repositories: 228
- Profile: https://github.com/hexylena
(Experiencing reduced availability, feel free to ping, expect delayed responses.) Systems Witch ✨ Casting the spell to make the servers work 🧙♀️
GitHub Events
Total
- Release event: 1
- Watch event: 2
- Issue comment event: 3
- Push event: 5
- Pull request review event: 1
- Pull request event: 2
- Create event: 3
Last Year
- Release event: 1
- Watch event: 2
- Issue comment event: 3
- Push event: 5
- Pull request review event: 1
- Pull request event: 2
- Create event: 3
Committers
Last synced: 8 months ago
Top Committers
| Name | Commits | |
|---|---|---|
| Eric Rasche | r****c@g****m | 81 |
| Eric Rasche | r****c@y****u | 52 |
| Anton Khodak | a****k@u****t | 51 |
| Matthias Bernt | m****t@u****e | 26 |
| Michael R. Crusoe | m****e@g****m | 7 |
| Hervé Ménager | h****r@g****m | 4 |
| Roman Valls Guimera | b****m@n****g | 3 |
| Dusan Figala | d****a@p****m | 1 |
| Bjoern Gruening | b****g@g****m | 1 |
| Eric Rasche | e****r@t****u | 1 |
Committer Domains (Top 20 + Academic)
Issues and Pull Requests
Last synced: 6 months ago
All Time
- Total issues: 47
- Total pull requests: 27
- Average time to close issues: 2 months
- Average time to close pull requests: 25 days
- Total issue authors: 8
- Total pull request authors: 7
- Average comments per issue: 1.45
- Average comments per pull request: 2.04
- Merged pull requests: 22
- Bot issues: 0
- Bot pull requests: 0
Past Year
- Issues: 0
- Pull requests: 1
- Average time to close issues: N/A
- Average time to close pull requests: 5 days
- Issue authors: 0
- Pull request authors: 1
- Average comments per issue: 0
- Average comments per pull request: 4.0
- Merged pull requests: 1
- Bot issues: 0
- Bot pull requests: 0
Top Authors
Issue Authors
- hexylena (25)
- mr-c (10)
- anton-khodak (4)
- alexlenail (3)
- bernt-matthias (2)
- MatthewRalston (1)
- ksebby (1)
- bgruening (1)
Pull Request Authors
- bernt-matthias (8)
- hexylena (6)
- mr-c (5)
- hmenager (4)
- figi44 (2)
- anton-khodak (2)
- bgruening (1)
Top Labels
Issue Labels
GalaxyXML (7)
CWL (7)
bug (2)
enhancement (2)
help wanted (1)
Pull Request Labels
bug (2)
GalaxyXML (1)
CWL (1)
wip (1)
Packages
- Total packages: 1
-
Total downloads:
- pypi 92 last-month
- Total dependent packages: 0
- Total dependent repositories: 1
- Total versions: 11
- Total maintainers: 1
pypi.org: argparse2tool
Instrument for forming Galaxy XML and CWL tool descriptions from argparse arguments
- Homepage: https://github.com/hexylena/argparse2tool
- Documentation: https://argparse2tool.readthedocs.io/
- License: Apache Software License
-
Latest release: 0.5.2
published over 1 year ago
Rankings
Dependent packages count: 10.0%
Forks count: 11.4%
Stargazers count: 12.0%
Average: 15.3%
Downloads: 21.5%
Dependent repos count: 21.7%
Maintainers (1)
Last synced:
7 months ago
Dependencies
requirements.txt
pypi
- galaxyxml ==0.4.6
- jinja2 >=2.8
setup.py
pypi
- galaxyxml ==0.4.6
.github/workflows/ci.yml
actions
- actions/checkout v2 composite
- actions/setup-python v2 composite
.github/workflows/publish.yml
actions
- actions/checkout v2 composite
- actions/setup-python v2 composite
- pypa/gh-action-pypi-publish release/v1 composite