add cmake target aliases

This commit is contained in:
BlackMATov
2022-12-31 04:54:41 +07:00
parent 761eb11e47
commit 02cb0fabfb
8 changed files with 35 additions and 28 deletions

View File

@@ -27,6 +27,8 @@ project(meta.hpp
HOMEPAGE_URL "https://github.com/blackmatov/meta.hpp") HOMEPAGE_URL "https://github.com/blackmatov/meta.hpp")
add_library(${PROJECT_NAME} INTERFACE) add_library(${PROJECT_NAME} INTERFACE)
add_library(meta.hpp::meta.hpp ALIAS ${PROJECT_NAME})
target_compile_features(${PROJECT_NAME} INTERFACE cxx_std_20) target_compile_features(${PROJECT_NAME} INTERFACE cxx_std_20)
target_include_directories(${PROJECT_NAME} INTERFACE headers) target_include_directories(${PROJECT_NAME} INTERFACE headers)

View File

@@ -41,7 +41,7 @@ Also, you can add the root repository directory to your [cmake](https://cmake.or
```cmake ```cmake
add_subdirectory(external/meta.hpp) 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 ## Examples

View File

@@ -1,14 +1,15 @@
# https://clang.llvm.org/docs/AddressSanitizer.html # 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 -fsanitize=address
-fno-omit-frame-pointer -fno-omit-frame-pointer
-fsanitize-address-use-after-scope -fsanitize-address-use-after-scope
-fsanitize-address-use-after-return=always) -fsanitize-address-use-after-return=always)
target_link_options(enable_asan INTERFACE target_link_options(${PROJECT_NAME}.enable_asan INTERFACE
-fsanitize=address -fsanitize=address
-fno-omit-frame-pointer -fno-omit-frame-pointer
-fsanitize-address-use-after-scope -fsanitize-address-use-after-scope

View File

@@ -1,9 +1,10 @@
# https://clang.llvm.org/docs/SourceBasedCodeCoverage.html # 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) --coverage)
target_link_options(enable_gcov INTERFACE target_link_options(${PROJECT_NAME}.enable_gcov INTERFACE
--coverage) --coverage)

View File

@@ -1,11 +1,12 @@
# https://clang.llvm.org/docs/UndefinedBehaviorSanitizer.html # 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 -fsanitize=undefined
-fno-omit-frame-pointer) -fno-omit-frame-pointer)
target_link_options(enable_ubsan INTERFACE target_link_options(${PROJECT_NAME}.enable_ubsan INTERFACE
-fsanitize=undefined -fsanitize=undefined
-fno-omit-frame-pointer) -fno-omit-frame-pointer)

View File

@@ -4,10 +4,10 @@ file(GLOB_RECURSE MANUALS_SOURCES "*.cpp" "*.hpp")
source_group(TREE ${CMAKE_CURRENT_SOURCE_DIR} FILES ${MANUALS_SOURCES}) source_group(TREE ${CMAKE_CURRENT_SOURCE_DIR} FILES ${MANUALS_SOURCES})
add_executable(${PROJECT_NAME} ${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}) 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 # setup defines
@@ -27,14 +27,14 @@ setup_defines_for_target(${PROJECT_NAME}.singles)
# #
function(setup_libraries_for_target TARGET) 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}) if(${BUILD_WITH_COVERAGE})
target_link_libraries(${TARGET} PRIVATE enable_gcov) target_link_libraries(${TARGET} PRIVATE meta.hpp::enable_gcov)
endif() endif()
if(${BUILD_WITH_SANITIZERS}) 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() endif()
endfunction() endfunction()

View File

@@ -6,24 +6,26 @@ project(meta.hpp.singles)
find_package(Python3 REQUIRED COMPONENTS Interpreter) find_package(Python3 REQUIRED COMPONENTS Interpreter)
set(META_ROOT_DIR "${CMAKE_CURRENT_SOURCE_DIR}/..") set(META_HPP_ROOT_DIR "${CMAKE_CURRENT_SOURCE_DIR}/..")
set(META_SINGLES_INPUT "${META_ROOT_DIR}/headers/meta.hpp/meta_all.hpp") set(META_HPP_SINGLES_INPUT "${META_HPP_ROOT_DIR}/headers/meta.hpp/meta_all.hpp")
set(META_SINGLES_OUTPUT "${META_ROOT_DIR}/singles/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_ROOT_DIR}/headers/*.hpp") file(GLOB_RECURSE META_SINGLES_DEPENDS "${META_HPP_ROOT_DIR}/headers/*.hpp")
add_custom_command(OUTPUT "${META_SINGLES_OUTPUT}" add_custom_command(OUTPUT "${META_HPP_SINGLES_OUTPUT}"
COMMAND "${Python3_EXECUTABLE}" "singles/scripts/build_singles.py" "${META_SINGLES_INPUT}" "${META_SINGLES_OUTPUT}" COMMAND "${Python3_EXECUTABLE}" "singles/scripts/build_singles.py" "${META_HPP_SINGLES_INPUT}" "${META_HPP_SINGLES_OUTPUT}"
DEPENDS ${META_SINGLES_DEPENDS} DEPENDS ${META_SINGLES_DEPENDS}
WORKING_DIRECTORY "${META_ROOT_DIR}") WORKING_DIRECTORY "${META_HPP_ROOT_DIR}")
add_custom_target(${PROJECT_NAME}.generate add_custom_target(${PROJECT_NAME}.generate
DEPENDS "${META_SINGLES_OUTPUT}") DEPENDS "${META_HPP_SINGLES_OUTPUT}")
# #
# library # library
# #
add_library(${PROJECT_NAME} INTERFACE) add_library(${PROJECT_NAME} INTERFACE)
add_library(meta.hpp::singles ALIAS ${PROJECT_NAME})
add_dependencies(${PROJECT_NAME} ${PROJECT_NAME}.generate) add_dependencies(${PROJECT_NAME} ${PROJECT_NAME}.generate)
target_compile_features(${PROJECT_NAME} INTERFACE cxx_std_20) target_compile_features(${PROJECT_NAME} INTERFACE cxx_std_20)
target_include_directories(${PROJECT_NAME} INTERFACE headers) target_include_directories(${PROJECT_NAME} INTERFACE headers)

View File

@@ -4,10 +4,10 @@ file(GLOB_RECURSE UNTESTS_SOURCES "*.cpp" "*.hpp")
source_group(TREE ${CMAKE_CURRENT_SOURCE_DIR} FILES ${UNTESTS_SOURCES}) source_group(TREE ${CMAKE_CURRENT_SOURCE_DIR} FILES ${UNTESTS_SOURCES})
add_executable(${PROJECT_NAME} ${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}) 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 # setup defines
@@ -27,14 +27,14 @@ setup_defines_for_target(${PROJECT_NAME}.singles)
# #
function(setup_libraries_for_target TARGET) 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}) if(${BUILD_WITH_COVERAGE})
target_link_libraries(${TARGET} PRIVATE enable_gcov) target_link_libraries(${TARGET} PRIVATE meta.hpp::enable_gcov)
endif() endif()
if(${BUILD_WITH_SANITIZERS}) 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() endif()
endfunction() endfunction()