Обновление MyxCMake
This commit is contained in:
		@@ -16,5 +16,11 @@ myx_add_interface_library(${PROJECT_NAME}
 | 
				
			|||||||
    ${PROJECT_SOURCE_DIR}/include/${PROJECT_NAME}/sum.hpp
 | 
					    ${PROJECT_SOURCE_DIR}/include/${PROJECT_NAME}/sum.hpp
 | 
				
			||||||
)
 | 
					)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					# Автоматически генерируемый файл с информацией о репозитории
 | 
				
			||||||
 | 
					myx_generate_git_info_header(${PROJECT_NAME} "git_info_p.hpp")
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					# Автоматически генерируемый приватный заголовочный файл
 | 
				
			||||||
 | 
					myx_generate_private_config_header(${PROJECT_NAME} "config_p.hpp")
 | 
				
			||||||
 | 
					
 | 
				
			||||||
# Форматирование исходных текстов с помощью uncrustify
 | 
					# Форматирование исходных текстов с помощью uncrustify
 | 
				
			||||||
myx_uncrustify(${PROJECT_NAME})
 | 
					myx_uncrustify(${PROJECT_NAME})
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -24,8 +24,7 @@ set(MYX_CMAKE_LIB_DIR "${MYX_CMAKE_SOURCE_DIR}/lib")
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
# Модули для обеспечения обратной совместимости со старыми версиями CMake
 | 
					# Модули для обеспечения обратной совместимости со старыми версиями CMake
 | 
				
			||||||
include(${MYX_CMAKE_BACKPORTS_DIR}/IncludeGuard.cmake)
 | 
					include(${MYX_CMAKE_BACKPORTS_DIR}/IncludeGuard.cmake)
 | 
				
			||||||
include(${MYX_CMAKE_BACKPORTS_DIR}/TopLevelProject.cmake)
 | 
					if(${CMAKE_VERSION} VERSION_LESS 3.11)
 | 
				
			||||||
if(${CMAKE_VERSION} VERSION_LESS "3.11.0")
 | 
					 | 
				
			||||||
  include(${MYX_CMAKE_BACKPORTS_DIR}/FetchContent.cmake)
 | 
					  include(${MYX_CMAKE_BACKPORTS_DIR}/FetchContent.cmake)
 | 
				
			||||||
else()
 | 
					else()
 | 
				
			||||||
  include(FetchContent)
 | 
					  include(FetchContent)
 | 
				
			||||||
@@ -44,6 +43,7 @@ include(${MYX_CMAKE_LIB_DIR}/macro/CheckEnableCxxCompilerFlag.cmake)
 | 
				
			|||||||
include(${MYX_CMAKE_LIB_DIR}/macro/GTest.cmake)
 | 
					include(${MYX_CMAKE_LIB_DIR}/macro/GTest.cmake)
 | 
				
			||||||
include(${MYX_CMAKE_LIB_DIR}/macro/QTest.cmake)
 | 
					include(${MYX_CMAKE_LIB_DIR}/macro/QTest.cmake)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					include(${MYX_CMAKE_LIB_DIR}/ProjectIsTopLevel.cmake)
 | 
				
			||||||
include(${MYX_CMAKE_LIB_DIR}/ColoredMessages.cmake)
 | 
					include(${MYX_CMAKE_LIB_DIR}/ColoredMessages.cmake)
 | 
				
			||||||
include(${MYX_CMAKE_LIB_DIR}/PopulateCMakeBinaryDir.cmake)
 | 
					include(${MYX_CMAKE_LIB_DIR}/PopulateCMakeBinaryDir.cmake)
 | 
				
			||||||
include(${MYX_CMAKE_LIB_DIR}/CurrentDate.cmake)
 | 
					include(${MYX_CMAKE_LIB_DIR}/CurrentDate.cmake)
 | 
				
			||||||
@@ -53,10 +53,7 @@ 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}/DownloadContent.cmake)
 | 
					include(${MYX_CMAKE_LIB_DIR}/DownloadContent.cmake)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
set(MYX_CMAKE_TOOLCHAINS_DIR "${MYX_CMAKE_LIB_DIR}/toolchains")
 | 
					 | 
				
			||||||
include(${MYX_CMAKE_LIB_DIR}/Toolchains.cmake)
 | 
					include(${MYX_CMAKE_LIB_DIR}/Toolchains.cmake)
 | 
				
			||||||
unset(MYX_CMAKE_TOOLCHAINS_DIR)
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
include(${MYX_CMAKE_LIB_DIR}/AddExecutable.cmake)
 | 
					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)
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -1,4 +1,4 @@
 | 
				
			|||||||
set(MYX_CMAKE_PACKAGE_VERSION "2.4.10")
 | 
					set(MYX_CMAKE_PACKAGE_VERSION "2.4.33")
 | 
				
			||||||
if(MYX_CMAKE_PACKAGE_VERSION VERSION_LESS PACKAGE_FIND_VERSION)
 | 
					if(MYX_CMAKE_PACKAGE_VERSION VERSION_LESS PACKAGE_FIND_VERSION)
 | 
				
			||||||
  set(PACKAGE_VERSION_COMPATIBLE FALSE)
 | 
					  set(PACKAGE_VERSION_COMPATIBLE FALSE)
 | 
				
			||||||
else()
 | 
					else()
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -1,11 +0,0 @@
 | 
				
			|||||||
include_guard(GLOBAL)
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
if(${CMAKE_VERSION} VERSION_LESS 3.21)
 | 
					 | 
				
			||||||
  get_property(__parent_directory DIRECTORY PROPERTY PARENT_DIRECTORY)
 | 
					 | 
				
			||||||
  if(NOT __parent_directory)
 | 
					 | 
				
			||||||
    set(PROJECT_IS_TOP_LEVEL TRUE)
 | 
					 | 
				
			||||||
  else()
 | 
					 | 
				
			||||||
    set(PROJECT_IS_TOP_LEVEL FALSE)
 | 
					 | 
				
			||||||
  endif()
 | 
					 | 
				
			||||||
  unset(__parent_directory)
 | 
					 | 
				
			||||||
endif()
 | 
					 | 
				
			||||||
@@ -14,7 +14,7 @@ myx_add_executable
 | 
				
			|||||||
include_guard(GLOBAL)
 | 
					include_guard(GLOBAL)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
function(myx_add_executable TARGET_NAME)
 | 
					function(myx_add_executable TARGET_NAME)
 | 
				
			||||||
  if(${CMAKE_VERSION} VERSION_LESS "3.11.0")
 | 
					  if(${CMAKE_VERSION} VERSION_LESS 3.11.0)
 | 
				
			||||||
    add_executable(${TARGET_NAME} ${ARGN} "")
 | 
					    add_executable(${TARGET_NAME} ${ARGN} "")
 | 
				
			||||||
  else()
 | 
					  else()
 | 
				
			||||||
    add_executable(${TARGET_NAME} ${ARGN})
 | 
					    add_executable(${TARGET_NAME} ${ARGN})
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -20,12 +20,12 @@ include_guard(GLOBAL)
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
include(CMakePackageConfigHelpers)
 | 
					include(CMakePackageConfigHelpers)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
if(${CMAKE_VERSION} VERSION_LESS "3.17.0")
 | 
					if(${CMAKE_VERSION} VERSION_LESS 3.17)
 | 
				
			||||||
  set(MYX_CMAKE_LIB_DIR_BACKPORT "${CMAKE_CURRENT_LIST_DIR}")
 | 
					  set(MYX_CMAKE_LIB_DIR_BACKPORT "${CMAKE_CURRENT_LIST_DIR}")
 | 
				
			||||||
endif()
 | 
					endif()
 | 
				
			||||||
 | 
					
 | 
				
			||||||
function(myx_add_interface_library TARGET_NAME)
 | 
					function(myx_add_interface_library TARGET_NAME)
 | 
				
			||||||
  if(${CMAKE_VERSION} VERSION_LESS "3.17.0")
 | 
					  if(${CMAKE_VERSION} VERSION_LESS 3.17)
 | 
				
			||||||
    set(CMAKE_CURRENT_FUNCTION_LIST_DIR ${MYX_CMAKE_LIB_DIR_BACKPORT})
 | 
					    set(CMAKE_CURRENT_FUNCTION_LIST_DIR ${MYX_CMAKE_LIB_DIR_BACKPORT})
 | 
				
			||||||
  endif()
 | 
					  endif()
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -43,32 +43,47 @@ function(myx_add_interface_library TARGET_NAME)
 | 
				
			|||||||
  endif()
 | 
					  endif()
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  # Вызов стандартной функции `add_library()`
 | 
					  # Вызов стандартной функции `add_library()`
 | 
				
			||||||
  if(${CMAKE_VERSION} VERSION_LESS "3.19.0")
 | 
					  if(${CMAKE_VERSION} VERSION_LESS 3.19)
 | 
				
			||||||
    add_library(${TARGET_NAME} INTERFACE)
 | 
					    add_library(${TARGET_NAME} INTERFACE)
 | 
				
			||||||
    target_sources(${TARGET_NAME} INTERFACE $<BUILD_INTERFACE:${ARG_HEADERS}>)
 | 
					    target_sources(${TARGET_NAME} INTERFACE $<BUILD_INTERFACE:${ARG_HEADERS}>)
 | 
				
			||||||
  else()
 | 
					  else()
 | 
				
			||||||
    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})
 | 
					 | 
				
			||||||
  endforeach()
 | 
					  endforeach()
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  if(ARG_LINK_LIBRARIES)
 | 
					  if(ARG_LINK_LIBRARIES)
 | 
				
			||||||
    target_link_libraries(${TARGET_NAME} INTERFACE ${ARG_LINK_LIBRARIES})
 | 
					    foreach(lib ${ARG_LINK_LIBRARIES})
 | 
				
			||||||
    if(${CMAKE_VERSION} VERSION_GREATER "3.15.0")
 | 
					      if(TARGET ${lib})
 | 
				
			||||||
      foreach(__lib ${ARG_LINK_LIBRARIES})
 | 
					        set(exlib ${lib})
 | 
				
			||||||
        if(TARGET ${__lib})
 | 
					        get_target_property(type ${lib} TYPE)
 | 
				
			||||||
          install(
 | 
					        if(type)
 | 
				
			||||||
            TARGETS ${__lib}
 | 
					          get_target_property(include_dirs ${lib} INTERFACE_INCLUDE_DIRECTORIES)
 | 
				
			||||||
 | 
					          if(include_dirs)
 | 
				
			||||||
 | 
					            target_include_directories(${TARGET_NAME} INTERFACE ${include_dirs})
 | 
				
			||||||
 | 
					          endif()
 | 
				
			||||||
 | 
					        endif()
 | 
				
			||||||
 | 
					        if(${CMAKE_VERSION} VERSION_GREATER 3.13)
 | 
				
			||||||
 | 
					          install(TARGETS ${lib}
 | 
				
			||||||
                  EXPORT ${TARGET_NAME}Targets
 | 
					                  EXPORT ${TARGET_NAME}Targets
 | 
				
			||||||
                  COMPONENT DEV)
 | 
					                  COMPONENT DEV)
 | 
				
			||||||
 | 
					        else()
 | 
				
			||||||
 | 
					          get_target_property(target_type ${lib} TYPE)
 | 
				
			||||||
 | 
					          if(target_type STREQUAL "OBJECT_LIBRARY")
 | 
				
			||||||
 | 
					            if(TARGET "${lib}_static")
 | 
				
			||||||
 | 
					              set(exlib "${lib}_static")
 | 
				
			||||||
 | 
					            elseif(TARGET "${lib}_shared")
 | 
				
			||||||
 | 
					              set(exlib "${lib}_shared")
 | 
				
			||||||
 | 
					            endif()
 | 
				
			||||||
 | 
					          endif()
 | 
				
			||||||
 | 
					        endif()
 | 
				
			||||||
 | 
					        target_link_libraries(${TARGET_NAME} INTERFACE ${exlib})
 | 
				
			||||||
      endif()
 | 
					      endif()
 | 
				
			||||||
    endforeach()
 | 
					    endforeach()
 | 
				
			||||||
  endif()
 | 
					  endif()
 | 
				
			||||||
  endif()
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
  # Библиотека, состоящая только из заголовочных файлов не требует сборки.
 | 
					  # Библиотека, состоящая только из заголовочных файлов не требует сборки.
 | 
				
			||||||
  # Стандартные пути к заголовочным файлам
 | 
					  # Стандартные пути к заголовочным файлам
 | 
				
			||||||
