Compiling on Linux
Documented platforms
The documentation here covers Debian/Ubuntu and Flatpak. Debian .deb packages and Flatpak are the primary deployment platforms for Linux. It is certainly possible to compile OpenCPN on other Linux distributions by adapting these instructions.
The instructions are based on the files in the ci/ directory, at the time of writing ci/generic_build_debian.sh and ci/generic_build_flatpak.sh. These files which are continously tested is the ultimate source for how to build on Linux.
Debian/Ubuntu
2. Install build dependencies
$ sudo apt install devscripts equivs
$ sudo mk-build-deps -i -r ci/control
$ sudo apt-get --allow-unauthenticated install -f
Notes: * The build setup is generally updated for Debian and Ubuntu LTS releases.
4. Build it
We’ll build everything in a subdirectory to keep the codebase clean (easier to catch changes).
$ mkdir build
$ cd build
$ cmake ..
$ make
Notes:
Default install dir is /usr/local, this can be changed by providing the appropriate option to cmake:
$ cmake -DCMAKE_INSTALL_PREFIX=/usr ..
cmake is only required when building source code for the first time, then running make is enough even if the source code is updated.
Flatpak
1. Install flatpak
Install flatpak and flatpak-builder as described in https://flatpak.org/setup/.
2. Install runtime and SDK
At the time of writing version 22.08 is used. Check flatpak/org.opencpn.OpenCPN.yaml for the version actually used, look for runtime-version:. Install the proper runtime and Sdk, for example:
$ sudo flatpak install flathub org.freedesktop.Platform//22.08
$ sudo flatpak install flathub org.freedesktop.Sdk//22.08
3. Build and install:
$ cd build
$ make -f ../flatpak/Makefile build
The makefile will build the flatpak version and also install it.
5. Debugging
The flatpak’ed OpenCPN runs in a sandbox, so specialized debugging techniques must be applied. See The flatpak site
Compiling for Raspberry Pi (RPi)
From RPi 4 the board has resources enough to run a native build, which is performed according to the instructions for Debian.
For RPi 3 with 1GB of ram builds are usually done utilizing cross-compiling on Linux, often using docker and, for 32-bit armhf builds, also qemu. A description of these builds is out of scope for this document.
Fedora
To install the dependencies required to build OpenCPN from source on Fedora (Tested on 38), run the following command:
sudo dnf install wxGTK-devel cmake gcc-c++ git glew-devel openssl-devel \
libcurl-devel libarchive-devel elfutils-libelf-devel redhat-lsb-core \
libusb1-devel tinyxml-devel systemd-devel portaudio-devel libsndfile-devel \
gtest-devel sqlite-devel rapidjson-devel
Then use whichever build method you prefer.
IDEs
Visual Studio Code
Visual Studio Code provides very decent support for C development. Install the language support for C, cmake and Git and open the root folder of the OpenCPN source tree.
Eclipse
The current version has native support for cmake projects.
It is thus possible to just create a new CMake project based on current
sources out of the box. There is thus no need to use the
unmaintained cmake -G "Eclipse CDT4 - Unix Makefiles" ../
cmake
project generation.
However, this version suffers from https://bugs.eclipse.org/bugs/show_bug.cgi?id=400073 which makes it impossible to index the sources. Without indexing, eclipse does not add that much value.
KDevelop
Current version 5.6.2 has native support for CMake project. There
is thus no need to use the unmaintained
cmake -G "KDevelop3 - Unix Makefiles" ../
cmake project generation
tools.
CLion
The CLion IDE is currently used by some of the core project developers with good results.
CLion is commercial software, but are giving out free licenses for open source development in certain cases.
wxFormBuilder
Initially, many of the dialogs was developed using wxFormBuilder. However, the sources has since long been patched "manually" and it is not possible to maintain them using this tool which basically has been abandoned in the project.
Running inside an IDE
In order to be able to run OpenCPN from inside the IDE installed data needs to be copied to the build/ folder according to
$ cd build
$ for d in gshhs s57data tcdata; do; cp -ar ../data/$d .; done
$ mkdir uidata
$ cp ../src/bitmaps/*.xml ../src/bitmaps/*.png ../src/bitmaps/*.svg uidata
$ cp ../data/authors.html ../data/license.html .
opencpn should be run with the -p options which sets it into 'portable' mode and therefore looks in the location the 'opencpn' executable is run from, i.e. the 'build' directory.
Creating a working IDE setup is somewhat complex, and the details varies between different IDEs.