Обновление
This commit is contained in:
parent
e625864248
commit
547ed6d0f1
@ -3,23 +3,22 @@ cmake_policy(SET CMP0057 NEW) # IN_LIST operator
|
||||
|
||||
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_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}/TopLevelProject.cmake)
|
||||
if(${CMAKE_VERSION} VERSION_LESS "3.11.0")
|
||||
include(${MYX_CMAKE_BACKPORTS_DIR}/FetchContent.cmake)
|
||||
endif()
|
||||
|
||||
include(${MYX_CMAKE_LIB_DIR}/Includes.cmake)
|
||||
include(${MYX_CMAKE_LIB_DIR}/ColoredMessages.cmake)
|
||||
include(${MYX_CMAKE_LIB_DIR}/NinjaGeneratorWarning.cmake)
|
||||
include(${MYX_CMAKE_LIB_DIR}/DirectoriesGuards.cmake)
|
||||
include(${MYX_CMAKE_LIB_DIR}/SemanticProjectVersion.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}/InstallLibrary.cmake)
|
||||
@ -28,7 +27,6 @@ include(${MYX_CMAKE_LIB_DIR}/Qt5TargetSetup.cmake)
|
||||
|
||||
unset(MYX_CMAKE_SOURCE_DIR)
|
||||
unset(MYX_CMAKE_BACKPORTS_DIR)
|
||||
unset(MYX_CMAKE_CONFIG_DIR)
|
||||
unset(MYX_CMAKE_LIB_DIR)
|
||||
|
||||
cmake_policy(POP)
|
||||
|
@ -1,4 +1,4 @@
|
||||
set(MYX_CMAKE_PACKAGE_VERSION "1.99.9")
|
||||
set(MYX_CMAKE_PACKAGE_VERSION "1.99.10")
|
||||
if(MYX_CMAKE_PACKAGE_VERSION VERSION_LESS PACKAGE_FIND_VERSION)
|
||||
set(PACKAGE_VERSION_COMPATIBLE FALSE)
|
||||
else()
|
||||
|
@ -11,6 +11,6 @@
|
||||
`project` добавить строку:
|
||||
|
||||
```cmake
|
||||
find_package(MyxCMake 1.99.9 PATHS cmake/myx NO_DEFAULT_PATH QUIET REQUIRED)
|
||||
find_package(MyxCMake 1.99.10 PATHS cmake/myx NO_DEFAULT_PATH QUIET REQUIRED)
|
||||
```
|
||||
|
||||
|
@ -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)
|
||||
|
@ -1,20 +1,42 @@
|
||||
#[=======================================================================[.rst:
|
||||
myx_add_library
|
||||
---------------
|
||||
|
||||
Вспомогательная функция для создания библиотеки::
|
||||
|
||||
myx_add_library(NAME TYPE)
|
||||
|
||||
Обязательные параметры: `NAME` - имя библиотеки и `TYPE` - тип цели.
|
||||
Все остальные параметры передаются стандартной функции `add_library()`
|
||||
|
||||
#]=======================================================================]
|
||||
|
||||
include_guard(GLOBAL)
|
||||
|
||||
include(GenerateExportHeader)
|
||||
|
||||
function(myx_add_library NAME)
|
||||
function(myx_add_library NAME TYPE)
|
||||
set(options)
|
||||
set(oneValueArgs TYPE)
|
||||
set(multiValueArgs SOURCES)
|
||||
cmake_parse_arguments(arg "${options}" "${oneValueArgs}" "${multiValueArgs}" ${ARGN})
|
||||
set(oneValueArgs)
|
||||
set(multiValueArgs)
|
||||
|
||||
if(NOT arg_TYPE)
|
||||
set(arg_TYPE "OBJECT")
|
||||
cmake_parse_arguments(ARG "${options}" "${oneValueArgs}" "${multiValueArgs}" ${ARGN})
|
||||
|
||||
# Вызов стандартной функции `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()
|
||||
|
||||
add_library(${NAME} ${arg_TYPE})
|
||||
|
||||
if(arg_TYPE STREQUAL INTERFACE)
|
||||
if(TYPE STREQUAL INTERFACE)
|
||||
# Стандартные пути к заголовочным файлам
|
||||
target_include_directories(${NAME}
|
||||
INTERFACE
|
||||
$<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)
|
||||
|
||||
# Стандартные пути к заголовочным файлам
|
||||
target_include_directories(${NAME}
|
||||
PUBLIC
|
||||
$<BUILD_INTERFACE:${PROJECT_SOURCE_DIR}/include>
|
||||
PRIVATE
|
||||
$<BUILD_INTERFACE:${PROJECT_SOURCE_DIR}/src>
|
||||
$<INSTALL_INTERFACE:${CMAKE_INSTALL_INCLUDEDIR}>
|
||||
)
|
||||
|
||||
@ -38,13 +62,13 @@ function(myx_add_library NAME)
|
||||
|
||||
string(TOUPPER ${NAME} suffix)
|
||||
generate_export_header(${NAME}
|
||||
BASE_NAME "${suffix}"
|
||||
BASE_NAME ${suffix}
|
||||
EXPORT_MACRO_NAME "EXPORT_${suffix}"
|
||||
DEPRECATED_MACRO_NAME "DEPRECATED_${suffix}"
|
||||
NO_DEPRECATED_MACRO_NAME "NO_DEPRECATED_${suffix}"
|
||||
NO_EXPORT_MACRO_NAME "NO_EXPORT_${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
|
||||
)
|
||||
|
||||
|
@ -1,4 +1,9 @@
|
||||
# Обёртки для функций вывода сообщений
|
||||
#[=======================================================================[.rst:
|
||||
|
||||
Обёртки для функции `message()`, которые в терминале UNIX
|
||||
подсвечиают сообщения в зависимости от важности.
|
||||
|
||||
#]=======================================================================]
|
||||
|
||||
include_guard(GLOBAL)
|
||||
|
||||
@ -22,14 +27,22 @@ if(DEFINED ENV{TERM} AND UNIX)
|
||||
set(MyxColorBoldWhite "${Esc}[1;37m")
|
||||
endif()
|
||||
|
||||
function(myx_message_error)
|
||||
function(myx_message_fatal_error)
|
||||
message(FATAL_ERROR ${MyxColorBoldRed}${ARGV}${MyxColorReset})
|
||||
endfunction()
|
||||
|
||||
function(myx_message_send_error)
|
||||
message(SEND_ERROR ${MyxColorBoldRed}${ARGV}${MyxColorReset})
|
||||
endfunction()
|
||||
|
||||
function(myx_message_warning)
|
||||
message(WARNING ${MyxColorRed}${ARGV}${MyxColorReset})
|
||||
endfunction()
|
||||
|
||||
function(myx_message_deprecation)
|
||||
message(DEPRECATION ${MyxColorBoldMagenta}${ARGV}${MyxColorReset})
|
||||
endfunction()
|
||||
|
||||
function(myx_message_status)
|
||||
message(STATUS ${MyxColorMagenta}${ARGV}${MyxColorReset})
|
||||
endfunction()
|
||||
|
@ -1,8 +1,12 @@
|
||||
# Запись результатов сборки проекта внутрь иерархии каталогов с исходными текстами
|
||||
# приводит к засорению файлами формируемыми на этапе сборки, которые затрудняют
|
||||
# разработку, поиск в оригинальных файлах и мешают ориентироваться в проекте.
|
||||
# При работе с несколькими типами сборки, например, отладка и выпуск, появляется
|
||||
# необходимость корректного полного удаления результатов предыдущего варианта.
|
||||
#[=======================================================================[.rst:
|
||||
|
||||
Запись результатов сборки проекта внутрь иерархии каталогов с исходными текстами
|
||||
приводит к засорению файлами формируемыми на этапе сборки, которые затрудняют
|
||||
разработку, поиск в оригинальных файлах и мешают ориентироваться в проекте.
|
||||
При работе с несколькими типами сборки, например, отладка и выпуск, появляется
|
||||
необходимость корректного полного удаления результатов предыдущего варианта.
|
||||
|
||||
#]=======================================================================]
|
||||
|
||||
include_guard(GLOBAL)
|
||||
|
||||
@ -47,4 +51,3 @@ unset(cmake_binary_dir)
|
||||
unset(project_source_dir)
|
||||
unset(project_binary_dir)
|
||||
unset(cmake_install_prefix)
|
||||
|
||||
|
35
lib/FetchContentAdd.cmake
Normal file
35
lib/FetchContentAdd.cmake
Normal 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()
|
4
lib/Includes.cmake
Normal file
4
lib/Includes.cmake
Normal file
@ -0,0 +1,4 @@
|
||||
include_guard(GLOBAL)
|
||||
|
||||
include(FetchContent)
|
||||
include(GNUInstallDirs)
|
Loading…
Reference in New Issue
Block a user