From 4b2609c148ed7bd7c4dee852f68b17389824d6fa Mon Sep 17 00:00:00 2001 From: Sean Harmer Date: Wed, 13 Apr 2022 12:03:35 +0100 Subject: [PATCH 1/3] Add initial .gitignore --- .gitignore | 2 ++ 1 file changed, 2 insertions(+) create mode 100644 .gitignore diff --git a/.gitignore b/.gitignore new file mode 100644 index 0000000..6cb2227 --- /dev/null +++ b/.gitignore @@ -0,0 +1,2 @@ +.vscode +build/* From 33a458302efa9dea468c6f0f158549fb1665c3e4 Mon Sep 17 00:00:00 2001 From: Sean Harmer Date: Wed, 13 Apr 2022 12:06:48 +0100 Subject: [PATCH 2/3] Modernize the cmake usage To use targets and properties so that lunasvg can be more easily added to external projects using cmake's FetchContent. --- CMakeLists.txt | 70 +++++++++++++++++++++++++++++------- cmake/lunasvgConfig.cmake.in | 3 ++ example/CMakeLists.txt | 2 +- include/CMakeLists.txt | 16 +++++++-- include/lunasvg.h | 11 ++---- 5 files changed, 77 insertions(+), 25 deletions(-) create mode 100644 cmake/lunasvgConfig.cmake.in diff --git a/CMakeLists.txt b/CMakeLists.txt index 9916c67..cb7c3f7 100755 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -1,4 +1,4 @@ -cmake_minimum_required(VERSION 3.3) +cmake_minimum_required(VERSION 3.20) project(lunasvg VERSION 2.3.1 LANGUAGES CXX C) @@ -15,25 +15,69 @@ add_subdirectory(source) add_subdirectory(3rdparty/software) add_subdirectory(3rdparty/plutovg) -if(BUILD_SHARED_LIBS) - target_compile_definitions(lunasvg PUBLIC LUNASVG_SHARED) - target_compile_definitions(lunasvg PRIVATE LUNASVG_EXPORT) +set_target_properties(lunasvg + PROPERTIES + ARCHIVE_OUTPUT_DIRECTORY "${CMAKE_BINARY_DIR}/lib" + LIBRARY_OUTPUT_DIRECTORY "${CMAKE_BINARY_DIR}/lib" + RUNTIME_OUTPUT_DIRECTORY "${CMAKE_BINARY_DIR}/bin" + CXX_VISIBILITY_PRESET hidden + VISIBILITY_INLINES_HIDDEN 1 +) + +add_library(lunasvg::lunasvg ALIAS lunasvg) + +if(NOT BUILD_SHARED_LIBS) + set_target_properties(lunasvg + PROPERTIES + COMPILE_FLAGS -DLUNARSVG_STATIC_DEFINE + ) endif() if(LUNASVG_BUILD_EXAMPLES) add_subdirectory(example) endif() -set(LUNASVG_LIBDIR ${CMAKE_INSTALL_PREFIX}/lib) -set(LUNASVG_INCDIR ${CMAKE_INSTALL_PREFIX}/include) +# +# Installation +# +include(GNUInstallDirs) +install( + FILES + ${CMAKE_CURRENT_SOURCE_DIR}/include/lunasvg.h + ${CMAKE_CURRENT_BINARY_DIR}/include/lunasvg_export.h DESTINATION ${CMAKE_INSTALL_INCLUDEDIR}/lunasvg +) +install( + TARGETS lunasvg + EXPORT lunasvg-targets + LIBRARY DESTINATION ${CMAKE_INSTALL_LIBDIR} + ARCHIVE DESTINATION ${CMAKE_INSTALL_LIBDIR} + RUNTIME DESTINATION ${CMAKE_INSTALL_BINDIR} +) +install( + EXPORT lunasvg-targets + DESTINATION ${CMAKE_INSTALL_LIBDIR}/cmake/lunasvg NAMESPACE lunasvg:: FILE lunasvgTargets.cmake +) + +include(CMakePackageConfigHelpers) +configure_package_config_file( + ${CMAKE_CURRENT_SOURCE_DIR}/cmake/lunasvgConfig.cmake.in + ${CMAKE_CURRENT_BINARY_DIR}/lunasvgConfig.cmake + INSTALL_DESTINATION + ${CMAKE_INSTALL_LIBDIR}/cmake/lunasvg +) -install(FILES - include/lunasvg.h - DESTINATION ${LUNASVG_INCDIR} +write_basic_package_version_file(lunasvgConfigVersion.cmake + VERSION ${PROJECT_VERSION} + COMPATIBILITY SameMajorVersion ) -install(TARGETS lunasvg - LIBRARY DESTINATION ${LUNASVG_LIBDIR} - ARCHIVE DESTINATION ${LUNASVG_LIBDIR} - INCLUDES DESTINATION ${LUNASVG_INCDIR} +install(FILES + ${CMAKE_CURRENT_BINARY_DIR}/lunasvgConfig.cmake + ${CMAKE_CURRENT_BINARY_DIR}/lunasvgConfigVersion.cmake + DESTINATION ${CMAKE_INSTALL_LIBDIR}/cmake/lunasvg ) + +export(EXPORT lunasvg-targets FILE ${CMAKE_CURRENT_BINARY_DIR}/lunasvgTargets.cmake NAMESPACE lunasvg::) + +# Register package in user's package registry +export(PACKAGE lunasvg) diff --git a/cmake/lunasvgConfig.cmake.in b/cmake/lunasvgConfig.cmake.in new file mode 100644 index 0000000..850098f --- /dev/null +++ b/cmake/lunasvgConfig.cmake.in @@ -0,0 +1,3 @@ +@PACKAGE_INIT@ + +include("${CMAKE_CURRENT_LIST_DIR}/lunasvgTargets.cmake") diff --git a/example/CMakeLists.txt b/example/CMakeLists.txt index 53ec5ef..5c8ca91 100644 --- a/example/CMakeLists.txt +++ b/example/CMakeLists.txt @@ -1,4 +1,4 @@ -cmake_minimum_required(VERSION 3.3) +cmake_minimum_required(VERSION 3.20) set(CMAKE_CXX_STANDARD 14) diff --git a/include/CMakeLists.txt b/include/CMakeLists.txt index de58954..70d896f 100755 --- a/include/CMakeLists.txt +++ b/include/CMakeLists.txt @@ -1,4 +1,16 @@ +# Generate a standard header with export macros +include(GenerateExportHeader) +generate_export_header(lunasvg) + target_include_directories(lunasvg -PUBLIC - "${CMAKE_CURRENT_LIST_DIR}" + # When building a project that uses the lunasvg library, + # we need to look in the installed include directory + PUBLIC + $ + + # When building the lunasvg library we need to look in the + # build dir for the lunasvg_export.h header and in the source + # dir for other headers + $ + $ ) diff --git a/include/lunasvg.h b/include/lunasvg.h index c83c27c..74c7e37 100644 --- a/include/lunasvg.h +++ b/include/lunasvg.h @@ -26,15 +26,8 @@ #include #include -#if defined(_MSC_VER) && defined(LUNASVG_SHARED) -#ifdef LUNASVG_EXPORT -#define LUNASVG_API __declspec(dllexport) -#else -#define LUNASVG_API __declspec(dllimport) -#endif -#else -#define LUNASVG_API -#endif +#include +#define LUNASVG_API LUNASVG_EXPORT namespace lunasvg { From b08d7d03a2975989717f873a7bbbe545b623e80f Mon Sep 17 00:00:00 2001 From: Sean Harmer Date: Thu, 21 Apr 2022 13:21:24 +0100 Subject: [PATCH 3/3] Relax the cmake version and other improvements Based upon feedback. --- CMakeLists.txt | 17 +++++++---------- example/CMakeLists.txt | 2 +- 2 files changed, 8 insertions(+), 11 deletions(-) diff --git a/CMakeLists.txt b/CMakeLists.txt index cb7c3f7..2b324f8 100755 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -1,10 +1,15 @@ -cmake_minimum_required(VERSION 3.20) +cmake_minimum_required(VERSION 3.13) project(lunasvg VERSION 2.3.1 LANGUAGES CXX C) set(CMAKE_CXX_STANDARD 14) set(CMAKE_C_STANDARD 11) +# Default to hidden visibility for symbols +set(CMAKE_C_VISIBILITY_PRESET hidden) +set(CMAKE_CXX_VISIBILITY_PRESET hidden) +set(CMAKE_VISIBILITY_INLINES_HIDDEN 1) + option(BUILD_SHARED_LIBS "Builds as shared library" OFF) option(LUNASVG_BUILD_EXAMPLES "Builds examples" OFF) @@ -20,17 +25,12 @@ set_target_properties(lunasvg ARCHIVE_OUTPUT_DIRECTORY "${CMAKE_BINARY_DIR}/lib" LIBRARY_OUTPUT_DIRECTORY "${CMAKE_BINARY_DIR}/lib" RUNTIME_OUTPUT_DIRECTORY "${CMAKE_BINARY_DIR}/bin" - CXX_VISIBILITY_PRESET hidden - VISIBILITY_INLINES_HIDDEN 1 ) add_library(lunasvg::lunasvg ALIAS lunasvg) if(NOT BUILD_SHARED_LIBS) - set_target_properties(lunasvg - PROPERTIES - COMPILE_FLAGS -DLUNARSVG_STATIC_DEFINE - ) + target_compile_definitions(lunasvg PUBLIC LUNASVG_STATIC_DEFINE) endif() if(LUNASVG_BUILD_EXAMPLES) @@ -78,6 +78,3 @@ install(FILES ) export(EXPORT lunasvg-targets FILE ${CMAKE_CURRENT_BINARY_DIR}/lunasvgTargets.cmake NAMESPACE lunasvg::) - -# Register package in user's package registry -export(PACKAGE lunasvg) diff --git a/example/CMakeLists.txt b/example/CMakeLists.txt index 5c8ca91..de18b31 100644 --- a/example/CMakeLists.txt +++ b/example/CMakeLists.txt @@ -1,4 +1,4 @@ -cmake_minimum_required(VERSION 3.20) +cmake_minimum_required(VERSION 3.13) set(CMAKE_CXX_STANDARD 14)