Skip to content

Commit

Permalink
Merge pull request #4994 from cneumann/fix-spdlog-external-fmt
Browse files Browse the repository at this point in the history
[spdlog] Fix spdlog handling of external fmt lib
  • Loading branch information
Rastaban committed Dec 21, 2018
2 parents ebe86ab + 3d164e3 commit 501abec
Show file tree
Hide file tree
Showing 2 changed files with 104 additions and 4 deletions.
100 changes: 100 additions & 0 deletions ports/spdlog/fmt-external-cmake-option.patch
Original file line number Diff line number Diff line change
@@ -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()
8 changes: 4 additions & 4 deletions ports/spdlog/portfile.cmake
Original file line number Diff line number Diff line change
Expand Up @@ -6,13 +6,16 @@ vcpkg_from_github(
REF v1.2.1
SHA512 418f91efc207fa227558212d82c41639c0bb59e84ea47447e0b6276c4842e97f1f8aaf5802c071ef15d80ec525e317e70b6a39661a6c96ab39d33d9bd1570da1
HEAD_REF v1.x
PATCHES
fmt-external-cmake-option.patch # This patch is in the upstream project and can be removed next version update.
)

vcpkg_configure_cmake(
SOURCE_PATH ${SOURCE_PATH}
PREFER_NINJA
OPTIONS
-DSPDLOG_BUILD_TESTING=OFF
-DSPDLOG_FMT_EXTERNAL=ON
)

vcpkg_install_cmake()
Expand All @@ -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)
Expand Down

0 comments on commit 501abec

Please sign in to comment.