mirror of
https://github.com/microsoft/vcpkg.git
synced 2025-01-01 13:37:55 +08:00
Fix spdlog handling of external fmt lib
Using an external fmt lib should cause the spdlog::spdlog target to have a dependency on fmt lib - so that a consuming project does not need to call find_package(fmt) and target_link_libraries(... fmt::fmt). To this end a new cmake option SPDLOG_FMT_EXTERNAL is introduced which makes spdlog depend on fmt lib and defines the SPDLOG_FMT_EXTERNAL macro to avoid using the bundled fmt lib. The value of SPDLOG_FMT_EXTERNAL is also stored in the installed spdlogConfig.cmake and if it is ON find_dependency() is used to ensure the fmt::fmt target is imported.
This commit is contained in:
parent
fcde2e64eb
commit
f643622019
100
ports/spdlog/fmt-external-cmake-option.patch
Normal file
100
ports/spdlog/fmt-external-cmake-option.patch
Normal file
@ -0,0 +1,100 @@
|
||||
diff --git a/CMakeLists.txt b/CMakeLists.txt
|
||||
index fc75346..5b3a5c8 100644
|
||||
--- a/CMakeLists.txt
|
||||
+++ b/CMakeLists.txt
|
||||
@@ -59,6 +59,12 @@ cmake_dependent_option(SPDLOG_BUILD_TESTING
|
||||
"BUILD_TESTING" OFF
|
||||
)
|
||||
|
||||
+option(SPDLOG_FMT_EXTERNAL "Use external fmt library instead of bundled" OFF)
|
||||
+
|
||||
+if(SPDLOG_FMT_EXTERNAL)
|
||||
+ find_package(fmt REQUIRED CONFIG)
|
||||
+endif()
|
||||
+
|
||||
target_include_directories(
|
||||
spdlog
|
||||
INTERFACE
|
||||
@@ -66,6 +72,11 @@ target_include_directories(
|
||||
"$<INSTALL_INTERFACE:${CMAKE_INSTALL_INCLUDEDIR}>"
|
||||
)
|
||||
|
||||
+if(SPDLOG_FMT_EXTERNAL)
|
||||
+ target_compile_definitions(spdlog INTERFACE SPDLOG_FMT_EXTERNAL)
|
||||
+ target_link_libraries(spdlog INTERFACE fmt::fmt)
|
||||
+endif()
|
||||
+
|
||||
set(HEADER_BASE "${CMAKE_CURRENT_SOURCE_DIR}/include")
|
||||
|
||||
if(SPDLOG_BUILD_EXAMPLES)
|
||||
@@ -88,7 +99,8 @@ set(config_install_dir "${CMAKE_INSTALL_LIBDIR}/cmake/${PROJECT_NAME}")
|
||||
set(include_install_dir "${CMAKE_INSTALL_INCLUDEDIR}")
|
||||
set(pkgconfig_install_dir "${CMAKE_INSTALL_LIBDIR}/pkgconfig")
|
||||
set(version_config "${CMAKE_BINARY_DIR}/${PROJECT_NAME}ConfigVersion.cmake")
|
||||
-set(project_config "${PROJECT_NAME}Config.cmake")
|
||||
+set(project_config "${CMAKE_CURRENT_BINARY_DIR}/${PROJECT_NAME}Config.cmake")
|
||||
+set(targets_config "${PROJECT_NAME}Targets.cmake")
|
||||
set(pkg_config "${CMAKE_BINARY_DIR}/${PROJECT_NAME}.pc")
|
||||
set(targets_export_name "${PROJECT_NAME}Targets")
|
||||
set(namespace "${PROJECT_NAME}::")
|
||||
@@ -101,6 +113,8 @@ write_basic_package_version_file(
|
||||
|
||||
# configure pkg config file
|
||||
configure_file("cmake/spdlog.pc.in" "${pkg_config}" @ONLY)
|
||||
+# configure spdlogConfig.cmake file
|
||||
+configure_file("cmake/Config.cmake.in" "${project_config}" @ONLY)
|
||||
|
||||
# install targets
|
||||
install(
|
||||
@@ -114,9 +128,9 @@ install(
|
||||
DESTINATION "${include_install_dir}"
|
||||
)
|
||||
|
||||
-# install project version file
|
||||
+# install project config and version file
|
||||
install(
|
||||
- FILES "${version_config}"
|
||||
+ FILES "${project_config}" "${version_config}"
|
||||
DESTINATION "${config_install_dir}"
|
||||
)
|
||||
|
||||
@@ -126,19 +140,19 @@ install(
|
||||
DESTINATION "${pkgconfig_install_dir}"
|
||||
)
|
||||
|
||||
-# install project config file
|
||||
+# install targets config file
|
||||
install(
|
||||
EXPORT "${targets_export_name}"
|
||||
NAMESPACE "${namespace}"
|
||||
DESTINATION "${config_install_dir}"
|
||||
- FILE ${project_config}
|
||||
+ FILE ${targets_config}
|
||||
)
|
||||
|
||||
-# export build directory config file
|
||||
+# export build directory targets file
|
||||
export(
|
||||
EXPORT ${targets_export_name}
|
||||
NAMESPACE "${namespace}"
|
||||
- FILE ${project_config}
|
||||
+ FILE ${targets_config}
|
||||
)
|
||||
|
||||
# register project in CMake user registry
|
||||
diff --git a/cmake/Config.cmake.in b/cmake/Config.cmake.in
|
||||
index ba0b36f..0b0fd11 100644
|
||||
--- a/cmake/Config.cmake.in
|
||||
+++ b/cmake/Config.cmake.in
|
||||
@@ -21,4 +21,11 @@
|
||||
# * SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. */
|
||||
# *************************************************************************/
|
||||
|
||||
+set(SPDLOG_FMT_EXTERNAL @SPDLOG_FMT_EXTERNAL@)
|
||||
+
|
||||
include("${CMAKE_CURRENT_LIST_DIR}/@targets_export_name@.cmake")
|
||||
+
|
||||
+if(SPDLOG_FMT_EXTERNAL)
|
||||
+ include(CMakeFindDependencyMacro)
|
||||
+ find_dependency(fmt CONFIG)
|
||||
+endif()
|
@ -6,6 +6,8 @@ vcpkg_from_github(
|
||||
REF v1.2.1
|
||||
SHA512 418f91efc207fa227558212d82c41639c0bb59e84ea47447e0b6276c4842e97f1f8aaf5802c071ef15d80ec525e317e70b6a39661a6c96ab39d33d9bd1570da1
|
||||
HEAD_REF v1.x
|
||||
PATCHES
|
||||
fmt-external-cmake-option.patch
|
||||
)
|
||||
|
||||
vcpkg_configure_cmake(
|
||||
@ -13,6 +15,7 @@ vcpkg_configure_cmake(
|
||||
PREFER_NINJA
|
||||
OPTIONS
|
||||
-DSPDLOG_BUILD_TESTING=OFF
|
||||
-DSPDLOG_FMT_EXTERNAL=ON
|
||||
)
|
||||
|
||||
vcpkg_install_cmake()
|
||||
@ -22,11 +25,8 @@ vcpkg_fixup_cmake_targets(CONFIG_PATH lib/cmake/spdlog)
|
||||
file(REMOVE_RECURSE ${CURRENT_PACKAGES_DIR}/debug)
|
||||
file(REMOVE_RECURSE ${CURRENT_PACKAGES_DIR}/lib)
|
||||
|
||||
# use vcpkg-provided fmt library
|
||||
# use vcpkg-provided fmt library (see also option SPDLOG_FMT_EXTERNAL above)
|
||||
file(REMOVE_RECURSE ${CURRENT_PACKAGES_DIR}/include/spdlog/fmt/bundled)
|
||||
file(READ ${CURRENT_PACKAGES_DIR}/include/spdlog/tweakme.h SPDLOG_TWEAKME_CONTENTS)
|
||||
string(REPLACE "// #define SPDLOG_FMT_EXTERNAL" "#define SPDLOG_FMT_EXTERNAL" SPDLOG_TWEAKME_CONTENTS "${SPDLOG_TWEAKME_CONTENTS}")
|
||||
file(WRITE ${CURRENT_PACKAGES_DIR}/include/spdlog/tweakme.h "${SPDLOG_TWEAKME_CONTENTS}")
|
||||
|
||||
# Handle copyright
|
||||
file(COPY ${SOURCE_PATH}/LICENSE DESTINATION ${CURRENT_PACKAGES_DIR}/share/spdlog)
|
||||
|
Loading…
x
Reference in New Issue
Block a user