Installing CDPKit

CDPKit can be installed in different ways:

  • By means of an official binary installer package. This is the best approach for most users. It will provide a full-featured stable CDPKit version and pre-built installers are available for most platforms.

  • Build and install from source. This is the best option for users who want the latest-and-greatest features and aren’t afraid of compiling C++ code and/or run brand-new software. This is also needed for users who run an operating system version for which no installer has been provided and for users who wish to contribute to the project.

  • Installation via pip. pip will only install the CDPL Python bindings. This is the best option for users who only want to develop or run Python software that uses CDPL functionality.

Installation via installer package

Installers for macOS (DMG-file, Apple Silicon processors only), Linux x86_64 (self-extracting archive) and Windows 10 (graphical installer based on NSIS) can be downloaded from the Releases page of the CDPKit GitHub repository. These installer packages will provide everything CDPKit has to offer:

  • Command line tools and GUI applications

  • CDPL binaries for dynamic linking

  • CDPL binaries for static linking

  • CDPL C++ header files

  • CDPL Python bindings

  • Python example scripts

  • Offline CDPKit documentation

Installations of CDPKit are self-contained, i.e., after finishing the installation process no additional software packages have to be installed.

Note

After the installation process the PATH environment variable needs to be edited to include the full path to the Bin folder below the CDPKit installation directory. Furthermore, to enable the use of the CDPL Python bindings, the PYTHONPATH environment variable must include the full path to the corresponding Python subfolder.

Installation from source

Build requirements

Compilation of the CDPKit sources requires a properly set up build environment. This includes a C++ compiler toolchain that supports the C++17 standard, the CMake makefile generator, and the development version of several software libraries. The following table provides a complete list of the CDPKit build requirements and dependencies:

Build requirement

Version

Comment

C++17 compliant compiler [1]

-

mandatory

cmake

3.17+

mandatory

Python interpreter

3.6+

mandatory

boost-devel

1.63+

mandatory

boost-python3-devel

1.63+

optional, required for building CDPL Python bindings

python-devel

3.6+

optional, required for building CDPL Python bindings

NumPy

1.17+

optional, recommended to be installed for CDPL Python NumPy-conversion features

Qt5-devel

5.6+

optional, required for building Qt rendering backend and GUI applications

cairo-devel

1.14+

optional, required for building cairo rendering backend

Sphinx

4.5+

optional, required for generating CDPKit documentation pages

sphinx-rtd-theme

1.0.0+

optional, required for generating CDPKit documentation pages

sphinx-inline-tabs

2021.4.11b8+

optional, required for generating CDPKit documentation pages

sphinx-sitemap

2.5.1+

optional, required for generating CDPKit documentation pages

sphinxcontrib-bibtex

2.5.5+

optional, required for generating CDPKit documentation pages

docs-versions-menu

0.5.2+

optional, required for generating CDPKit documentation pages

Doxygen

1.8.5+

optional, required for generating C++ and Python API documentation

Build environment setup

Linux

Package managers on modern Linux systems usually provide all listed software packages in the required minimum versions.

macOS

On macOS (Big Sur is the minimum supported version) the best way to install everything needed for a successful build is to use the Homebrew or MacPorts (recommended) package distributions.

Windows

On Windows (8/10/11) the least error prone way to get started is to set up a MinGW build environment by installing packages from the MSYS2 software distribution. However, the downside heare is that the built CDPL Python bindings will only work with the Python interpreter shipped with MSYS2. In order to make the CDPL Python bindings work with an official Python distribution obtained from https://www.python.org, a build using Microsoft’s Visual C++ compiler (MSVC) toolchain is required.

Recommended sources for the software packages listed above are:

Build system configuration

The configuration and generation of the build system files is performed by the command cmake. In the following <BUILD-DIR> refers to the directory that will contain the CDPKit build ouput and <SOURCE-DIR> refers to the directory hosting the CDPKit source tree. The description of the build steps on Windows depends on whether the build environment is based on MSYS2 (employing the MinGW gcc port as C++ compiler) or utilizes the MSVC toolset.

