IMP logo
IMP Manual  for IMP version 2.10.1
cmake_config.md
1 CMake configuration options {#cmake_config}
2 ===========================
3 
4 [TOC]
5 
6 # Building with CMake {#cmake_building}
7 
8 We use [CMake](https://cmake.org) to configure the %IMP build when
9 [building from source](@ref installation_compilation).
10 
11 There are two different ways to configure with `cmake`; one is to run `cmake`
12 in a fresh directory passing some options on the command line, and the other
13 is to run `ccmake` and use its editor to change options. For both, assume you
14 are in a directory called `debug` and the %IMP source is in a directory at
15 `../imp`. We are using the default of makefiles for the actual building.
16 
17 # Configuring with cmake command line options {#cmake_cmdline}
18 
19 To configure and build as simply as possible do
20 
21  cmake ../imp
22  make -j8
23 
24 To make a debug build of %IMP with the `cgal` and `membrane` modules disabled
25 and `core` compiled in per-cpp mode, and to use
26 [Ninja](https://ninja-build.org/) instead of `make` as your build
27 command do:
28 
29  cmake ../imp -DCMAKE_BUILD_TYPE=Debug -G Ninja -DIMP_DISABLED_MODULES=cgal:membrane -DIMP_PER_CPP_COMPILATION=core
30  ninja -j8
31 
32 # Configuring using ccmake {#ccmake_config}
33 1. Run `ccmake ../imp`
34 You can then look through the various options available.
35 2. If you want a debug build, set `CMAKE_BUILD_TYPE` to `Debug`
36 3. Tell cmake to configure (hit `c`) and generate (hit `g`)
37 4. `make -j8`
38 
39 You can run `ccmake` after running `cmake` as above if you want, too.
40 Running it never hurts.
41 
42 # Further configuration options {#cmake_further}
43 
44 You can use [Ninja](https://ninja-build.org/)
45 instead if it is available by passing `-G Ninja` to the `(c)cmake` call.
46 That is highly recommended when it is available.
47 
48 Various aspects of %IMP build behavior can be controlled via variables. These can be set interactively using `ccmake` (eg `ccmake ../imp`) or by passing them with `-D` in a call to `cmake`. Key ones include:
49 - `IMP_DISABLED_MODULES`: A colon-separated list of disabled modules.
50 - `IMP_MAX_CHECKS`: One of `NONE`, `USAGE`, `INTERNAL` to control what check levels will be supported.
51 - `IMP_MAX_LOG`: One of `SILENT`, `PROGRESS`, `TERSE`, `VERBOSE` to control what log levels are supported.
52 - `IMP_PER_CPP_COMPILATION`: A colon-separated list of modules to build one .cpp at a time.
53 - `CMAKE_BUILD_TYPE`: one of `Debug` or `Release`.
54 
55 There also are a [variety of standard cmake options](https://gitlab.kitware.com/cmake/community/wikis/doc/cmake/Useful-Variables)
56 which control the build. For example:
57 - `CMAKE_INCLUDE_PATH` and `CMAKE_LIBRARY_PATH` control the paths CMake searches
58  in to locate %IMP prerequisite libraries. If your libraries are installed in
59  non-standard locations, you can set these variables to help CMake find them.
60  For example, on a 32-bit RHEL5 system, which has both Boost and HDF5 in
61  non-standard locations, we use
62 
63  -DCMAKE_INCLUDE_PATH="/usr/include/boost141;/usr/include/hdf518/" -DCMAKE_LIBRARY_PATH="/usr/lib/boost141;/usr/lib/hdf518"
64 
65 - `CMAKE_INSTALL_PREFIX` should be set if you want to install %IMP in a
66  non-standard location.
67 
68 # Workarounds for common CMake issues {#cmake_issues}
69 
70 ## Python binary/header mismatch {#cmake_python}
71 
72 In order to build %IMP Python extensions, CMake needs to find the Python header
73 and library files that match the `python` binary. If you have multiple versions
74 of Python installed (for example on a Mac with [Homebrew](https://brew.sh/)),
75 it might find headers for one version and the binary for another. This can
76 be worked around by explicitly telling CMake where your Python library and
77 headers are by setting the `PYTHON_LIBRARY` and `PYTHON_INCLUDE_DIR` CMake
78 variables.
79 
80 For example, on a Mac with Homebrew, where `python` is Homebrew's
81 `/usr/local/bin/python`, CMake will often find Apple's Python headers. This
82 can be resolved by telling CMake where the Homebrew Python headers and library
83 are, by addinng to your CMake invocation something like
84 `-DPYTHON_LIBRARY=/usr/local/opt/python@2/Frameworks/Python.framework/Versions/Current/lib/libpython2.7.dylib -DPYTHON_INCLUDE_DIR=/usr/local/opt/python@2/Frameworks/Python.framework/Versions/Current/Headers`
85 
86 ## CMake reports that it found a dependency but then reports failed {#cmake_compile}
87 
88 For each dependency CMake will first try to find the header and library
89 files for that dependency, reporting success if it finds them. Next, it will
90 often try to build a small C or C++ test program that uses those headers
91 and libraries. If this fails the dependency cannot be used (and CMake will,
92 somewhat confusing, report that the dependency was first found and then not
93 found). To fix issues like this, check the CMake error log in
94 `CMakeFiles/CMakeError.log` to see what failed. In some cases this can be
95 fixed by modifying the flags passed to the C or C++ compiler. For example,
96 recent versions of [Protobuf](https://developers.google.com/protocol-buffers/)
97 fail on some systems because they require C++11 support, and this can be
98 fixed by adding to your CMake invocation
99 `-DCMAKE_CXX_FLAGS="-std=c++11"`
100 
101 ## Wrong version of helper binaries found {#cmake_path}
102 
103 Note also that CMake searches in the system path (`PATH` environment variable)
104 for command line tools such as `python` and `swig`. Thus, if you have multiple
105 versions of tools (e.g. `/usr/bin/swig` and `/usr/local/bin/swig`) make sure
106 the `PATH` variable is set correctly so that the right tool is found *before*
107 you run CMake. You may need to make symlinks or copies to help it out if your
108 binaries are named oddly; for example on a RHEL5 system we need to force CMake
109 to use `/usr/bin/python2.6` rather than `/usr/bin/python` (which is Python 2.4,
110 which is too old to work with %IMP) by doing something like:
111 
112  mkdir bin
113  ln -sf /usr/bin/python26 bin/python
114  PATH=`pwd`/bin:$PATH