nf-core_modules/README.md

71 lines
4.5 KiB
Markdown
Raw Normal View History

2019-07-26 05:19:07 -04:00
# ![nf-core/modules](docs/images/nfcore-modules_logo.png)
> DSL2 IS AN EXPERIMENTAL FEATURE UNDER DEVELOPMENT. SYNTAX, ORGANISATION AND LAYOUT OF THIS REPOSITORY MAY CHANGE IN THE NEAR FUTURE!
2019-07-26 08:38:08 -04:00
A repository for hosting nextflow [`DSL2`](https://www.nextflow.io/docs/edge/dsl2.htmlhttps://www.nextflow.io/docs/edge/dsl2.html) module files containing tool-specific process definitions and their associated documentation.
2019-07-26 05:19:07 -04:00
## Table of contents
2019-07-26 08:38:08 -04:00
* [Using existing modules](#using-existing-modules)
2019-07-26 05:19:07 -04:00
* [Configuration and parameters](#configuration-and-parameters)
* [Offline usage](#offline-usage)
2019-07-26 08:38:08 -04:00
* [Adding a new module file](#adding-a-new-module-file)
2019-07-26 05:19:07 -04:00
* [Testing](#testing)
* [Documentation](#documentation)
* [Uploading to `nf-core/modules`](#uploading-to-nf-coremodules)
* [Help](#help)
2019-07-26 08:38:08 -04:00
## Using existing modules
2019-07-26 05:19:07 -04:00
2019-07-26 08:30:26 -04:00
The Nextflow [`include`](https://www.nextflow.io/docs/edge/dsl2.html#modules-include) statement can be used within your pipelines in order to load module files that you have available locally.
2019-07-26 05:19:07 -04:00
2019-07-26 08:30:26 -04:00
You should be able to get a good idea as to how other people are using module files by looking at pipelines available in nf-core e.g. [`nf-core/rnaseq`](https://github.com/nf-core/rnaseq/pull/162)
2019-07-26 05:19:07 -04:00
2019-07-26 08:30:26 -04:00
### Configuration and parameters
2019-07-26 05:19:07 -04:00
2019-07-26 08:38:08 -04:00
The module files hosted in this repository define a set of processes for software tools such as `fastqc`, `trimgalore`, `bwa` etc. This allows you to share and add common functionality across multiple pipelines in a modular fashion.
2019-07-26 11:06:49 -04:00
> The definition and standards for module files are still under discussion amongst the community but hopefully, a description should be added here soon!
2019-07-26 05:19:07 -04:00
### Offline usage
2019-07-26 08:30:26 -04:00
If you want to use an existing module file available in `nf-core/modules`, and you're running on a system that has no internet connection, you'll need to download the repository (e.g. `git clone https://github.com/nf-core/modules.git`) and place it in a location that is visible to the file system on which you are running the pipeline. Then run the pipeline by creating a custom config file called e.g. `custom_module.conf` containing the following information:
2019-07-26 05:19:07 -04:00
```bash
2019-07-26 08:30:26 -04:00
include /path/to/downloaded/modules/directory/
2019-07-26 05:19:07 -04:00
```
2019-07-26 08:30:26 -04:00
Then you can run the pipeline by directly passing the additional config file with the `-c` parameter:
2019-07-26 05:19:07 -04:00
```bash
2019-07-26 08:30:26 -04:00
nextflow run /path/to/pipeline/ -c /path/to/custom_module.conf
2019-07-26 05:19:07 -04:00
```
> Note that the nf-core/tools helper package has a `download` command to download all required pipeline
2019-07-26 08:30:26 -04:00
> files + singularity containers + institutional configs + modules in one go for you, to make this process easier.
2019-07-26 05:19:07 -04:00
2019-07-26 08:30:26 -04:00
## Adding a new module file
2019-07-26 05:19:07 -04:00
2019-07-26 08:38:08 -04:00
If you decide to upload your module file to `nf-core/modules` then this will ensure that it will be automatically downloaded, and available at run-time to all nf-core pipelines, and to everyone within the Nextflow community! See [`nf-core/modules/nf`](https://github.com/nf-core/modules/tree/master/nf) for examples.
2019-07-26 05:19:07 -04:00
2019-07-26 11:06:49 -04:00
> The definition and standards for module files are still under discussion amongst the community but hopefully, a description should be added here soon!
2019-07-26 05:19:07 -04:00
### Testing
2019-07-26 08:30:26 -04:00
If you want to add a new module config file to `nf-core/modules` please test that your pipeline of choice runs as expected by using the [`-include`](https://www.nextflow.io/docs/edge/dsl2.html#modules-include) statement with a local version of the module file.
2019-07-26 05:19:07 -04:00
### Documentation
2019-07-26 11:05:13 -04:00
Please add some documentation to the top of the module file in the form of native Nextflow comments. This has to be specified in a particular format as you will be able to see from other examples in the [`nf-core/modules/nf`](https://github.com/nf-core/modules/tree/master/nf) directory.
2019-07-26 05:19:07 -04:00
### Uploading to `nf-core/modules`
2019-07-26 11:05:13 -04:00
[Fork](https://help.github.com/articles/fork-a-repo/) the `nf-core/modules` repository to your own GitHub account. Within the local clone of your fork add the module file to the [`nf-core/modules/nf`](https://github.com/nf-core/modules/tree/master/nf) directory. Please keep the naming consistent between the module and documentation files e.g. `bwa.nf` and `bwa.md`, respectively.
2019-07-26 05:19:07 -04:00
2019-07-26 08:30:26 -04:00
Commit and push these changes to your local clone on GitHub, and then [create a pull request](https://help.github.com/articles/creating-a-pull-request-from-a-fork/) on `nf-core/modules` GitHub repo with the appropriate information.
2019-07-26 05:19:07 -04:00
We will be notified automatically when you have created your pull request, and providing that everything adheres to nf-core guidelines we will endeavour to approve your pull request as soon as possible.
## Help
2019-07-30 10:31:44 -04:00
If you have any questions or issues please send us a message on [Slack](https://nf-co.re/join/slack).