The deal.II README file gives an overview over the basics of configuring and building the deal.II library. This page provides more details about using the deal.II CMake build system.
      When configuring deal.II by
      running cmake, the cmake program
      creates a cache in the current (build) directory that contains
      the values of all (cached) variables that had previously been passed
      as command line arguments, been found through running tests,
      or had otherwise been set.
    
      On a subsequent call to cmake, e.g. to change the
      configuration or due to a callback from the build system because some
      configuration file (the CMakeLists.txt and
      cmake/<..>.cmake files) has changed,
      cmake will only run whatever tests are
      necessary; values for variables that are already in the cache
      are not re-evaluated. This means that calling cmake
      a second time without any arguments at all in a situation like this
mkdir build cd build cmake -DCMAKE_INSTALL_PREFIX=/path/install/dir ../deal.II cmake ../deal.IIhas no effect: In particular, the
CMAKE_INSTALL_PREFIX
      specified on the first invocation of cmake is
      cached and therefore still valid after the second invocation
      of cmake This is different from the way the
      autoconf/configure mechanism worked.
    
    The cache has an important reason: one can modify all sort of configuration parameters and thereby interact with the configuration system in rather powerful (and, possibly, destructive) ways. For example, the following commands
mkdir build cd build cmake ../deal.II ccmakefirst configure a bare-bone setup and then call the
ccmake program -- an interactive editor for the
      cached variables. Similarly,
mkdir build cd build cmake ../deal.II cmake -D<OPTION>=<VALUE> [...] ../deal.IIsets a variable the second time around without destroying all the configuration that has happened the first time around. Likewise,
mkdir build cd build cmake ../deal.II cmake -DDEAL_II_WITH_METIS=OFF . cmake -DDEAL_II_WITH_TRILINOS=ON -DTRILINOS_DIR=/path/to/trilinos .switches off support for the METIS library that may have been automatically detected during the first invocation of
cmake and enables support for Trilinos by enabling
      DEAL_II_WITH_TRILINOS and setting
      TRILINOS_DIR.
    
    
    A cached variable can be set on the command line via
cmake -D<VARIABLE>=<VALUE> .Cached variables can be removed from the cache via
cmake -U<VARIABLE> .It is possible to use
-U together with a globbing
      expression. E.g. to remove the current feature configuration and
      rerun the autodetection one can invoke
cmake -U"DEAL_II_WITH_*" .
ccmake and special build targets 
      A very convenient way to alter the configuration is to use the graphical
      user interface ccmake to the
      variables cmake stores upon running. It can be invoked via
ccmake .or by
make edit_cacheA reconfiguration (without editing the cache) can be run via
make rebuild_cache
      All variables starting with WITH_ will be automatically
      renamed to DEAL_II_WITH_*. So, it suffices to specify
cmake -DWITH_MPI=ON <...>instead of the longer
cmake -DDEAL_II_WITH_MPI=ON <...>The same holds for all variables starting with
COMPONENT_
      and all individual component names:
      DOCUMENTATION, and EXAMPLES
      (which will be expanded to the full DEAL_II_COMPONENT_*
      variable name).
    
    
    This section provides some further details and advanced topics with respect to configuration and building that is not covered in the README.
 The current list of primary build targets can be queried via
    make info:
### # # The following targets are available (invoke by $ make <target>): # # all - compile the library and all enabled components # clean - remove all generated files # install - install into CMAKE_INSTALL_PREFIX # # info - print this help message # help - print a list of valid top level targets # # edit_cache - run ccmake for changing (cached) configuration variables # and reruns the configure and generate phases of CMake # rebuild_cache - rerun the configure and generate phases of CMake # # compat_files - build and install component 'compat_files' # documentation - build and install component 'documentation' # examples - build and install component 'examples' # library - build and install component 'library' # package - build binary package # # test - run a minimal set of tests # # setup_tests - set up testsuite subprojects # prune_tests - remove all testsuite subprojects # ###
      A configuration run of cmake (or ccmake)
      writes a short summary of the current configuration into
      CMAKE_BUILD_DIR/summary.log:
