diff options
author | Alexey Edelev <alexey.edelev@qt.io> | 2021-07-30 17:51:07 +0200 |
---|---|---|
committer | Alexey Edelev <alexey.edelev@qt.io> | 2021-08-27 11:01:47 +0200 |
commit | e1fe816d4662875032946844fadfed3ea691fdd8 (patch) | |
tree | acbf411b2ca012bbe7b1be8d9659ff210e5ad455 /cmake/QtModuleHelpers.cmake | |
parent | 928ffbd1e20860fdcfbddde8e39303252a9ebb98 (diff) |
Implement generating of private cpp exports
Add the generating of private cpp exports for Qt modules.
Add the GENERATE_PRIVATE_CPP_EXPORTS option to qt_internal_add_module
that is the manual switch for private exports generator. Existing
modules in qtbase doesn't follow any strict convention of using
private cpp export. So there is no clue how to detect if generating of
the private exports is required or not for the module.
Use autogenerated private cpp exports in QtNetwork module.
CPP_EXPORT_HEADER_NAME argument of the qt_internal_add_module function
is replaced by the CPP_EXPORT_HEADER_BASE_NAME and has a different
meaning. The provided name is used as a base name for the private and
non-private headers that contains cpp exports. Header files suffixes
are constant: .h and _p.h for the non-private and private header files
accordingly.
Pick-to: 6.2
Task-number: QTBUG-90492
Change-Id: Icf11304e00379fb8521a865965c19b974e01e62f
Reviewed-by: Alexandru Croitor <alexandru.croitor@qt.io>
Reviewed-by: Qt CI Bot <qt_ci_bot@qt-project.org>
Diffstat (limited to 'cmake/QtModuleHelpers.cmake')
-rw-r--r-- | cmake/QtModuleHelpers.cmake | 109 |
1 files changed, 88 insertions, 21 deletions
diff --git a/cmake/QtModuleHelpers.cmake b/cmake/QtModuleHelpers.cmake index eeebd05de9..39088a64fd 100644 --- a/cmake/QtModuleHelpers.cmake +++ b/cmake/QtModuleHelpers.cmake @@ -21,7 +21,6 @@ macro(qt_internal_get_internal_add_module_keywords option_args single_args multi CONFIG_MODULE_NAME PRECOMPILED_HEADER CONFIGURE_FILE_PATH - CPP_EXPORT_HEADER_NAME ${__default_target_info_args} ) set(${multi_args} @@ -35,6 +34,16 @@ macro(qt_internal_get_internal_add_module_keywords option_args single_args multi ) endmacro() +macro(qt_internal_get_generate_cpp_global_exports_keywords option_args single_args multi_args) + set(${option_args} + GENERATE_PRIVATE_CPP_EXPORTS + ) + set(${single_args} + CPP_EXPORT_HEADER_BASE_NAME + ) + set(${multi_args} "") +endmacro() + # This is the main entry function for creating a Qt module, that typically # consists of a library, public header files, private header files and configurable # features. @@ -62,9 +71,30 @@ endmacro() # function(qt_internal_add_module target) qt_internal_get_internal_add_module_keywords( - option_args - single_args - multi_args + module_option_args + module_single_args + module_multi_args + ) + + qt_internal_get_generate_cpp_global_exports_keywords( + cpp_exports_option_args + cpp_exports_single_args + cpp_exports_multi_args + ) + + set(option_args + ${module_option_args} + ${cpp_exports_option_args} + ) + + set(single_args + ${module_single_args} + ${cpp_exports_single_args} + ) + + set(multi_args + ${module_multi_args} + ${cpp_exports_multi_args} ) qt_parse_all_arguments(arg "qt_internal_add_module" @@ -154,15 +184,6 @@ function(qt_internal_add_module target) string(REPLACE "-" "_" module_define_infix "${module_define_infix}") string(REPLACE "." "_" module_define_infix "${module_define_infix}") - if(arg_GENERATE_CPP_EXPORTS) - if(arg_CPP_EXPORT_HEADER_NAME) - set(cpp_export_header_name "CPP_EXPORT_HEADER_NAME;${arg_CPP_EXPORT_HEADER_NAME}") - endif() - qt_internal_generate_cpp_global_exports(${target} ${module_define_infix} - "${cpp_export_header_name}" - ) - endif() - set(property_prefix "INTERFACE_") if(NOT arg_HEADER_MODULE) qt_set_common_target_properties(${target}) @@ -316,6 +337,25 @@ function(qt_internal_add_module target) ### FIXME: Can we replace headers.pri? qt_read_headers_pri("${module_build_interface_include_dir}" "module_headers") + if(arg_GENERATE_CPP_EXPORTS) + if(arg_CPP_EXPORT_HEADER_BASE_NAME) + set(cpp_export_header_base_name + "CPP_EXPORT_HEADER_BASE_NAME;${arg_CPP_EXPORT_HEADER_BASE_NAME}" + ) + endif() + if(arg_GENERATE_PRIVATE_CPP_EXPORTS) + set(generate_private_cpp_export "GENERATE_PRIVATE_CPP_EXPORTS") + endif() + qt_internal_generate_cpp_global_exports(${target} ${module_define_infix} + generated_public_cpp_export + generated_private_cpp_export + "${cpp_export_header_base_name}" + "${generate_private_cpp_export}" + ) + list(APPEND module_headers_public "${generated_public_cpp_export}") + list(APPEND module_headers_private "${generated_private_cpp_export}") + endif() + set(module_depends_header "${module_build_interface_include_dir}/${module_include_name}Depends") if(is_framework) @@ -922,24 +962,51 @@ function(qt_describe_module target) qt_install(FILES "${descfile_out}" DESTINATION "${install_dir}") endfunction() -function(qt_internal_generate_cpp_global_exports target module_define_infix) +function(qt_internal_generate_cpp_global_exports target module_define_infix + out_public_header out_private_header) + + qt_internal_get_generate_cpp_global_exports_keywords( + option_args + single_args + multi_args + ) + cmake_parse_arguments(arg - "" - "CPP_EXPORT_HEADER_NAME" - "" ${ARGN}) + "${option_args}" + "${single_args}" + "${multi_args}" ${ARGN} + ) + qt_internal_module_info(module "${target}") - if(NOT arg_CPP_EXPORT_HEADER_NAME) - set(arg_CPP_EXPORT_HEADER_NAME "qt${module_lower}exports.h") + + set(header_base_name "qt${module_lower}exports") + if(arg_CPP_EXPORT_HEADER_BASE_NAME) + set(header_base_name "${arg_CPP_EXPORT_HEADER_BASE_NAME}") endif() + # Is used as a part of the header guard define. + string(TOUPPER "${header_base_name}" header_base_name_upper) set(generated_header_path - "${module_build_interface_include_dir}/${arg_CPP_EXPORT_HEADER_NAME}" + "${module_build_interface_include_dir}/${header_base_name}.h" ) configure_file("${QT_CMAKE_DIR}/modulecppexports.h.in" "${generated_header_path}" @ONLY ) + set(${out_public_header} "${generated_header_path}" PARENT_SCOPE) target_sources(${target} PRIVATE "${generated_header_path}") - set_property(TARGET ${target} APPEND PROPERTY PUBLIC_HEADER "${generated_header_path}") + + if(arg_GENERATE_PRIVATE_CPP_EXPORTS) + set(generated_private_header_path + "${module_build_interface_private_include_dir}/${header_base_name}_p.h" + ) + + configure_file("${QT_CMAKE_DIR}/modulecppexports_p.h.in" + "${generated_private_header_path}" @ONLY + ) + + set(${out_private_header} "${generated_private_header_path}" PARENT_SCOPE) + target_sources(${target} PRIVATE "${generated_private_header_path}") + endif() endfunction() |