mirror of
https://github.com/boostorg/json.git
synced 2025-05-12 06:01:41 +00:00
Refactor CMake support:
* Add VS CMake integration config * add cmake 3.10.0 support * fix compiler and linker flags * disable verbose build output * added cmake policy * Fix source groups * Group folder related settings * Add support for the boost superproject and cmake 3.16 * Remove library headers from executable projects * Fix boost superproject compatibility
This commit is contained in:
parent
61a0691583
commit
bc95b55c35
19
.gitignore
vendored
19
.gitignore
vendored
@ -1,10 +1,13 @@
|
|||||||
bin
|
/bin
|
||||||
bin64
|
/bin64
|
||||||
*.*#
|
|
||||||
temp
|
temp
|
||||||
|
|
||||||
# Because of CMake and VS2017
|
# Emacs
|
||||||
Win32/
|
*#
|
||||||
x64/
|
|
||||||
out/
|
# Vim
|
||||||
.vs/
|
*~
|
||||||
|
|
||||||
|
# Visual Studio
|
||||||
|
/.vs
|
||||||
|
/out
|
||||||
|
165
CMakeLists.txt
165
CMakeLists.txt
@ -7,148 +7,67 @@
|
|||||||
# Official repository: https://github.com/vinniefalco/json
|
# Official repository: https://github.com/vinniefalco/json
|
||||||
#
|
#
|
||||||
|
|
||||||
cmake_minimum_required (VERSION 3.5.1)
|
cmake_minimum_required(VERSION 3.5...3.16)
|
||||||
|
|
||||||
if (POLICY CMP0074)
|
set(BOOST_JSON_VERSION 1)
|
||||||
cmake_policy (SET CMP0074 NEW)
|
if(BOOST_SUPERPROJECT_VERSION)
|
||||||
|
set(BOOST_JSON_VERSION ${BOOST_SUPERPROJECT_VERSION})
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
#-------------------------------------------------------------------------------
|
project(boost_json VERSION ${BOOST_JSON_VERSION} LANGUAGES CXX)
|
||||||
|
|
||||||
function (DoGroupSources curdir rootdir folder)
|
file(GLOB_RECURSE BOOST_JSON_HEADERS CONFIGURE_DEPENDS
|
||||||
file (GLOB children RELATIVE ${PROJECT_SOURCE_DIR}/${curdir} ${PROJECT_SOURCE_DIR}/${curdir}/*)
|
include/boost/*.hpp
|
||||||
foreach (child ${children})
|
include/boost/*.ipp
|
||||||
if (IS_DIRECTORY ${PROJECT_SOURCE_DIR}/${curdir}/${child})
|
include/boost/*.natvis
|
||||||
DoGroupSources (${curdir}/${child} ${rootdir} ${folder})
|
)
|
||||||
elseif (${child} STREQUAL "CMakeLists.txt")
|
|
||||||
source_group("" FILES ${PROJECT_SOURCE_DIR}/${curdir}/${child})
|
|
||||||
else()
|
|
||||||
string (REGEX REPLACE ^${rootdir} ${folder} groupname ${curdir})
|
|
||||||
string (REPLACE "/" "\\" groupname ${groupname})
|
|
||||||
source_group (${groupname} FILES ${PROJECT_SOURCE_DIR}/${curdir}/${child})
|
|
||||||
endif()
|
|
||||||
endforeach()
|
|
||||||
endfunction()
|
|
||||||
|
|
||||||
function (GroupSources curdir folder)
|
set(BOOST_JSON_SOURCES
|
||||||
DoGroupSources (${curdir} ${curdir} ${folder})
|
${CMAKE_CURRENT_SOURCE_DIR}/src/src.cpp
|
||||||
endfunction()
|
)
|
||||||
|
|
||||||
#-------------------------------------------------------------------------------
|
|
||||||
#
|
|
||||||
# JSON
|
|
||||||
#
|
|
||||||
#-------------------------------------------------------------------------------
|
|
||||||
|
|
||||||
project (JSON VERSION 1)
|
|
||||||
|
|
||||||
set_property(GLOBAL PROPERTY USE_FOLDERS ON)
|
set_property(GLOBAL PROPERTY USE_FOLDERS ON)
|
||||||
|
|
||||||
if (MSVC)
|
if(${CMAKE_VERSION} VERSION_GREATER 3.7.2)
|
||||||
set (CMAKE_VERBOSE_MAKEFILE FALSE)
|
source_group(TREE ${CMAKE_CURRENT_SOURCE_DIR}/include/boost PREFIX "" FILES ${BOOST_JSON_HEADERS})
|
||||||
|
source_group(TREE ${CMAKE_CURRENT_SOURCE_DIR}/src PREFIX "" FILES ${BOOST_JSON_SOURCES})
|
||||||
|
endif()
|
||||||
|
|
||||||
add_definitions (
|
add_library(boost_json ${BOOST_JSON_HEADERS} ${BOOST_JSON_SOURCES})
|
||||||
-D_WIN32_WINNT=0x0601
|
add_library(Boost::json ALIAS boost_json)
|
||||||
-D_CRT_SECURE_NO_WARNINGS
|
|
||||||
)
|
|
||||||
|
|
||||||
add_compile_options(
|
target_compile_features(boost_json PUBLIC cxx_constexpr)
|
||||||
/permissive- # strict C++
|
|
||||||
/W4 # enable all warnings
|
|
||||||
/MP # Multi-processor compilation
|
|
||||||
)
|
|
||||||
|
|
||||||
add_link_options(
|
target_include_directories(boost_json PUBLIC include)
|
||||||
/INCREMENTAL:NO
|
|
||||||
)
|
|
||||||
|
|
||||||
set (Boost_USE_STATIC_LIBS ON)
|
target_compile_definitions(boost_json PUBLIC BOOST_JSON_NO_LIB=1)
|
||||||
set (Boost_USE_STATIC_RUNTIME ON)
|
|
||||||
|
|
||||||
set (CMAKE_CXX_FLAGS_DEBUG "${CMAKE_CXX_FLAGS_DEBUG} /MTd")
|
|
||||||
set (CMAKE_CXX_FLAGS_RELEASE "${CMAKE_CXX_FLAGS_RELEASE} /Ob2 /Oi /Ot /GL /MT")
|
|
||||||
set (CMAKE_CXX_FLAGS_RELWITHDEBINFO "${CMAKE_CXX_FLAGS_RELWITHDEBINFO} /Oi /Ot /MT")
|
|
||||||
|
|
||||||
set (CMAKE_EXE_LINKER_FLAGS "${CMAKE_EXE_LINKER_FLAGS} /SAFESEH:NO")
|
|
||||||
set (CMAKE_EXE_LINKER_FLAGS_RELEASE "${CMAKE_EXE_LINKER_FLAGS_RELEASE} /LTCG")
|
|
||||||
|
|
||||||
# for RelWithDebInfo builds, disable incremental linking
|
|
||||||
# since CMake sets it ON by default for that build type and it
|
|
||||||
# causes warnings
|
|
||||||
#
|
|
||||||
string (REPLACE "/INCREMENTAL" "/INCREMENTAL:NO" replacement_flags
|
|
||||||
${CMAKE_EXE_LINKER_FLAGS_RELWITHDEBINFO})
|
|
||||||
set (CMAKE_EXE_LINKER_FLAGS_RELWITHDEBINFO ${replacement_flags})
|
|
||||||
|
|
||||||
|
if(BUILD_SHARED_LIBS)
|
||||||
|
target_compile_definitions(boost_json PUBLIC BOOST_JSON_DYN_LINK=1)
|
||||||
else()
|
else()
|
||||||
set (THREADS_PREFER_PTHREAD_FLAG ON)
|
target_compile_definitions(boost_json PUBLIC BOOST_JSON_STATIC_LINK=1)
|
||||||
find_package (Threads)
|
|
||||||
|
|
||||||
set( CMAKE_CXX_FLAGS
|
|
||||||
"${CMAKE_CXX_FLAGS} -std=c++11 -Wall -Wextra -Wpedantic -Wno-unused-parameter")
|
|
||||||
|
|
||||||
if ("${CMAKE_CXX_COMPILER_ID}" STREQUAL "Clang")
|
|
||||||
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -Wrange-loop-analysis")
|
|
||||||
endif ()
|
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
# Must come before Boost includes, otherwise the
|
if(CMAKE_SOURCE_DIR STREQUAL CMAKE_CURRENT_SOURCE_DIR)
|
||||||
# IDE sees the wrong file due to boost/ symlinks.
|
if(${CMAKE_VERSION} VERSION_LESS 3.16)
|
||||||
include_directories (include)
|
message(FATAL_ERROR "Boost.JSON development requires CMake 3.16 or newer.")
|
||||||
|
|
||||||
#-------------------------------------------------------------------------------
|
|
||||||
#
|
|
||||||
# Boost
|
|
||||||
#
|
|
||||||
#-------------------------------------------------------------------------------
|
|
||||||
|
|
||||||
get_filename_component (BOOST_ROOT ../../ ABSOLUTE)
|
|
||||||
|
|
||||||
# VFALCO I want static but "b2 stage" builds a minimal set which excludes static
|
|
||||||
add_definitions (-DBOOST_ALL_STATIC_LINK=1)
|
|
||||||
|
|
||||||
include_directories (${BOOST_ROOT})
|
|
||||||
|
|
||||||
link_directories(${BOOST_ROOT}/stage/lib)
|
|
||||||
|
|
||||||
#-------------------------------------------------------------------------------
|
|
||||||
|
|
||||||
if ("${VARIANT}" STREQUAL "coverage")
|
|
||||||
if (MSVC)
|
|
||||||
else()
|
|
||||||
set (CMAKE_BUILD_TYPE DEBUG)
|
|
||||||
set (CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -msse4.2 --coverage")
|
|
||||||
set (CMAKE_EXE_LINKER_FLAGS "${CMAKE_EXE_LINKER_FLAGS} --coverage")
|
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
elseif ("${VARIANT}" STREQUAL "ubasan")
|
get_filename_component(BOOST_ROOT ../.. ABSOLUTE)
|
||||||
if (MSVC)
|
target_include_directories(boost_json PUBLIC ${BOOST_ROOT})
|
||||||
else()
|
target_link_directories(boost_json PUBLIC ${BOOST_ROOT}/stage/lib)
|
||||||
set (CMAKE_BUILD_TYPE RELWITHDEBINFO)
|
|
||||||
set (CMAKE_CXX_FLAGS
|
|
||||||
"${CMAKE_CXX_FLAGS} -msse4.2 -funsigned-char -fno-omit-frame-pointer -fsanitize=address,undefined -fno-sanitize-recover=address,undefined -fsanitize-blacklist=${PROJECT_SOURCE_DIR}/tools/blacklist.supp")
|
|
||||||
set (CMAKE_EXE_LINKER_FLAGS "${CMAKE_EXE_LINKER_FLAGS} -fsanitize=address,undefined -fno-sanitize-recover=address,undefined")
|
|
||||||
endif()
|
|
||||||
|
|
||||||
elseif ("${VARIANT}" STREQUAL "debug")
|
|
||||||
set (CMAKE_BUILD_TYPE DEBUG)
|
|
||||||
|
|
||||||
elseif ("${VARIANT}" STREQUAL "release")
|
|
||||||
set (CMAKE_BUILD_TYPE RELEASE)
|
|
||||||
|
|
||||||
endif()
|
|
||||||
|
|
||||||
#-------------------------------------------------------------------------------
|
|
||||||
#
|
|
||||||
# Tests and examples
|
|
||||||
#
|
|
||||||
|
|
||||||
file (GLOB_RECURSE PROJECT_FILES
|
|
||||||
${PROJECT_SOURCE_DIR}/include/boost/json/*.hpp
|
|
||||||
${PROJECT_SOURCE_DIR}/include/boost/json/*.ipp
|
|
||||||
${PROJECT_SOURCE_DIR}/include/boost/json/*.natvis
|
|
||||||
)
|
|
||||||
|
|
||||||
add_subdirectory(bench)
|
add_subdirectory(bench)
|
||||||
add_subdirectory(example)
|
add_subdirectory(example)
|
||||||
add_subdirectory(test)
|
add_subdirectory(test)
|
||||||
|
else()
|
||||||
|
target_link_libraries(boost_json
|
||||||
|
PUBLIC
|
||||||
|
Boost::assert
|
||||||
|
Boost::config
|
||||||
|
Boost::core
|
||||||
|
Boost::exception
|
||||||
|
Boost::system
|
||||||
|
Boost::utility
|
||||||
|
)
|
||||||
|
endif()
|
||||||
|
@ -47,6 +47,11 @@ The design of the library also achieves these goals:
|
|||||||
* Security-aware treatment of untrusted inputs
|
* Security-aware treatment of untrusted inputs
|
||||||
* Fast compilation performance
|
* Fast compilation performance
|
||||||
|
|
||||||
|
## CMake
|
||||||
|
|
||||||
|
cmake -G "Visual Studio 16 2019" -A Win32 -B bin -DCMAKE_TOOLCHAIN_FILE=cmake/toolchains/msvc.cmake
|
||||||
|
cmake -G "Visual Studio 16 2019" -A x64 -B bin64 -DCMAKE_TOOLCHAIN_FILE=cmake/toolchains/msvc.cmake
|
||||||
|
|
||||||
## License
|
## License
|
||||||
|
|
||||||
Distributed under the Boost Software License, Version 1.0.
|
Distributed under the Boost Software License, Version 1.0.
|
||||||
|
@ -7,38 +7,17 @@
|
|||||||
# Official repository: https://github.com/vinniefalco/json
|
# Official repository: https://github.com/vinniefalco/json
|
||||||
#
|
#
|
||||||
|
|
||||||
source_group (json FILES ${PROJECT_SOURCE_DIR}/include/boost/json.hpp)
|
source_group("" FILES
|
||||||
source_group (json FILES ${PROJECT_SOURCE_DIR}/include/boost/pilfer.hpp)
|
|
||||||
source_group (TREE ${PROJECT_SOURCE_DIR}/include/boost/json PREFIX json FILES ${PROJECT_FILES})
|
|
||||||
|
|
||||||
GroupSources(bench "/")
|
|
||||||
|
|
||||||
# Disable auto-linking
|
|
||||||
add_definitions(-DBOOST_ALL_NO_LIB=1)
|
|
||||||
|
|
||||||
include_directories(../test)
|
|
||||||
|
|
||||||
if (MSVC)
|
|
||||||
if (CMAKE_BUILD_TYPE EQUAL "Debug")
|
|
||||||
else()
|
|
||||||
add_compile_options(
|
|
||||||
/GL # Whole program optimization
|
|
||||||
/Ob2 # inline any suitable
|
|
||||||
)
|
|
||||||
|
|
||||||
add_link_options(
|
|
||||||
/LTCG # Link Time Code Generation
|
|
||||||
)
|
|
||||||
endif()
|
|
||||||
endif()
|
|
||||||
|
|
||||||
add_executable (bench
|
|
||||||
${PROJECT_FILES}
|
|
||||||
${PROJECT_SOURCE_DIR}/include/boost/json.hpp
|
|
||||||
${PROJECT_SOURCE_DIR}/include/boost/pilfer.hpp
|
|
||||||
${PROJECT_SOURCE_DIR}/src/src.cpp
|
|
||||||
Jamfile
|
Jamfile
|
||||||
bench.cpp
|
bench.cpp
|
||||||
)
|
)
|
||||||
|
|
||||||
|
add_executable(bench
|
||||||
|
Jamfile
|
||||||
|
bench.cpp
|
||||||
|
)
|
||||||
|
|
||||||
|
target_include_directories(bench PRIVATE ../test)
|
||||||
|
target_link_libraries(bench PRIVATE boost_json)
|
||||||
|
|
||||||
add_test(json-tests json-tests)
|
add_test(json-tests json-tests)
|
||||||
|
5
cmake/toolchains/clang.cmake
Normal file
5
cmake/toolchains/clang.cmake
Normal file
@ -0,0 +1,5 @@
|
|||||||
|
# Include gcc options.
|
||||||
|
include(${CMAKE_CURRENT_LIST_DIR}/gcc.cmake)
|
||||||
|
|
||||||
|
# Compiler options.
|
||||||
|
add_compile_options(-Wrange-loop-analysis)
|
18
cmake/toolchains/common.cmake
Normal file
18
cmake/toolchains/common.cmake
Normal file
@ -0,0 +1,18 @@
|
|||||||
|
# C++ standard.
|
||||||
|
set(CMAKE_CXX_STANDARD 11 CACHE STRING "")
|
||||||
|
set(CMAKE_CXX_STANDARD_REQUIRED ON CACHE STRING "")
|
||||||
|
set(CMAKE_CXX_EXTENSIONS OFF CACHE STRING "")
|
||||||
|
|
||||||
|
# Static library linkage.
|
||||||
|
set(BUILD_SHARED_LIBS OFF CACHE STRING "")
|
||||||
|
add_definitions(-DBOOST_ALL_STATIC_LINK=1)
|
||||||
|
|
||||||
|
# Interprocedural optimization.
|
||||||
|
set(CMAKE_INTERPROCEDURAL_OPTIMIZATION_RELEASE ON CACHE STRING "")
|
||||||
|
set(CMAKE_INTERPROCEDURAL_OPTIMIZATION_MINSIZEREL ON CACHE STRING "")
|
||||||
|
set(CMAKE_INTERPROCEDURAL_OPTIMIZATION_RELWITHDEBINFO ON CACHE STRING "")
|
||||||
|
|
||||||
|
# Compiler definitions.
|
||||||
|
if(WIN32)
|
||||||
|
add_definitions(-D_WIN32_WINNT=0x0601 -D_CRT_SECURE_NO_WARNINGS)
|
||||||
|
endif()
|
5
cmake/toolchains/gcc.cmake
Normal file
5
cmake/toolchains/gcc.cmake
Normal file
@ -0,0 +1,5 @@
|
|||||||
|
# Include common options.
|
||||||
|
include(${CMAKE_CURRENT_LIST_DIR}/common.cmake)
|
||||||
|
|
||||||
|
# Compiler options.
|
||||||
|
add_compile_options(-Wall -Wextra -Wpedantic -Wno-unused-parameter)
|
28
cmake/toolchains/msvc.cmake
Normal file
28
cmake/toolchains/msvc.cmake
Normal file
@ -0,0 +1,28 @@
|
|||||||
|
# Include common options.
|
||||||
|
include(${CMAKE_CURRENT_LIST_DIR}/common.cmake)
|
||||||
|
|
||||||
|
# Static runtime linkage.
|
||||||
|
set(CMAKE_MSVC_RUNTIME_LIBRARY "MultiThreaded$<$<CONFIG:Debug>:Debug>" CACHE STRING "")
|
||||||
|
|
||||||
|
# Compiler options.
|
||||||
|
add_compile_options(
|
||||||
|
/permissive- # strict C++
|
||||||
|
/W4 # enable all warnings
|
||||||
|
/MP # multi-processor compilation
|
||||||
|
)
|
||||||
|
|
||||||
|
# Linker options.
|
||||||
|
add_link_options(
|
||||||
|
)
|
||||||
|
|
||||||
|
# Disable logos.
|
||||||
|
foreach(lang C CXX ASM_MASM RC)
|
||||||
|
set(CMAKE_${lang}_FLAGS_INIT "/nologo")
|
||||||
|
endforeach()
|
||||||
|
foreach(type EXE SHARED MODULE)
|
||||||
|
set(CMAKE_${type}_LINKER_FLAGS_INIT "/nologo")
|
||||||
|
endforeach()
|
||||||
|
|
||||||
|
# Silence Visual Studio CMake integration warnings.
|
||||||
|
set(SILENCE_VS_DEFINITIONS ${CMAKE_TOOLCHAIN_FILE} ${CMAKE_C_COMPILER})
|
||||||
|
set(SILENCE_VS_DEFINITIONS)
|
@ -7,18 +7,22 @@
|
|||||||
# Official repository: https://github.com/vinniefalco/json
|
# Official repository: https://github.com/vinniefalco/json
|
||||||
#
|
#
|
||||||
|
|
||||||
GroupSources(example "/")
|
source_group("" FILES
|
||||||
|
file.hpp
|
||||||
|
pretty.cpp
|
||||||
|
validate.cpp
|
||||||
|
)
|
||||||
|
|
||||||
add_executable(pretty
|
add_executable(pretty
|
||||||
${PROJECT_SOURCE_DIR}/src/src.cpp
|
|
||||||
file.hpp
|
file.hpp
|
||||||
pretty.cpp
|
pretty.cpp
|
||||||
)
|
)
|
||||||
set_property(TARGET pretty PROPERTY FOLDER "example")
|
set_property(TARGET pretty PROPERTY FOLDER "example")
|
||||||
|
target_link_libraries(pretty PRIVATE boost_json)
|
||||||
|
|
||||||
add_executable(validate
|
add_executable(validate
|
||||||
${PROJECT_SOURCE_DIR}/src/src.cpp
|
|
||||||
file.hpp
|
file.hpp
|
||||||
validate.cpp
|
validate.cpp
|
||||||
)
|
)
|
||||||
set_property(TARGET validate PROPERTY FOLDER "example")
|
set_property(TARGET validate PROPERTY FOLDER "example")
|
||||||
|
target_link_libraries(validate PRIVATE boost_json)
|
||||||
|
@ -7,52 +7,12 @@
|
|||||||
# Official repository: https://github.com/vinniefalco/json
|
# Official repository: https://github.com/vinniefalco/json
|
||||||
#
|
#
|
||||||
|
|
||||||
source_group (boost FILES ${PROJECT_SOURCE_DIR}/include/boost/json.hpp)
|
file(GLOB_RECURSE BOOST_JSON_TESTS_FILES CONFIGURE_DEPENDS Jamfile *.cpp *.hpp)
|
||||||
source_group (boost FILES ${PROJECT_SOURCE_DIR}/include/boost/pilfer.hpp)
|
source_group(TREE ${CMAKE_CURRENT_SOURCE_DIR} PREFIX "" FILES ${BOOST_JSON_TESTS_FILES})
|
||||||
source_group (TREE ${PROJECT_SOURCE_DIR}/include/boost/json PREFIX json FILES ${PROJECT_FILES})
|
|
||||||
|
|
||||||
GroupSources(test "/")
|
add_executable(tests ${BOOST_JSON_TESTS_FILES})
|
||||||
|
|
||||||
add_definitions(-DBOOST_JSON_HEADER_ONLY=1)
|
target_include_directories(tests PRIVATE .)
|
||||||
|
target_link_libraries(tests PRIVATE boost_json)
|
||||||
|
|
||||||
include_directories(.)
|
add_test(json-tests tests)
|
||||||
|
|
||||||
add_executable (json-tests
|
|
||||||
${PROJECT_FILES}
|
|
||||||
${PROJECT_SOURCE_DIR}/include/boost/json.hpp
|
|
||||||
${PROJECT_SOURCE_DIR}/include/boost/pilfer.hpp
|
|
||||||
${PROJECT_SOURCE_DIR}/include/boost/json/json.natvis
|
|
||||||
${PROJECT_SOURCE_DIR}/src/src.cpp
|
|
||||||
Jamfile
|
|
||||||
test.hpp
|
|
||||||
test_suite.hpp
|
|
||||||
parse-vectors.hpp
|
|
||||||
main.cpp
|
|
||||||
_detail_number.cpp
|
|
||||||
array.cpp
|
|
||||||
basic_parser.cpp
|
|
||||||
error.cpp
|
|
||||||
json.cpp
|
|
||||||
kind.cpp
|
|
||||||
limits.cpp
|
|
||||||
number_cast.cpp
|
|
||||||
object.cpp
|
|
||||||
parser.cpp
|
|
||||||
pool.cpp
|
|
||||||
serializer.cpp
|
|
||||||
snippets.cpp
|
|
||||||
storage.cpp
|
|
||||||
storage_ptr.cpp
|
|
||||||
string.cpp
|
|
||||||
to_value.cpp
|
|
||||||
traits.cpp
|
|
||||||
value.cpp
|
|
||||||
value_cast.cpp
|
|
||||||
value_ref.cpp
|
|
||||||
ryu/d2s_intrinsics_test.cpp
|
|
||||||
ryu/d2s_table_test.cpp
|
|
||||||
ryu/d2s_test.cpp
|
|
||||||
ryu/gtest.hpp
|
|
||||||
)
|
|
||||||
|
|
||||||
add_test(json-tests json-tests)
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user