@@ -82,7 +97,7 @@ function(myx_add_interface_library TARGET_NAME)
 | 
				
			|||||||
  # При этом сама цель `${TARGET_NAME}` может участвовать в сборке,
 | 
					  # При этом сама цель `${TARGET_NAME}` может участвовать в сборке,
 | 
				
			||||||
  # если окажется в перечне зависимостей.
 | 
					  # если окажется в перечне зависимостей.
 | 
				
			||||||
  if(NOT PROJECT_IS_TOP_LEVEL)
 | 
					  if(NOT PROJECT_IS_TOP_LEVEL)
 | 
				
			||||||
    if(${CMAKE_VERSION} VERSION_GREATER "3.17.0")
 | 
					    if(${CMAKE_VERSION} VERSION_GREATER 3.17)
 | 
				
			||||||
      set_target_properties(${TARGET_NAME} PROPERTIES EXCLUDE_FROM_ALL True)
 | 
					      set_target_properties(${TARGET_NAME} PROPERTIES EXCLUDE_FROM_ALL True)
 | 
				
			||||||
    else()
 | 
					    else()
 | 
				
			||||||
      set_target_properties(${TARGET_NAME} PROPERTIES INTERFACE_EXCLUDE_FROM_ALL True)
 | 
					      set_target_properties(${TARGET_NAME} PROPERTIES INTERFACE_EXCLUDE_FROM_ALL True)
 | 
				
			||||||
