Compare commits
3 Commits
b817f24022
...
ed531c24dd
Author | SHA1 | Date | |
---|---|---|---|
ed531c24dd | |||
7bb6c2d39c | |||
fe65d429f1 |
@ -61,7 +61,7 @@ include(${MYX_CMAKE_LIB_DIR}/AddExecutable.cmake)
|
|||||||
include(${MYX_CMAKE_LIB_DIR}/AddInterfaceLibrary.cmake)
|
include(${MYX_CMAKE_LIB_DIR}/AddInterfaceLibrary.cmake)
|
||||||
include(${MYX_CMAKE_LIB_DIR}/AddObjectLibrary.cmake)
|
include(${MYX_CMAKE_LIB_DIR}/AddObjectLibrary.cmake)
|
||||||
include(${MYX_CMAKE_LIB_DIR}/TargetSetup.cmake)
|
include(${MYX_CMAKE_LIB_DIR}/TargetSetup.cmake)
|
||||||
include(${MYX_CMAKE_LIB_DIR}/Qt5TargetSetup.cmake)
|
include(${MYX_CMAKE_LIB_DIR}/QtTargetSetup.cmake)
|
||||||
|
|
||||||
include(${MYX_CMAKE_LIB_DIR}/uncrustify/Uncrustify.cmake)
|
include(${MYX_CMAKE_LIB_DIR}/uncrustify/Uncrustify.cmake)
|
||||||
include(${MYX_CMAKE_LIB_DIR}/doc/Doxygen.cmake)
|
include(${MYX_CMAKE_LIB_DIR}/doc/Doxygen.cmake)
|
||||||
|
@ -50,6 +50,7 @@ function(myx_add_interface_library TARGET_NAME)
|
|||||||
add_library(${TARGET_NAME} INTERFACE ${ARG_HEADERS})
|
add_library(${TARGET_NAME} INTERFACE ${ARG_HEADERS})
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
|
|
||||||
foreach(__iter ${ARG_PACKAGES})
|
foreach(__iter ${ARG_PACKAGES})
|
||||||
target_include_directories(${TARGET_NAME} INTERFACE ${${__iter}_INCLUDE_DIRS})
|
target_include_directories(${TARGET_NAME} INTERFACE ${${__iter}_INCLUDE_DIRS})
|
||||||
target_compile_definitions(${TARGET_NAME} INTERFACE ${${__iter}_COMPILE_DEFINITIONS})
|
target_compile_definitions(${TARGET_NAME} INTERFACE ${${__iter}_COMPILE_DEFINITIONS})
|
||||||
@ -71,7 +72,10 @@ function(myx_add_interface_library TARGET_NAME)
|
|||||||
|
|
||||||
# Библиотека, состоящая только из заголовочных файлов не требует сборки.
|
# Библиотека, состоящая только из заголовочных файлов не требует сборки.
|
||||||
# Стандартные пути к заголовочным файлам
|
# Стандартные пути к заголовочным файлам
|
||||||
target_include_directories(${TARGET_NAME} INTERFACE $<BUILD_INTERFACE:${PROJECT_SOURCE_DIR}/include>)
|
target_include_directories(${TARGET_NAME} INTERFACE
|
||||||
|
$<BUILD_INTERFACE:${PROJECT_SOURCE_DIR}/include>
|
||||||
|
$<INSTALL_INTERFACE:include>
|
||||||
|
)
|
||||||
|
|
||||||
# Если вызов был выполнен не из проекта верхнего уровня,
|
# Если вызов был выполнен не из проекта верхнего уровня,
|
||||||
# то созданная цель исключается из цели `all`.
|
# то созданная цель исключается из цели `all`.
|
||||||
|
@ -1,43 +1,53 @@
|
|||||||
include_guard(GLOBAL)
|
include_guard(GLOBAL)
|
||||||
|
|
||||||
function(myx_qt5_target_setup TARGET_NAME)
|
function(myx_qt_target_setup TARGET_NAME)
|
||||||
set(options)
|
set(options)
|
||||||
set(oneValueArgs)
|
set(oneValueArgs VERSION)
|
||||||
set(multiValueArgs COMPONENTS PRIVATE PUBLIC_MOC PRIVATE_MOC UI QRC LANGS)
|
set(multiValueArgs COMPONENTS PRIVATE PUBLIC_MOC PRIVATE_MOC UI QRC LANGS)
|
||||||
|
|
||||||
cmake_parse_arguments(ARG "${options}" "${oneValueArgs}" "${multiValueArgs}" ${ARGN})
|
cmake_parse_arguments(ARG "${options}" "${oneValueArgs}" "${multiValueArgs}" ${ARGN})
|
||||||
|
|
||||||
|
if(NOT ARG_VERSION)
|
||||||
|
set(ARG_VERSION "5")
|
||||||
|
endif()
|
||||||
|
|
||||||
|
if(NOT (ARG_VERSION STREQUAL "5" OR ARG_VERSION STREQUAL "6"))
|
||||||
|
myx_message_fatal_error("Supported Qt versions are 5 and 6")
|
||||||
|
endif()
|
||||||
|
|
||||||
get_target_property(__target_type ${TARGET_NAME} TYPE)
|
get_target_property(__target_type ${TARGET_NAME} TYPE)
|
||||||
|
|
||||||
foreach(iter ${ARG_COMPONENTS})
|
foreach(iter ${ARG_COMPONENTS})
|
||||||
|
find_package(Qt${ARG_VERSION} COMPONENTS ${iter} REQUIRED)
|
||||||
if(__target_type STREQUAL "INTERFACE_LIBRARY")
|
if(__target_type STREQUAL "INTERFACE_LIBRARY")
|
||||||
target_include_directories(${TARGET_NAME} INTERFACE ${Qt5${iter}_INCLUDE_DIRS})
|
target_include_directories(${TARGET_NAME} INTERFACE ${Qt${ARG_VERSION}${iter}_INCLUDE_DIRS})
|
||||||
else()
|
else()
|
||||||
target_include_directories(${TARGET_NAME} PRIVATE ${Qt5${iter}_INCLUDE_DIRS})
|
target_include_directories(${TARGET_NAME} PRIVATE ${Qt${ARG_VERSION}${iter}_INCLUDE_DIRS})
|
||||||
endif()
|
endif()
|
||||||
if(NOT iter STREQUAL "LinguistTools")
|
if(NOT iter STREQUAL "LinguistTools")
|
||||||
if(__target_type STREQUAL "EXECUTABLE")
|
if(__target_type STREQUAL "EXECUTABLE")
|
||||||
target_link_libraries(${TARGET_NAME} PRIVATE "Qt5::${iter}")
|
target_link_libraries(${TARGET_NAME} PRIVATE "Qt${ARG_VERSION}::${iter}")
|
||||||
endif()
|
endif()
|
||||||
if(__target_type STREQUAL "SHARED_LIBRARY")
|
if(__target_type STREQUAL "SHARED_LIBRARY")
|
||||||
target_link_libraries(${TARGET_NAME} PUBLIC "Qt5::${iter}")
|
target_link_libraries(${TARGET_NAME} PUBLIC "Qt${ARG_VERSION}::${iter}")
|
||||||
endif()
|
endif()
|
||||||
if((${CMAKE_VERSION} VERSION_GREATER "3.8.0") AND (__target_type STREQUAL "OBJECT_LIBRARY"))
|
if((${CMAKE_VERSION} VERSION_GREATER "3.8.0") AND (__target_type STREQUAL "OBJECT_LIBRARY"))
|
||||||
target_link_libraries(${TARGET_NAME} PUBLIC "Qt5::${iter}")
|
target_link_libraries(${TARGET_NAME} PUBLIC "Qt${ARG_VERSION}::${iter}")
|
||||||
endif()
|
endif()
|
||||||
endif()
|
endif()
|
||||||
endforeach()
|
endforeach()
|
||||||
|
|
||||||
foreach(iter ${ARG_PRIVATE})
|
foreach(iter ${ARG_PRIVATE})
|
||||||
|
find_package("Qt${ARG_VERSION}${iter}" COMPONENTS Private REQUIRED)
|
||||||
if(__target_type STREQUAL "INTERFACE_LIBRARY")
|
if(__target_type STREQUAL "INTERFACE_LIBRARY")
|
||||||
target_include_directories(${TARGET_NAME} INTERFACE ${Qt5${iter}_PRIVATE_INCLUDE_DIRS})
|
target_include_directories(${TARGET_NAME} INTERFACE ${Qt${ARG_VERSION}${iter}_PRIVATE_INCLUDE_DIRS})
|
||||||
else()
|
else()
|
||||||
target_include_directories(${TARGET_NAME} PRIVATE ${Qt5${iter}_PRIVATE_INCLUDE_DIRS})
|
target_include_directories(${TARGET_NAME} PRIVATE ${Qt${ARG_VERSION}${iter}_PRIVATE_INCLUDE_DIRS})
|
||||||
endif()
|
endif()
|
||||||
endforeach()
|
endforeach()
|
||||||
|
|
||||||
if(__target_type STREQUAL "EXECUTABLE")
|
if(__target_type STREQUAL "EXECUTABLE")
|
||||||
target_compile_options(${TARGET_NAME} PRIVATE ${Qt5Core_EXECUTABLE_COMPILE_FLAGS})
|
target_compile_options(${TARGET_NAME} PRIVATE ${Qt${ARG_VERSION}Core_EXECUTABLE_COMPILE_FLAGS})
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
if(ARG_PUBLIC_MOC)
|
if(ARG_PUBLIC_MOC)
|
||||||
@ -51,15 +61,27 @@ function(myx_qt5_target_setup TARGET_NAME)
|
|||||||
endif()
|
endif()
|
||||||
|
|
||||||
if(ARG_PUBLIC_MOC OR ARG_PRIVATE_MOC)
|
if(ARG_PUBLIC_MOC OR ARG_PRIVATE_MOC)
|
||||||
|
if(ARG_VERSION STREQUAL "5")
|
||||||
qt5_wrap_cpp(moc_cpp ${ARG_PUBLIC_MOC} ${ARG_PRIVATE_MOC})
|
qt5_wrap_cpp(moc_cpp ${ARG_PUBLIC_MOC} ${ARG_PRIVATE_MOC})
|
||||||
|
else()
|
||||||
|
qt6_wrap_cpp(moc_cpp ${ARG_PUBLIC_MOC} ${ARG_PRIVATE_MOC})
|
||||||
|
endif()
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
if(ARG_QRC)
|
if(ARG_QRC)
|
||||||
|
if(ARG_VERSION STREQUAL "5")
|
||||||
qt5_add_resources(qrc_cpp ${ARG_QRC})
|
qt5_add_resources(qrc_cpp ${ARG_QRC})
|
||||||
|
else()
|
||||||
|
qt6_add_resources(qrc_cpp ${ARG_QRC})
|
||||||
|
endif()
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
if(ARG_UI AND "Widgets" IN_LIST ARG_COMPONENTS)
|
if(ARG_UI AND "Widgets" IN_LIST ARG_COMPONENTS)
|
||||||
|
if(ARG_VERSION STREQUAL "5")
|
||||||
qt5_wrap_ui(ui_h ${ARG_UI})
|
qt5_wrap_ui(ui_h ${ARG_UI})
|
||||||
|
else()
|
||||||
|
qt6_wrap_ui(ui_h ${ARG_UI})
|
||||||
|
endif()
|
||||||
set_property(TARGET ${TARGET_NAME} APPEND PROPERTY TR_FILES ${ARG_UI})
|
set_property(TARGET ${TARGET_NAME} APPEND PROPERTY TR_FILES ${ARG_UI})
|
||||||
# TODO
|
# TODO
|
||||||
target_include_directories(${PROJECT_NAME} PRIVATE ${PROJECT_BINARY_DIR})
|
target_include_directories(${PROJECT_NAME} PRIVATE ${PROJECT_BINARY_DIR})
|
||||||
@ -79,9 +101,15 @@ function(myx_qt5_target_setup TARGET_NAME)
|
|||||||
foreach(iter ${ARG_LANGS})
|
foreach(iter ${ARG_LANGS})
|
||||||
# Создание или обновление файла переводов в каталоге ${PROJECT_SOURCE_DIR}/l10n
|
# Создание или обновление файла переводов в каталоге ${PROJECT_SOURCE_DIR}/l10n
|
||||||
# и его компиляция в каталог ${PROJECT_BINARY_DIR}
|
# и его компиляция в каталог ${PROJECT_BINARY_DIR}
|
||||||
|
if(ARG_VERSION STREQUAL "5")
|
||||||
qt5_create_translation(qm ${tr}
|
qt5_create_translation(qm ${tr}
|
||||||
"${PROJECT_SOURCE_DIR}/l10n/${TARGET_NAME}_${iter}.ts"
|
"${PROJECT_SOURCE_DIR}/l10n/${TARGET_NAME}_${iter}.ts"
|
||||||
OPTIONS -I ${PROJECT_SOURCE_DIR}/include -I ${PROJECT_SOURCE_DIR}/include/${PROJECT_NAME})
|
OPTIONS -I ${PROJECT_SOURCE_DIR}/include -I ${PROJECT_SOURCE_DIR}/include/${PROJECT_NAME})
|
||||||
|
else()
|
||||||
|
qt6_create_translation(qm ${tr}
|
||||||
|
"${PROJECT_SOURCE_DIR}/l10n/${TARGET_NAME}_${iter}.ts"
|
||||||
|
OPTIONS -I ${PROJECT_SOURCE_DIR}/include -I ${PROJECT_SOURCE_DIR}/include/${PROJECT_NAME})
|
||||||
|
endif()
|
||||||
# Добавление записи для скомпилированного файла переводов в ресурсный файл
|
# Добавление записи для скомпилированного файла переводов в ресурсный файл
|
||||||
file(APPEND ${PROJECT_BINARY_DIR}/${TARGET_NAME}_l10n.qrc
|
file(APPEND ${PROJECT_BINARY_DIR}/${TARGET_NAME}_l10n.qrc
|
||||||
"<file alias=\"${TARGET_NAME}_${iter}\">${TARGET_NAME}_${iter}.qm</file>\n")
|
"<file alias=\"${TARGET_NAME}_${iter}\">${TARGET_NAME}_${iter}.qm</file>\n")
|
||||||
@ -91,7 +119,11 @@ function(myx_qt5_target_setup TARGET_NAME)
|
|||||||
# Окончание файла ресурсов
|
# Окончание файла ресурсов
|
||||||
file(APPEND ${PROJECT_BINARY_DIR}/${TARGET_NAME}_l10n.qrc "</qresource></RCC>\n")
|
file(APPEND ${PROJECT_BINARY_DIR}/${TARGET_NAME}_l10n.qrc "</qresource></RCC>\n")
|
||||||
# Компиляция файла ресурсов с переводами
|
# Компиляция файла ресурсов с переводами
|
||||||
|
if(ARG_VERSION STREQUAL "5")
|
||||||
qt5_add_resources(qrc_l10n ${PROJECT_BINARY_DIR}/${TARGET_NAME}_l10n.qrc)
|
qt5_add_resources(qrc_l10n ${PROJECT_BINARY_DIR}/${TARGET_NAME}_l10n.qrc)
|
||||||
|
else()
|
||||||
|
qt6_add_resources(qrc_l10n ${PROJECT_BINARY_DIR}/${TARGET_NAME}_l10n.qrc)
|
||||||
|
endif()
|
||||||
target_sources(${TARGET_NAME} PRIVATE ${qrc_l10n})
|
target_sources(${TARGET_NAME} PRIVATE ${qrc_l10n})
|
||||||
endif()
|
endif()
|
||||||
unset(tr)
|
unset(tr)
|
@ -1,36 +1,54 @@
|
|||||||
|
#[=======================================================================[.rst:
|
||||||
|
myx_find_packages
|
||||||
|
-----------------
|
||||||
|
|
||||||
|
Вспомогательная функция для поиска зависимостей::
|
||||||
|
|
||||||
|
myx_find_packages()
|
||||||
|
|
||||||
|
Упрощённый способ поиска необходимых и опциональных зависимостей.
|
||||||
|
Для поиска зависимостей с учётом особенных требований (например, номер версии)
|
||||||
|
следует использовать функции `find_package` и `pkg_check_modules`.
|
||||||
|
Параметр `REQUIRED` содержит перечисление необходимых зависимостей
|
||||||
|
для поиска с помощью функции `find_package`.
|
||||||
|
Параметр `OPTIONAL` содержит перечисление опциональных зависимостей
|
||||||
|
для поиска с помощью функции `find_package`.
|
||||||
|
Параметр `PKG_REQUIRED` содержит перечисление необходимых зависимостей
|
||||||
|
для поиска с помощью функции `pkg_check_modules`.
|
||||||
|
Параметр `PKG_OPTIONAL` содержит перечисление опциональных зависимостей
|
||||||
|
для поиска с помощью функции `pkg_check_modules`.
|
||||||
|
|
||||||
|
#]=======================================================================]
|
||||||
|
|
||||||
include_guard(GLOBAL)
|
include_guard(GLOBAL)
|
||||||
|
|
||||||
macro(myx_find_required_packages)
|
macro(myx_find_packages)
|
||||||
set(options)
|
set(options)
|
||||||
set(oneValueArgs)
|
set(oneValueArgs)
|
||||||
set(multiValueArgs PACKAGES Boost Qt5 Qt5Private Qt6 Qt6Private)
|
set(multiValueArgs REQUIRED OPTIONAL PKG_REQUIRED PKG_OPTIONAL)
|
||||||
cmake_parse_arguments(ARG "${options}" "${oneValueArgs}" "${multiValueArgs}" ${ARGN})
|
cmake_parse_arguments(ARG "${options}" "${oneValueArgs}" "${multiValueArgs}" ${ARGN})
|
||||||
|
|
||||||
foreach(iter ${ARG_PACKAGES})
|
foreach(iter ${ARG_REQUIRED})
|
||||||
find_package(${iter} REQUIRED)
|
find_package(${iter} REQUIRED)
|
||||||
endforeach()
|
endforeach()
|
||||||
|
|
||||||
if(ARG_Boost)
|
foreach(iter ${ARG_OPTIONAL})
|
||||||
find_package(Boost COMPONENTS ${ARG_Boost} REQUIRED)
|
find_package(${iter})
|
||||||
endif()
|
endforeach()
|
||||||
|
|
||||||
if(ARG_Qt5)
|
if(ARG_PKG_REQUIRED)
|
||||||
find_package(Qt5 COMPONENTS ${ARG_Qt5} REQUIRED)
|
find_package(PkgConfig REQUIRED)
|
||||||
endif()
|
foreach(iter ${ARG_PKG_REQUIRED})
|
||||||
|
string(TOUPPER ${iter} iu)
|
||||||
if(ARG_Qt5Private)
|
pkg_check_modules(${iu} REQUIRED ${iter})
|
||||||
foreach(iter ${ARG_Qt5Private})
|
|
||||||
find_package("Qt5${iter}" COMPONENTS Private REQUIRED)
|
|
||||||
endforeach()
|
endforeach()
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
if(ARG_Qt6)
|
if(ARG_PKG_OPTIONAL)
|
||||||
find_package(Qt6 COMPONENTS ${ARG_Qt6} REQUIRED)
|
find_package(PkgConfig REQUIRED)
|
||||||
endif()
|
foreach(iter ${ARG_PKG_OPTIONAL})
|
||||||
|
string(TOUPPER ${iter} iu)
|
||||||
if(ARG_Qt6Private)
|
pkg_check_modules(${iu} ${iter})
|
||||||
foreach(iter ${ARG_Qt6Private})
|
|
||||||
find_package("Qt6${iter}" COMPONENTS Private REQUIRED)
|
|
||||||
endforeach()
|
endforeach()
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
@ -41,4 +59,4 @@ macro(myx_find_required_packages)
|
|||||||
unset(multiValueArgs)
|
unset(multiValueArgs)
|
||||||
unset(oneValueArgs)
|
unset(oneValueArgs)
|
||||||
unset(options)
|
unset(options)
|
||||||
endmacro(myx_find_required_packages)
|
endmacro(myx_find_packages)
|
||||||
|
@ -21,7 +21,7 @@ macro(myx_add_qtest TARGET_NAME)
|
|||||||
endforeach()
|
endforeach()
|
||||||
|
|
||||||
add_executable(${TARGET_NAME} ${mocs} ${cpps} ${hpps})
|
add_executable(${TARGET_NAME} ${mocs} ${cpps} ${hpps})
|
||||||
target_link_libraries(${TARGET_NAME} Qt5::Core Qt5::Test)
|
target_link_libraries(${TARGET_NAME} PRIVATE Qt5::Core Qt5::Test)
|
||||||
|
|
||||||
add_test(NAME ${TARGET_NAME} COMMAND ${TARGET_NAME})
|
add_test(NAME ${TARGET_NAME} COMMAND ${TARGET_NAME})
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user