mirror of
https://github.com/microsoft/vcpkg.git
synced 2025-01-07 23:57:55 +08:00
132 lines
4.7 KiB
Diff
132 lines
4.7 KiB
Diff
|
diff --git a/cdk/cmake/dependency.cmake b/cdk/cmake/dependency.cmake
|
||
|
index a1775da..f9c3edf 100644
|
||
|
--- a/cdk/cmake/dependency.cmake
|
||
|
+++ b/cdk/cmake/dependency.cmake
|
||
|
@@ -57,6 +57,7 @@ set(EXT_FWD
|
||
|
CMAKE_SYSTEM_NAME CMAKE_SYSTEM_VERSION
|
||
|
CMAKE_SYSTEM_PROCESSOR
|
||
|
CMAKE_C_COMPILER CMAKE_CXX_COMPILER
|
||
|
+ BUILD_SHARED_LIBS STATIC_MSVCRT BUILD_STATIC
|
||
|
)
|
||
|
|
||
|
set(EXT_DIR ${CMAKE_CURRENT_LIST_DIR}/ext CACHE INTERNAL "external project utils location")
|
||
|
@@ -117,7 +118,7 @@ function(add_ext NAME)
|
||
|
endif()
|
||
|
|
||
|
foreach(var ${EXT_FWD})
|
||
|
- if(${var})
|
||
|
+ if(DEFINED ${var})
|
||
|
message("-- option ${var}: ${${var}}")
|
||
|
list(APPEND cmake_opts -D${var}=${${var}})
|
||
|
endif()
|
||
|
diff --git a/cdk/extra/lz4/CMakeLists.txt b/cdk/extra/lz4/CMakeLists.txt
|
||
|
index 4c3aab0..a1596af 100644
|
||
|
--- a/cdk/extra/lz4/CMakeLists.txt
|
||
|
+++ b/cdk/extra/lz4/CMakeLists.txt
|
||
|
@@ -34,6 +34,10 @@ include(platform)
|
||
|
|
||
|
enable_pic()
|
||
|
|
||
|
+if (MSVC AND STATIC_MSVCRT)
|
||
|
+ message("lz4 using static runtime library")
|
||
|
+ set_msvcrt(STATIC)
|
||
|
+endif (MSVC AND STATIC_MSVCRT)
|
||
|
add_library(lz4 STATIC
|
||
|
lz4.c
|
||
|
lz4frame.c
|
||
|
diff --git a/cdk/extra/protobuf/protobuf-3.19.4/cmake/CMakeLists.txt b/cdk/extra/protobuf/protobuf-3.19.4/cmake/CMakeLists.txt
|
||
|
index efe6b97..377a817 100644
|
||
|
--- a/cdk/extra/protobuf/protobuf-3.19.4/cmake/CMakeLists.txt
|
||
|
+++ b/cdk/extra/protobuf/protobuf-3.19.4/cmake/CMakeLists.txt
|
||
|
@@ -186,9 +186,9 @@ else (protobuf_BUILD_SHARED_LIBS)
|
||
|
# Prior to CMake 3.15, the MSVC runtime library was pushed into the same flags
|
||
|
# making programmatic control difficult. Prefer the functionality in newer
|
||
|
# CMake versions when available.
|
||
|
- if(CMAKE_VERSION VERSION_GREATER 3.15 OR CMAKE_VERSION VERSION_EQUAL 3.15)
|
||
|
- set(CMAKE_MSVC_RUNTIME_LIBRARY MultiThreaded$<$<CONFIG:Debug>:Debug>)
|
||
|
- else()
|
||
|
+ #if(CMAKE_VERSION VERSION_GREATER 3.15 OR CMAKE_VERSION VERSION_EQUAL 3.15)
|
||
|
+ # set(CMAKE_MSVC_RUNTIME_LIBRARY MultiThreaded$<$<CONFIG:Debug>:Debug>)
|
||
|
+ #else()
|
||
|
# In case we are building static libraries, link also the runtime library statically
|
||
|
# so that MSVCR*.DLL is not required at runtime.
|
||
|
# https://msdn.microsoft.com/en-us/library/2kzt1wy3.aspx
|
||
|
@@ -203,7 +203,7 @@ else (protobuf_BUILD_SHARED_LIBS)
|
||
|
endif(${flag_var} MATCHES "/MD")
|
||
|
endforeach(flag_var)
|
||
|
endif (MSVC AND protobuf_MSVC_STATIC_RUNTIME)
|
||
|
- endif()
|
||
|
+ #endif()
|
||
|
endif (protobuf_BUILD_SHARED_LIBS)
|
||
|
|
||
|
if (MSVC)
|
||
|
diff --git a/cdk/extra/zlib/CMakeLists.txt b/cdk/extra/zlib/CMakeLists.txt
|
||
|
index 237c2c3..7746bd0 100644
|
||
|
--- a/cdk/extra/zlib/CMakeLists.txt
|
||
|
+++ b/cdk/extra/zlib/CMakeLists.txt
|
||
|
@@ -162,6 +162,10 @@ endif()
|
||
|
|
||
|
# -------------------------------------------------------------------------
|
||
|
|
||
|
+if (MSVC AND STATIC_MSVCRT)
|
||
|
+ message("zlib using static runtime library")
|
||
|
+ set_msvcrt(STATIC)
|
||
|
+endif (MSVC AND STATIC_MSVCRT)
|
||
|
ADD_LIBRARY(zlib STATIC
|
||
|
${ZLIB_SRCS} ${ZLIB_PUBLIC_HDRS} ${ZLIB_PRIVATE_HDRS})
|
||
|
|
||
|
diff --git a/cdk/extra/zstd/CMakeLists.txt b/cdk/extra/zstd/CMakeLists.txt
|
||
|
index 2109f3e..a60034e 100644
|
||
|
--- a/cdk/extra/zstd/CMakeLists.txt
|
||
|
+++ b/cdk/extra/zstd/CMakeLists.txt
|
||
|
@@ -57,6 +57,10 @@ SET(ZSTD_SRCS
|
||
|
lib/dictBuilder/zdict.c
|
||
|
)
|
||
|
|
||
|
+if (MSVC AND STATIC_MSVCRT)
|
||
|
+ message("zstd using static runtime library")
|
||
|
+ set_msvcrt(STATIC)
|
||
|
+endif (MSVC AND STATIC_MSVCRT)
|
||
|
ADD_LIBRARY(zstd STATIC ${ZSTD_SRCS})
|
||
|
set_target_properties(zstd PROPERTIES FOLDER "Misc")
|
||
|
|
||
|
diff --git a/cmake/libutils.cmake b/cmake/libutils.cmake
|
||
|
index 05ea32e..ff26ba6 100644
|
||
|
--- a/cmake/libutils.cmake
|
||
|
+++ b/cmake/libutils.cmake
|
||
|
@@ -164,7 +164,11 @@ function(merge_libraries TARGET)
|
||
|
set_property(SOURCE "${LIBUTILS_SCRIPT_DIR}/empty.cc" PROPERTY LANGUAGE CXX)
|
||
|
|
||
|
add_library(${TARGET} ${TYPE} "${LIBUTILS_SCRIPT_DIR}/empty.cc")
|
||
|
- target_link_libraries(${TARGET} PRIVATE ${ARGN})
|
||
|
+ if(TYPE STREQUAL "SHARED")
|
||
|
+ target_link_libraries(${TARGET} PRIVATE ${ARGN})
|
||
|
+ else()
|
||
|
+ add_dependencies(${TARGET} ${ARGN})
|
||
|
+ endif()
|
||
|
|
||
|
#
|
||
|
# Arrange for marge_archives.cmake script to be executed in a POST_BUILD
|
||
|
@@ -314,7 +318,7 @@ function(merge_libraries TARGET)
|
||
|
--target ${TARGET}-deps
|
||
|
--config $<CONFIG>
|
||
|
--
|
||
|
- /nologo /v:q /filelogger /flp:Verbosity=q /flp:ShowCommandLine
|
||
|
+ /nologo /v:q /filelogger /flp:Verbosity=m /flp:ShowCommandLine
|
||
|
/flp:LogFile=\"${log_file}.STATIC\"
|
||
|
|
||
|
WORKING_DIRECTORY ${CMAKE_CURRENT_BINARY_DIR}
|
||
|
diff --git a/install_layout.cmake b/install_layout.cmake
|
||
|
index 5730ce4..e6514ac 100644
|
||
|
--- a/install_layout.cmake
|
||
|
+++ b/install_layout.cmake
|
||
|
@@ -177,7 +177,7 @@ set(LIB_NAME_BASE "mysqlcppconn${CONCPP_VERSION_MAJOR}")
|
||
|
set(LIB_NAME_STATIC "${LIB_NAME_BASE}-static")
|
||
|
|
||
|
if(WIN32 AND STATIC_MSVCRT)
|
||
|
- set(LIB_NAME_STATIC "${LIB_NAME}-mt")
|
||
|
+ set(LIB_NAME_STATIC "${LIB_NAME_STATIC}-mt")
|
||
|
endif()
|
||
|
|
||
|
if(BUILD_STATIC)
|