This file describes how to install comparem2 for development purposes. If you want to add new analysis rules you will be defining and configuring a conda environment that will eventually be added to the apptainer-compatible dockerfile, you must run everything through Conda. Once you make a pull request and it is accepted, your conda environment will be added to the official docker image which is then published with the next version number.
CompareM2 only works on Linux.
comparem2 can be installed by downloading the code and setting up an alias in your user profile that let's you launch the pipeline from any directory on your machine.
The only requisites for running comparem2 is:
- conda compatible package manager (We recommend mamba from miniforge)
- git distributed version control
First, check that you have the prerequisites available on your system.
which mamba && mamba --version # Should be <2
which git
Then download the comparem2 pipeline and set up an alias in your profile (.bashrc on most linux distributions). Proposed installation directory is in your home directory (~).
cd ~ # Enter the directory where you want to install comparem2.
git clone https://github.com/cmkobel/comparem2.git comparem2
cd comparem2
mamba env create -y -f environment.yaml -n comparem2_dev
If you are planning to make a pull request, you can also clone your personal fork instead of cloning the official repository.
If you have Apptainer on your machine, you should use this specific profile to force using Conda instead.
Skippable: If you are planning to make changes in CompareM2 that do not add or modify individual Conda environments, you can skip this step.
export COMPAREM2_PROFILE="$(realpath profile/conda/default)"
realpath
makes sure that you get the absolute path. This is helpful, should you later change directory.
You can read more about CompareM2 environment variables here: https://comparem2.readthedocs.io/en/latest/10%20installation/#advanced-configuration
Finally, you can run the pipeline with the following code:
conda activate comparem2_dev
unzip tests/E._faecium/fna.zip # Or gather your own relevant files for testing.
./comparem2 --config input_genomes="*.fna" --until fast --dry-run
Issuing a dry run is a good way to get started, checking that everything is OK.
Happy hacking!