4 releases
0.3.2 | Feb 9, 2024 |
---|---|
0.3.1 | Dec 19, 2023 |
0.3.0 | Nov 7, 2023 |
0.2.0 | Nov 6, 2023 |
#343 in Biology
140KB
1.5K
SLoC
Rust Bioinformatics Toolbox (rboss)
Rust Bioinformatics Toolbox, abbreviated as rboss, is a command-line tool designed to facilitate various operations on bioinformatics files. It provides a range of commands to manipulate sequence data files commonly used in bioinformatics, such as BAM, FASTA, and FASTQ formats.
Minimum Supported Rust Version (MSRV)
This project adheres to a Minimum Supported Rust Version (MSRV) policy. The Minimum Supported Rust Version (MSRV) is 1.70.0. We ensure that all code within the project is compatible with this version or newer to maintain stability and compatibility.
Features
- High Performance: Take advantage of Rust's performance for heavy computational tasks.
- Safety: Rust's strong type system and ownership model ensure safety across bioinformatics operations.
- Concurrency: Utilize Rust's modern concurrency tools for parallel data processing.
Installation
You can install rboss
using Cargo, the Rust package manager. Ensure you have Rust and Cargo installed on your system, then run:
cargo install rboss
Getting Started
To begin using rboss
, you may invoke it with the following syntax:
rboss [OPTIONS] [COMMAND]
rboss
provides several commands to perform different operations:
Commands
-
extract
(aliases:e
): Extract reads from a BAM file.Usage:
rboss extract [OPTIONS] <BAM_FILE>
-
index
: Index a BAM file to speed up read access.Usage:
rboss index <BAM_FILE>
-
fa2fq
: Convert a FASTA file to FASTQ format.Usage:
rboss fa2fq <FASTA_FILE>
-
fq2fa
: Convert a FASTQ file to FASTA format.Usage:
rboss fq2fa <FASTQ_FILE>
-
rsoft
: Create soft links to files with the same suffix in one directory recursively.Usage:
rboss rsoft <TARGET_DIR> -s <SUFFIX>
-
help
: Print detailed help information forrboss
or its subcommands.Usage:
rboss help [COMMAND]
Options
-
--generate <GENERATOR>
: Generate shell completions forrboss
for the specified shell. Possible values includebash
,elvish
,fish
,powershell
, andzsh
. -
-v
,--verbose
: Increase verbosity. The more occurrences of this flag, the more detailed the output. -
-q
,--quiet
: Decrease verbosity. The more occurrences of this flag, the less detailed the output. -
-h
,--help
: Print help information forrboss
and its subcommands. -
-V
,--version
: Print the version information forrboss
.
Examples
Extracting reads from a BAM file based on reads.txt
:
rboss extract reads.txt sample.bam
Indexing a BAM file:
rboss index sample.bam
Converting a FASTA file to FASTQ:
rboss fa2fq sample.fasta
Converting a FASTQ file to FASTA:
rboss fq2fa sample.fastq
Creating soft links for files with a .txt
or .csv
suffix:
rboss rsoft /path/to/directory -s txt csv
For further help on any specific command, you can use the help
command:
rboss help extract
For the latest updates and more detailed documentation, please visit the official rboss
repository.
Contributing
Contributions to rboss
are welcome. If you have suggestions for improvements or have identified issues, please open an issue or a pull request in the repository.
Thank you for using rboss
, the versatile Rust-powered toolbox for bioinformatics data manipulation!
License
rboss is distributed under the terms of both the MIT license and the Apache License (Version 2.0). See LICENSE-APACHE and LICENSE-MIT for details.
Community
Join us on Discord/Gitter/Forum to discuss rboss development, ask questions, and collaborate with other contributors.
Credits
rboss is being actively developed and maintained by bioinformatics enthusiasts and the Rust community. We thank all contributors for their efforts.
Dependencies
~55MB
~1M SLoC