6.6 KiB
CMake
Integration
You can use the nlohmann_json::nlohmann_json
interface target in CMake. This target populates the appropriate usage
requirements for INTERFACE_INCLUDE_DIRECTORIES
to point to the appropriate include directories and INTERFACE_COMPILE_FEATURES
for the necessary C++11 flags.
External
To use this library from a CMake project, you can locate it directly with find_package()
and use the namespaced imported target from the generated package configuration:
!!! example
```cmake title="CMakeLists.txt"
cmake_minimum_required(VERSION 3.5)
project(ExampleProject LANGUAGES CXX)
find_package(nlohmann_json 3.12.0 REQUIRED)
add_executable(example example.cpp)
target_link_libraries(example PRIVATE nlohmann_json::nlohmann_json)
```
The package configuration file, nlohmann_jsonConfig.cmake
, can be used either from an install tree or directly out of
the build tree.
Embedded
To embed the library directly into an existing CMake project, place the entire source tree in a subdirectory and call
add_subdirectory()
in your CMakeLists.txt
file.
!!! example
```cmake title="CMakeLists.txt"
cmake_minimum_required(VERSION 3.5)
project(ExampleProject LANGUAGES CXX)
# If you only include this third party in PRIVATE source files, you do not need to install it
# when your main project gets installed.
set(JSON_Install OFF CACHE INTERNAL "")
add_subdirectory(nlohmann_json)
add_executable(example example.cpp)
target_link_libraries(example PRIVATE nlohmann_json::nlohmann_json)
```
!!! note
Do not use `#!cmake include(nlohmann_json/CMakeLists.txt)`, since that carries with it unintended consequences that
will break the build. It is generally discouraged (although not necessarily well documented as such) to use
`#!cmake include(...)` for pulling in other CMake projects anyways.
Supporting Both
To allow your project to support either an externally supplied or an embedded JSON library, you can use a pattern akin to the following.
!!! example
```cmake title="CMakeLists.txt"
project(ExampleProject LANGUAGES CXX)
option(EXAMPLE_USE_EXTERNAL_JSON "Use an external JSON library" OFF)
add_subdirectory(thirdparty)
add_executable(example example.cpp)
# Note that the namespaced target will always be available regardless of the import method
target_link_libraries(example PRIVATE nlohmann_json::nlohmann_json)
```
```cmake title="thirdparty/CMakeLists.txt"
if(EXAMPLE_USE_EXTERNAL_JSON)
find_package(nlohmann_json 3.12.0 REQUIRED)
else()
set(JSON_BuildTests OFF CACHE INTERNAL "")
add_subdirectory(nlohmann_json)
endif()
```
`thirdparty/nlohmann_json` is then a complete copy of this source tree.
FetchContent
Since CMake v3.11, FetchContent can be used to automatically download a release as a dependency at configure time.
!!! example
```cmake title="CMakeLists.txt"
cmake_minimum_required(VERSION 3.11)
project(ExampleProject LANGUAGES CXX)
include(FetchContent)
FetchContent_Declare(json URL https://github.com/nlohmann/json/releases/download/v3.12.0/json.tar.xz)
FetchContent_MakeAvailable(json)
add_executable(example example.cpp)
target_link_libraries(example PRIVATE nlohmann_json::nlohmann_json)
```
!!! Note
It is recommended to use the URL approach described above which is supported as of version 3.10.0. It is also
possible to pass the Git repository like
```cmake
FetchContent_Declare(json
GIT_REPOSITORY https://github.com/nlohmann/json
GIT_TAG v3.12.0
)
```
However, the repository <https://github.com/nlohmann/json> download size is quite large.
CMake Options
JSON_BuildTests
Build the unit tests when BUILD_TESTING
is enabled. This option is ON
by default if the library's CMake project is the top project. That is, when integrating the library as described above, the test suite is not built unless explicitly switched on with this option.
JSON_CI
Enable CI build targets. The exact targets are used during the several CI steps and are subject to change without notice. This option is OFF
by default.
JSON_Diagnostics
Enable extended diagnostic messages by defining macro JSON_DIAGNOSTICS
. This option is OFF
by default.
JSON_Diagnostic_Positions
Enable position diagnostics by defining macro JSON_DIAGNOSTIC_POSITIONS
. This option is OFF
by default.
JSON_DisableEnumSerialization
Disable default enum
serialization by defining the macro
JSON_DISABLE_ENUM_SERIALIZATION
. This option is OFF
by default.
JSON_FastTests
Skip expensive/slow test suites. This option is OFF
by default. Depends on JSON_BuildTests
.
JSON_GlobalUDLs
Place user-defined string literals in the global namespace by defining the macro
JSON_USE_GLOBAL_UDLS
. This option is OFF
by default.
JSON_ImplicitConversions
Enable implicit conversions by defining macro JSON_USE_IMPLICIT_CONVERSIONS
. This option is ON
by default.
JSON_Install
Install CMake targets during install step. This option is ON
by default if the library's CMake project is the top project.
JSON_LegacyDiscardedValueComparison
Enable the (incorrect) legacy comparison behavior of discarded JSON values by defining macro JSON_USE_LEGACY_DISCARDED_VALUE_COMPARISON
. This option is OFF
by default.
JSON_MultipleHeaders
Use the non-amalgamated version of the library. This option is OFF
by default.
JSON_SystemInclude
Treat the library headers like system headers (i.e., adding SYSTEM
to the target_include_directories
call) to check for this library by tools like Clang-Tidy. This option is OFF
by default.
JSON_Valgrind
Execute the test suite with Valgrind. This option is OFF
by default. Depends on JSON_BuildTests
.