diff --git a/CMakeLists.txt b/CMakeLists.txt index d745fb3..fb5b869 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -27,6 +27,8 @@ project(meta.hpp HOMEPAGE_URL "https://github.com/blackmatov/meta.hpp") add_library(${PROJECT_NAME} INTERFACE) +add_library(meta.hpp::meta.hpp ALIAS ${PROJECT_NAME}) + target_compile_features(${PROJECT_NAME} INTERFACE cxx_std_20) target_include_directories(${PROJECT_NAME} INTERFACE headers) diff --git a/README.md b/README.md index 90e937d..bc9a06c 100644 --- a/README.md +++ b/README.md @@ -41,7 +41,7 @@ Also, you can add the root repository directory to your [cmake](https://cmake.or ```cmake add_subdirectory(external/meta.hpp) -target_link_libraries(your_project_target meta.hpp) +target_link_libraries(your_project_target PUBLIC meta.hpp::meta.hpp) ``` ## Examples diff --git a/cmake/EnableASan.cmake b/cmake/EnableASan.cmake index 83a9be5..1af49c9 100644 --- a/cmake/EnableASan.cmake +++ b/cmake/EnableASan.cmake @@ -1,14 +1,15 @@ # https://clang.llvm.org/docs/AddressSanitizer.html -add_library(enable_asan INTERFACE) +add_library(${PROJECT_NAME}.enable_asan INTERFACE) +add_library(${PROJECT_NAME}::enable_asan ALIAS ${PROJECT_NAME}.enable_asan) -target_compile_options(enable_asan INTERFACE +target_compile_options(${PROJECT_NAME}.enable_asan INTERFACE -fsanitize=address -fno-omit-frame-pointer -fsanitize-address-use-after-scope -fsanitize-address-use-after-return=always) -target_link_options(enable_asan INTERFACE +target_link_options(${PROJECT_NAME}.enable_asan INTERFACE -fsanitize=address -fno-omit-frame-pointer -fsanitize-address-use-after-scope diff --git a/cmake/EnableGCov.cmake b/cmake/EnableGCov.cmake index f390dd4..e98ea88 100644 --- a/cmake/EnableGCov.cmake +++ b/cmake/EnableGCov.cmake @@ -1,9 +1,10 @@ # https://clang.llvm.org/docs/SourceBasedCodeCoverage.html -add_library(enable_gcov INTERFACE) +add_library(${PROJECT_NAME}.enable_gcov INTERFACE) +add_library(${PROJECT_NAME}::enable_gcov ALIAS ${PROJECT_NAME}.enable_gcov) -target_compile_options(enable_gcov INTERFACE +target_compile_options(${PROJECT_NAME}.enable_gcov INTERFACE --coverage) -target_link_options(enable_gcov INTERFACE +target_link_options(${PROJECT_NAME}.enable_gcov INTERFACE --coverage) diff --git a/cmake/EnableUBSan.cmake b/cmake/EnableUBSan.cmake index ee954ff..358b14d 100644 --- a/cmake/EnableUBSan.cmake +++ b/cmake/EnableUBSan.cmake @@ -1,11 +1,12 @@ # https://clang.llvm.org/docs/UndefinedBehaviorSanitizer.html -add_library(enable_ubsan INTERFACE) +add_library(${PROJECT_NAME}.enable_ubsan INTERFACE) +add_library(${PROJECT_NAME}::enable_ubsan ALIAS ${PROJECT_NAME}.enable_ubsan) -target_compile_options(enable_ubsan INTERFACE +target_compile_options(${PROJECT_NAME}.enable_ubsan INTERFACE -fsanitize=undefined -fno-omit-frame-pointer) -target_link_options(enable_ubsan INTERFACE +target_link_options(${PROJECT_NAME}.enable_ubsan INTERFACE -fsanitize=undefined -fno-omit-frame-pointer) diff --git a/manuals/CMakeLists.txt b/manuals/CMakeLists.txt index 3e214f3..9a959a7 100644 --- a/manuals/CMakeLists.txt +++ b/manuals/CMakeLists.txt @@ -4,10 +4,10 @@ file(GLOB_RECURSE MANUALS_SOURCES "*.cpp" "*.hpp") source_group(TREE ${CMAKE_CURRENT_SOURCE_DIR} FILES ${MANUALS_SOURCES}) add_executable(${PROJECT_NAME} ${MANUALS_SOURCES}) -target_link_libraries(${PROJECT_NAME} PRIVATE meta.hpp) +target_link_libraries(${PROJECT_NAME} PRIVATE meta.hpp::meta.hpp) add_executable(${PROJECT_NAME}.singles ${MANUALS_SOURCES}) -target_link_libraries(${PROJECT_NAME}.singles PRIVATE meta.hpp.singles) +target_link_libraries(${PROJECT_NAME}.singles PRIVATE meta.hpp::singles) # # setup defines @@ -27,14 +27,14 @@ setup_defines_for_target(${PROJECT_NAME}.singles) # function(setup_libraries_for_target TARGET) - target_link_libraries(${TARGET} PRIVATE doctest_with_main) + target_link_libraries(${TARGET} PRIVATE doctest::doctest_with_main) if(${BUILD_WITH_COVERAGE}) - target_link_libraries(${TARGET} PRIVATE enable_gcov) + target_link_libraries(${TARGET} PRIVATE meta.hpp::enable_gcov) endif() if(${BUILD_WITH_SANITIZERS}) - target_link_libraries(${TARGET} PRIVATE enable_asan enable_ubsan) + target_link_libraries(${TARGET} PRIVATE meta.hpp::enable_asan meta.hpp::enable_ubsan) endif() endfunction() diff --git a/singles/CMakeLists.txt b/singles/CMakeLists.txt index 993a5d1..9c784a8 100644 --- a/singles/CMakeLists.txt +++ b/singles/CMakeLists.txt @@ -6,24 +6,26 @@ project(meta.hpp.singles) find_package(Python3 REQUIRED COMPONENTS Interpreter) -set(META_ROOT_DIR "${CMAKE_CURRENT_SOURCE_DIR}/..") -set(META_SINGLES_INPUT "${META_ROOT_DIR}/headers/meta.hpp/meta_all.hpp") -set(META_SINGLES_OUTPUT "${META_ROOT_DIR}/singles/headers/meta.hpp/meta_all.hpp") -file(GLOB_RECURSE META_SINGLES_DEPENDS "${META_ROOT_DIR}/headers/*.hpp") +set(META_HPP_ROOT_DIR "${CMAKE_CURRENT_SOURCE_DIR}/..") +set(META_HPP_SINGLES_INPUT "${META_HPP_ROOT_DIR}/headers/meta.hpp/meta_all.hpp") +set(META_HPP_SINGLES_OUTPUT "${META_HPP_ROOT_DIR}/singles/headers/meta.hpp/meta_all.hpp") +file(GLOB_RECURSE META_SINGLES_DEPENDS "${META_HPP_ROOT_DIR}/headers/*.hpp") -add_custom_command(OUTPUT "${META_SINGLES_OUTPUT}" - COMMAND "${Python3_EXECUTABLE}" "singles/scripts/build_singles.py" "${META_SINGLES_INPUT}" "${META_SINGLES_OUTPUT}" +add_custom_command(OUTPUT "${META_HPP_SINGLES_OUTPUT}" + COMMAND "${Python3_EXECUTABLE}" "singles/scripts/build_singles.py" "${META_HPP_SINGLES_INPUT}" "${META_HPP_SINGLES_OUTPUT}" DEPENDS ${META_SINGLES_DEPENDS} - WORKING_DIRECTORY "${META_ROOT_DIR}") + WORKING_DIRECTORY "${META_HPP_ROOT_DIR}") add_custom_target(${PROJECT_NAME}.generate - DEPENDS "${META_SINGLES_OUTPUT}") + DEPENDS "${META_HPP_SINGLES_OUTPUT}") # # library # add_library(${PROJECT_NAME} INTERFACE) +add_library(meta.hpp::singles ALIAS ${PROJECT_NAME}) + add_dependencies(${PROJECT_NAME} ${PROJECT_NAME}.generate) target_compile_features(${PROJECT_NAME} INTERFACE cxx_std_20) target_include_directories(${PROJECT_NAME} INTERFACE headers) diff --git a/untests/CMakeLists.txt b/untests/CMakeLists.txt index c8a425f..8cec3ff 100644 --- a/untests/CMakeLists.txt +++ b/untests/CMakeLists.txt @@ -4,10 +4,10 @@ file(GLOB_RECURSE UNTESTS_SOURCES "*.cpp" "*.hpp") source_group(TREE ${CMAKE_CURRENT_SOURCE_DIR} FILES ${UNTESTS_SOURCES}) add_executable(${PROJECT_NAME} ${UNTESTS_SOURCES}) -target_link_libraries(${PROJECT_NAME} PRIVATE meta.hpp) +target_link_libraries(${PROJECT_NAME} PRIVATE meta.hpp::meta.hpp) add_executable(${PROJECT_NAME}.singles ${UNTESTS_SOURCES}) -target_link_libraries(${PROJECT_NAME}.singles PRIVATE meta.hpp.singles) +target_link_libraries(${PROJECT_NAME}.singles PRIVATE meta.hpp::singles) # # setup defines @@ -27,14 +27,14 @@ setup_defines_for_target(${PROJECT_NAME}.singles) # function(setup_libraries_for_target TARGET) - target_link_libraries(${TARGET} PRIVATE doctest_with_main) + target_link_libraries(${TARGET} PRIVATE doctest::doctest_with_main) if(${BUILD_WITH_COVERAGE}) - target_link_libraries(${TARGET} PRIVATE enable_gcov) + target_link_libraries(${TARGET} PRIVATE meta.hpp::enable_gcov) endif() if(${BUILD_WITH_SANITIZERS}) - target_link_libraries(${TARGET} PRIVATE enable_asan enable_ubsan) + target_link_libraries(${TARGET} PRIVATE meta.hpp::enable_asan meta.hpp::enable_ubsan) endif() endfunction()