Open a terminal and execute:

$ mkdir <BUILD-DIR>
$ cd <BUILD-DIR>
$ cmake <SOURCE-DIR>

Open a MSYS2 MinGW 64-bit command prompt and execute:

$ mkdir <BUILD-DIR>
$ cd <BUILD-DIR>
$ cmake <SOURCE-DIR> -G "MinGW Makefiles"

Open a x64 Native Tools Command Promp via the Windows start menu and execute:

> mkdir <BUILD-DIR>
> cd <BUILD-DIR>
> cmake <SOURCE-DIR> -DCMAKE_PREFIX_PATH=/path/to/Qt/installation/subdir/msvc<VER>_64 -D_CAIRO_LIBDIR=/path/to/cairo/lib/dir -D_CAIRO_INCLUDEDIR=/path/to/cairo/include/dir -G "NMake Makefiles"

If cmake is executed as shown above the default build type will be Release. Configuring for a different build type can be achieved via the argument -DCMAKE_BUILD_TYPE=<BUILD-TYPE> on the cmake command line. Possible values of <BUILD-TYPE> are:

  • Debug

  • Releasex

  • RelWithDebInfo

  • MinSizeRel

Compilation

If the build system configuration step proceeded without errors

$ make
$ mingw32-make
> nmake

will start the build process.

Build of HTML documentation

This step is optional and needs to be carried out only if a build of offline CDPKit documentation pages is required or desired. If the documentation should be installed together with the built binaries then this step must be executed before carrying out the installation procedure (see next section). Mandatory for a successful build is the availability of the Sphinx documentation generator plus the listed extensions (see Build requirements). Furthermore, for generating CDPL C++ and Python API-documentation (optional), the program Doxygen has to be installed.

Hint

Sphinx and its extensions can be installed via the Python package installer pip.

If all prerequisites are fulfilled

$ make doc
$ mingw32-make doc
> nmake doc

should successfully build the CDPKit documentation pages which can then be found in <BUILD-DIR>/Doc/html.

Installation of the generated binaries

If the previous steps proceeded without errors

$  make install
$ mingw32-make install
> nmake install

will install CDPKit in a platform specific default directory (Linux: /opt, macOS: /Users/Shared, and Windows: C:\Program Files). A different installation location can be specified by the argument -DCMAKE_INSTALL_PREFIX=<INSTALL-DIR> on the cmake command line (see Build system configuration).

Installation using pip

Note

pip will only install the CDPL Python bindings. This is the recommended option for users who only want to develop or run Python software that uses CDPL functionality.

Installation of the latest binary release

The latest binary release of the CDPL Python bindings deposited on PyPI can be installed by issuing the following command in a terminal session:

$ pip install cdpkit

If no wheel file for the platform (defined by OS, processor architecture and Python version) the command was executed on is available, an on-the-fly build of the CDPKit sources is attempted. This will only proceed without errors if a proper build environment has been set up (see next section).

Installation via a build of the sources

For a successful build of the CDPL Python bindings the information provided in section Installation from source applies also here. However, since a full-featured CDPKit build is not required the list of requirements is a bit shorter:

Build requirement

Version

Comment

C++17 compliant compiler

-

mandatory

Python interpreter

3.6+

mandatory, implicitly fulfilled

boost-devel

1.63+

mandatory

boost-python3-devel

1.63+

mandatary

python-devel

3.6+

mandatory

NumPy

1.17+

optional, will be installed automatically (listed as pip installation requirement)

cairo-devel

1.14+

optional, required for building cairo rendering backend

Option 1: Build the CDPKit sources deposited on PyPI

This will be done automatically if no pre-built binary package is available (see previous section) or can be enforced by adding the argument –no-binary :all::

$ pip install cdpkit --no-binary :all:

Option 2: Installation of the current development version by specifying the GitHub repository URL

$ pip install git+https://github.com/molinfo-vienna/CDPKit.git

Option 3: Installation under specification of a local directory containing the CDPKit sources

Enter (cd) the CDPKit source code folder and then from within the folder run

$ pip install .