Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
build json11 as external dep and link it using the target syntax
- Loading branch information
1 parent
634bbd1
commit f940b52
Showing
24 changed files
with
199 additions
and
60 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,4 +1,4 @@ | ||
add_library(dronecode_sdk_info ${PLUGIN_LIBRARY_TYPE} | ||
add_library(dronecode_sdk_info | ||
info.cpp | ||
info_impl.cpp | ||
) | ||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Submodule json11
deleted from
59c962
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,36 @@ | ||
cmake_minimum_required(VERSION 3.1) | ||
|
||
project(external-json11) | ||
include(ExternalProject) | ||
|
||
list(APPEND CMAKE_ARGS | ||
"-DCMAKE_INSTALL_PREFIX:PATH=${CMAKE_INSTALL_PREFIX}" | ||
"-DCMAKE_TOOLCHAIN_FILE:PATH=${CMAKE_TOOLCHAIN_FILE}" | ||
"-DCMAKE_POSITION_INDEPENDENT_CODE=ON" | ||
"-DBUILD_SHARED_LIBS=OFF" | ||
) | ||
|
||
if(ANDROID) | ||
list(APPEND CMAKE_ARGS | ||
"-DANDROID_ABI:STRING=${ANDROID_ABI}" | ||
"-DANDROID_STL:STRING=${ANDROID_STL}" | ||
"-DANDROID_PLATFORM=${ANDROID_PLATFORM}" | ||
) | ||
elseif(IOS) | ||
list(APPEND CMAKE_ARGS | ||
"-DIOS_PLATFORM=${IOS_PLATFORM}" | ||
) | ||
endif() | ||
|
||
message(STATUS "Preparing external project \"json11\" with args:") | ||
foreach(CMAKE_ARG ${CMAKE_ARGS}) | ||
message(STATUS "-- ${CMAKE_ARG}") | ||
endforeach() | ||
|
||
ExternalProject_add( | ||
json11 | ||
URL https://github.com/dropbox/json11/archive/v1.0.0.tar.gz | ||
PREFIX json11 | ||
PATCH_COMMAND patch -p1 < ${PROJECT_SOURCE_DIR}/export_config.patch | ||
CONFIGURE_COMMAND ${CMAKE_COMMAND} "${CMAKE_ARGS}" <SOURCE_DIR> | ||
) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,40 @@ | ||
commit 1ff431620c61c3e68a8c9e68dd2652ef66da9f95 | ||
Author: fegorsch <flix.gorschi@gmail.com> | ||
Date: Tue May 8 15:23:14 2018 +0200 | ||
|
||
Export json11Config.cmake on install | ||
|
||
So you can easily use installed builds from other CMake projects by | ||
setting json11_DIR. | ||
|
||
diff --git a/CMakeLists.txt b/CMakeLists.txt | ||
index 819c36f..899f06c 100644 | ||
--- a/CMakeLists.txt | ||
+++ b/CMakeLists.txt | ||
@@ -23,7 +23,10 @@ if(CMAKE_INSTALL_PREFIX_INITIALIZED_TO_DEFAULT) | ||
endif() | ||
|
||
add_library(json11 json11.cpp) | ||
-target_include_directories(json11 PUBLIC ${CMAKE_CURRENT_SOURCE_DIR}) | ||
+target_include_directories(json11 PUBLIC | ||
+ $<BUILD_INTERFACE:${CMAKE_CURRENT_SOURCE_DIR}> | ||
+ $<INSTALL_INTERFACE:.> | ||
+) | ||
target_compile_options(json11 | ||
PRIVATE -fPIC -fno-rtti -fno-exceptions -Wall) | ||
|
||
@@ -52,6 +55,11 @@ if (JSON11_BUILD_TESTS) | ||
target_link_libraries(json11_test json11) | ||
endif() | ||
|
||
-install(TARGETS json11 DESTINATION lib/${CMAKE_LIBRARY_ARCHITECTURE}) | ||
+install(TARGETS json11 EXPORT json11Config DESTINATION lib | ||
+ ARCHIVE DESTINATION lib | ||
+ LIBRARY DESTINATION lib | ||
+ RUNTIME DESTINATION bin | ||
+ INCLUDES DESTINATION include) | ||
-install(FILES "${CMAKE_CURRENT_SOURCE_DIR}/json11.hpp" DESTINATION include/${CMAKE_LIBRARY_ARCHITECTURE}) | ||
-install(FILES "${CMAKE_CURRENT_BINARY_DIR}/json11.pc" DESTINATION lib/${CMAKE_LIBRARY_ARCHITECTURE}/pkgconfig) | ||
+install(FILES "${CMAKE_CURRENT_SOURCE_DIR}/json11.hpp" DESTINATION include) | ||
+install(FILES "${CMAKE_CURRENT_BINARY_DIR}/json11.pc" DESTINATION lib/pkgconfig) | ||
+install(EXPORT json11Config NAMESPACE json11:: DESTINATION cmake) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,89 @@ | ||
diff --git a/CMakeLists.txt b/CMakeLists.txt | ||
index 0fe939d..1873459 100644 | ||
--- a/CMakeLists.txt | ||
+++ b/CMakeLists.txt | ||
@@ -123,7 +123,7 @@ set(ZLIB_SRCS | ||
zutil.c | ||
) | ||
|
||
-if(NOT MINGW) | ||
+if(BUILD_SHARED_LIBS AND NOT MINGW) | ||
set(ZLIB_DLL_SRCS | ||
win32/zlib1.rc # If present will override custom build rule below. | ||
) | ||
@@ -167,7 +167,7 @@ file(READ ${CMAKE_CURRENT_SOURCE_DIR}/zlib.h _zlib_h_contents) | ||
string(REGEX REPLACE ".*#define[ \t]+ZLIB_VERSION[ \t]+\"([-0-9A-Za-z.]+)\".*" | ||
"\\1" ZLIB_FULL_VERSION ${_zlib_h_contents}) | ||
|
||
-if(MINGW) | ||
+if(BUILD_SHARED_LIBS AND MINGW) | ||
# This gets us DLL resource information when compiling on MinGW. | ||
if(NOT CMAKE_RC_COMPILER) | ||
set(CMAKE_RC_COMPILER windres.exe) | ||
@@ -181,37 +181,42 @@ if(MINGW) | ||
-o ${CMAKE_CURRENT_BINARY_DIR}/zlib1rc.obj | ||
-i ${CMAKE_CURRENT_SOURCE_DIR}/win32/zlib1.rc) | ||
set(ZLIB_DLL_SRCS ${CMAKE_CURRENT_BINARY_DIR}/zlib1rc.obj) | ||
-endif(MINGW) | ||
- | ||
-add_library(zlib SHARED ${ZLIB_SRCS} ${ZLIB_ASMS} ${ZLIB_DLL_SRCS} ${ZLIB_PUBLIC_HDRS} ${ZLIB_PRIVATE_HDRS}) | ||
-add_library(zlibstatic STATIC ${ZLIB_SRCS} ${ZLIB_ASMS} ${ZLIB_PUBLIC_HDRS} ${ZLIB_PRIVATE_HDRS}) | ||
-set_target_properties(zlib PROPERTIES DEFINE_SYMBOL ZLIB_DLL) | ||
-set_target_properties(zlib PROPERTIES SOVERSION 1) | ||
- | ||
-if(NOT CYGWIN) | ||
- # This property causes shared libraries on Linux to have the full version | ||
- # encoded into their final filename. We disable this on Cygwin because | ||
- # it causes cygz-${ZLIB_FULL_VERSION}.dll to be created when cygz.dll | ||
- # seems to be the default. | ||
- # | ||
- # This has no effect with MSVC, on that platform the version info for | ||
- # the DLL comes from the resource file win32/zlib1.rc | ||
- set_target_properties(zlib PROPERTIES VERSION ${ZLIB_FULL_VERSION}) | ||
endif() | ||
|
||
+add_library(zlib ${ZLIB_SRCS} ${ZLIB_ASMS} ${ZLIB_DLL_SRCS} ${ZLIB_PUBLIC_HDRS} ${ZLIB_PRIVATE_HDRS}) | ||
+ | ||
if(UNIX) | ||
# On unix-like platforms the library is almost always called libz | ||
- set_target_properties(zlib zlibstatic PROPERTIES OUTPUT_NAME z) | ||
- if(NOT APPLE) | ||
- set_target_properties(zlib PROPERTIES LINK_FLAGS "-Wl,--version-script,\"${CMAKE_CURRENT_SOURCE_DIR}/zlib.map\"") | ||
- endif() | ||
-elseif(BUILD_SHARED_LIBS AND WIN32) | ||
- # Creates zlib1.dll when building shared library version | ||
- set_target_properties(zlib PROPERTIES SUFFIX "1.dll") | ||
+ set_target_properties(zlib PROPERTIES OUTPUT_NAME z) | ||
+endif() | ||
+ | ||
+if(BUILD_SHARED_LIBS) | ||
+ set_target_properties(zlib PROPERTIES DEFINE_SYMBOL ZLIB_DLL) | ||
+ set_target_properties(zlib PROPERTIES SOVERSION 1) | ||
+ | ||
+ if(NOT CYGWIN) | ||
+ # This property causes shared libraries on Linux to have the full version | ||
+ # encoded into their final filename. We disable this on Cygwin because | ||
+ # it causes cygz-${ZLIB_FULL_VERSION}.dll to be created when cygz.dll | ||
+ # seems to be the default. | ||
+ # | ||
+ # This has no effect with MSVC, on that platform the version info for | ||
+ # the DLL comes from the resource file win32/zlib1.rc | ||
+ set_target_properties(zlib PROPERTIES VERSION ${ZLIB_FULL_VERSION}) | ||
+ endif() | ||
+ | ||
+ if(UNIX AND NOT APPLE) | ||
+ set_target_properties(zlib PROPERTIES LINK_FLAGS "-Wl,--version-script,\"${CMAKE_CURRENT_SOURCE_DIR}/zlib.map\"") | ||
+ endif() | ||
+ | ||
+ if(WIN32) | ||
+ # Creates zlib1.dll when building shared library version | ||
+ set_target_properties(zlib PROPERTIES SUFFIX "1.dll") | ||
+ endif() | ||
endif() | ||
|
||
if(NOT SKIP_INSTALL_LIBRARIES AND NOT SKIP_INSTALL_ALL ) | ||
- install(TARGETS zlib zlibstatic | ||
+ install(TARGETS zlib | ||
RUNTIME DESTINATION "${INSTALL_BIN_DIR}" | ||
ARCHIVE DESTINATION "${INSTALL_LIB_DIR}" | ||
LIBRARY DESTINATION "${INSTALL_LIB_DIR}" ) |