view cherry_pick_fasta.xml @ 2:321cad0eb507 draft

"planemo upload for repository https://github.com/ARTbio/tools-artbio/tree/master/tools/cherry_pick_fasta commit b5ef783237b244d684e26b1ed1cc333a8305ce3e"
author artbio
date Tue, 16 Mar 2021 23:25:57 +0000
parents ea8fde9c6f82
children c282a8a47dd9
line wrap: on
line source

<tool id="cherry_pick_fasta" name="Pick Fasta sequences" version="2.1.0">
  <description>with header satisfying a string query</description>
  <requirements>
      <requirement type="package" version="3.7.6">python</requirement>
  </requirements>
  <command interpreter="python">cherry_pick_fasta.py
                                   --input $input
                                   --searchfor '$search.searchfor'
                                   #if $search.options_selector == 'single':
                                       --query-string '$search.query'
                                   #else:
                                       --query-file '$search.query'
                                   #end if
                                   --output $output
  </command>

  <inputs>
    <param name="input" type="data" format="fasta" label="Source file" help="Fasta file to parse" />

    <conditional name="search">
        <param name="options_selector" type="select" display="radio" label="by single term or file of terms">
            <option value="single" selected="True">single term</option>
            <option value="textdataset">terms in a text dataset</option>
        </param>
        <when value="single">
            <param name="query" type="text" size="30" value="" label="Search string" help="exemple: gi|40557596">
                <sanitizer>
                    <valid initial="string.printable">
                        <remove value="&quot;"/>
                        <remove value="\"/>
                    </valid>
                    <mapping initial="none">
                        <add source="&quot;" target="\&quot;"/>
                        <add source="\" target="\\"/>
                    </mapping>
                </sanitizer>
            </param>
            <param name="searchfor" type="select" label="retrieve sequences whose headers contain or do not contain the search string">
                <option value="with" selected="true">contain</option>
                <option value="without">do not contain</option>
            </param>
        </when>
        <when value="textdataset">
            <param name="query" type="data" format="txt" label="term dataset" help="a list of term to search for, one term per line" />
            <param name="searchfor" type="select" label="retrieve sequences whose headers contain or do not contain the search list">
                <option value="with" selected="true">contain</option>
                <option value="without">do not contain</option>
            </param>
        </when>
    </conditional>
  </inputs>
  <outputs>
    <data name="output" format="fasta" label="Fasta sequences ${search.searchfor.value} ${search.options_selector} term(s) in header" />
  </outputs>
  <tests>
    <test>
        <param ftype="fasta" name="input" value="input.fa" />
        <!-- <param name="options_selector" value="textdataset" /> -->
        <param name="query" value="gi|81971654" />
        <param name="searchfor" value="with" />
        <output name="output" ftype="fasta" file="output.fa" />
    </test>
    <test>
        <param ftype="fasta" name="input" value="input.fa" />
        <!-- <param name="options_selector" value="textdataset" /> -->
        <param name="query" value="RNA" />
        <param name="searchfor" value="without" />
        <output name="output" ftype="fasta" file="output_without.fa" />
    </test>
    <test>
        <param ftype="fasta" name="input" value="input.fa" />
        <param name="options_selector" value="textdataset" />
        <param name="query" ftype="txt" value="termlist.txt" />
        <param name="searchfor" value="without" />
        <output name="output" ftype="fasta" file="output_termlist.fa" />
    </test>
    <test>
        <param ftype="fasta" name="input" value="input.fa" />
        <param name="options_selector" value="textdataset" />
        <param name="query" ftype="txt" value="termlist.txt" />
        <param name="searchfor" value="without" />
        <output name="output" ftype="fasta" file="output_termlist_without.fa" />
    </test>
  </tests>

  <help>
**What it does**

This tool retrieves nucleotide/peptide sequences from a fasta file whose headers match
or do not match a given string.

It is Copyright © 2019 `CNRS and Sorbonne-Université`_ and is released under the `MIT license`_.

.. _CNRS and  Sorbonne-Université: http://www.sorbonne-universite.fr/en
.. _MIT license: http://opensource.org/licenses/MIT

  </help>
</tool>