This commit is contained in:
Andrei Astafev 2022-10-01 17:35:11 +03:00
parent 3f0b64cee7
commit ecc83c05a8
10 changed files with 146 additions and 64 deletions

2
.gitignore vendored
View File

@ -67,7 +67,7 @@ tags
### ###
# #
export_autogen.hpp *_export.hpp
# Prerequisites # Prerequisites
*.d *.d

View File

@ -9,27 +9,31 @@ project(msg VERSION 1.1.1 LANGUAGES CXX)
### ###
# Подключение дополнительных функций для CMake # Подключение дополнительных функций для CMake
# По умолчанию предполагается использование версии MyxCMake,
# файлы которой находятся в каталоге `cmake/myx` текущего проекта.
# Если определена переменная `MYX_CMAKE_USE_SYSTEM`, то выполняется
# поиск версии в каталогах перечисленных в переменной `CMAKE_MODULES_DIR`.
### ###
find_package(MyxCMake 1.99.9 PATHS ${PROJECT_SOURCE_DIR}/cmake/myx NO_DEFAULT_PATH QUIET REQUIRED) if(MYX_CMAKE_USE_SYSTEM)
find_package(MyxCMake 1.99.9 PATHS "${PROJECT_SOURCE_DIR}/cmake/myx" NO_DEFAULT_PATH QUIET REQUIRED)
else()
include(${PROJECT_SOURCE_DIR}/cmake/myx/MyxCMakeConfig.cmake)
endif()
# Если проект верхнего уровня, подключаем зависимости # Если проект верхнего уровня, подключаем зависимости
# с помощью модуля FetchContent # с помощью модуля FetchContent
if(PROJECT_IS_TOP_LEVEL) if(PROJECT_IS_TOP_LEVEL)
include(FetchContent) FetchContent_Add(pow
FetchContent_Declare(pow
GIT_REPOSITORY https://git.246060.ru/cmake/pow GIT_REPOSITORY https://git.246060.ru/cmake/pow
) GIT_PATH cmake/pow
if(NOT pow_POPULATED) GIT_REMOTE origin
FetchContent_Populate(pow) )
add_subdirectory(${pow_SOURCE_DIR} ${pow_BINARY_DIR})
endif()
endif() endif()
# Цель для компиляции объектных файлов разделяемой библиотеки # Цель для компиляции объектных файлов разделяемой библиотеки
myx_add_library(${PROJECT_NAME} myx_add_library(${PROJECT_NAME} OBJECT)
TYPE OBJECT
)
# Настройка свойств цели
myx_target_setup(${PROJECT_NAME} myx_target_setup(${PROJECT_NAME}
SOURCES SOURCES
${PROJECT_SOURCE_DIR}/include/msg/message.hpp ${PROJECT_SOURCE_DIR}/include/msg/message.hpp
@ -40,6 +44,5 @@ myx_target_setup(${PROJECT_NAME}
pow pow
) )
if(PROJECT_IS_TOP_LEVEL) # Команды для установки библиотеки
myx_install_library(${PROJECT_NAME}) myx_install_library(${PROJECT_NAME})
endif()

View File

@ -3,23 +3,22 @@ cmake_policy(SET CMP0057 NEW) # IN_LIST operator
get_filename_component(MYX_CMAKE_SOURCE_DIR "${CMAKE_CURRENT_LIST_FILE}" DIRECTORY) get_filename_component(MYX_CMAKE_SOURCE_DIR "${CMAKE_CURRENT_LIST_FILE}" DIRECTORY)
set(MYX_CMAKE_CONFIG_DIR "${MYX_CMAKE_SOURCE_DIR}/config")
set(MYX_CMAKE_BACKPORTS_DIR "${MYX_CMAKE_SOURCE_DIR}/backports") set(MYX_CMAKE_BACKPORTS_DIR "${MYX_CMAKE_SOURCE_DIR}/backports")
set(MYX_CMAKE_LIB_DIR "${MYX_CMAKE_SOURCE_DIR}/lib") set(MYX_CMAKE_LIB_DIR "${MYX_CMAKE_SOURCE_DIR}/lib")
include(${MYX_CMAKE_CONFIG_DIR}/Globals.cmake)
include(${MYX_CMAKE_BACKPORTS_DIR}/IncludeGuard.cmake) include(${MYX_CMAKE_BACKPORTS_DIR}/IncludeGuard.cmake)
include(${MYX_CMAKE_BACKPORTS_DIR}/TopLevelProject.cmake) include(${MYX_CMAKE_BACKPORTS_DIR}/TopLevelProject.cmake)
if(${CMAKE_VERSION} VERSION_LESS "3.11.0") if(${CMAKE_VERSION} VERSION_LESS "3.11.0")
include(${MYX_CMAKE_BACKPORTS_DIR}/FetchContent.cmake) include(${MYX_CMAKE_BACKPORTS_DIR}/FetchContent.cmake)
endif() endif()
include(${MYX_CMAKE_LIB_DIR}/Includes.cmake)
include(${MYX_CMAKE_LIB_DIR}/ColoredMessages.cmake) include(${MYX_CMAKE_LIB_DIR}/ColoredMessages.cmake)
include(${MYX_CMAKE_LIB_DIR}/NinjaGeneratorWarning.cmake) include(${MYX_CMAKE_LIB_DIR}/NinjaGeneratorWarning.cmake)
include(${MYX_CMAKE_LIB_DIR}/DirectoriesGuards.cmake) include(${MYX_CMAKE_LIB_DIR}/DirectoriesGuards.cmake)
include(${MYX_CMAKE_LIB_DIR}/SemanticProjectVersion.cmake) include(${MYX_CMAKE_LIB_DIR}/SemanticProjectVersion.cmake)
include(${MYX_CMAKE_LIB_DIR}/NinjaGeneratorWrapper.cmake) include(${MYX_CMAKE_LIB_DIR}/NinjaGeneratorWrapper.cmake)
include(${MYX_CMAKE_LIB_DIR}/FetchContentAdd.cmake)
include(${MYX_CMAKE_LIB_DIR}/AddLibrary.cmake) include(${MYX_CMAKE_LIB_DIR}/AddLibrary.cmake)
include(${MYX_CMAKE_LIB_DIR}/InstallLibrary.cmake) include(${MYX_CMAKE_LIB_DIR}/InstallLibrary.cmake)
@ -28,7 +27,6 @@ include(${MYX_CMAKE_LIB_DIR}/Qt5TargetSetup.cmake)
unset(MYX_CMAKE_SOURCE_DIR) unset(MYX_CMAKE_SOURCE_DIR)
unset(MYX_CMAKE_BACKPORTS_DIR) unset(MYX_CMAKE_BACKPORTS_DIR)
unset(MYX_CMAKE_CONFIG_DIR)
unset(MYX_CMAKE_LIB_DIR) unset(MYX_CMAKE_LIB_DIR)
cmake_policy(POP) cmake_policy(POP)

View File

@ -1,8 +0,0 @@
include(GNUInstallDirs)
#set(CMAKE_ARCHIVE_OUTPUT_DIRECTORY ${PROJECT_BINARY_DIR}/${CMAKE_INSTALL_LIBDIR} PARENT_SCOPE)
#set(CMAKE_LIBRARY_OUTPUT_DIRECTORY ${PROJECT_BINARY_DIR}/${CMAKE_INSTALL_LIBDIR} PARENT_SCOPE)
#set(CMAKE_RUNTIME_OUTPUT_DIRECTORY ${PROJECT_BINARY_DIR}/${CMAKE_INSTALL_BINDIR} PARENT_SCOPE)
#set(MYX_CMAKE_SCRIPTS_PREFIX ${CMAKE_INSTALL_LIBDIR}/cmake/${PROJECT_NAME} PARENT_SCOPE)

View File

@ -1,20 +1,42 @@
#[=======================================================================[.rst:
myx_add_library
---------------
Вспомогательная функция для создания библиотеки::
myx_add_library(NAME TYPE)
Обязательные параметры: `NAME` - имя библиотеки и `TYPE` - тип цели.
Все остальные параметры передаются стандартной функции `add_library()`
#]=======================================================================]
include_guard(GLOBAL) include_guard(GLOBAL)
include(GenerateExportHeader) include(GenerateExportHeader)
function(myx_add_library NAME) function(myx_add_library NAME TYPE)
set(options) set(options)
set(oneValueArgs TYPE) set(oneValueArgs)
set(multiValueArgs SOURCES) set(multiValueArgs)
cmake_parse_arguments(arg "${options}" "${oneValueArgs}" "${multiValueArgs}" ${ARGN})
if(NOT arg_TYPE) cmake_parse_arguments(ARG "${options}" "${oneValueArgs}" "${multiValueArgs}" ${ARGN})
set(arg_TYPE "OBJECT")
# Вызов стандартной функции `add_library()`
add_library(${NAME} ${TYPE} ${ARG_UNPARSED_ARGUMENTS})
# Если вызов был выполнен не из проекта верхнего уровня,
# то созданная цель исключается из цели `all`.
# При этом сама цель `${NAME}` может участвовать в сборке,
# если окажется в перечне зависимостей.
if(NOT PROJECT_IS_TOP_LEVEL)
set_target_properties(${NAME} PROPERTIES
EXCLUDE_FROM_ALL True
)
endif() endif()
add_library(${NAME} ${arg_TYPE}) if(TYPE STREQUAL INTERFACE)
# Стандартные пути к заголовочным файлам
if(arg_TYPE STREQUAL INTERFACE)
target_include_directories(${NAME} target_include_directories(${NAME}
INTERFACE INTERFACE
$<BUILD_INTERFACE:${PROJECT_SOURCE_DIR}/include> $<BUILD_INTERFACE:${PROJECT_SOURCE_DIR}/include>
@ -27,10 +49,12 @@ function(myx_add_library NAME)
# Опция для разрешения сборки статической библиотеки # Опция для разрешения сборки статической библиотеки
option(${PROJECT_NAME_UPPER}_BUILD_STATIC "Build static library" ON) option(${PROJECT_NAME_UPPER}_BUILD_STATIC "Build static library" ON)
# Стандартные пути к заголовочным файлам
target_include_directories(${NAME} target_include_directories(${NAME}
PUBLIC PUBLIC
$<BUILD_INTERFACE:${PROJECT_SOURCE_DIR}/include> $<BUILD_INTERFACE:${PROJECT_SOURCE_DIR}/include>
PRIVATE PRIVATE
$<BUILD_INTERFACE:${PROJECT_SOURCE_DIR}/src>
$<INSTALL_INTERFACE:${CMAKE_INSTALL_INCLUDEDIR}> $<INSTALL_INTERFACE:${CMAKE_INSTALL_INCLUDEDIR}>
) )
@ -38,14 +62,14 @@ function(myx_add_library NAME)
string(TOUPPER ${NAME} suffix) string(TOUPPER ${NAME} suffix)
generate_export_header(${NAME} generate_export_header(${NAME}
BASE_NAME "${suffix}" BASE_NAME ${suffix}
EXPORT_MACRO_NAME "EXPORT_${suffix}" EXPORT_MACRO_NAME "EXPORT_${suffix}"
DEPRECATED_MACRO_NAME "DEPRECATED_${suffix}" DEPRECATED_MACRO_NAME "DEPRECATED_${suffix}"
NO_DEPRECATED_MACRO_NAME "NO_DEPRECATED_${suffix}" NO_DEPRECATED_MACRO_NAME "NO_DEPRECATED_${suffix}"
NO_EXPORT_MACRO_NAME "NO_EXPORT_${suffix}" NO_EXPORT_MACRO_NAME "NO_EXPORT_${suffix}"
STATIC_DEFINE "STATIC_DEFINE_${suffix}" STATIC_DEFINE "STATIC_DEFINE_${suffix}"
EXPORT_FILE_NAME "${PROJECT_SOURCE_DIR}/include/${NAME}/export_autogen.hpp" EXPORT_FILE_NAME "${PROJECT_SOURCE_DIR}/include/${NAME}/${NAME}_export.hpp"
DEFINE_NO_DEPRECATED DEFINE_NO_DEPRECATED
) )
# Цель для создания разделяемой библиотеки из объектных файлов # Цель для создания разделяемой библиотеки из объектных файлов

View File

@ -1,4 +1,9 @@
# Обёртки для функций вывода сообщений #[=======================================================================[.rst:
Обёртки для функции `message()`, которые в терминале UNIX
подсвечиают сообщения в зависимости от важности.
#]=======================================================================]
include_guard(GLOBAL) include_guard(GLOBAL)
@ -22,14 +27,22 @@ if(DEFINED ENV{TERM} AND UNIX)
set(MyxColorBoldWhite "${Esc}[1;37m") set(MyxColorBoldWhite "${Esc}[1;37m")
endif() endif()
function(myx_message_error) function(myx_message_fatal_error)
message(FATAL_ERROR ${MyxColorBoldRed}${ARGV}${MyxColorReset}) message(FATAL_ERROR ${MyxColorBoldRed}${ARGV}${MyxColorReset})
endfunction() endfunction()
function(myx_message_send_error)
message(SEND_ERROR ${MyxColorBoldRed}${ARGV}${MyxColorReset})
endfunction()
function(myx_message_warning) function(myx_message_warning)
message(WARNING ${MyxColorRed}${ARGV}${MyxColorReset}) message(WARNING ${MyxColorRed}${ARGV}${MyxColorReset})
endfunction() endfunction()
function(myx_message_deprecation)
message(DEPRECATION ${MyxColorBoldMagenta}${ARGV}${MyxColorReset})
endfunction()
function(myx_message_status) function(myx_message_status)
message(STATUS ${MyxColorMagenta}${ARGV}${MyxColorReset}) message(STATUS ${MyxColorMagenta}${ARGV}${MyxColorReset})
endfunction() endfunction()

View File

@ -1,8 +1,12 @@
# Запись результатов сборки проекта внутрь иерархии каталогов с исходными текстами #[=======================================================================[.rst:
# приводит к засорению файлами формируемыми на этапе сборки, которые затрудняют
# разработку, поиск в оригинальных файлах и мешают ориентироваться в проекте. Запись результатов сборки проекта внутрь иерархии каталогов с исходными текстами
# При работе с несколькими типами сборки, например, отладка и выпуск, появляется приводит к засорению файлами формируемыми на этапе сборки, которые затрудняют
# необходимость корректного полного удаления результатов предыдущего варианта. разработку, поиск в оригинальных файлах и мешают ориентироваться в проекте.
При работе с несколькими типами сборки, например, отладка и выпуск, появляется
необходимость корректного полного удаления результатов предыдущего варианта.
#]=======================================================================]
include_guard(GLOBAL) include_guard(GLOBAL)
@ -47,4 +51,3 @@ unset(cmake_binary_dir)
unset(project_source_dir) unset(project_source_dir)
unset(project_binary_dir) unset(project_binary_dir)
unset(cmake_install_prefix) unset(cmake_install_prefix)

View File

@ -0,0 +1,35 @@
include_guard(GLOBAL)
function(FetchContent_Add NAME)
set(options "")
set(oneValueArgs GIT_REPOSITORY GIT_REMOTE GIT_PATH)
set(multiValueArgs "")
cmake_parse_arguments(arg "${options}" "${oneValueArgs}" "${multiValueArgs}" ${ARGN})
find_package(Git)
if(GIT_FOUND AND arg_GIT_REMOTE AND arg_GIT_PATH)
execute_process(COMMAND ${GIT_EXECUTABLE} config --get remote.${arg_GIT_REMOTE}.url OUTPUT_VARIABLE REMOTE_URL ERROR_QUIET)
if(REMOTE_URL)
string(REGEX REPLACE ":.*" "" SERVER ${REMOTE_URL})
string(FIND ${SERVER} "http" POS)
if(NOT POS EQUAL 0)
if(NOT SERVER STREQUAL REMOTE_URL)
set(arg_GIT_REPOSITORY "${SERVER}:${arg_GIT_PATH}")
endif()
endif()
endif()
endif()
FetchContent_Declare(
${NAME}
${arg_UNPARSED_ARGUMENTS}
GIT_REPOSITORY ${arg_GIT_REPOSITORY}
)
if(NOT ${NAME}_POPULATED)
FetchContent_Populate(${NAME})
add_subdirectory(${${NAME}_SOURCE_DIR} ${${NAME}_BINARY_DIR})
endif()
endfunction()

View File

@ -0,0 +1,4 @@
include_guard(GLOBAL)
include(FetchContent)
include(GNUInstallDirs)

View File

@ -11,6 +11,8 @@ function(myx_install_library NAME)
return() return()
endif() endif()
get_target_property(type ${NAME} TYPE)
write_basic_package_version_file( write_basic_package_version_file(
${CMAKE_CURRENT_BINARY_DIR}/${NAME}ConfigVersion.cmake ${CMAKE_CURRENT_BINARY_DIR}/${NAME}ConfigVersion.cmake
VERSION ${PROJECT_VERSION} VERSION ${PROJECT_VERSION}
@ -43,22 +45,30 @@ function(myx_install_library NAME)
COMPONENT dev COMPONENT dev
) )
if(TARGET ${NAME}_shared) if(${type} STREQUAL "OBJECT_LIBRARY")
install( if(TARGET ${NAME}_shared)
TARGETS ${NAME}_shared install(
EXPORT ${NAME}Targets TARGETS ${NAME}_shared
LIBRARY EXPORT ${NAME}Targets
DESTINATION ${CMAKE_INSTALL_LIBDIR} LIBRARY DESTINATION ${CMAKE_INSTALL_LIBDIR}
COMPONENT lib COMPONENT lib
) )
endif()
if(TARGET ${NAME}_static)
install(
TARGETS ${NAME}_static
EXPORT ${NAME}Targets
ARCHIVE DESTINATION ${CMAKE_INSTALL_LIBDIR}
COMPONENT lib
)
endif()
endif() endif()
if(TARGET ${NAME}_static) if(${type} STREQUAL "INTERFACE_LIBRARY")
install( install(
TARGETS ${NAME}_static TARGETS ${NAME}
EXPORT ${NAME}Targets EXPORT ${NAME}Targets
ARCHIVE
DESTINATION ${CMAKE_INSTALL_LIBDIR}
COMPONENT lib COMPONENT lib
) )
endif() endif()