mirror of
https://github.com/BlackMATov/meta.hpp.git
synced 2025-12-15 11:52:08 +07:00
add cmake target aliases
This commit is contained in:
@@ -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)
|
||||||
|
|
||||||
|
|||||||
@@ -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
|
||||||
|
|||||||
@@ -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
|
||||||
|
|||||||
@@ -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)
|
||||||
|
|||||||
@@ -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)
|
||||||
|
|||||||
@@ -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()
|
||||||
|
|
||||||
|
|||||||
@@ -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)
|
||||||
|
|||||||
@@ -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()
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user