@@ -107,9 +122,12 @@ function(myx_add_interface_library TARGET_NAME)
 | 
				
			|||||||
    NO_CHECK_REQUIRED_COMPONENTS_MACRO
 | 
					    NO_CHECK_REQUIRED_COMPONENTS_MACRO
 | 
				
			||||||
  )
 | 
					  )
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  install(EXPORT ${TARGET_NAME}Targets
 | 
					  if(${CMAKE_VERSION} VERSION_GREATER 3.13)
 | 
				
			||||||
 | 
					    install(
 | 
				
			||||||
 | 
					      EXPORT ${TARGET_NAME}Targets
 | 
				
			||||||
      DESTINATION ${CMAKE_INSTALL_LIBDIR}/cmake/${TARGET_NAME}
 | 
					      DESTINATION ${CMAKE_INSTALL_LIBDIR}/cmake/${TARGET_NAME}
 | 
				
			||||||
      COMPONENT DEV)
 | 
					      COMPONENT DEV)
 | 
				
			||||||
 | 
					  endif()
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  install(
 | 
					  install(
 | 
				
			||||||
    FILES
 | 
					    FILES
 | 
				
			||||||
@@ -139,10 +157,12 @@ function(myx_add_interface_library TARGET_NAME)
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
  # Установка библиотеки из заголовочных файлов
 | 
					  # Установка библиотеки из заголовочных файлов
 | 
				
			||||||
  target_include_directories(${TARGET_NAME} SYSTEM INTERFACE $<INSTALL_INTERFACE:${CMAKE_INSTALL_INCLUDEDIR}>)
 | 
					  target_include_directories(${TARGET_NAME} SYSTEM INTERFACE $<INSTALL_INTERFACE:${CMAKE_INSTALL_INCLUDEDIR}>)
 | 
				
			||||||
 | 
					  if(${CMAKE_VERSION} VERSION_GREATER 3.13)
 | 
				
			||||||
    install(
 | 
					    install(
 | 
				
			||||||
      TARGETS ${TARGET_NAME}
 | 
					      TARGETS ${TARGET_NAME}
 | 
				
			||||||
      EXPORT ${TARGET_NAME}Targets
 | 
					      EXPORT ${TARGET_NAME}Targets
 | 
				
			||||||
      COMPONENT DEV)
 | 
					      COMPONENT DEV)
 | 
				
			||||||
 | 
					  endif()
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  # Установка публичных заголовочных файлов
 | 
					  # Установка публичных заголовочных файлов
 | 
				
			||||||
  if(PROJECT_IS_TOP_LEVEL AND ARG_HEADERS)
 | 
					  if(PROJECT_IS_TOP_LEVEL AND ARG_HEADERS)
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -21,12 +21,12 @@ myx_add_object_library
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
include_guard(GLOBAL)
 | 
					include_guard(GLOBAL)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
if(${CMAKE_VERSION} VERSION_LESS "3.17.0")
 | 
					if(${CMAKE_VERSION} VERSION_LESS 3.17)
 | 
				
			||||||
  set(MYX_CMAKE_LIB_DIR_BACKPORT "${CMAKE_CURRENT_LIST_DIR}")
 | 
					  set(MYX_CMAKE_LIB_DIR_BACKPORT "${CMAKE_CURRENT_LIST_DIR}")
 | 
				
			||||||
endif()
 | 
					endif()
 | 
				
			||||||
 | 
					
 | 
				
			||||||
function(myx_add_object_library TARGET_NAME)
 | 
					function(myx_add_object_library TARGET_NAME)
 | 
				
			||||||
  if(${CMAKE_VERSION} VERSION_LESS "3.17.0")
 | 
					  if(${CMAKE_VERSION} VERSION_LESS 3.17)
 | 
				
			||||||
    set(CMAKE_CURRENT_FUNCTION_LIST_DIR ${MYX_CMAKE_LIB_DIR_BACKPORT})
 | 
					    set(CMAKE_CURRENT_FUNCTION_LIST_DIR ${MYX_CMAKE_LIB_DIR_BACKPORT})
 | 
				
			||||||
  endif()
 | 
					  endif()
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -44,12 +44,12 @@ function(myx_add_object_library TARGET_NAME)
 | 
				
			|||||||
  # Вызов стандартной функции `add_library()`
 | 
					  # Вызов стандартной функции `add_library()`
 | 
				
			||||||
  add_library(${TARGET_NAME} OBJECT ${ARG_UNPARSED_ARGUMENTS})
 | 
					  add_library(${TARGET_NAME} OBJECT ${ARG_UNPARSED_ARGUMENTS})
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  string(TOUPPER ${TARGET_NAME} __project_name_upper)
 | 
					  string(TOUPPER ${TARGET_NAME} project_name_upper)
 | 
				
			||||||
  # Опция для разрешения сборки динамической библиотеки
 | 
					  # Опция для разрешения сборки динамической библиотеки
 | 
				
			||||||
  cmake_dependent_option(${__project_name_upper}_BUILD_SHARED
 | 
					  cmake_dependent_option(${project_name_upper}_BUILD_SHARED
 | 
				
			||||||
    "Build shared library for ${TARGET_NAME}" ON "BUILD_SHARED_LIBS" OFF)
 | 
					    "Build shared library for ${TARGET_NAME}" ON "BUILD_SHARED_LIBS" OFF)
 | 
				
			||||||
  # Опция для разрешения сборки статической библиотеки
 | 
					  # Опция для разрешения сборки статической библиотеки
 | 
				
			||||||
  cmake_dependent_option(${__project_name_upper}_BUILD_STATIC
 | 
					  cmake_dependent_option(${project_name_upper}_BUILD_STATIC
 | 
				
			||||||
    "Build static library for ${TARGET_NAME}" ON "NOT BUILD_SHARED_LIBS" OFF)
 | 
					    "Build static library for ${TARGET_NAME}" ON "NOT BUILD_SHARED_LIBS" OFF)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  # Стандартные пути к заголовочным файлам
 | 
					  # Стандартные пути к заголовочным файлам
 | 
				
			||||||
@@ -68,7 +68,7 @@ function(myx_add_object_library TARGET_NAME)
 | 
				
			|||||||
  if(NOT ARG_NO_EXPORT)
 | 
					  if(NOT ARG_NO_EXPORT)
 | 
				
			||||||
    include(GenerateExportHeader)
 | 
					    include(GenerateExportHeader)
 | 
				
			||||||
    if(NOT EXPORT_BASE_NAME)
 | 
					    if(NOT EXPORT_BASE_NAME)
 | 
				
			||||||
      set(ARG_EXPORT_BASE_NAME ${__project_name_upper})
 | 
					      set(ARG_EXPORT_BASE_NAME ${project_name_upper})
 | 
				
			||||||
    endif()
 | 
					    endif()
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    if(NOT ARG_EXPORT_FILE_NAME)
 | 
					    if(NOT ARG_EXPORT_FILE_NAME)
 | 
				
			||||||
@@ -89,7 +89,7 @@ function(myx_add_object_library TARGET_NAME)
 | 
				
			|||||||
  endif()
 | 
					  endif()
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  # Цель для создания динамической библиотеки из объектных файлов
 | 
					  # Цель для создания динамической библиотеки из объектных файлов
 | 
				
			||||||
  if(${__project_name_upper}_BUILD_SHARED)
 | 
					  if(${project_name_upper}_BUILD_SHARED)
 | 
				
			||||||
    # Для создания динамической библиотеки используются объектные файлы цели ${TARGET_NAME}
 | 
					    # Для создания динамической библиотеки используются объектные файлы цели ${TARGET_NAME}
 | 
				
			||||||
    add_library(${TARGET_NAME}_shared SHARED $<TARGET_OBJECTS:${TARGET_NAME}>)
 | 
					    add_library(${TARGET_NAME}_shared SHARED $<TARGET_OBJECTS:${TARGET_NAME}>)
 | 
				
			||||||
    # Установка дополнительных свойств для цели ${TARGET_NAME}_shared
 | 
					    # Установка дополнительных свойств для цели ${TARGET_NAME}_shared
 | 
				
			||||||
@@ -105,7 +105,7 @@ function(myx_add_object_library TARGET_NAME)
 | 
				
			|||||||
  endif()
 | 
					  endif()
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  # Цель для создания статической библиотеки из объектных файлов
 | 
					  # Цель для создания статической библиотеки из объектных файлов
 | 
				
			||||||
  if(${__project_name_upper}_BUILD_STATIC)
 | 
					  if(${project_name_upper}_BUILD_STATIC)
 | 
				
			||||||
    # Для создания статической библиотеки используются
 | 
					    # Для создания статической библиотеки используются
 | 
				
			||||||
    # объектные файлы цели ${TARGET_NAME}
 | 
					    # объектные файлы цели ${TARGET_NAME}
 | 
				
			||||||
    add_library(${TARGET_NAME}_static STATIC $<TARGET_OBJECTS:${TARGET_NAME}>)
 | 
					    add_library(${TARGET_NAME}_static STATIC $<TARGET_OBJECTS:${TARGET_NAME}>)
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -7,15 +7,20 @@ myx_download_content
 | 
				
			|||||||
  myx_download_content(NAME
 | 
					  myx_download_content(NAME
 | 
				
			||||||
    [ DOWNLOAD_DIR dir ] |
 | 
					    [ DOWNLOAD_DIR dir ] |
 | 
				
			||||||
    [ GIT_REPOSITORY url ] |
 | 
					    [ GIT_REPOSITORY url ] |
 | 
				
			||||||
    [ GIT_TAG tag ] )
 | 
					    [ GIT_TAG tag ] |
 | 
				
			||||||
 | 
					    [ AUTOFETCH ] | [ AUTOPULL ] )
 | 
				
			||||||
 | 
					
 | 
				
			||||||
Обязательный параметр: `NAME` - имя целевого каталога.
 | 
					Обязательный параметр: `NAME` - имя целевого каталога.
 | 
				
			||||||
Параметр `DOWNLOAD_DIR` содержит имя каталога, в который будет загружаться
 | 
					Параметр `DOWNLOAD_DIR` содержит имя каталога, в который будет загружаться
 | 
				
			||||||
содержимое (по умолчанию `downloads`).
 | 
					содержимое (по умолчанию `_downloads`).
 | 
				
			||||||
Параметр `GIT_REPOSITORY` содержит адрес внешнего проекта, который нужно
 | 
					Параметр `GIT_REPOSITORY` содержит адрес внешнего проекта, который нужно
 | 
				
			||||||
загрузить с помощью git.
 | 
					загрузить с помощью git.
 | 
				
			||||||
Параметр `GIT_TAG` содержит используемые метку, идентификатор коммита или
 | 
					Параметр `GIT_TAG` содержит используемые метку, идентификатор коммита или
 | 
				
			||||||
ветку в загружаемом репозитории.
 | 
					ветку в загружаемом репозитории.
 | 
				
			||||||
 | 
					Если указана опция `AUTOFETCH`, то на этапе конфигурирования для загруженного
 | 
				
			||||||
 | 
					репозитория будут скачиваться изменения.
 | 
				
			||||||
 | 
					Если указана опция `AUTOPULL`, то на этапе конфигурирования из загруженного
 | 
				
			||||||
 | 
					репозитория будет изменяться рабочий каталог.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#]=======================================================================]
 | 
					#]=======================================================================]
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -23,8 +28,12 @@ find_package(Git QUIET)
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
option(ENABLE_DOWNLOAD_CONTENT "Enable download content" ON)
 | 
					option(ENABLE_DOWNLOAD_CONTENT "Enable download content" ON)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					if(CMAKE_SCRIPT_MODE_FILE)
 | 
				
			||||||
 | 
					  include(${CMAKE_CURRENT_LIST_DIR}/ProjectIsTopLevel.cmake)
 | 
				
			||||||
 | 
					endif()
 | 
				
			||||||
 | 
					
 | 
				
			||||||
function(myx_download_content NAME)
 | 
					function(myx_download_content NAME)
 | 
				
			||||||
  set(options)
 | 
					  set(options AUTOFETCH AUTOPULL)
 | 
				
			||||||
  set(oneValueArgs)
 | 
					  set(oneValueArgs)
 | 
				
			||||||
  set(multiValueArgs DOWNLOAD_DIR GIT_REPOSITORY GIT_TAG)
 | 
					  set(multiValueArgs DOWNLOAD_DIR GIT_REPOSITORY GIT_TAG)
 | 
				
			||||||
  cmake_parse_arguments(ARG "${options}" "${oneValueArgs}" "${multiValueArgs}" ${ARGN})
 | 
					  cmake_parse_arguments(ARG "${options}" "${oneValueArgs}" "${multiValueArgs}" ${ARGN})
 | 
				
			||||||
@@ -40,6 +49,10 @@ function(myx_download_content NAME)
 | 
				
			|||||||
    endif()
 | 
					    endif()
 | 
				
			||||||
  endif()
 | 
					  endif()
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  if(NOT PROJECT_IS_TOP_LEVEL)
 | 
				
			||||||
 | 
					    return()
 | 
				
			||||||
 | 
					  endif()
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  if(NOT ARG_DOWNLOAD_DIR)
 | 
					  if(NOT ARG_DOWNLOAD_DIR)
 | 
				
			||||||
    set(ARG_DOWNLOAD_DIR "_downloads")
 | 
					    set(ARG_DOWNLOAD_DIR "_downloads")
 | 
				
			||||||
  endif()
 | 
					  endif()
 | 
				
			||||||
@@ -53,25 +66,30 @@ function(myx_download_content NAME)
 | 
				
			|||||||
    execute_process(COMMAND ${CMAKE_COMMAND} -E make_directory ${ARG_DOWNLOAD_DIR})
 | 
					    execute_process(COMMAND ${CMAKE_COMMAND} -E make_directory ${ARG_DOWNLOAD_DIR})
 | 
				
			||||||
  endif()
 | 
					  endif()
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  set(WORK_DIR "${ARG_DOWNLOAD_DIR}/${NAME}")
 | 
				
			||||||
  if(ENABLE_DOWNLOAD_CONTENT AND GIT_EXECUTABLE AND ARG_GIT_REPOSITORY)
 | 
					  if(ENABLE_DOWNLOAD_CONTENT AND GIT_EXECUTABLE AND ARG_GIT_REPOSITORY)
 | 
				
			||||||
    if(NOT IS_DIRECTORY ${ARG_DOWNLOAD_DIR}/${NAME})
 | 
					    if(NOT IS_DIRECTORY ${WORK_DIR})
 | 
				
			||||||
      execute_process(COMMAND ${GIT_EXECUTABLE} clone ${ARG_GIT_REPOSITORY} ${NAME}
 | 
					      execute_process(COMMAND ${GIT_EXECUTABLE} clone ${ARG_GIT_REPOSITORY} ${NAME}
 | 
				
			||||||
                      WORKING_DIRECTORY ${ARG_DOWNLOAD_DIR})
 | 
					                      WORKING_DIRECTORY ${ARG_DOWNLOAD_DIR})
 | 
				
			||||||
    else()
 | 
					    else()
 | 
				
			||||||
 | 
					      if(ARG_AUTOFETCH)
 | 
				
			||||||
        execute_process(COMMAND ${GIT_EXECUTABLE} fetch
 | 
					        execute_process(COMMAND ${GIT_EXECUTABLE} fetch
 | 
				
			||||||
                      WORKING_DIRECTORY ${ARG_DOWNLOAD_DIR}/${NAME})
 | 
					                        WORKING_DIRECTORY ${WORK_DIR})
 | 
				
			||||||
 | 
					      endif()
 | 
				
			||||||
    endif()
 | 
					    endif()
 | 
				
			||||||
    if(ARG_GIT_TAG)
 | 
					    if(ARG_GIT_TAG)
 | 
				
			||||||
      execute_process(COMMAND ${GIT_EXECUTABLE} checkout ${ARG_GIT_TAG}
 | 
					      execute_process(COMMAND ${GIT_EXECUTABLE} checkout ${ARG_GIT_TAG}
 | 
				
			||||||
                      WORKING_DIRECTORY ${ARG_DOWNLOAD_DIR}/${NAME})
 | 
					                      WORKING_DIRECTORY ${WORK_DIR})
 | 
				
			||||||
    else()
 | 
					    else()
 | 
				
			||||||
 | 
					      if(ARG_AUTOPULL)
 | 
				
			||||||
        execute_process(COMMAND ${GIT_EXECUTABLE} pull
 | 
					        execute_process(COMMAND ${GIT_EXECUTABLE} pull
 | 
				
			||||||
                      WORKING_DIRECTORY ${ARG_DOWNLOAD_DIR}/${NAME})
 | 
					                        WORKING_DIRECTORY ${WORK_DIR})
 | 
				
			||||||
 | 
					      endif()
 | 
				
			||||||
    endif()
 | 
					    endif()
 | 
				
			||||||
  endif()
 | 
					  endif()
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  if(NOT CMAKE_SCRIPT_MODE_FILE)
 | 
					  if(NOT CMAKE_SCRIPT_MODE_FILE AND EXISTS "${WORK_DIR}/CMakeLists.txt")
 | 
				
			||||||
    add_subdirectory(${ARG_DOWNLOAD_DIR}/${NAME} EXCLUDE_FROM_ALL)
 | 
					    add_subdirectory(${WORK_DIR} EXCLUDE_FROM_ALL)
 | 
				
			||||||
  endif()
 | 
					  endif()
 | 
				
			||||||
endfunction()
 | 
					endfunction()
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -1,8 +1,7 @@
 | 
				
			|||||||
# Версии CMake, как минимум до 3.8.0, генерируют некорректные
 | 
					# Версии CMake, как минимум до 3.8, генерируют некорректные правила для ninja.
 | 
				
			||||||
# правила для ninja.
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
include_guard(GLOBAL)
 | 
					include_guard(GLOBAL)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
if(${CMAKE_VERSION} VERSION_LESS "3.8.0" AND CMAKE_GENERATOR MATCHES Ninja)
 | 
					if(${CMAKE_VERSION} VERSION_LESS 3.8 AND CMAKE_GENERATOR MATCHES Ninja)
 | 
				
			||||||
  myx_message_send_error("Myx: Old CMake versions should use Makefile generator")
 | 
					  myx_message_send_error("Myx: Old CMake versions should use Makefile generator")
 | 
				
			||||||
endif()
 | 
					endif()
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -3,7 +3,8 @@ include_guard(GLOBAL)
 | 
				
			|||||||
function(myx_target_setup TARGET_NAME)
 | 
					function(myx_target_setup TARGET_NAME)
 | 
				
			||||||
  set(options)
 | 
					  set(options)
 | 
				
			||||||
  set(oneValueArgs PCH)
 | 
					  set(oneValueArgs PCH)
 | 
				
			||||||
  set(multiValueArgs COMPILE_DEFINITIONS PACKAGES LINK_LIBRARIES
 | 
					  set(multiValueArgs PACKAGES
 | 
				
			||||||
 | 
					                     COMPILE_DEFINITIONS INCLUDE_DIRECTORIES LINK_LIBRARIES
 | 
				
			||||||
                     CPP PUBLIC_HEADERS PRIVATE_HEADERS)
 | 
					                     CPP PUBLIC_HEADERS PRIVATE_HEADERS)
 | 
				
			||||||
  cmake_parse_arguments(ARG "${options}" "${oneValueArgs}" "${multiValueArgs}" ${ARGN})
 | 
					  cmake_parse_arguments(ARG "${options}" "${oneValueArgs}" "${multiValueArgs}" ${ARGN})
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -11,8 +12,8 @@ function(myx_target_setup TARGET_NAME)
 | 
				
			|||||||
    myx_message_fatal_error("Target ${TARGET_NAME} does not exists.")
 | 
					    myx_message_fatal_error("Target ${TARGET_NAME} does not exists.")
 | 
				
			||||||
  endif()
 | 
					  endif()
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  get_target_property(__target_type ${TARGET_NAME} TYPE)
 | 
					  get_target_property(target_type ${TARGET_NAME} TYPE)
 | 
				
			||||||
  if(${__target_type} STREQUAL "INTERFACE_LIBRARY")
 | 
					  if(${target_type} STREQUAL "INTERFACE_LIBRARY")
 | 
				
			||||||
    myx_message_fatal_error("This function will not work for interface targets.")
 | 
					    myx_message_fatal_error("This function will not work for interface targets.")
 | 
				
			||||||
  endif()
 | 
					  endif()
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -53,7 +54,7 @@ function(myx_target_setup TARGET_NAME)
 | 
				
			|||||||
      $<BUILD_INTERFACE:${PROJECT_SOURCE_DIR}/src>)
 | 
					      $<BUILD_INTERFACE:${PROJECT_SOURCE_DIR}/src>)
 | 
				
			||||||
  endif()
 | 
					  endif()
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  if(__target_type STREQUAL "EXECUTABLE")
 | 
					  if(target_type STREQUAL "EXECUTABLE")
 | 
				
			||||||
    if(IS_DIRECTORY "${PROJECT_SOURCE_DIR}/include")
 | 
					    if(IS_DIRECTORY "${PROJECT_SOURCE_DIR}/include")
 | 
				
			||||||
      target_include_directories(${PROJECT_NAME} PRIVATE
 | 
					      target_include_directories(${PROJECT_NAME} PRIVATE
 | 
				
			||||||
        $<BUILD_INTERFACE:${PROJECT_SOURCE_DIR}/include>)
 | 
					        $<BUILD_INTERFACE:${PROJECT_SOURCE_DIR}/include>)
 | 
				
			||||||