### # # deal.II configuration: # CMAKE_BUILD_TYPE: DebugRelease # BUILD_SHARED_LIBS: ON # CMAKE_INSTALL_PREFIX: /tmp/deal.II/install # CMAKE_SOURCE_DIR: /tmp/deal.II/deal.II (Version 8.1.pre) # CMAKE_BINARY_DIR: /tmp/deal.II/build # CMAKE_CXX_COMPILER: GNU 4.7.3 on platform Linux x86_64 # /usr/bin/c++ # # Configured Features (DEAL_II_ALLOW_BUNDLED = ON, DEAL_II_ALLOW_AUTODETECTION = ON): # ( DEAL_II_WITH_64BIT_INDICES = OFF ) # DEAL_II_WITH_ARPACK set up with external dependencies # DEAL_II_WITH_BOOST set up with external dependencies # [...] # # Component configuration: # ( DEAL_II_COMPONENT_DOCUMENTATION = OFF ) # DEAL_II_COMPONENT_EXAMPLES # # Detailed information (compiler flags, feature configuration) can be found in detailed.log # # Run $ make info to print a help message with a list of top level targets # ###This summary is also printed at the end of the configuration phase. It tells you about build and install directory locations, feature configuration (whether a feature is enabled with external/internal dependencies, disabled or forced) and component configuration. A more detailed version can be found in
CMAKE_BUILD_DIR/detailed.log that also includes detailed
      information about feature configuration, e.g.
# DEAL_II_WITH_BOOST set up with external dependencies # BOOST_VERSION = 1.61.0 # BOOST_DIR = # Boost_INCLUDE_DIRS = /usr/include # Boost_LIBRARIES = /usr/lib64/libboost_serialization-mt.so;/usr/lib64/libboost_system-mt.so; # [...]If this information is not sufficient, you might want to have a look at the following files in
CMAKE_BUILD_DIR
      CMakeCache.txt: The file CMake stores its cached
        variables in. Do not change directly.
        include/deal.II/base/config.h: The generated
        config.h file
        lib/cmake/deal.II/deal.IIConfig.cmake: The project
        configuration file for external projects.
      
      A so called out-of-source build is a setup where the build directory
      (the directory containing intermediate and generated files) is
      different from the source directory (the directory containing the
      source code). With CMake an out-of-source build is set up by invoking
      cmake (or ccmake) from the designated build
      directory, so for example (a build directory under the source
      directory):
$ mkdir build $ cd build $ cmake ..The big advantage is that source files and intermediate files are strictly separated (highly desired for version control) and that you can have multiple build directories (with different configuration) at the same time.
Note: However, under rare occasions an in-source build might be useful or needed , so it is supported
$ cmake .But we highly discourage it!
Cmake is a Makefile Generator. This allows to switch the generator that is used to something different. If you for example want to automatically generate an Eclipse project of deal.II, you can run
$ cmake -G"Eclipse CDT4 - Unix Makefiles" [...]and load up the build directory as a project directly into Eclipse. Have a look at the Wiki's Eclipse page for more information.
An interesting alternative to (GNU) Make might also be Ninja. Configure via
$ cmake -GNinja [...]and run
ninja instead of make.
    
    
    
      It is not necessary to install the library in order to use deal.II.
      Invoking the all or library target will
      compile the library and set up all necessary configuration in the
      build directory so that external projects can directly use it.
      However, we strongly recommend to proceed in the way explained in the
      README and install the
      library to a designated install directory (different from source and
      build directory).
    
      For installing the library it is necessary to set the CMake variable
      CMAKE_INSTALL_PREFIX to the designated install
      directory. You can do this by invoking cmake together
      with -DCMAKE_INSTALL_PREFIX=<...> or by invoking
      ccmake.
    
Note: When you don't install deal.II to an install directory and use it directly from a build directory, both, the build and source directories have to be kept.
Note: It is not necessary for the source, build and or install directory to be different. All combinations are supported.
If you want to only generate, compile and install a specific component (most notably the documentation) you can use one of the following top level targets:
documentation - builds and installs the 'documentation' component examples - builds and installs the 'examples' component library - builds and installs the 'library' component
The various configuration options of the deal.II library are organized in three categories: feature, component, and build/install configuration.
      deal.II provides (optional) interfaces to quite a
      number of external libraries as well as multiple versions
      of C++. All of these options are represented
      by cmake variables that may be set to either ON
      or OFF.
      By default, deal.II's CMake build scripts
      will attempt to find the newest C++ version available by
      checking which language version flags work with the detected compiler. For
      example: if CMake detects GCC 5.1 or Clang
      3.6, deal.II will be compiled
      in C++14 mode unless C++14 support is explicitly
      disabled. Another example: if DEAL_II_WITH_CXX14=ON is passed
      to CMake, then deal.II will check if the
      compiler supports enough of the C++14 standard to enable
      the C++14-specific parts of the library. The configuration
      process will fail if a feature flag is passed in that cannot be supported.
      The remaining flags are set to ON if an external package is
      found or to OFF otherwise. By explicitly setting it to off
      either on the command line or using ccmake, you can
      prevent deal.II from using an external package, even if
      it is found.
    
