aboutsummaryrefslogtreecommitdiffstats
path: root/cmake/QtCreatorAPI.cmake
diff options
context:
space:
mode:
Diffstat (limited to 'cmake/QtCreatorAPI.cmake')
-rw-r--r--cmake/QtCreatorAPI.cmake642
1 files changed, 130 insertions, 512 deletions
diff --git a/cmake/QtCreatorAPI.cmake b/cmake/QtCreatorAPI.cmake
index d88cff2fc6..8030f17d66 100644
--- a/cmake/QtCreatorAPI.cmake
+++ b/cmake/QtCreatorAPI.cmake
@@ -3,76 +3,7 @@ if(QT_CREATOR_API_DEFINED)
endif()
set(QT_CREATOR_API_DEFINED TRUE)
-if (CMAKE_VERSION VERSION_LESS 3.16)
- set(BUILD_WITH_PCH OFF)
-endif()
-
-include(FeatureSummary)
-
-#
-# Default Qt compilation defines
-#
-
-list(APPEND DEFAULT_DEFINES
- QT_CREATOR
- QT_NO_JAVA_STYLE_ITERATORS
- QT_NO_CAST_TO_ASCII QT_RESTRICTED_CAST_FROM_ASCII
- QT_DISABLE_DEPRECATED_BEFORE=0x050900
- QT_USE_FAST_OPERATOR_PLUS
- QT_USE_FAST_CONCATENATION
-)
-
-if (WIN32)
- list(APPEND DEFAULT_DEFINES UNICODE _UNICODE _CRT_SECURE_NO_WARNINGS)
-
- if (NOT BUILD_WITH_PCH)
- # Windows 8 0x0602
- list(APPEND DEFAULT_DEFINES
- WINVER=0x0602 _WIN32_WINNT=0x0602
- WIN32_LEAN_AND_MEAN)
- endif()
-endif()
-
-#
-# Setup path handling
-#
-
-if (APPLE)
- set(_IDE_APP_PATH ".")
- set(_IDE_APP_TARGET "${IDE_DISPLAY_NAME}")
-
- set(_IDE_OUTPUT_PATH "${_IDE_APP_PATH}/${_IDE_APP_TARGET}.app/Contents")
-
- set(_IDE_PLUGIN_PATH "${_IDE_OUTPUT_PATH}/PlugIns")
- set(_IDE_LIBRARY_BASE_PATH "Frameworks")
- set(_IDE_LIBRARY_PATH "${_IDE_OUTPUT_PATH}/Frameworks")
- set(_IDE_LIBEXEC_PATH "${_IDE_OUTPUT_PATH}/Resources/libexec")
- set(_IDE_DATA_PATH "${_IDE_OUTPUT_PATH}/Resources")
- set(_IDE_DOC_PATH "${_IDE_OUTPUT_PATH}/Resources/doc")
- set(_IDE_BIN_PATH "${_IDE_OUTPUT_PATH}/MacOS")
-
- set(QT_DEST_PLUGIN_PATH "${_IDE_PLUGIN_PATH}")
- set(QT_DEST_QML_PATH "${_IDE_DATA_PATH}/../Imports/qtquick2")
-else ()
- set(_IDE_APP_PATH "bin")
- set(_IDE_APP_TARGET "${IDE_ID}")
-
- set(_IDE_LIBRARY_BASE_PATH "lib")
- set(_IDE_LIBRARY_PATH "lib/${IDE_ID}")
- set(_IDE_PLUGIN_PATH "lib/${IDE_ID}/plugins")
- if (WIN32)
- set(_IDE_LIBEXEC_PATH "bin")
- set(QT_DEST_PLUGIN_PATH "bin/plugins")
- set(QT_DEST_QML_PATH "bin/qml")
- else ()
- set(_IDE_LIBEXEC_PATH "libexec/${IDE_ID}")
- set(QT_DEST_PLUGIN_PATH "lib/Qt/plugins")
- set(QT_DEST_QML_PATH "lib/Qt/qml")
- endif ()
- set(_IDE_DATA_PATH "share/${IDE_ID}")
- set(_IDE_DOC_PATH "share/doc/${IDE_ID}")
- set(_IDE_BIN_PATH "bin")
-endif ()
+include(${CMAKE_CURRENT_LIST_DIR}/QtCreatorAPIInternal.cmake)
set(IDE_APP_PATH "${_IDE_APP_PATH}") # The target path of the IDE application (relative to CMAKE_INSTALL_PREFIX).
set(IDE_APP_TARGET "${_IDE_APP_TARGET}") # The IDE application name.
@@ -96,232 +27,9 @@ list(APPEND DEFAULT_DEFINES
RELATIVE_DOC_PATH="${RELATIVE_DOC_PATH}"
)
-file(RELATIVE_PATH _PLUGIN_TO_LIB "/${IDE_PLUGIN_PATH}" "/${IDE_LIBRARY_PATH}")
-file(RELATIVE_PATH _PLUGIN_TO_QT "/${IDE_PLUGIN_PATH}" "/${IDE_LIBRARY_BASE_PATH}/Qt/lib")
-file(RELATIVE_PATH _LIB_TO_QT "/${IDE_LIBRARY_PATH}" "/${IDE_LIBRARY_BASE_PATH}/Qt/lib")
-
-if (APPLE)
- set(_RPATH_BASE "@executable_path")
- set(_LIB_RPATH "@loader_path")
- set(_PLUGIN_RPATH "@loader_path;@loader_path/${_PLUGIN_TO_LIB}")
-elseif (WIN32)
- set(_RPATH_BASE "")
- set(_LIB_RPATH "")
- set(_PLUGIN_RPATH "")
-else()
- set(_RPATH_BASE "\$ORIGIN")
- set(_LIB_RPATH "\$ORIGIN;\$ORIGIN/${_LIB_TO_QT}")
- set(_PLUGIN_RPATH "\$ORIGIN;\$ORIGIN/${_PLUGIN_TO_LIB};\$ORIGIN/${_PLUGIN_TO_QT}")
-endif ()
-
-set(__QTC_PLUGINS "" CACHE INTERNAL "*** Internal ***")
-set(__QTC_INSTALLED_PLUGINS "" CACHE INTERNAL "*** Internal ***")
-set(__QTC_LIBRARIES "" CACHE INTERNAL "*** Internal ***")
-set(__QTC_INSTALLED_LIBRARIES "" CACHE INTERNAL "*** Internal ***")
-set(__QTC_EXECUTABLES "" CACHE INTERNAL "*** Internal ***")
-set(__QTC_INSTALLED_EXECUTABLES "" CACHE INTERNAL "*** Internal ***")
-set(__QTC_TESTS "" CACHE INTERNAL "*** Internal ***")
-
-#
-# Internal functions
-#
-
-function(append_extra_translations target_name)
- if(NOT ARGN)
- return()
- endif()
-
- if(TARGET "${target_name}")
- get_target_property(_input "${target_name}" QT_EXTRA_TRANSLATIONS)
- if (_input)
- set(_output "${_input}" "${ARGN}")
- else()
- set(_output "${ARGN}")
- endif()
- set_target_properties("${target_name}" PROPERTIES QT_EXTRA_TRANSLATIONS "${_output}")
- endif()
-endfunction()
-
-function(update_cached_list name value)
- set(_tmp_list "${${name}}")
- list(APPEND _tmp_list "${value}")
- set("${name}" "${_tmp_list}" CACHE INTERNAL "*** Internal ***")
-endfunction()
-
-function(compare_sources_with_existing_disk_files target_name sources)
- if(NOT WITH_DEBUG_CMAKE)
- return()
- endif()
-
- file(GLOB_RECURSE existing_files RELATIVE ${CMAKE_CURRENT_LIST_DIR} "*.cpp" "*.hpp" "*.c" "*.h" "*.ui" "*.qrc")
- foreach(file IN LISTS existing_files)
- if(NOT ${file} IN_LIST sources)
- if (NOT WITH_TESTS AND ${file} MATCHES "test")
- continue()
- endif()
- message(STATUS "${target_name} doesn't include ${file}")
- endif()
- endforeach()
-
- foreach(source IN LISTS "${sources}")
- if(NOT ${source} IN_LIST existing_files)
- if (NOT WITH_TESTS AND ${file} MATCHES "test")
- continue()
- endif()
- message(STATUS "${target_name} contains non existing ${source}")
- endif()
- endforeach()
-endfunction(compare_sources_with_existing_disk_files)
-
-function(separate_object_libraries libraries REGULAR_LIBS OBJECT_LIBS OBJECT_LIB_OBJECTS)
- if (CMAKE_VERSION VERSION_LESS 3.14)
- foreach(lib IN LISTS libraries)
- if (TARGET ${lib})
- get_target_property(lib_type ${lib} TYPE)
- if (lib_type STREQUAL "OBJECT_LIBRARY")
- list(APPEND object_libs ${lib})
- list(APPEND object_libs_objects $<TARGET_OBJECTS:${lib}>)
- else()
- list(APPEND regular_libs ${lib})
- endif()
- else()
- list(APPEND regular_libs ${lib})
- endif()
- set(${REGULAR_LIBS} ${regular_libs} PARENT_SCOPE)
- set(${OBJECT_LIBS} ${object_libs} PARENT_SCOPE)
- set(${OBJECT_LIB_OBJECTS} ${object_libs_objects} PARENT_SCOPE)
- endforeach()
- else()
- set(${REGULAR_LIBS} ${libraries} PARENT_SCOPE)
- unset(${OBJECT_LIBS} PARENT_SCOPE)
- unset(${OBJECT_LIB_OBJECTS} PARENT_SCOPE)
- endif()
-endfunction(separate_object_libraries)
-
-function(set_explicit_moc target_name file)
- unset(file_dependencies)
- if (file MATCHES "^.*plugin.h$")
- set(file_dependencies DEPENDS "${CMAKE_CURRENT_BINARY_DIR}/${target_name}.json")
- endif()
- set_property(SOURCE "${file}" PROPERTY SKIP_AUTOMOC ON)
- qt5_wrap_cpp(file_moc "${file}" ${file_dependencies})
- target_sources(${target_name} PRIVATE "${file_moc}")
-endfunction()
-
-function(set_public_headers target sources)
- foreach(source IN LISTS sources)
- if (source MATCHES "\.h$|\.hpp$")
-
- if (NOT IS_ABSOLUTE ${source})
- set(source "${CMAKE_CURRENT_SOURCE_DIR}/${source}")
- endif()
-
- get_filename_component(source_dir ${source} DIRECTORY)
- file(RELATIVE_PATH include_dir_relative_path ${PROJECT_SOURCE_DIR} ${source_dir})
-
- install(
- FILES ${source}
- DESTINATION "include/${include_dir_relative_path}"
- COMPONENT Devel EXCLUDE_FROM_ALL
- )
- endif()
- endforeach()
-endfunction()
-
-function(set_public_includes target includes)
- foreach(inc_dir IN LISTS includes)
- if (NOT IS_ABSOLUTE ${inc_dir})
- set(inc_dir "${CMAKE_CURRENT_SOURCE_DIR}/${inc_dir}")
- endif()
- file(RELATIVE_PATH include_dir_relative_path ${PROJECT_SOURCE_DIR} ${inc_dir})
- target_include_directories(${target} PUBLIC
- $<BUILD_INTERFACE:${inc_dir}>
- $<INSTALL_INTERFACE:include/${include_dir_relative_path}>
- )
- endforeach()
-endfunction()
-
-function(finalize_test_setup test_name)
- # Never translate tests:
- set_tests_properties(${name}
- PROPERTIES
- QT_SKIP_TRANSLATION ON
- TIMEOUT 5
- )
-
- if (WIN32)
- list(APPEND env_path $ENV{PATH})
- list(APPEND env_path ${CMAKE_BINARY_DIR}/${IDE_PLUGIN_PATH})
- list(APPEND env_path ${CMAKE_BINARY_DIR}/${IDE_BIN_PATH})
- list(APPEND env_path $<TARGET_FILE_DIR:Qt5::Test>)
- if (TARGET libclang)
- list(APPEND env_path $<TARGET_FILE_DIR:libclang>)
- endif()
-
- if (TARGET elfutils::elf)
- list(APPEND env_path $<TARGET_FILE_DIR:elfutils::elf>)
- endif()
-
- string(REPLACE "/" "\\" env_path "${env_path}")
- string(REPLACE ";" "\\;" env_path "${env_path}")
-
- set_tests_properties(${test_name} PROPERTIES ENVIRONMENT "PATH=${env_path}")
- endif()
-endfunction()
-
-function(add_qtc_depends target_name)
- cmake_parse_arguments(_arg "" "" "PRIVATE;PUBLIC" ${ARGN})
- if (${_arg_UNPARSED_ARGUMENTS})
- message(FATAL_ERROR "add_qtc_depends had unparsed arguments")
- endif()
-
- separate_object_libraries("${_arg_PRIVATE}"
- depends object_lib_depends object_lib_depends_objects)
- separate_object_libraries("${_arg_PUBLIC}"
- public_depends object_public_depends object_public_depends_objects)
-
- target_sources(${target_name} PRIVATE ${object_lib_depends_objects} ${object_public_depends_objects})
-
- get_target_property(target_type ${target_name} TYPE)
- if (NOT target_type STREQUAL "OBJECT_LIBRARY")
- target_link_libraries(${target_name} PRIVATE ${depends} PUBLIC ${public_depends})
- else()
- list(APPEND object_lib_depends ${depends})
- list(APPEND object_public_depends ${public_depends})
- endif()
-
- foreach(obj_lib IN LISTS object_lib_depends)
- target_compile_definitions(${target_name} PRIVATE $<TARGET_PROPERTY:${obj_lib},INTERFACE_COMPILE_DEFINITIONS>)
- target_include_directories(${target_name} PRIVATE $<TARGET_PROPERTY:${obj_lib},INTERFACE_INCLUDE_DIRECTORIES>)
- endforeach()
- foreach(obj_lib IN LISTS object_public_depends)
- target_compile_definitions(${target_name} PUBLIC $<TARGET_PROPERTY:${obj_lib},INTERFACE_COMPILE_DEFINITIONS>)
- target_include_directories(${target_name} PUBLIC $<TARGET_PROPERTY:${obj_lib},INTERFACE_INCLUDE_DIRECTORIES>)
- endforeach()
-endfunction()
-
-function(find_dependent_plugins varName)
- set(_RESULT ${ARGN})
-
- foreach(i ${ARGN})
- get_property(_dep TARGET "${i}" PROPERTY _arg_DEPENDS)
- if (_dep)
- find_dependent_plugins(_REC ${_dep})
- list(APPEND _RESULT ${_REC})
- endif()
- endforeach()
-
- if (_RESULT)
- list(REMOVE_DUPLICATES _RESULT)
- list(SORT _RESULT)
- endif()
-
- set("${varName}" ${_RESULT} PARENT_SCOPE)
-endfunction()
-
function(qtc_plugin_enabled varName name)
if (NOT (name IN_LIST __QTC_PLUGINS))
- message(FATAL_ERROR "extend_qtc_plugin: Unknown plugin target \"${name}\"")
+ message(FATAL_ERROR "qtc_plugin_enabled: Unknown plugin target \"${name}\"")
endif()
if (TARGET ${name})
set(${varName} ON PARENT_SCOPE)
@@ -332,7 +40,7 @@ endfunction()
function(qtc_library_enabled varName name)
if (NOT (name IN_LIST __QTC_LIBRARIES))
- message(FATAL_ERROR "extend_qtc_library: Unknown library target \"${name}\"")
+ message(FATAL_ERROR "qtc_library_enabled: Unknown library target \"${name}\"")
endif()
if (TARGET ${name})
set(${varName} ON PARENT_SCOPE)
@@ -341,82 +49,6 @@ function(qtc_library_enabled varName name)
endif()
endfunction()
-function(enable_pch target)
- if (BUILD_WITH_PCH)
- # Skip PCH for targets that do not use the expected visibility settings:
- get_target_property(visibility_property "${target}" CXX_VISIBILITY_PRESET)
- get_target_property(inlines_property "${target}" VISIBILITY_INLINES_HIDDEN)
-
- if (NOT visibility_property STREQUAL "hidden" OR NOT inlines_property)
- return()
- endif()
-
- # Skip PCH for targets that do not have QT_NO_CAST_TO_ASCII
- get_target_property(target_defines "${target}" COMPILE_DEFINITIONS)
- if (NOT "QT_NO_CAST_TO_ASCII" IN_LIST target_defines)
- return()
- endif()
-
- get_target_property(target_type ${target} TYPE)
- if (NOT ${target_type} STREQUAL "OBJECT_LIBRARY")
- function(_recursively_collect_dependencies input_target)
- get_target_property(input_type ${input_target} TYPE)
- if (${input_type} STREQUAL "INTERFACE_LIBRARY")
- set(prefix "INTERFACE_")
- endif()
- get_target_property(link_libraries ${input_target} ${prefix}LINK_LIBRARIES)
- foreach(library IN LISTS link_libraries)
- if(TARGET ${library} AND NOT ${library} IN_LIST dependencies)
- list(APPEND dependencies ${library})
- _recursively_collect_dependencies(${library})
- endif()
- endforeach()
- set(dependencies ${dependencies} PARENT_SCOPE)
- endfunction()
- _recursively_collect_dependencies(${target})
-
- function(_add_pch_target pch_target pch_file pch_dependency)
- if (EXISTS ${pch_file})
- add_library(${pch_target} STATIC
- ${CMAKE_CURRENT_BINARY_DIR}/empty_pch.cpp
- ${CMAKE_CURRENT_BINARY_DIR}/empty_pch.c)
- target_compile_definitions(${pch_target} PRIVATE ${DEFAULT_DEFINES})
- set_target_properties(${pch_target} PROPERTIES
- PRECOMPILE_HEADERS ${pch_file}
- CXX_VISIBILITY_PRESET hidden
- VISIBILITY_INLINES_HIDDEN ON)
- target_link_libraries(${pch_target} PRIVATE ${pch_dependency})
- endif()
- endfunction()
-
- if (NOT TARGET QtCreatorPchGui AND NOT TARGET QtCreatorPchConsole)
- file(GENERATE
- OUTPUT ${CMAKE_CURRENT_BINARY_DIR}/empty_pch.c
- CONTENT "/*empty file*/")
- file(GENERATE
- OUTPUT ${CMAKE_CURRENT_BINARY_DIR}/empty_pch.cpp
- CONTENT "/*empty file*/")
- _add_pch_target(QtCreatorPchGui
- "${PROJECT_SOURCE_DIR}/src/shared/qtcreator_gui_pch.h" Qt5::Widgets)
- _add_pch_target(QtCreatorPchConsole
- "${PROJECT_SOURCE_DIR}/src/shared/qtcreator_pch.h" Qt5::Core)
- endif()
-
- unset(PCH_TARGET)
- if ("Qt5::Widgets" IN_LIST dependencies)
- set(PCH_TARGET QtCreatorPchGui)
- elseif ("Qt5::Core" IN_LIST dependencies)
- set(PCH_TARGET QtCreatorPchConsole)
- endif()
-
- if (TARGET "${PCH_TARGET}")
- set_target_properties(${target} PROPERTIES
- PRECOMPILE_HEADERS_REUSE_FROM ${PCH_TARGET})
- endif()
- endif()
- endif()
-endfunction()
-
function(qtc_output_binary_dir varName)
if (QTC_MERGE_BINARY_DIR)
set(${varName} ${QtCreator_BINARY_DIR} PARENT_SCOPE)
@@ -425,23 +57,10 @@ function(qtc_output_binary_dir varName)
endif()
endfunction()
-function(condition_info varName condition)
- if (NOT ${condition})
- set(${varName} "" PARENT_SCOPE)
- else()
- string(REPLACE ";" " " _contents "${${condition}}")
- set(${varName} "with CONDITION ${_contents}" PARENT_SCOPE)
- endif()
-endfunction()
-
-#
-# Public API functions
-#
-
function(add_qtc_library name)
cmake_parse_arguments(_arg "STATIC;OBJECT;SKIP_TRANSLATION;BUILD_BY_DEFAULT;ALLOW_ASCII_CASTS;UNVERSIONED"
"DESTINATION;COMPONENT"
- "DEFINES;DEPENDS;EXTRA_TRANSLATIONS;INCLUDES;PUBLIC_DEFINES;PUBLIC_DEPENDS;PUBLIC_INCLUDES;SOURCES;EXPLICIT_MOC;SKIP_AUTOMOC;PROPERTIES" ${ARGN}
+ "DEPENDS;PUBLIC_DEPENDS;DEFINES;PUBLIC_DEFINES;INCLUDES;PUBLIC_INCLUDES;SOURCES;EXPLICIT_MOC;SKIP_AUTOMOC;EXTRA_TRANSLATIONS;PROPERTIES" ${ARGN}
)
set(default_defines_copy ${DEFAULT_DEFINES})
@@ -497,35 +116,26 @@ function(add_qtc_library name)
set(TEST_DEFINES WITH_TESTS SRCDIR="${CMAKE_CURRENT_SOURCE_DIR}")
endif()
- file(RELATIVE_PATH include_dir_relative_path ${PROJECT_SOURCE_DIR} ${CMAKE_CURRENT_SOURCE_DIR})
+ extend_qtc_target(${name}
+ INCLUDES ${_arg_INCLUDES}
+ PUBLIC_INCLUDES ${_arg_PUBLIC_INCLUDES}
+ DEFINES ${EXPORT_SYMBOL} ${default_defines_copy} ${_arg_DEFINES} ${TEST_DEFINES}
+ PUBLIC_DEFINES ${_arg_PUBLIC_DEFINES}
+ DEPENDS ${_arg_DEPENDS} ${IMPLICIT_DEPENDS}
+ PUBLIC_DEPENDS ${_arg_PUBLIC_DEPENDS}
+ EXPLICIT_MOC ${_arg_EXPLICIT_MOC}
+ SKIP_AUTOMOC ${_arg_SKIP_AUTOMOC}
+ EXTRA_TRANSLATIONS ${_arg_EXTRA_TRANSLATIONS}
+ )
+ file(RELATIVE_PATH include_dir_relative_path ${PROJECT_SOURCE_DIR} ${CMAKE_CURRENT_SOURCE_DIR})
target_include_directories(${name}
PRIVATE
- ${_arg_INCLUDES}
"$<BUILD_INTERFACE:${CMAKE_CURRENT_SOURCE_DIR}>"
PUBLIC
"$<BUILD_INTERFACE:${CMAKE_CURRENT_SOURCE_DIR}/..>"
"$<INSTALL_INTERFACE:include/${include_dir_relative_path}/..>"
)
- set_public_includes(${name} "${_arg_PUBLIC_INCLUDES}")
-
- target_compile_definitions(${name}
- PRIVATE ${EXPORT_SYMBOL} ${default_defines_copy} ${_arg_DEFINES} ${TEST_DEFINES}
- PUBLIC ${_arg_PUBLIC_DEFINES}
- )
-
- add_qtc_depends(${name}
- PRIVATE ${_arg_DEPENDS} ${IMPLICIT_DEPENDS}
- PUBLIC ${_arg_PUBLIC_DEPENDS}
- )
-
- foreach(file IN LISTS _arg_EXPLICIT_MOC)
- set_explicit_moc(${name} "${file}")
- endforeach()
-
- foreach(file IN LISTS _arg_SKIP_AUTOMOC)
- set_property(SOURCE ${file} PROPERTY SKIP_AUTOMOC ON)
- endforeach()
set(skip_translation OFF)
if (_arg_SKIP_TRANSLATION)
@@ -542,6 +152,8 @@ function(add_qtc_library name)
SOURCES_DIR "${CMAKE_CURRENT_SOURCE_DIR}"
VERSION "${IDE_VERSION}"
SOVERSION "${PROJECT_VERSION_MAJOR}"
+ MACHO_CURRENT_VERSION ${IDE_VERSION}
+ MACHO_COMPATIBILITY_VERSION ${IDE_VERSION_COMPAT}
CXX_EXTENSIONS OFF
CXX_VISIBILITY_PRESET hidden
VISIBILITY_INLINES_HIDDEN ON
@@ -619,15 +231,13 @@ function(add_qtc_library name)
OPTIONAL
)
endif()
-
- append_extra_translations("${name}" "${_arg_EXTRA_TRANSLATIONS}")
endfunction(add_qtc_library)
function(add_qtc_plugin target_name)
cmake_parse_arguments(_arg
"EXPERIMENTAL;SKIP_DEBUG_CMAKE_FILE_CHECK;SKIP_INSTALL;INTERNAL_ONLY;SKIP_TRANSLATION"
- "VERSION;COMPAT_VERSION;PLUGIN_JSON_IN;PLUGIN_PATH;PLUGIN_NAME;OUTPUT_NAME"
- "CONDITION;DEPENDS;EXTRA_TRANSLATIONS;PUBLIC_DEPENDS;DEFINES;PUBLIC_DEFINES;INCLUDES;PUBLIC_INCLUDES;PLUGIN_DEPENDS;PLUGIN_RECOMMENDS;SOURCES;EXPLICIT_MOC"
+ "VERSION;COMPAT_VERSION;PLUGIN_JSON_IN;PLUGIN_PATH;PLUGIN_NAME;OUTPUT_NAME;BUILD_DEFAULT"
+ "CONDITION;DEPENDS;PUBLIC_DEPENDS;DEFINES;PUBLIC_DEFINES;INCLUDES;PUBLIC_INCLUDES;SOURCES;EXPLICIT_MOC;SKIP_AUTOMOC;EXTRA_TRANSLATIONS;PLUGIN_DEPENDS;PLUGIN_RECOMMENDS"
${ARGN}
)
@@ -648,7 +258,11 @@ function(add_qtc_plugin target_name)
endif()
string(TOUPPER "BUILD_PLUGIN_${target_name}" _build_plugin_var)
- set(_build_plugin_default "ON")
+ if (DEFINED _arg_BUILD_DEFAULT)
+ set(_build_plugin_default ${_arg_BUILD_DEFAULT})
+ else()
+ set(_build_plugin_default "ON")
+ endif()
if (DEFINED ENV{QTC_${_build_plugin_var}})
set(_build_plugin_default "$ENV{QTC_${_build_plugin_var}}")
endif()
@@ -752,11 +366,21 @@ function(add_qtc_plugin target_name)
set(TEST_DEFINES WITH_TESTS SRCDIR="${CMAKE_CURRENT_SOURCE_DIR}")
endif()
- file(RELATIVE_PATH include_dir_relative_path ${PROJECT_SOURCE_DIR} ${CMAKE_CURRENT_SOURCE_DIR})
+ extend_qtc_target(${target_name}
+ INCLUDES ${_arg_INCLUDES}
+ PUBLIC_INCLUDES ${_arg_PUBLIC_INCLUDES}
+ DEFINES ${EXPORT_SYMBOL} ${DEFAULT_DEFINES} ${_arg_DEFINES} ${TEST_DEFINES}
+ PUBLIC_DEFINES ${_arg_PUBLIC_DEFINES}
+ DEPENDS ${_arg_DEPENDS} ${_DEP_PLUGINS} ${IMPLICIT_DEPENDS}
+ PUBLIC_DEPENDS ${_arg_PUBLIC_DEPENDS}
+ EXPLICIT_MOC ${_arg_EXPLICIT_MOC}
+ SKIP_AUTOMOC ${_arg_SKIP_AUTOMOC}
+ EXTRA_TRANSLATIONS ${_arg_EXTRA_TRANSLATIONS}
+ )
+ file(RELATIVE_PATH include_dir_relative_path ${PROJECT_SOURCE_DIR} ${CMAKE_CURRENT_SOURCE_DIR})
target_include_directories(${target_name}
PRIVATE
- ${_arg_INCLUDES}
"${CMAKE_CURRENT_BINARY_DIR}"
"${CMAKE_BINARY_DIR}/src"
"$<BUILD_INTERFACE:${CMAKE_CURRENT_SOURCE_DIR}>"
@@ -764,17 +388,6 @@ function(add_qtc_plugin target_name)
"$<BUILD_INTERFACE:${CMAKE_CURRENT_SOURCE_DIR}/..>"
"$<INSTALL_INTERFACE:include/${include_dir_relative_path}/..>"
)
- set_public_includes(${target_name} "${_arg_PUBLIC_INCLUDES}")
-
- target_compile_definitions(${target_name}
- PRIVATE ${EXPORT_SYMBOL} ${DEFAULT_DEFINES} ${_arg_DEFINES} ${TEST_DEFINES}
- PUBLIC ${_arg_PUBLIC_DEFINES}
- )
-
- add_qtc_depends(${target_name}
- PRIVATE ${_arg_DEPENDS} ${_DEP_PLUGINS} ${IMPLICIT_DEPENDS}
- PUBLIC ${_arg_PUBLIC_DEPENDS}
- )
set(plugin_dir "${IDE_PLUGIN_PATH}")
if (_arg_PLUGIN_PATH)
@@ -789,6 +402,8 @@ function(add_qtc_plugin target_name)
qtc_output_binary_dir(_output_binary_dir)
set_target_properties(${target_name} PROPERTIES
SOURCES_DIR "${CMAKE_CURRENT_SOURCE_DIR}"
+ MACHO_CURRENT_VERSION ${IDE_VERSION}
+ MACHO_COMPATIBILITY_VERSION ${IDE_VERSION_COMPAT}
CXX_EXTENSIONS OFF
CXX_VISIBILITY_PRESET hidden
VISIBILITY_INLINES_HIDDEN ON
@@ -811,13 +426,8 @@ function(add_qtc_plugin target_name)
PREFIX ""
)
endif()
- append_extra_translations("${target_name}" "${_arg_EXTRA_TRANSLATIONS}")
enable_pch(${target_name})
- foreach(file IN LISTS _arg_EXPLICIT_MOC)
- set_explicit_moc(${target_name} "${file}")
- endforeach()
-
if (NOT _arg_SKIP_INSTALL)
install(TARGETS ${target_name}
EXPORT ${IDE_CASED_ID}
@@ -841,76 +451,6 @@ function(add_qtc_plugin target_name)
endif()
endfunction()
-function(extend_qtc_target target_name)
- cmake_parse_arguments(_arg
- ""
- "SOURCES_PREFIX;FEATURE_INFO"
- "CONDITION;DEPENDS;PUBLIC_DEPENDS;DEFINES;PUBLIC_DEFINES;INCLUDES;PUBLIC_INCLUDES;SOURCES;EXPLICIT_MOC"
- ${ARGN}
- )
-
- if (${_arg_UNPARSED_ARGUMENTS})
- message(FATAL_ERROR "extend_qtc_target had unparsed arguments")
- endif()
-
- condition_info(_extra_text _arg_CONDITION)
- if (NOT _arg_CONDITION)
- set(_arg_CONDITION ON)
- endif()
- if (${_arg_CONDITION})
- set(_feature_enabled ON)
- else()
- set(_feature_enabled OFF)
- endif()
- if (_arg_FEATURE_INFO)
- add_feature_info(${_arg_FEATURE_INFO} _feature_enabled "${_extra_text}")
- endif()
- if (NOT _feature_enabled)
- return()
- endif()
-
- add_qtc_depends(${target_name}
- PRIVATE ${_arg_DEPENDS}
- PUBLIC ${_arg_PUBLIC_DEPENDS}
- )
- target_compile_definitions(${target_name}
- PRIVATE ${_arg_DEFINES}
- PUBLIC ${_arg_PUBLIC_DEFINES}
- )
- target_include_directories(${target_name} PRIVATE ${_arg_INCLUDES})
-
- set_public_includes(${target_name} "${_arg_PUBLIC_INCLUDES}")
-
- if (_arg_SOURCES_PREFIX)
- foreach(source IN LISTS _arg_SOURCES)
- list(APPEND prefixed_sources "${_arg_SOURCES_PREFIX}/${source}")
- endforeach()
-
- if (NOT IS_ABSOLUTE ${_arg_SOURCES_PREFIX})
- set(_arg_SOURCES_PREFIX "${CMAKE_CURRENT_SOURCE_DIR}/${_arg_SOURCES_PREFIX}")
- endif()
- target_include_directories(${target_name} PRIVATE $<BUILD_INTERFACE:${_arg_SOURCES_PREFIX}>)
-
- set(_arg_SOURCES ${prefixed_sources})
- endif()
- target_sources(${target_name} PRIVATE ${_arg_SOURCES})
-
- if (APPLE AND BUILD_WITH_PCH)
- foreach(source IN LISTS _arg_SOURCES)
- if (source MATCHES "^.*\.mm$")
- set_source_files_properties(${source} PROPERTIES SKIP_PRECOMPILE_HEADERS ON)
- endif()
- endforeach()
- endif()
-
- set_public_headers(${target_name} "${_arg_SOURCES}")
-
- foreach(file IN LISTS _arg_EXPLICIT_MOC)
- set_explicit_moc(${target_name} "${file}")
- endforeach()
-
-endfunction()
-
function(extend_qtc_plugin target_name)
qtc_plugin_enabled(_plugin_enabled ${target_name})
if (NOT _plugin_enabled)
@@ -929,10 +469,17 @@ function(extend_qtc_library target_name)
extend_qtc_target(${target_name} ${ARGN})
endfunction()
+function(extend_qtc_test target_name)
+ if (NOT (target_name IN_LIST __QTC_TESTS))
+ message(FATAL_ERROR "extend_qtc_test: Unknown test target \"${name}\"")
+ endif()
+ extend_qtc_target(${target_name} ${ARGN})
+endfunction()
+
function(add_qtc_executable name)
cmake_parse_arguments(_arg "SKIP_INSTALL;SKIP_TRANSLATION;ALLOW_ASCII_CASTS"
"DESTINATION;COMPONENT"
- "DEFINES;DEPENDS;EXTRA_TRANSLATIONS;INCLUDES;SOURCES;PROPERTIES" ${ARGN})
+ "DEPENDS;DEFINES;INCLUDES;SOURCES;EXPLICIT_MOC;SKIP_AUTOMOC;EXTRA_TRANSLATIONS;PROPERTIES" ${ARGN})
if ($_arg_UNPARSED_ARGUMENTS)
message(FATAL_ERROR "add_qtc_executable had unparsed arguments!")
@@ -975,9 +522,15 @@ function(add_qtc_executable name)
endif()
add_executable("${name}" ${_arg_SOURCES})
- target_include_directories("${name}" PRIVATE "${CMAKE_BINARY_DIR}/src" ${_arg_INCLUDES})
- target_compile_definitions("${name}" PRIVATE ${default_defines_copy} ${TEST_DEFINES} ${_arg_DEFINES} )
- target_link_libraries("${name}" PRIVATE ${_arg_DEPENDS} ${IMPLICIT_DEPENDS})
+
+ extend_qtc_target("${name}"
+ INCLUDES "${CMAKE_BINARY_DIR}/src" ${_arg_INCLUDES}
+ DEFINES ${default_defines_copy} ${TEST_DEFINES} ${_arg_DEFINES}
+ DEPENDS ${_arg_DEPENDS} ${IMPLICIT_DEPENDS}
+ EXPLICIT_MOC ${_arg_EXPLICIT_MOC}
+ SKIP_AUTOMOC ${_arg_SKIP_AUTOMOC}
+ EXTRA_TRANSLATIONS ${_arg_EXTRA_TRANSLATIONS}
+ )
set(skip_translation OFF)
if (_arg_SKIP_TRANSLATION)
@@ -1005,7 +558,6 @@ function(add_qtc_executable name)
VISIBILITY_INLINES_HIDDEN ON
${_arg_PROPERTIES}
)
- append_extra_translations("${name}" "${_arg_EXTRA_TRANSLATIONS}")
enable_pch(${name})
if (NOT _arg_SKIP_INSTALL)
@@ -1089,7 +641,7 @@ function(extend_qtc_executable name)
endfunction()
function(add_qtc_test name)
- cmake_parse_arguments(_arg "GTEST" "" "DEFINES;DEPENDS;INCLUDES;SOURCES" ${ARGN})
+ cmake_parse_arguments(_arg "GTEST" "TIMEOUT" "DEFINES;DEPENDS;INCLUDES;SOURCES;EXPLICIT_MOC;SKIP_AUTOMOC" ${ARGN})
foreach(dependency ${_arg_DEPENDS})
if (NOT TARGET ${dependency} AND NOT _arg_GTEST)
@@ -1107,17 +659,23 @@ function(add_qtc_test name)
update_cached_list(__QTC_TESTS "${name}")
set(TEST_DEFINES SRCDIR="${CMAKE_CURRENT_SOURCE_DIR}")
+
+ # relax cast requirements for tests
+ set(default_defines_copy ${DEFAULT_DEFINES})
+ list(REMOVE_ITEM default_defines_copy QT_NO_CAST_TO_ASCII QT_RESTRICTED_CAST_FROM_ASCII)
+
file(RELATIVE_PATH _RPATH "/${IDE_BIN_PATH}" "/${IDE_LIBRARY_PATH}")
add_executable(${name} ${_arg_SOURCES})
- add_qtc_depends(${name}
- PRIVATE ${_arg_DEPENDS} ${IMPLICIT_DEPENDS}
+ extend_qtc_target(${name}
+ DEPENDS ${_arg_DEPENDS} ${IMPLICIT_DEPENDS}
+ INCLUDES "${CMAKE_BINARY_DIR}/src" ${_arg_INCLUDES}
+ DEFINES ${_arg_DEFINES} ${TEST_DEFINES} ${default_defines_copy}
+ EXPLICIT_MOC ${_arg_EXPLICIT_MOC}
+ SKIP_AUTOMOC ${_arg_SKIP_AUTOMOC}
)
- target_include_directories(${name} PRIVATE "${CMAKE_BINARY_DIR}/src" ${_arg_INCLUDES})
- target_compile_definitions(${name} PRIVATE ${_arg_DEFINES} ${TEST_DEFINES} ${DEFAULT_DEFINES})
-
set_target_properties(${name} PROPERTIES
BUILD_RPATH "${_RPATH_BASE}/${_RPATH}"
INSTALL_RPATH "${_RPATH_BASE}/${_RPATH}"
@@ -1126,15 +684,23 @@ function(add_qtc_test name)
if (NOT _arg_GTEST)
add_test(NAME ${name} COMMAND ${name})
- finalize_test_setup(${name})
+ if (DEFINED _arg_TIMEOUT)
+ set(timeout_option TIMEOUT ${_arg_TIMEOUT})
+ else()
+ set(timeout_option)
+ endif()
+ finalize_test_setup(${name} ${timeout_option})
endif()
endfunction()
-function(finalize_qtc_gtest test_name)
+function(finalize_qtc_gtest test_name exclude_sources_regex)
if (NOT TARGET ${test_name})
return()
endif()
get_target_property(test_sources ${test_name} SOURCES)
+ if (exclude_sources_regex)
+ list(FILTER test_sources EXCLUDE REGEX "${exclude_sources_regex}")
+ endif()
include(GoogleTest)
gtest_add_tests(TARGET ${test_name} SOURCES ${test_sources} TEST_LIST test_list)
@@ -1155,3 +721,55 @@ function(qtc_glob_resources)
string(APPEND qrcData "</qresource></RCC>")
file(WRITE "${_arg_QRC_FILE}" "${qrcData}")
endfunction()
+
+function(qtc_copy_to_builddir custom_target_name)
+ cmake_parse_arguments(_arg "CREATE_SUBDIRS" "DESTINATION" "FILES;DIRECTORIES" ${ARGN})
+ set(timestampFiles)
+
+ qtc_output_binary_dir(_output_binary_dir)
+
+ foreach(srcFile ${_arg_FILES})
+ string(MAKE_C_IDENTIFIER "${srcFile}" destinationTimestampFilePart)
+ set(destinationTimestampFileName "${CMAKE_CURRENT_BINARY_DIR}/.${destinationTimestampFilePart}_timestamp")
+ list(APPEND timestampFiles "${destinationTimestampFileName}")
+
+ if (IS_ABSOLUTE "${srcFile}")
+ set(srcPath "")
+ else()
+ get_filename_component(srcPath "${srcFile}" DIRECTORY)
+ endif()
+
+ add_custom_command(OUTPUT "${destinationTimestampFileName}"
+ COMMAND "${CMAKE_COMMAND}" -E make_directory "${_output_binary_dir}/${_arg_DESTINATION}/${srcPath}"
+ COMMAND "${CMAKE_COMMAND}" -E copy "${srcFile}" "${_output_binary_dir}/${_arg_DESTINATION}/${srcPath}"
+ COMMAND "${CMAKE_COMMAND}" -E touch "${destinationTimestampFileName}"
+ WORKING_DIRECTORY "${CMAKE_CURRENT_SOURCE_DIR}"
+ COMMENT "Copy ${srcFile} into build directory"
+ DEPENDS "${srcFile}"
+ VERBATIM
+ )
+ endforeach()
+
+ foreach(srcDirectory ${_arg_DIRECTORIES})
+ string(MAKE_C_IDENTIFIER "${srcDirectory}" destinationTimestampFilePart)
+ set(destinationTimestampFileName "${CMAKE_CURRENT_BINARY_DIR}/.${destinationTimestampFilePart}_timestamp")
+ list(APPEND timestampFiles "${destinationTimestampFileName}")
+ set(destinationDirectory "${_output_binary_dir}/${_arg_DESTINATION}")
+
+ if(_arg_CREATE_SUBDIRS)
+ set(destinationDirectory "${destinationDirectory}/${srcDirectory}")
+ endif()
+
+ file(GLOB_RECURSE filesToCopy "${srcDirectory}/*")
+ add_custom_command(OUTPUT "${destinationTimestampFileName}"
+ COMMAND "${CMAKE_COMMAND}" -E copy_directory "${srcDirectory}" "${destinationDirectory}"
+ COMMAND "${CMAKE_COMMAND}" -E touch "${destinationTimestampFileName}"
+ WORKING_DIRECTORY "${CMAKE_CURRENT_SOURCE_DIR}"
+ COMMENT "Copy ${srcDirectory}/ into build directory"
+ DEPENDS ${filesToCopy}
+ VERBATIM
+ )
+ endforeach()
+
+ add_custom_target("${custom_target_name}" ALL DEPENDS ${timestampFiles})
+endfunction()