Disable finalizers by default for the non-ld linkers
Check if link order matters before use the object library finalizer.
Amends 5fb99e3860
Pick-to: 6.2
Change-Id: Ie996bc175ebea36ccda1bb2fe388ae3b7fcde395
Reviewed-by: Alexandru Croitor <alexandru.croitor@qt.io>
This commit is contained in:
parent
72e21ad3e9
commit
cdbb390c4a
@ -1,11 +1,23 @@
|
|||||||
# Helper to check if the finalizer mode should be used.
|
# Helper to check if the finalizer mode should be used.
|
||||||
# If true or unset, use finalizer mode.
|
# If true, use finalizer mode.
|
||||||
# If false, use regular mode (usage requirement propagation via associated Qt module)
|
# If false, use regular mode (usage requirement propagation via associated Qt module)
|
||||||
|
# Arguments:
|
||||||
|
# DEFAULT_VALUE specifies the default value of the finalizer mode flag if it is not set.
|
||||||
function(__qt_internal_check_finalizer_mode target out_var finalizer)
|
function(__qt_internal_check_finalizer_mode target out_var finalizer)
|
||||||
|
set(option_args "")
|
||||||
|
set(single_args DEFAULT_VALUE)
|
||||||
|
set(multi_args "")
|
||||||
|
cmake_parse_arguments(arg "${option_args}" "${single_args}" "${multi_args}" ${ARGN})
|
||||||
|
|
||||||
|
if(NOT DEFINED arg_DEFAULT_VALUE OR arg_DEFAULT_VALUE)
|
||||||
|
set(arg_DEFAULT_VALUE TRUE)
|
||||||
|
else()
|
||||||
|
set(arg_DEFAULT_VALUE FALSE)
|
||||||
|
endif()
|
||||||
get_target_property(value ${target} _qt_${finalizer}_finalizer_mode)
|
get_target_property(value ${target} _qt_${finalizer}_finalizer_mode)
|
||||||
if("${value}" STREQUAL "value-NOTFOUND")
|
if("${value}" STREQUAL "value-NOTFOUND")
|
||||||
__qt_internal_enable_finalizer_mode(${target} ${finalizer} "TRUE")
|
__qt_internal_enable_finalizer_mode(${target} ${finalizer} "${arg_DEFAULT_VALUE}")
|
||||||
set(value "TRUE")
|
set(value "${arg_DEFAULT_VALUE}")
|
||||||
endif()
|
endif()
|
||||||
set(${out_var} "${value}" PARENT_SCOPE)
|
set(${out_var} "${value}" PARENT_SCOPE)
|
||||||
endfunction()
|
endfunction()
|
||||||
|
@ -104,9 +104,13 @@ function(__qt_internal_process_dependency_object_libraries target)
|
|||||||
endif()
|
endif()
|
||||||
set_target_properties(${target} PROPERTIES _qt_object_libraries_finalizer_processed TRUE)
|
set_target_properties(${target} PROPERTIES _qt_object_libraries_finalizer_processed TRUE)
|
||||||
|
|
||||||
|
get_target_property(qt_link_order_matters
|
||||||
|
${QT_CMAKE_EXPORT_NAMESPACE}::Platform _qt_link_order_matters
|
||||||
|
)
|
||||||
__qt_internal_check_finalizer_mode(${target}
|
__qt_internal_check_finalizer_mode(${target}
|
||||||
use_finalizer_mode
|
use_finalizer_mode
|
||||||
object_libraries
|
object_libraries
|
||||||
|
DEFAULT_VALUE "${qt_link_order_matters}"
|
||||||
)
|
)
|
||||||
|
|
||||||
if(NOT use_finalizer_mode)
|
if(NOT use_finalizer_mode)
|
||||||
|
Loading…
Reference in New Issue
Block a user