-
Notifications
You must be signed in to change notification settings - Fork 36
/
CMakeLists.txt
102 lines (75 loc) · 3.48 KB
/
CMakeLists.txt
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
cmake_minimum_required(VERSION 3.13)
project(Aether VERSION 0.1.0 LANGUAGES Fortran C CXX)
# Policy settings
if (POLICY CMP0078)
cmake_policy(SET CMP0078 NEW)
endif ()
if(POLICY CMP0086)
cmake_policy(SET CMP0086 NEW)
endif()
get_property(IS_MULTI_CONFIG GLOBAL PROPERTY GENERATOR_IS_MULTI_CONFIG)
list(APPEND CMAKE_MODULE_PATH "${CMAKE_CURRENT_SOURCE_DIR}/cmake")
# Required for creating documentation from restructured text files
find_package(Sphinx)
# Helpful functions
include(miscfunctions)
# Create additional build types
include(buildtypes)
# Mark some variables as advanced hiding them from basic users
tidy_gui()
# Build shared or static library
add_project_config_parameter(BUILD_SHARED ON BOOL "Build shared library (true) or static library (false)")
set(BUILD_SHARED_LIBS ${AETHER_BUILD_SHARED} CACHE INTERNAL "Internalise BUILD_SHARED_LIBS, manipulate via AETHER_BUILD_SHARED" FORCE)
# Set the build type Release, Debug plus more if you define them
if (NOT IS_MULTI_CONFIG)
add_project_config_parameter(BUILD_TYPE Release STRING "Set the build type; [Release], Debug, Pedantic (GNU Fortran only)")
set(CMAKE_BUILD_TYPE ${AETHER_BUILD_TYPE} CACHE INTERNAL "Internalise CMAKE_BUILD_TYPE, manipulate via AETHER_BUILD_TYPE" FORCE)
endif()
# Set whether to build bindings or not, will require SWIG
option(AETHER_BUILD_BINDINGS "Build bindings for ${PROJECT}, will require SWIG" YES)
# Add option for enabling or disabling the tests.
option(AETHER_ENABLE_TESTS "Enable building of the tests." ON)
# Set base install location
add_project_config_parameter(INSTALL_PREFIX ${CMAKE_INSTALL_PREFIX} PATH "Set the base install prefix.")
set(CMAKE_INSTALL_PREFIX ${AETHER_INSTALL_PREFIX} CACHE INTERNAL "Internlaise CMAKE_INSTALL_PREFIX, manipulate via AETHER_INSTALL_PREFIX" FORCE)
mark_as_advanced(AETHER_INSTALL_PREFIX)
# Turn on the ability to create folders to organize projects (.vcproj)
# It creates "CMakePredefinedTargets" folder by default and adds CMake
# defined projects like INSTALL.vcproj and ZERO_CHECK.vcproj
set_property(GLOBAL PROPERTY USE_FOLDERS ON)
# All the source files for the library and bindings are located under this directory.
add_subdirectory(src)
if(AETHER_ENABLE_TESTS)
# Must enable testing at the lowest level in CMake.
enable_testing()
# All the tests for the library are located under this directory.
add_subdirectory(tests)
endif()
# If Sphinx was found we can add some targets for building the documentation.
set(ADDITIONAL_GENERATED_FILES)
if(SPHINX_FOUND)
if(NOT DEFINED SPHINX_THEME)
set(SPHINX_THEME default)
endif()
if(NOT DEFINED SPHINX_THEME_DIR)
set(SPHINX_THEME_DIR)
endif()
# Sphinx cache with pickled ReST documents
set(SPHINX_CACHE_DIR "${CMAKE_CURRENT_BINARY_DIR}/_doctrees")
# HTML output directory
set(SPHINX_HTML_DIR "${CMAKE_CURRENT_BINARY_DIR}/html")
# Sphinx source directory
set(SPHINX_SOURCE_DIR "${CMAKE_CURRENT_SOURCE_DIR}/documentation")
# Add a target 'docs' that will build the documentation inside the build directory on the local computer.
add_custom_target(docs
${SPHINX_EXECUTABLE}
-q -b html
-d "${SPHINX_CACHE_DIR}"
"${SPHINX_SOURCE_DIR}"
"${SPHINX_HTML_DIR}"
WORKING_DIRECTORY "${SPHINX_SOURCE_DIR}"
COMMENT "Building HTML documentation with Sphinx")
# Remove Sphinx generated files when the 'clean' target is used.
list(APPEND ADDITIONAL_GENERATED_FILES html _doctrees)
endif()
set_directory_properties(PROPERTIES ADDITIONAL_MAKE_CLEAN_FILES "${ADDITIONAL_GENERATED_FILES}")