Specifically, the following variables exist (the list may grow over time, but names are standardized):
DEAL_II_WITH_64BIT_INDICES DEAL_II_WITH_ADOLC DEAL_II_WITH_ARPACK DEAL_II_WITH_ASSIMP DEAL_II_WITH_BOOST DEAL_II_WITH_COMPLEX_VALUES DEAL_II_WITH_CUDA DEAL_II_WITH_CXX14 DEAL_II_WITH_CXX17 DEAL_II_WITH_GINKGO DEAL_II_WITH_GMSH DEAL_II_WITH_GSL DEAL_II_WITH_HDF5 DEAL_II_WITH_LAPACK DEAL_II_WITH_METIS DEAL_II_WITH_MPI DEAL_II_WITH_MUPARSER DEAL_II_WITH_NANOFLANN DEAL_II_WITH_NETCDF DEAL_II_WITH_OPENCASCADE DEAL_II_WITH_P4EST DEAL_II_WITH_PETSC DEAL_II_WITH_SCALAPACK DEAL_II_WITH_SLEPC DEAL_II_WITH_SUNDIALS DEAL_II_WITH_SYMENGINE DEAL_II_WITH_THREADS DEAL_II_WITH_TRILINOS DEAL_II_WITH_UMFPACK DEAL_II_WITH_ZLIBThey all have standard meaning with the exception of two:
DEAL_II_WITH_BOOST is always ON
          since BOOST is a mandatory build time dependency.
        DEAL_II_WITH_THREADS enables threading support
          with the help of the Threading Building Blocks (TBB) library.
      
      If enabled, each of the features above will usually add one or
      more dependencies to external or 'bundled' (i.e. bundled with
      deal.II and residing under bundled/)
      libraries.
    
Additionally, the variable
DEAL_II_CXX_VERSION_FLAGmay be set to specify the
C++ language version flag passed to
      the compiler.
    
    There are some options to determine the behavior of the dependency resolution.
            DEAL_II_ALLOW_BUNDLED:
          
            If set to ON external libraries still have
            precedence. But if there is no external library the bundled
            library will be used.
            If set to OFF bundled libraries will not be
            used and the dependency resolution will fail if there is no
            external library.
          
            DEAL_II_FORCE_BUNDLED_(BOOST|MUPARSER|THREADS|UMFPACK):
          
            Forces the use of the bundled library regardless whether
            DEAL_II_ALLOW_BUNDLED is set to OFF
            or an external library is found.
          
DEAL_II_ALLOW_BUNDLED, as well as every
          DEAL_II_FORCE_BUNDLED_<library>
          have to be set to OFF.  Conversely,
          DEAL_II_FORCE_BUNDLED_<library>=ON
          will not automatically enable the corresponding
          DEAL_II_WITH_<feature> toggle. This has to be
          set separately.
      
      As long as DEAL_II_WITH_<FEATURE> is
      not explicitly set to ON or OFF
      in the cache it will be automatically configured. If a toggle
      DEAL_II_WITH_<FEATURE> is defined it won't
      be altered.
      This means that the very first configuration run will set
      all available features to ON and the rest
      to OFF. In all subsequent configuration steps
      DEAL_II_WITH_<FEATURE> has to be changed by hand,
      see the previous section.
    
This behavior can be controlled via several variables:
DEAL_II_ALLOW_AUTODETECTION=OFF: This will
          disable any autoconfiguration by setting undefined
          DEAL_II_WITH_<FEATURE> toggles to
          OFF.
	DEAL_II_FORCE_AUTODETECTION=ON: This will
          force the reconfiguration of every feature by undefining
          DEAL_II_WITH_<FEATURE> prior to
          configuration, effectively overwriting any supplied or
          cached value.
      External libraries will be searched depending on hints in the following order:
            Paths specified via CMAKE_PREFIX_PATH take
            precedence, e.g. with
make -DCMAKE_PREFIX_PATH=~/workspace/local ../deal.IIlibraries from
~/workspace/local will be
	    preferred for dependency resolution.
	  
	
	    Hints given by <library>_DIR via command
            line or environment for some libraries:
make -DP4EST_DIR=~/workspace/p4est-install/ ../deal.IIor
export P4EST_DIR=~/workspace/p4est-install/ cmake ../deal.IIwhere
-D<library>_DIR takes precedence
            over environment.
	  
	  Currently, the following variables will be considered:
