-
Notifications
You must be signed in to change notification settings - Fork 77
Build System
Building SWMM requires CMake
-- an industry standard build system for C/C++ projects that supports Windows, Linux, and MacOS builds. It can be used to generate platform native build systems for your compiler of choice. CMake
automatically detects the platform it is running on and generates the appropriate build system for the platform default compiler. Different generators can also be specified. To install or learn more about CMake
use the links immediately below.
CMake Download: https://cmake.org/download/
CMake Documentation: https://cmake.org/documentation/
CMake
is powerful and can be used to customize virtually every aspect of the build process. Unfortunately, it can be difficult to configure. The SWMM project maintains the CMake
build system configuration for the benefit of the developer community and to facilitate Continuous Integration as part of our project quality management plan.
CMake
itself is an executable that gets installed on the build machine. Using it is a two step process. The first step is to run CMake
to generate the build system. The second is to run the build system to generate the software artifacts. Configuration files (CMakeLists.txt
) located in the project root directory and nearly every other folder throughout the project describe the build system configuration for creating each desired build artifact.
A build "artifact" is a discrete build product like a library, an executable, or a bundle of generated documents. Artifacts are the runnable files created when the build system gets executed. The CMakeLists.txt
configuration files found throughout the project are organized so that each artifact is described separately. This makes it easier to create and maintain the configuration files and makes clear the build dependencies within the project.
The most important CMakeLists.txt
file is located in the project root directory, swmm/
. It is the configuration file that gets passed to the CMake
executable when the build system gets generated. It contains settings global to the project and references each subdirectory containing a configuration file defining the overall structure of the project. A map of the build system is provided in Table 1. There are three main build artifacts described in the project -- the output library, the command line executable, and the solver library. The source code for these artifacts is found in the src/
folder.
Table 1: Build System Map
Project Folder | Purpose | Dependencies |
---|---|---|
swmm/ | Global settings, options, add | None |
subdirs, install, and pack | ||
/bindings | Install files | None |
/docs | Generate and install docs | Doxygen |
/src/outfile | Build, install, stage for test | Shared, swmm-output |
/src/run | Build, install, stage for test | swmm5 |
/src/solver | Build, install, stage for test | None |
/tests | Find package, build, and add tests | Boost, swmm5 |
/tests/outfile | Build test | Boost, swmm-output |
/tests/solver | Build tests | Boost, swmm5 |
To build the SWMM library and its command line executable using CMake
, first open a command prompt console window and navigate to the project's root directory. Then enter the following commands:
\> cd swmm
\swmm>cmake -E make_directory build
\swmm>cmake -E chdir build cmake -G "Visual Studio 15 2017" ..
\swmm>cmake --build .\build --config Release --target ALL_BUILD
The commands above can be modified to meet different build requirements. To build 64Bit on Windows substitute the following -G "Visual Studio 15 2017 Win64" ..
, to build in Debug mode substitute --config Debug
, and to build various targets substitute any of the build targets from Table 2 for the --target
command.
Table 2: Build Targets
Build Target | Purpose |
---|---|
ALL_BUILD | Builds all targets associated with the project |
ZERO_CHECK | Runs CMake to regenerate build system |
RUN_TESTS | Runs tests registered with CTest (Req -DBUILD_TESTS=ON) |
INSTALL | Prepare the install directory |
PACKAGE | Run CPack to generate install packaging (zip archive) |
doxygen | Builds Toolkit documentation (Req -DBUILD_DOCS=ON) |
clean | Removes all generated files |
Options are available to further customize a build, see Table 3. For example, the following commands can be used to generate Toolkit documentation provided doxygen
has been installed.
\swmm>cmake -DBUILD_DOCS=ON .\build
\swmm>cmake --build .\build --config Release --target doxygen
Table 3: Build Options
Build Option | Purpose |
---|---|
BUILD_TESTS | Build unit tests |
BUILD_DOCS | Build Toolkit documentation |
BUILD_COVERAGE | Instrument build for coverage |
Build artifacts can be accessed directly from the build\install
folder using the INSTALL
target. The install folder can be automatically packaged using the PACKAGE
target.
\swmm>cmake --build .\build --config Release --target install
\swmm>cmake --build .\build --config Release --target package
The swmm-solver
project can easily be included in another CMake
based project using the target import scripts found in the install\cmake
folder by including the following commands in your project CMakeLists.txt
file.
set(swmm5_DIR "<path to install>/cmake")
find_package(swmm5)