@@ -76,40 +77,42 @@ function(myx_target_setup TARGET_NAME)
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
  target_sources(${TARGET_NAME} PUBLIC ${ARG_PUBLIC_HEADERS})
 | 
					  target_sources(${TARGET_NAME} PUBLIC ${ARG_PUBLIC_HEADERS})
 | 
				
			||||||
  target_sources(${TARGET_NAME} PRIVATE ${ARG_CPP} ${ARG_PCH} ${ARG_PRIVATE_HEADERS})
 | 
					  target_sources(${TARGET_NAME} PRIVATE ${ARG_CPP} ${ARG_PCH} ${ARG_PRIVATE_HEADERS})
 | 
				
			||||||
  target_sources(${TARGET_NAME} PUBLIC $<BUILD_INTERFACE:${ARG_INTERFACE_HEADERS}>)
 | 
					 | 
				
			||||||
  target_compile_definitions(${TARGET_NAME} PRIVATE ${ARG_COMPILE_DEFINITIONS})
 | 
					  target_compile_definitions(${TARGET_NAME} PRIVATE ${ARG_COMPILE_DEFINITIONS})
 | 
				
			||||||
 | 
					  target_include_directories(${TARGET_NAME} PRIVATE ${ARG_INCLUDE_DIRECTORIES})
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  # CMake до версии 3.12 не умеет извлекать из целей типа `OBJECT_LIBRARY`
 | 
					  # CMake до версии 3.12 не умеет извлекать из целей типа `OBJECT_LIBRARY`
 | 
				
			||||||
  # информацию о заголовочных файлах. Это обход.
 | 
					  # информацию о заголовочных файлах. Это обход.
 | 
				
			||||||
  if(${CMAKE_VERSION} VERSION_GREATER "3.11.99")
 | 
					  if(${CMAKE_VERSION} VERSION_GREATER "3.11.99")
 | 
				
			||||||
    target_link_libraries(${TARGET_NAME} PRIVATE ${ARG_LINK_LIBRARIES})
 | 
					    target_link_libraries(${TARGET_NAME} PRIVATE ${ARG_LINK_LIBRARIES})
 | 
				
			||||||
  else()
 | 
					  else()
 | 
				
			||||||
    if((NOT ${__target_type} STREQUAL "OBJECT_LIBRARY") AND
 | 
					    if((NOT ${target_type} STREQUAL "OBJECT_LIBRARY") AND
 | 
				
			||||||
       (NOT ${__target_type} STREQUAL "EXECUTABLE"))
 | 
					       (NOT ${target_type} STREQUAL "EXECUTABLE"))
 | 
				
			||||||
      target_link_libraries(${TARGET_NAME} PRIVATE ${ARG_LINK_LIBRARIES})
 | 
					      target_link_libraries(${TARGET_NAME} PRIVATE ${ARG_LINK_LIBRARIES})
 | 
				
			||||||
    else()
 | 
					    else()
 | 
				
			||||||
      foreach(__link_library ${ARG_LINK_LIBRARIES})
 | 
					      foreach(link_library ${ARG_LINK_LIBRARIES})
 | 
				
			||||||
        if(TARGET ${__link_library})
 | 
					        if(TARGET ${link_library})
 | 
				
			||||||
          get_target_property(__lib_type ${__link_library} TYPE)
 | 
					          get_target_property(library_type ${link_library} TYPE)
 | 
				
			||||||
          if(__lib_type)
 | 
					          if(library_type)
 | 
				
			||||||
            get_target_property(__include_dirs ${__link_library} INTERFACE_INCLUDE_DIRECTORIES)
 | 
					            get_target_property(include_dirs ${link_library} INTERFACE_INCLUDE_DIRECTORIES)
 | 
				
			||||||
            if(__include_dirs)
 | 
					            if(include_dirs)
 | 
				
			||||||
              target_include_directories(${TARGET_NAME} PUBLIC ${__include_dirs})
 | 
					              target_include_directories(${TARGET_NAME} PUBLIC ${include_dirs})
 | 
				
			||||||
            endif()
 | 
					            endif()
 | 
				
			||||||
            if(${__target_type} STREQUAL "EXECUTABLE")
 | 
					            if(${target_type} STREQUAL "EXECUTABLE")
 | 
				
			||||||
              if(${__lib_type} STREQUAL "OBJECT_LIBRARY")
 | 
					              if(${library_type} STREQUAL "OBJECT_LIBRARY")
 | 
				
			||||||
                if(TARGET ${__link_library}_static)
 | 
					                if(TARGET ${link_library}_static)
 | 
				
			||||||
                  target_link_libraries(${TARGET_NAME} PRIVATE ${__link_library}_static)
 | 
					                  target_link_libraries(${TARGET_NAME} PRIVATE ${link_library}_static)
 | 
				
			||||||
                else()
 | 
					                else()
 | 
				
			||||||
                  target_link_libraries(${TARGET_NAME} PRIVATE ${__link_library}_shared)
 | 
					                  target_link_libraries(${TARGET_NAME} PRIVATE ${link_library}_shared)
 | 
				
			||||||
                endif()
 | 
					                endif()
 | 
				
			||||||
              else()
 | 
					              else()
 | 
				
			||||||
                target_link_libraries(${TARGET_NAME} PRIVATE ${__link_library})
 | 
					                target_link_libraries(${TARGET_NAME} PRIVATE ${link_library})
 | 
				
			||||||
              endif()
 | 
					              endif()
 | 
				
			||||||
            endif()
 | 
					            endif()
 | 
				
			||||||
          endif()
 | 
					          endif()
 | 
				
			||||||
        else()
 | 
					        else()
 | 
				
			||||||
          target_link_libraries(${TARGET_NAME} PRIVATE ${__link_library})
 | 
					          if((${CMAKE_VERSION} VERSION_GREATER "3.7.99") OR (NOT target_type STREQUAL "OBJECT_LIBRARY"))
 | 
				
			||||||
 | 
					            target_link_libraries(${TARGET_NAME} PRIVATE ${link_library})
 | 
				
			||||||
 | 
					          endif()
 | 
				
			||||||
        endif()
 | 
					        endif()
 | 
				
			||||||
      endforeach()
 | 
					      endforeach()
 | 
				
			||||||
    endif()
 | 
					    endif()
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -16,36 +16,38 @@ function(myx_target_setup_qt TARGET_NAME)
 | 
				
			|||||||
    myx_message_fatal_error("Supported Qt versions are 5 and 6")
 | 
					    myx_message_fatal_error("Supported Qt versions are 5 and 6")
 | 
				
			||||||
  endif()
 | 
					  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})
 | 
				
			||||||
    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${myx_qt_ver}${iter}_INCLUDE_DIRS})
 | 
				
			||||||
    else()
 | 
					    else()
 | 
				
			||||||
      target_include_directories(${TARGET_NAME} PRIVATE ${Qt5${iter}_INCLUDE_DIRS})
 | 
					      target_include_directories(${TARGET_NAME} PRIVATE ${Qt${myx_qt_ver}${iter}_INCLUDE_DIRS})
 | 
				
			||||||
    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 Qt${myx_qt_ver}::${iter})
 | 
					          target_link_libraries(${TARGET_NAME} PRIVATE Qt${myx_qt_ver}::${iter})
 | 
				
			||||||
        endif()
 | 
					        endif()
 | 
				
			||||||
      if(__target_type STREQUAL "SHARED_LIBRARY")
 | 
					        if(target_type STREQUAL "SHARED_LIBRARY")
 | 
				
			||||||
          target_link_libraries(${TARGET_NAME} PUBLIC Qt${myx_qt_ver}::${iter})
 | 
					          target_link_libraries(${TARGET_NAME} PUBLIC Qt${myx_qt_ver}::${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 Qt${myx_qt_ver}::${iter})
 | 
					          target_link_libraries(${TARGET_NAME} PUBLIC Qt${myx_qt_ver}::${iter})
 | 
				
			||||||
 | 
					        else()
 | 
				
			||||||
 | 
					          target_include_directories(${TARGET_NAME} PUBLIC ${Qt${myx_qt_ver}${iter}_INCLUDE_DIRS})
 | 
				
			||||||
 | 
					        endif()
 | 
				
			||||||
      endif()
 | 
					      endif()
 | 
				
			||||||
    endif()
 | 
					    endif()
 | 
				
			||||||
  endforeach()
 | 
					  endforeach()
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  foreach(iter ${ARG_PRIVATE})
 | 
					  foreach(iter ${ARG_PRIVATE})
 | 
				
			||||||
    if(__target_type STREQUAL "INTERFACE_LIBRARY")
 | 
					    if(target_type STREQUAL "INTERFACE_LIBRARY")
 | 
				
			||||||
      target_include_directories(${TARGET_NAME} INTERFACE ${Qt${myx_qt_ver}${iter}_PRIVATE_INCLUDE_DIRS})
 | 
					      target_include_directories(${TARGET_NAME} INTERFACE ${Qt${myx_qt_ver}${iter}_PRIVATE_INCLUDE_DIRS})
 | 
				
			||||||
    else()
 | 
					    else()
 | 
				
			||||||
      target_include_directories(${TARGET_NAME} PRIVATE ${Qt${myx_qt_ver}${iter}_PRIVATE_INCLUDE_DIRS})
 | 
					      target_include_directories(${TARGET_NAME} PRIVATE ${Qt${myx_qt_ver}${iter}_PRIVATE_INCLUDE_DIRS})
 | 
				
			||||||
    endif()
 | 
					    endif()
 | 
				
			||||||
  endforeach()
 | 
					  endforeach()
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  if(__target_type STREQUAL "EXECUTABLE")
 | 
					  if(target_type STREQUAL "EXECUTABLE")
 | 
				
			||||||
    target_compile_options(${TARGET_NAME} PRIVATE ${Qt${myx_qt_ver}Core_EXECUTABLE_COMPILE_FLAGS})
 | 
					    target_compile_options(${TARGET_NAME} PRIVATE ${Qt${myx_qt_ver}Core_EXECUTABLE_COMPILE_FLAGS})
 | 
				
			||||||
  endif()
 | 
					  endif()
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -76,7 +78,7 @@ function(myx_target_setup_qt TARGET_NAME)
 | 
				
			|||||||
  endif()
 | 
					  endif()
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  if(ARG_UI)
 | 
					  if(ARG_UI)
 | 
				
			||||||
    if(NOT COMMAND qt${myx_ver_qt}_wrap_ui)
 | 
					    if(NOT COMMAND qt${myx_qt_ver}_wrap_ui)
 | 
				
			||||||
      message(WARNING "MyxCMake: Widgets is required to process UI")
 | 
					      message(WARNING "MyxCMake: Widgets is required to process UI")
 | 
				
			||||||
    else()
 | 
					    else()
 | 
				
			||||||
      if(myx_qt_ver EQUAL 5)
 | 
					      if(myx_qt_ver EQUAL 5)
 | 
				
			||||||
@@ -92,7 +94,7 @@ function(myx_target_setup_qt TARGET_NAME)
 | 
				
			|||||||
  endif()
 | 
					  endif()
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  # Перечень файлов, подлежащих переводу
 | 
					  # Перечень файлов, подлежащих переводу
 | 
				
			||||||
  if(__target_type STREQUAL "INTERFACE_LIBRARY")
 | 
					  if(target_type STREQUAL "INTERFACE_LIBRARY")
 | 
				
			||||||
    get_target_property(tr ${TARGET_NAME} INTERFACE_TR_FILES)
 | 
					    get_target_property(tr ${TARGET_NAME} INTERFACE_TR_FILES)
 | 
				
			||||||
  else()
 | 
					  else()
 | 
				
			||||||
    get_target_property(tr ${TARGET_NAME} TR_FILES)
 | 
					    get_target_property(tr ${TARGET_NAME} TR_FILES)
 | 
				
			||||||
@@ -100,7 +102,7 @@ function(myx_target_setup_qt TARGET_NAME)
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
  # Формирование файла ресурсов с переводами
 | 
					  # Формирование файла ресурсов с переводами
 | 
				
			||||||
  if(tr AND ARG_LANGS)
 | 
					  if(tr AND ARG_LANGS)
 | 
				
			||||||
    if(NOT COMMAND qt${myx_ver_qt}_create_translation)
 | 
					    if(NOT COMMAND qt${myx_qt_ver}_create_translation)
 | 
				
			||||||
      message(WARNING "MyxCMake: LinguistTools is required to process LANGS")
 | 
					      message(WARNING "MyxCMake: LinguistTools is required to process LANGS")
 | 
				
			||||||
    else()
 | 
					    else()
 | 
				
			||||||
      # Заглавие файла ресурсов
 | 
					      # Заглавие файла ресурсов
 | 
				
			||||||
@@ -136,7 +138,7 @@ function(myx_target_setup_qt TARGET_NAME)
 | 
				
			|||||||
    endif()
 | 
					    endif()
 | 
				
			||||||
  endif()
 | 
					  endif()
 | 
				
			||||||
  unset(tr)
 | 
					  unset(tr)
 | 
				
			||||||
  if(__target_type STREQUAL "INTERFACE_LIBRARY")
 | 
					  if(target_type STREQUAL "INTERFACE_LIBRARY")
 | 
				
			||||||
    target_sources(${TARGET_NAME} INTERFACE ${ARG_PUBLIC_MOC} ${ARG_PRIVATE_MOC} ${moc_cpp} ${ui_h} ${qrc_cpp})
 | 
					    target_sources(${TARGET_NAME} INTERFACE ${ARG_PUBLIC_MOC} ${ARG_PRIVATE_MOC} ${moc_cpp} ${ui_h} ${qrc_cpp})
 | 
				
			||||||
  else()
 | 
					  else()
 | 
				
			||||||
    target_sources(${TARGET_NAME} PRIVATE ${ARG_PUBLIC_MOC} ${ARG_PRIVATE_MOC} ${moc_cpp} ${ui_h} ${qrc_cpp})
 | 
					    target_sources(${TARGET_NAME} PRIVATE ${ARG_PUBLIC_MOC} ${ARG_PRIVATE_MOC} ${moc_cpp} ${ui_h} ${qrc_cpp})
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -34,23 +34,38 @@ if(CMAKE_SYSTEM_NAME STREQUAL Linux)
 | 
				
			|||||||
endif()
 | 
					endif()
 | 
				
			||||||
 | 
					
 | 
				
			||||||
if(CMAKE_CXX_COMPILER_ID STREQUAL "GNU")
 | 
					if(CMAKE_CXX_COMPILER_ID STREQUAL "GNU")
 | 
				
			||||||
  include("${MYX_CMAKE_TOOLCHAINS_DIR}/GCC.cmake")
 | 
					  if(CMAKE_COLOR_MAKEFILE)
 | 
				
			||||||
 | 
					    check_enable_cxx_compiler_flag(-fdiagnostics-color=auto)
 | 
				
			||||||
 | 
					  endif()
 | 
				
			||||||
endif()
 | 
					endif()
 | 
				
			||||||
 | 
					
 | 
				
			||||||
if(CMAKE_CXX_COMPILER_ID STREQUAL "Clang")
 | 
					if(CMAKE_CXX_COMPILER_ID STREQUAL "Clang")
 | 
				
			||||||
  include("${MYX_CMAKE_TOOLCHAINS_DIR}/Clang.cmake")
 | 
					  if(CMAKE_COLOR_MAKEFILE)
 | 
				
			||||||
 | 
					    check_enable_cxx_compiler_flag(-fcolor-diagnostics)
 | 
				
			||||||
 | 
					  endif()
 | 
				
			||||||
endif()
 | 
					endif()
 | 
				
			||||||
 | 
					
 | 
				
			||||||
if((MYX_CMAKE_LSB_DISTRIBUTOR_ID  STREQUAL "AstraLinuxSE") AND
 | 
					if((MYX_CMAKE_LSB_DISTRIBUTOR_ID  STREQUAL "AstraLinuxSE") AND
 | 
				
			||||||
   (MYX_CMAKE_LSB_CODENAME        STREQUAL "smolensk") AND
 | 
					   (MYX_CMAKE_LSB_CODENAME        STREQUAL "smolensk") AND
 | 
				
			||||||
   (MYX_CMAKE_LSB_RELEASE_VERSION STREQUAL "1.5"))
 | 
					   (MYX_CMAKE_LSB_RELEASE_VERSION STREQUAL "1.5"))
 | 
				
			||||||
  include("${MYX_CMAKE_TOOLCHAINS_DIR}/AstraLinuxSE-1.5.cmake")
 | 
					  find_program(CMAKE_AR NAMES "/usr/bin/x86_64-linux-gnu-gcc-ar-4.7")
 | 
				
			||||||
  return()
 | 
					  find_program(CMAKE_NM NAMES "/usr/bin/x86_64-linux-gnu-gcc-nm-4.7")
 | 
				
			||||||
 | 
					  find_program(CMAKE_RANLIB NAMES "/usr/bin/x86_64-linux-gnu-gcc-ranlib-4.7")
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  set(CMAKE_CXX_STANDARD 11)
 | 
				
			||||||
 | 
					  set(CMAKE_CXX_EXTENSIONS ON)
 | 
				
			||||||
 | 
					  check_enable_cxx_compiler_flag(-Wno-shadow)
 | 
				
			||||||
endif()
 | 
					endif()
 | 
				
			||||||
 | 
					
 | 
				
			||||||
if((MYX_CMAKE_LSB_DISTRIBUTOR_ID  STREQUAL "ElbrusD") AND
 | 
					if((MYX_CMAKE_LSB_DISTRIBUTOR_ID  STREQUAL "ElbrusD") AND
 | 
				
			||||||
   (MYX_CMAKE_LSB_CODENAME        STREQUAL "Jessie") AND
 | 
					   (MYX_CMAKE_LSB_CODENAME        STREQUAL "Jessie") AND
 | 
				
			||||||
   (MYX_CMAKE_LSB_RELEASE_VERSION VERSION_GREATER "1.4"))
 | 
					   (MYX_CMAKE_LSB_RELEASE_VERSION VERSION_GREATER "1.4"))
 | 
				
			||||||
  include("${MYX_CMAKE_TOOLCHAINS_DIR}/ElbrusD-1.4.cmake")
 | 
					  find_program(CMAKE_AR NAMES "/usr/${CMAKE_SYSTEM_PROCESSOR}-linux/bin/ar")
 | 
				
			||||||
  return()
 | 
					  find_program(CMAKE_NM NAMES "/usr/${CMAKE_SYSTEM_PROCESSOR}-linux/bin/nm")
 | 
				
			||||||
 | 
					  find_program(CMAKE_RANLIB NAMES "/usr/${CMAKE_SYSTEM_PROCESSOR}-linux/bin/ranlib")
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  set(CMAKE_CXX_STANDARD 14)
 | 
				
			||||||
 | 
					  set(CMAKE_CXX_EXTENSIONS ON)
 | 
				
			||||||
 | 
					  check_enable_cxx_compiler_flag(-Wno-invalid-offsetof)
 | 
				
			||||||
 | 
					  list(APPEND CMAKE_LIBRARY_PATH "/usr/lib/e2k-linux-gnu")
 | 
				
			||||||
endif()
 | 
					endif()
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -1,11 +1,11 @@
 | 
				
			|||||||
if(${CMAKE_VERSION} VERSION_LESS "3.17.0")
 | 
					if(${CMAKE_VERSION} VERSION_LESS 3.17)
 | 
				
			||||||
  set(MYX_CMAKE_LIB_DOC_DIR_BACKPORT "${CMAKE_CURRENT_LIST_DIR}")
 | 
					  set(MYX_CMAKE_LIB_DOC_DIR_BACKPORT "${CMAKE_CURRENT_LIST_DIR}")
 | 
				
			||||||
endif()
 | 
					endif()
 | 
				
			||||||
 | 
					
 | 
				
			||||||
find_package(Doxygen QUIET)
 | 
					find_package(Doxygen QUIET)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
function(myx_doc_doxygen TARGET_NAME)
 | 
					function(myx_doc_doxygen TARGET_NAME)
 | 
				
			||||||
  if(${CMAKE_VERSION} VERSION_LESS "3.17.0")
 | 
					  if(${CMAKE_VERSION} VERSION_LESS 3.17)
 | 
				
			||||||
    set(CMAKE_CURRENT_FUNCTION_LIST_DIR ${MYX_CMAKE_LIB_DOC_DIR_BACKPORT})
 | 
					    set(CMAKE_CURRENT_FUNCTION_LIST_DIR ${MYX_CMAKE_LIB_DOC_DIR_BACKPORT})
 | 
				
			||||||
  endif()
 | 
					  endif()
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -17,12 +17,12 @@ myx_generate_git_info_header
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
include_guard(GLOBAL)
 | 
					include_guard(GLOBAL)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
if(${CMAKE_VERSION} VERSION_LESS "3.17.0")
 | 
					if(${CMAKE_VERSION} VERSION_LESS 3.17.0)
 | 
				
			||||||
  set(MYX_CMAKE_LIB_GENERATORS_DIR_BACKPORT "${CMAKE_CURRENT_LIST_DIR}")
 | 
					  set(MYX_CMAKE_LIB_GENERATORS_DIR_BACKPORT "${CMAKE_CURRENT_LIST_DIR}")
 | 
				
			||||||
endif()
 | 
					endif()
 | 
				
			||||||
 | 
					
 | 
				
			||||||
function(myx_generate_git_info_header TARGET_NAME BASE_FILENAME)
 | 
					function(myx_generate_git_info_header TARGET_NAME BASE_FILENAME)
 | 
				
			||||||
  if(${CMAKE_VERSION} VERSION_LESS "3.17.0")
 | 
					  if(${CMAKE_VERSION} VERSION_LESS 3.17.0)
 | 
				
			||||||
    set(CMAKE_CURRENT_FUNCTION_LIST_DIR ${MYX_CMAKE_LIB_GENERATORS_DIR_BACKPORT})
 | 
					    set(CMAKE_CURRENT_FUNCTION_LIST_DIR ${MYX_CMAKE_LIB_GENERATORS_DIR_BACKPORT})
 | 
				
			||||||
  endif()
 | 
					  endif()
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -31,26 +31,31 @@ function(myx_generate_git_info_header TARGET_NAME BASE_FILENAME)
 | 
				
			|||||||
  set(multiValueArgs)
 | 
					  set(multiValueArgs)
 | 
				
			||||||
  cmake_parse_arguments(ARG "${options}" "${oneValueArgs}" "${multiValueArgs}" ${ARGN})
 | 
					  cmake_parse_arguments(ARG "${options}" "${oneValueArgs}" "${multiValueArgs}" ${ARGN})
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  set(__filename "${PROJECT_BINARY_DIR}/include/${BASE_FILENAME}")
 | 
					  set(filename "${PROJECT_BINARY_DIR}/include/${BASE_FILENAME}")
 | 
				
			||||||
  file(APPEND ${__filename} "")
 | 
					  file(APPEND ${filename} "")
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  set(__prefix "")
 | 
					  set(prefix "")
 | 
				
			||||||
  if(ARG_PREFIX)
 | 
					  if(ARG_PREFIX)
 | 
				
			||||||
    string(APPEND ARG_PREFIX "_")
 | 
					    string(APPEND ARG_PREFIX "_")
 | 
				
			||||||
    string(REPLACE "-" "_" __prefix ${ARG_PREFIX})
 | 
					    string(REPLACE "-" "_" prefix ${ARG_PREFIX})
 | 
				
			||||||
  endif()
 | 
					  endif()
 | 
				
			||||||
 | 
					
 | 
				
			||||||
# cmake-format: off
 | 
					# cmake-format: off
 | 
				
			||||||
  if(NOT TARGET ${TARGET_NAME}-git-info-header)
 | 
					  if(NOT TARGET ${TARGET_NAME}-git-info-header)
 | 
				
			||||||
    add_custom_target(${TARGET_NAME}-git-info-header ALL
 | 
					    add_custom_target(${TARGET_NAME}-git-info-header ALL
 | 
				
			||||||
      ${CMAKE_COMMAND} -DGIT_INFO_FILE=${__filename} -DPREFIX=${__prefix}
 | 
					      ${CMAKE_COMMAND} -DGIT_INFO_FILE=${filename} -DPREFIX=${prefix}
 | 
				
			||||||
                       -P ${CMAKE_CURRENT_FUNCTION_LIST_DIR}/GitInfo.cmake
 | 
					                       -P ${CMAKE_CURRENT_FUNCTION_LIST_DIR}/GitInfo.cmake
 | 
				
			||||||
      BYPRODUCTS ${__filename}
 | 
					      BYPRODUCTS ${filename}
 | 
				
			||||||
      WORKING_DIRECTORY ${CMAKE_CURRENT_FUNCTION_LIST_DIR})
 | 
					      WORKING_DIRECTORY ${CMAKE_CURRENT_FUNCTION_LIST_DIR})
 | 
				
			||||||
  endif()
 | 
					  endif()
 | 
				
			||||||
# cmake-format: on
 | 
					# cmake-format: on
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  set_property(TARGET ${TARGET_NAME} APPEND PROPERTY PRIVATE_HEADER_FILES ${__filename})
 | 
					  set_property(TARGET ${TARGET_NAME} APPEND PROPERTY PRIVATE_HEADER_FILES ${filename})
 | 
				
			||||||
  target_sources(${TARGET_NAME} PRIVATE ${__filename})
 | 
					  get_target_property(target_type ${TARGET_NAME} TYPE)
 | 
				
			||||||
 | 
					  if(${target_type} STREQUAL "INTERFACE_LIBRARY")
 | 
				
			||||||
 | 
					    target_sources(${TARGET_NAME} INTERFACE $<BUILD_INTERFACE:${filename}>)
 | 
				
			||||||
 | 
					  else()
 | 
				
			||||||
 | 
					    target_sources(${TARGET_NAME} PRIVATE ${filename})
 | 
				
			||||||
 | 
					  endif()
 | 
				
			||||||
  add_dependencies(${TARGET_NAME} ${TARGET_NAME}-git-info-header)
 | 
					  add_dependencies(${TARGET_NAME} ${TARGET_NAME}-git-info-header)
 | 
				
			||||||
endfunction()
 | 
					endfunction()
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -14,12 +14,12 @@ myx_generate_private_config_header
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
include_guard(GLOBAL)
 | 
					include_guard(GLOBAL)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
if(${CMAKE_VERSION} VERSION_LESS "3.17.0")
 | 
					if(${CMAKE_VERSION} VERSION_LESS 3.17.0)
 | 
				
			||||||
  set(MYX_CMAKE_LIB_GENERATORS_DIR_BACKPORT "${CMAKE_CURRENT_LIST_DIR}")
 | 
					  set(MYX_CMAKE_LIB_GENERATORS_DIR_BACKPORT "${CMAKE_CURRENT_LIST_DIR}")
 | 
				
			||||||
endif()
 | 
					endif()
 | 
				
			||||||
 | 
					
 | 
				
			||||||
function(myx_generate_private_config_header TARGET_NAME BASE_FILENAME)
 | 
					function(myx_generate_private_config_header TARGET_NAME BASE_FILENAME)
 | 
				
			||||||
  if(${CMAKE_VERSION} VERSION_LESS "3.17.0")
 | 
					  if(${CMAKE_VERSION} VERSION_LESS 3.17.0)
 | 
				
			||||||
    set(CMAKE_CURRENT_FUNCTION_LIST_DIR ${MYX_CMAKE_LIB_GENERATORS_DIR_BACKPORT})
 | 
					    set(CMAKE_CURRENT_FUNCTION_LIST_DIR ${MYX_CMAKE_LIB_GENERATORS_DIR_BACKPORT})
 | 
				
			||||||
  endif()
 | 
					  endif()
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -27,9 +27,14 @@ function(myx_generate_private_config_header TARGET_NAME BASE_FILENAME)
 | 
				
			|||||||
  myx_project_version_int()
 | 
					  myx_project_version_int()
 | 
				
			||||||
  get_property(PROJECT_VERSION_INT GLOBAL PROPERTY PROJECT_VERSION_INT)
 | 
					  get_property(PROJECT_VERSION_INT GLOBAL PROPERTY PROJECT_VERSION_INT)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  set(__filename "${PROJECT_BINARY_DIR}/include/${BASE_FILENAME}")
 | 
					  set(filename "${PROJECT_BINARY_DIR}/include/${BASE_FILENAME}")
 | 
				
			||||||
  configure_file("${CMAKE_CURRENT_FUNCTION_LIST_DIR}/PrivateConfig.hpp.in" ${__filename})
 | 
					  configure_file("${CMAKE_CURRENT_FUNCTION_LIST_DIR}/PrivateConfig.hpp.in" ${filename})
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  set_property(TARGET ${TARGET_NAME} APPEND PROPERTY PRIVATE_HEADER_FILES ${__filename})
 | 
					  set_property(TARGET ${TARGET_NAME} APPEND PROPERTY PRIVATE_HEADER_FILES ${filename})
 | 
				
			||||||
  target_sources(${TARGET_NAME} PRIVATE ${__filename})
 | 
					  get_target_property(target_type ${TARGET_NAME} TYPE)
 | 
				
			||||||
 | 
					  if(${target_type} STREQUAL "INTERFACE_LIBRARY")
 | 
				
			||||||
 | 
					    target_sources(${TARGET_NAME} INTERFACE $<BUILD_INTERFACE:${filename}>)
 | 
				
			||||||
 | 
					  else()
 | 
				
			||||||
 | 
					    target_sources(${TARGET_NAME} PRIVATE ${filename})
 | 
				
			||||||
 | 
					  endif()
 | 
				
			||||||
endfunction()
 | 
					endfunction()
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -27,8 +27,8 @@ macro(check_enable_cxx_compiler_flag FLAG)
 | 
				
			|||||||
  endif()
 | 
					  endif()
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  unset(check_cxx_flag CACHE)
 | 
					  unset(check_cxx_flag CACHE)
 | 
				
			||||||
  foreach(__iter IN LISTS oneValueArgs multiValueArgs)
 | 
					  foreach(iter IN LISTS oneValueArgs multiValueArgs)
 | 
				
			||||||
    unset(ARG_${__iter})
 | 
					    unset(ARG_${iter})
 | 
				
			||||||
  endforeach()
 | 
					  endforeach()
 | 
				
			||||||
  unset(ARG_UNPARSED_ARGUMENTS)
 | 
					  unset(ARG_UNPARSED_ARGUMENTS)
 | 
				
			||||||
  unset(multiValueArgs)
 | 
					  unset(multiValueArgs)
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -3,7 +3,7 @@ include_guard(GLOBAL)
 | 
				
			|||||||
# Создание символических ссылок
 | 
					# Создание символических ссылок
 | 
				
			||||||
macro(myx_create_symlink ORIGINAL_FILENAME LINKNAME)
 | 
					macro(myx_create_symlink ORIGINAL_FILENAME LINKNAME)
 | 
				
			||||||
  if(UNIX AND (NOT EXISTS ${LINKNAME}))
 | 
					  if(UNIX AND (NOT EXISTS ${LINKNAME}))
 | 
				
			||||||
    if(${CMAKE_VERSION} VERSION_LESS "3.14.0")
 | 
					    if(${CMAKE_VERSION} VERSION_LESS 3.14.0)
 | 
				
			||||||
      execute_process(COMMAND ${CMAKE_COMMAND} -E create_symlink
 | 
					      execute_process(COMMAND ${CMAKE_COMMAND} -E create_symlink
 | 
				
			||||||
                              ${ORIGINAL_FILENAME} ${LINKNAME})
 | 
					                              ${ORIGINAL_FILENAME} ${LINKNAME})
 | 
				
			||||||
    else()
 | 
					    else()
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -52,8 +52,8 @@ macro(myx_find_packages)
 | 
				
			|||||||
    endforeach()
 | 
					    endforeach()
 | 
				
			||||||
  endif()
 | 
					  endif()
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  foreach(__iter IN LISTS oneValueArgs multiValueArgs)
 | 
					  foreach(iter IN LISTS oneValueArgs multiValueArgs)
 | 
				
			||||||
    unset(ARG_${__iter})
 | 
					    unset(ARG_${iter})
 | 
				
			||||||
  endforeach()
 | 
					  endforeach()
 | 
				
			||||||
  unset(ARG_UNPARSED_ARGUMENTS)
 | 
					  unset(ARG_UNPARSED_ARGUMENTS)
 | 
				
			||||||
  unset(multiValueArgs)
 | 
					  unset(multiValueArgs)
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -30,8 +30,8 @@ macro(myx_find_qt)
 | 
				
			|||||||
    find_package("Qt${ARG_VERSION}${iter}" COMPONENTS Private ${ARG_REQUIRED})
 | 
					    find_package("Qt${ARG_VERSION}${iter}" COMPONENTS Private ${ARG_REQUIRED})
 | 
				
			||||||
  endforeach()
 | 
					  endforeach()
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  foreach(__iter IN LISTS oneValueArgs multiValueArgs)
 | 
					  foreach(iter IN LISTS oneValueArgs multiValueArgs)
 | 
				
			||||||
    unset(ARG_${__iter})
 | 
					    unset(ARG_${iter})
 | 
				
			||||||
  endforeach()
 | 
					  endforeach()
 | 
				
			||||||
  unset(ARG_UNPARSED_ARGUMENTS)
 | 
					  unset(ARG_UNPARSED_ARGUMENTS)
 | 
				
			||||||
  unset(multiValueArgs)
 | 
					  unset(multiValueArgs)
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -19,8 +19,8 @@ macro(myx_add_gtest TARGET_NAME)
 | 
				
			|||||||
  endif()
 | 
					  endif()
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  add_test(NAME ${TARGET_NAME} COMMAND ${TARGET_NAME})
 | 
					  add_test(NAME ${TARGET_NAME} COMMAND ${TARGET_NAME})
 | 
				
			||||||
  foreach(__iter IN LISTS oneValueArgs multiValueArgs)
 | 
					  foreach(iter IN LISTS oneValueArgs multiValueArgs)
 | 
				
			||||||
    unset(ARG_${__iter})
 | 
					    unset(ARG_${iter})
 | 
				
			||||||
  endforeach()
 | 
					  endforeach()
 | 
				
			||||||
  unset(ARG_UNPARSED_ARGUMENTS)
 | 
					  unset(ARG_UNPARSED_ARGUMENTS)
 | 
				
			||||||
  unset(multiValueArgs)
 | 
					  unset(multiValueArgs)
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -14,8 +14,8 @@ macro(myx_add_qtest TARGET_NAME)
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
  foreach(filename ${ARG_UNPARSED_ARGUMENTS})
 | 
					  foreach(filename ${ARG_UNPARSED_ARGUMENTS})
 | 
				
			||||||
    get_filename_component(basename ${filename} NAME_WE)
 | 
					    get_filename_component(basename ${filename} NAME_WE)
 | 
				
			||||||
    list(APPEND cpps "${basename}.cpp")
 | 
					    list(APPEND cpps "${CMAKE_CURRENT_SOURCE_DIR}/${basename}.cpp")
 | 
				
			||||||
    list(APPEND hpps "${basename}.hpp")
 | 
					    list(APPEND hpps "${CMAKE_CURRENT_SOURCE_DIR}/${basename}.hpp")
 | 
				
			||||||
    qt5_wrap_cpp(moc "${basename}.hpp")
 | 
					    qt5_wrap_cpp(moc "${basename}.hpp")
 | 
				
			||||||
    list(APPEND mocs "${moc}")
 | 
					    list(APPEND mocs "${moc}")
 | 
				
			||||||
  endforeach()
 | 
					  endforeach()
 | 
				
			||||||
@@ -29,8 +29,8 @@ macro(myx_add_qtest TARGET_NAME)
 | 
				
			|||||||
  unset(hpps)
 | 
					  unset(hpps)
 | 
				
			||||||
  unset(moc)
 | 
					  unset(moc)
 | 
				
			||||||
  unset(mocs)
 | 
					  unset(mocs)
 | 
				
			||||||
  foreach(__iter IN LISTS oneValueArgs multiValueArgs)
 | 
					  foreach(iter IN LISTS oneValueArgs multiValueArgs)
 | 
				
			||||||
    unset(ARG_${__iter})
 | 
					    unset(ARG_${iter})
 | 
				
			||||||
  endforeach()
 | 
					  endforeach()
 | 
				
			||||||
  unset(ARG_UNPARSED_ARGUMENTS)
 | 
					  unset(ARG_UNPARSED_ARGUMENTS)
 | 
				
			||||||
  unset(multiValueArgs)
 | 
					  unset(multiValueArgs)
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -1,8 +0,0 @@
 | 
				
			|||||||
find_program(CMAKE_AR NAMES "/usr/bin/x86_64-linux-gnu-gcc-ar-4.7")
 | 
					 | 
				
			||||||
find_program(CMAKE_NM NAMES "/usr/bin/x86_64-linux-gnu-gcc-nm-4.7")
 | 
					 | 
				
			||||||
find_program(CMAKE_RANLIB NAMES "/usr/bin/x86_64-linux-gnu-gcc-ranlib-4.7")
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
set(CMAKE_CXX_STANDARD 11)
 | 
					 | 
				
			||||||
set(CMAKE_CXX_EXTENSIONS ON)
 | 
					 | 
				
			||||||
check_enable_cxx_compiler_flag(-Wno-shadow)
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
@@ -1,3 +0,0 @@
 | 
				
			|||||||
if(CMAKE_COLOR_MAKEFILE)
 | 
					 | 
				
			||||||
  check_enable_cxx_compiler_flag(-fcolor-diagnostics)
 | 
					 | 
				
			||||||
endif()
 | 
					 | 
				
			||||||
@@ -1,9 +0,0 @@
 | 
				
			|||||||
find_program(CMAKE_AR NAMES "/usr/${CMAKE_SYSTEM_PROCESSOR}-linux/bin/ar")
 | 
					 | 
				
			||||||
find_program(CMAKE_NM NAMES "/usr/${CMAKE_SYSTEM_PROCESSOR}-linux/bin/nm")
 | 
					 | 
				
			||||||
find_program(CMAKE_RANLIB NAMES "/usr/${CMAKE_SYSTEM_PROCESSOR}-linux/bin/ranlib")
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
set(CMAKE_CXX_STANDARD 14)
 | 
					 | 
				
			||||||
set(CMAKE_CXX_EXTENSIONS ON)
 | 
					 | 
				
			||||||
check_enable_cxx_compiler_flag(-Wno-invalid-offsetof)
 | 
					 | 
				
			||||||
list(APPEND CMAKE_LIBRARY_PATH "/usr/lib/e2k-linux-gnu")
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
@@ -1,3 +0,0 @@
 | 
				
			|||||||
if(CMAKE_COLOR_MAKEFILE)
 | 
					 | 
				
			||||||
  check_enable_cxx_compiler_flag(-fdiagnostics-color=auto)
 | 
					 | 
				
			||||||
endif()
 | 
					 | 
				
			||||||
@@ -1,11 +1,11 @@
 | 
				
			|||||||
if(${CMAKE_VERSION} VERSION_LESS "3.17.0")
 | 
					if(${CMAKE_VERSION} VERSION_LESS 3.17.0)
 | 
				
			||||||
  set(MYX_CMAKE_LIB_UNCRUSTIFY_DIR_BACKPORT "${CMAKE_CURRENT_LIST_DIR}")
 | 
					  set(MYX_CMAKE_LIB_UNCRUSTIFY_DIR_BACKPORT "${CMAKE_CURRENT_LIST_DIR}")
 | 
				
			||||||
endif()
 | 
					endif()
 | 
				
			||||||
 | 
					
 | 
				
			||||||
find_program(UNCRUSTIFY_EXE NAMES uncrustify)
 | 
					find_program(UNCRUSTIFY_EXE NAMES uncrustify)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
function(myx_uncrustify TARGET_NAME)
 | 
					function(myx_uncrustify TARGET_NAME)
 | 
				
			||||||
  if(${CMAKE_VERSION} VERSION_LESS "3.17.0")
 | 
					  if(${CMAKE_VERSION} VERSION_LESS 3.17.0)
 | 
				
			||||||
    set(CMAKE_CURRENT_FUNCTION_LIST_DIR ${MYX_CMAKE_LIB_UNCRUSTIFY_DIR_BACKPORT})
 | 
					    set(CMAKE_CURRENT_FUNCTION_LIST_DIR ${MYX_CMAKE_LIB_UNCRUSTIFY_DIR_BACKPORT})
 | 
				
			||||||
  endif()
 | 
					  endif()
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -45,51 +45,50 @@ function(myx_uncrustify TARGET_NAME)
 | 
				
			|||||||
  endif()
 | 
					  endif()
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  # Динамически сгенерированные файлы исключаются
 | 
					  # Динамически сгенерированные файлы исключаются
 | 
				
			||||||
  get_target_property(__target_type ${TARGET_NAME} TYPE)
 | 
					  get_target_property(target_type ${TARGET_NAME} TYPE)
 | 
				
			||||||
  if((${__target_type} STREQUAL "INTERFACE_LIBRARY") AND (${CMAKE_VERSION} VERSION_LESS "3.17.0"))
 | 
					  if((${target_type} STREQUAL "INTERFACE_LIBRARY") AND (${CMAKE_VERSION} VERSION_LESS 3.17.0))
 | 
				
			||||||
    get_target_property(__s1 ${TARGET_NAME} INTERFACE_SOURCES)
 | 
					    get_target_property(target_sources ${TARGET_NAME} INTERFACE_SOURCES)
 | 
				
			||||||
    if(__s1)
 | 
					    if(target_sources)
 | 
				
			||||||
      list(APPEND __all_sources ${__s1})
 | 
					      list(APPEND all_sources ${target_sources})
 | 
				
			||||||
    endif()
 | 
					    endif()
 | 
				
			||||||
  else()
 | 
					  else()
 | 
				
			||||||
    get_target_property(__s2 ${TARGET_NAME} SOURCES)
 | 
					    get_target_property(target_sources ${TARGET_NAME} SOURCES)
 | 
				
			||||||
    if(__s2)
 | 
					    if(target_sources)
 | 
				
			||||||
      list(APPEND __all_sources ${__s2})
 | 
					      list(APPEND all_sources ${target_sources})
 | 
				
			||||||
    endif()
 | 
					    endif()
 | 
				
			||||||
  endif()
 | 
					  endif()
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  foreach(iter ${__all_sources})
 | 
					  foreach(iter ${all_sources})
 | 
				
			||||||
    string(FIND ${iter} ${CMAKE_BINARY_DIR} pos)
 | 
					    string(FIND ${iter} ${CMAKE_BINARY_DIR} pos)
 | 
				
			||||||
    if(pos EQUAL -1)
 | 
					    if(pos EQUAL -1)
 | 
				
			||||||
      list(APPEND __sources ${iter})
 | 
					      list(APPEND sources ${iter})
 | 
				
			||||||
    endif()
 | 
					    endif()
 | 
				
			||||||
  endforeach()
 | 
					  endforeach()
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  target_sources(${TARGET_NAME} PRIVATE ${ARG_CONFIG})
 | 
					  set(fixed_config ${PROJECT_BINARY_DIR}/uncrustify-${TARGET_NAME}.cfg)
 | 
				
			||||||
  set(__fixed_config ${PROJECT_BINARY_DIR}/uncrustify-${TARGET_NAME}.cfg)
 | 
					  add_custom_command(OUTPUT ${fixed_config}
 | 
				
			||||||
  add_custom_command(OUTPUT ${__fixed_config}
 | 
					 | 
				
			||||||
                     DEPENDS ${ARG_CONFIG}
 | 
					                     DEPENDS ${ARG_CONFIG}
 | 
				
			||||||
                     COMMAND ${UNCRUSTIFY_EXE} --update-config-with-doc
 | 
					                     COMMAND ${UNCRUSTIFY_EXE} --update-config-with-doc
 | 
				
			||||||
                                               -c ${ARG_CONFIG} -o ${__fixed_config})
 | 
					                                               -c ${ARG_CONFIG} -o ${fixed_config})
 | 
				
			||||||
  list(APPEND __options -c ${__fixed_config})
 | 
					  list(APPEND options -c ${fixed_config})
 | 
				
			||||||
  # cmake-format: off
 | 
					  # cmake-format: off
 | 
				
			||||||
  add_custom_target(${TARGET_NAME}-uncrustify-check
 | 
					  add_custom_target(${TARGET_NAME}-uncrustify-check
 | 
				
			||||||
    DEPENDS ${__fixed_config}
 | 
					    DEPENDS ${fixed_config}
 | 
				
			||||||
    COMMAND ${UNCRUSTIFY_EXE} ${__options} --check ${__sources})
 | 
					    COMMAND ${UNCRUSTIFY_EXE} ${options} --check ${sources})
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  list(APPEND __options --replace --no-backup)
 | 
					  list(APPEND options --replace --no-backup)
 | 
				
			||||||
  add_custom_target(${TARGET_NAME}-uncrustify
 | 
					  add_custom_target(${TARGET_NAME}-uncrustify
 | 
				
			||||||
    DEPENDS ${__fixed_config}
 | 
					    DEPENDS ${fixed_config}
 | 
				
			||||||
    COMMAND ${UNCRUSTIFY_EXE} ${__options} --mtime ${__sources})
 | 
					    COMMAND ${UNCRUSTIFY_EXE} ${options} --mtime ${sources})
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  add_custom_target(${TARGET_NAME}-uncrustify-append-comments
 | 
					  add_custom_target(${TARGET_NAME}-uncrustify-append-comments
 | 
				
			||||||
    DEPENDS ${__fixed_config}
 | 
					    DEPENDS ${fixed_config}
 | 
				
			||||||
    COMMAND ${UNCRUSTIFY_EXE} ${__options}
 | 
					    COMMAND ${UNCRUSTIFY_EXE} ${options}
 | 
				
			||||||
            --set cmt_insert_class_header=${CMAKE_CURRENT_FUNCTION_LIST_DIR}/classheader.txt
 | 
					            --set cmt_insert_class_header=${CMAKE_CURRENT_FUNCTION_LIST_DIR}/classheader.txt
 | 
				
			||||||
            --set cmt_insert_file_footer=${CMAKE_CURRENT_FUNCTION_LIST_DIR}/filefooter.txt
 | 
					            --set cmt_insert_file_footer=${CMAKE_CURRENT_FUNCTION_LIST_DIR}/filefooter.txt
 | 
				
			||||||
            --set cmt_insert_file_header=${CMAKE_CURRENT_FUNCTION_LIST_DIR}/fileheader.txt
 | 
					            --set cmt_insert_file_header=${CMAKE_CURRENT_FUNCTION_LIST_DIR}/fileheader.txt
 | 
				
			||||||
            --set cmt_insert_func_header=${CMAKE_CURRENT_FUNCTION_LIST_DIR}/funcheader.txt
 | 
					            --set cmt_insert_func_header=${CMAKE_CURRENT_FUNCTION_LIST_DIR}/funcheader.txt
 | 
				
			||||||
            --set cmt_insert_before_ctor_dtor=true --mtime ${__sources})
 | 
					            --set cmt_insert_before_ctor_dtor=true --mtime ${sources})
 | 
				
			||||||
  # cmake-format: on
 | 
					  # cmake-format: on
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  add_dependencies(myx-uncrustify ${TARGET_NAME}-uncrustify)
 | 
					  add_dependencies(myx-uncrustify ${TARGET_NAME}-uncrustify)
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -20,11 +20,11 @@ if(ENV{MYX_CMAKE_DIR})
 | 
				
			|||||||
  set(MYX_CMAKE_DIR $ENV{MYX_CMAKE_DIR})
 | 
					  set(MYX_CMAKE_DIR $ENV{MYX_CMAKE_DIR})
 | 
				
			||||||
endif()
 | 
					endif()
 | 
				
			||||||
if(MYX_CMAKE_DIR)
 | 
					if(MYX_CMAKE_DIR)
 | 
				
			||||||
  find_package(MyxCMake 2.4.10 REQUIRED CONFIG PATHS ${MYX_CMAKE_DIR} NO_DEFAULT_PATH)
 | 
					  find_package(MyxCMake 2.4.33 REQUIRED CONFIG PATHS ${MYX_CMAKE_DIR} NO_DEFAULT_PATH)
 | 
				
			||||||
  myx_message_notice("== MyxCMake directory: ${MyxCMake_CONFIG} ==")
 | 
					  myx_message_notice("== MyxCMake directory: ${MyxCMake_CONFIG} ==")
 | 
				
			||||||
else()
 | 
					else()
 | 
				
			||||||
  if(MYX_CMAKE_USE_SYSTEM)
 | 
					  if(MYX_CMAKE_USE_SYSTEM)
 | 
				
			||||||
    find_package(MyxCMake 2.4.10 REQUIRED)
 | 
					    find_package(MyxCMake 2.4.33 REQUIRED)
 | 
				
			||||||
    myx_message_notice("== MyxCMake directory: ${MyxCMake_CONFIG} ==")
 | 
					    myx_message_notice("== MyxCMake directory: ${MyxCMake_CONFIG} ==")
 | 
				
			||||||
  else()
 | 
					  else()
 | 
				
			||||||
    include(${PROJECT_SOURCE_DIR}/cmake/myx/MyxCMakeConfig.cmake)
 | 
					    include(${PROJECT_SOURCE_DIR}/cmake/myx/MyxCMakeConfig.cmake)
 | 
				
			||||||
 
 | 
				
			|||||||
		Reference in New Issue
	
	Block a user