ARPACK_DIR,
BOOST_DIR,
HDF5_DIR,
LAPACK_DIR (and BLAS_DIR),
METIS_DIR,
MUPARSER_DIR,
P4EST_DIR (and SC_DIR),
PETSC_DIR and PETSC_ARCH (forming ${PETSC_DIR}/${PETSC_ARCH}),
SCALAPACK_DIR (and optionally BLACS_DIR)
SLEPC_DIR (forming ${SLEPC_DIR}/${PETSC_ARCH}),
TBB_DIR,
TRILINOS_DIR,
UMFPACK_DIR and SUITESPARSE_DIR (AMD_DIR, CHOLMOD_DIR, COLAMD_DIR, SUITESPARSECONFIG_DIR)
	  
	The default system locations for libraries and includes.
      Alternatively, cached variables set by the
      Find<Module> mechanism may be set,
      hinted or overwritten directly (variable names are highly
      dependent on the actual library). You can get a list via
make edit_cacheand entering advanced configuration mode by pressing [t]. Variables that could not be determined are suffixed with
-NOTFOUND and may be set by hand.
    
    Caveat: if you have a set of standard libraries in the default
    location, say /usr/lib and a set of
    private versions of the same libraries, for instance because you
    need different revisions sometimes, in your own library directory,
    you may receive an error message of the form:
CMake Warning at source/CMakeLists.txt:65 (ADD_LIBRARY):
  Cannot generate a safe runtime search path for target deal_II.g because
  files in some directories may conflict with libraries in implicit
  directories:
    runtime library [libtbb.so.2] in /usr/lib may be hidden by files in:
      /my/private/lib
  Some of these libraries may not be found correctly.
This is not a problem of CMake or deal.II, but rather a general Linux problem. In order to fix this, you have two options:
Warning: Do not do this unless absolutely necessary!
      It is possible to override the CMake find mechanism for external
      libraries manually. This is useful if a non standard library (e.g.
      BLAS or LAPACK) should be used but cannot be found by the
      FIND_PACKAGE(...) mechanism.
      In this case you can set by hand:
cmake -D<feature>_FOUND=true \
      -D<feature>_LIBRARIES="library;and;complete;link;interface" \
    ( -D<feature>_INCLUDE_DIRS="semicolon;separated;list;of;include;dirs" \
      -D<feature>_LINKER_FLAGS="..." \
      -D<feature>_<...depending on library...> )
      The first define ensures that cmake does not
      call the corresponding Find<lib>.cmake module.
      Therefore, all information that would be otherwise exported by the
      module must be specified by hand. (See the
      config.sample file for a
      detailed list of valid variables per feature.)
    
    An example of use is to select BLAS and LAPACK manually from a PETSc configuration: (Here, these libraries have been compiled with the gfortran compiler and need its support library):
cmake -DLAPACK_FOUND=true \
      -DLAPACK_LIBRARIES="/tmp/petsc-3.3-p6/arch-linux2-c-debug/lib/libflapack.a;/tmp/petsc-3.3-p6/arch-linux2-c-debug/lib/libfblas.a" \
      -DLAPACK_LINKER_FLAGS="-lgfortran -lm"
      You can set these values on the command line, with ccmake
      or by providing an initial cache file, see
      advanced setup section.
      Possible manual overrides are explained in detail in the
      in the config.sample file.
    
    
    The following options control which components of deal.II will be configured, built and installed:
            DEAL_II_COMPONENT_DOCUMENTATION
            (default OFF):
          
            Enable configuration, build and installation of the
            documentation including all of the tutorial programs and the
            doxygen-generated manual.  This adds a
            component documentation to the build system.
          
            DEAL_II_COMPONENT_EXAMPLES
            (default ON):
          
            Enable configuration and installation of the example steps (but
            not generate the documentation for the tutorial steps).
            This adds a component examples to the build system.
          
      The cmake variable CMAKE_BUILD_TYPE
      controls the type of build. We support Debug,
      Release and DebugRelease mode. Default
      is DebugRelease.
      
cmake the
          flag -DCMAKE_BUILD_TYPE=Debug will produce makefiles
          that compile and install only the debug library
          libdeal_II.g.so.
        cmake the
          flag -DCMAKE_BUILD_TYPE=Release result in only
          compiling and installing the optimized library libdeal_II.so.
        cmake the
          flag -DCMAKE_BUILD_TYPE=DebugRelease will build and
          install both libraries.
      The build can be further controlled by the following variables:
DEAL_II_ALLOW_PLATFORM_INTROSPECTION: If set
          (default), deal.II will perform platform
          introspection for the given CPU.
	BUILD_SHARED_LIBS: If set (default),
          deal.II will be linked as a shared library
        DEAL_II_PREFER_STATIC_LIBS (defaults to off): If set
        to true, static archives will be preferred over dynamic libraries when
        searching for features and corresponding link interface.
	DEAL_II_STATIC_EXECUTABLE (defaults to off):
          If set to true, deal.II will be configured in
          a way to provide a link interface that is suitable for static
          linkage of executables. Enabling this option forces
          BUILD_SHARED_LIBS=OFF and
          DEAL_II_PREFER_STATIC_LIBS=ON.
	CMAKE_INSTALL_RPATH_USE_LINK_PATH: If set
	  (default), the deal.II library will be
	  installed with rpaths  set for all libraries outside of the
	  system search paths
      CMAKE_(C|CXX|Fortran)_COMPILER:
CC=mpicc CXX=mpicxx FC=mpif90 cmake <...> cmake -DCMAKE_C_COMPILER="mpicc" -DCMAKE_CXX_COMPILER="mpicxx" -DCMAKE_Fortran_COMPILER="mpif90" <...>Please note that
cmake.
        
      deal.II will configure sensible default CXXFLAGS and
      LDFLAGS depending on platform, compiler and build
      target. There are two options to override this behaviour:
      
DEAL_II_CXX_FLAGS - used during all builds DEAL_II_CXX_FLAGS_DEBUG - additional flags for the debug library DEAL_II_CXX_FLAGS_RELEASE - additional flags for the release library DEAL_II_LINKER_FLAGS - used during all builds DEAL_II_LINKER_FLAGS_DEBUG - additional flags for the debug library DEAL_II_LINKER_FLAGS_RELEASE - additional flags for the release libraryThe content of the cached variables will be preserved and added to the end of the default compiler flags, hence providing the possibility for overriding a flag. E.g.:
-Wsign-compare, set by the build system, can be
	  overwritten by specifying:
cmake -DDEAL_II_CXX_FLAGS="-Wno-sign-compare" <...>
CFLAGS,
          CXXFLAGS, or LDFLAGS environment. These
          variables will also be appended after the default compiler flags
          (but before the corresponding cached variables).
	-D DEAL_II_SETUP_DEFAULT_COMPILER_FLAGS=OFF.
	  Beware of the fact that certain features
	  may still pull in necessary compiler flags.
        -D DEAL_II_SETUP_COVERAGE=ON.
      
      the location, where the deal.II library will be
      installed when invoking make install to is set with the
      help of
CMAKE_INSTALL_PREFIXThe default directory structure is:
${CMAKE_INSTALL_PREFIX}/
    bin
    include
    lib${LIB_SUFFIX}
    lib${LIB_SUFFIX}/cmake/deal.II
    share/deal.II/
    ./
    doc
    examples
      
    
    The default directory structure can be changed by setting the following variables:
DEAL_II_EXECUTABLE_RELDIR       default: bin
DEAL_II_INCLUDE_RELDIR          default: include
DEAL_II_LIBRARY_RELDIR          default: lib${LIB_SUFFIX}
DEAL_II_PROJECT_CONFIG_RELDIR   default: lib${LIB_SUFFIX}/cmake/deal.II
DEAL_II_SHARE_RELDIR            default: share/deal.II/
DEAL_II_DOCREADME_RELDIR        default: ./
DEAL_II_DOCHTML_RELDIR          default: doc
DEAL_II_EXAMPLES_RELDIR         default: examples
    
    
    A sample configuration file for preloading the CMake cache with
$ cmake -C config.sample <...>can be found here. This sample configuration covers all options mentioned in this documentation as well as some advanced aspects in feature configuration.
      While developing the library itself, it is often desirable
      to only compile certain parts. The build system generated by
      cmake allows to build specific, selected targets.
      A common scenario is that you only want to build debug or optimized
      libraries. This can be achieved using the following commands in
      the build directory:
make deal_II.g # only debug library make deal_II # only release (optimized) library make all # both make obj_grid_release # all objects in ./source/grid in release configuration
For a complete list of possible targets that allow even finer-grained control, do
make help
It is frequently useful to be able to see what a particular command does. In that case, use the following:
make deal_II.g VERBOSE=ONThis will show, for every command executed, the exact command line with which it was invoked, including compiler arguments, etc. Every command
cmake executes starts with
      a cd command to change the current directory
      appropriately so that the command line can be copied and executed
      from anywhere within the build directory.
    
    
      Note: Just because you can call make deal_II.g to
      only compile the debug version does not mean that a
      subsequent make install will only install the debug
      library. Rather, make install will still want to have both
      libraries up to date and will therefore invoke make all
      automatically. To restrict builds in such a way that only one library
      will be installed, see configuration
      and installation sections.