Learning Objective:
In this short guide you will learn how to set up Sharg and how to compile a small example to test whether everything works.
Difficulty | Easy |
---|---|
Duration | 30 Minutes |
Prerequisite tutorials | No prerequisites |
Recommended reading |
Requirements:
SeqAn requires GCC >= 10. Current versions of LLVM/Clang and VisualStudio/MSVC are not yet supported. We will briefly explain how to install GCC-11 (or the latest GCC if such an option is available) on some popular operating systems. We recommend using the latest version of GCC available. For more information, refer to your operating system's documentation.
To avoid interference with system packages, we recommend creating a new environment when using conda.
This will put GCC in a separate environment conda_gcc_env
which can be activated via conda activate conda_gcc_env
and deactivated via conda deactivate
.
The Windows Subsystem for Linux offers an easy way to run a Linux distribution under Windows. Follow Microsoft's setup guide to install WSL and then follow the steps listed for Linux-based systems.
gitpod.io allows you to edit, compile and run code from within your browser. The free version includes 50 hours of use per month, which is plenty for our tutorials. A GitHub account is required. Click here to open Sharg in gitpod.
g++ --version
should print the desired version. If not, you may have to use, for example, g++-11 --version
or even specify the full path to your compiler.Similarly, you may need to install CMake and git, e.g. apt install cmake git
.
In this section we will use the tree
command to show the directory structure. This program may not be installed on your system. If so, you may wish to install it or verify the directory structure in other ways, e.g. by using ls -l
.
For this project, we recommend following directory layout:
To set these directories up you can follow this script:
The output of the command tree -L 2
should now look like this:
To test whether everything works, we will now compile and run a small example.
First we create the file hello_world.cpp
in the source
directory with the following contents:
To compile it, we first create a CMakeLists.txt
file in the source
directory:
The directories should now look like this:
Now we can switch to the directory build
and run:
The output should be Hello World!
. Note that the build type is specified with -DCMAKE_BUILD_TYPE=Release
. Specifying Release
enables an optimized build where no debug information is available. Release mode is therefore suitable for the end user. Programs built using -DCMAKE_BUILD_TYPE=Debug
will run slower, but also make the detection of errors easier. Debug
is suitable for contributors, and we recommend using it while working with our Tutorials.
-DCMAKE_CXX_COMPILER=
, for example: If you create a new cpp
file and want to compile it, you need to add another add_executable
and target_link_libraries
directive to you CMakeLists.txt
. For example, after adding another_program.cpp
your CMakeLists.txt
may look like this:
/usr/lib/x86_64-linux-gnu/libstdc++.so.6: version 'CXXABI_1.3.11' not found
LD_LIBRARY_PATH
: <conda_install_path>
must be replaced by the path yo your conda installation.conda info --base
and may look similar to /home/user/miniconda3/
.... could not understand flag m ...
/usr/bin
to your PATH
: cmake
again.