CMake: Transform absolute library paths into link flags in .pri files
Before this change, the qt_lib_foo_private .pri files contained absolute paths to libraries, e.g. /usr/lib/x86_64-linux-gnu/libcups.so Whereas the qmake build instead embeds link flags like -lcups. Detect absolute library file paths, and transform them into link flags. This should make the .pri files relocatable. Fix the add_custom_commands to have the scripts as dependencies. Make sure to pass the suffix, prefix and other options to the qconfig.pri generation command as well. Also reverse the order of the link flags, to mirror the order that qmake generates for .pri files. Task-number: QTBUG-84781 Task-number: QTBUG-85240 Change-Id: I7bc3b234d9c86c785b169b11f3042450aa225c1f Reviewed-by: Joerg Bornemann <joerg.bornemann@qt.io>
This commit is contained in:
parent
2ed63e587e
commit
63f09a94db
@ -929,10 +929,19 @@ QT.${config_module_name}_private.disabled_features = ${disabled_private_features
|
||||
|
||||
qt_path_join(private_pri_file_path "${target_path}" "${private_pri_file_name}")
|
||||
list(APPEND pri_files "${private_pri_file_path}")
|
||||
|
||||
set(library_prefixes ${CMAKE_SHARED_LIBRARY_PREFIX} ${CMAKE_STATIC_LIBRARY_PREFIX})
|
||||
set(library_suffixes
|
||||
${CMAKE_SHARED_LIBRARY_SUFFIX}
|
||||
${CMAKE_EXTRA_SHARED_LIBRARY_SUFFIXES}
|
||||
${CMAKE_STATIC_LIBRARY_SUFFIX})
|
||||
add_custom_command(
|
||||
OUTPUT "${private_pri_file_path}"
|
||||
DEPENDS ${inputs}
|
||||
DEPENDS ${inputs} "${QT_CMAKE_DIR}/QtGenerateLibPri.cmake"
|
||||
COMMAND ${CMAKE_COMMAND} "-DIN_FILES=${inputs}" "-DOUT_FILE=${private_pri_file_path}"
|
||||
"-DLIBRARY_PREFIXES=${library_prefixes}"
|
||||
"-DLIBRARY_SUFFIXES=${library_suffixes}"
|
||||
"-DLINK_LIBRARY_FLAG=${CMAKE_LINK_LIBRARY_FLAG}"
|
||||
"-DCONFIGS=${configs}"
|
||||
-P "${QT_CMAKE_DIR}/QtGenerateLibPri.cmake"
|
||||
VERBATIM)
|
||||
@ -976,7 +985,7 @@ set(libs $<TARGET_FILE:${target}>)
|
||||
qt_path_join(qt_build_libdir ${QT_BUILD_DIR} ${INSTALL_LIBDIR})
|
||||
add_custom_command(
|
||||
OUTPUT "${pri_file}"
|
||||
DEPENDS ${inputs}
|
||||
DEPENDS ${inputs} "${QT_CMAKE_DIR}/QtGenerateExtPri.cmake"
|
||||
COMMAND ${CMAKE_COMMAND} "-DIN_FILES=${inputs}" "-DOUT_FILE=${pri_file}" -DLIB=${lib}
|
||||
"-DCONFIGS=${configs}"
|
||||
"-DQT_BUILD_LIBDIR=${qt_build_libdir}"
|
||||
@ -1275,10 +1284,18 @@ CONFIG += ${private_config_joined}
|
||||
list(APPEND inputs "${preliminary_pri_root}/${cfg}/${pri_data_cmake_file}")
|
||||
endforeach()
|
||||
|
||||
set(library_prefixes ${CMAKE_SHARED_LIBRARY_PREFIX} ${CMAKE_STATIC_LIBRARY_PREFIX})
|
||||
set(library_suffixes
|
||||
${CMAKE_SHARED_LIBRARY_SUFFIX}
|
||||
${CMAKE_EXTRA_SHARED_LIBRARY_SUFFIXES}
|
||||
${CMAKE_STATIC_LIBRARY_SUFFIX})
|
||||
add_custom_command(
|
||||
OUTPUT "${qmodule_pri_target_path}"
|
||||
DEPENDS ${inputs}
|
||||
DEPENDS ${inputs} "${QT_CMAKE_DIR}/QtGenerateLibPri.cmake"
|
||||
COMMAND ${CMAKE_COMMAND} "-DIN_FILES=${inputs}" "-DOUT_FILE=${qmodule_pri_target_path}"
|
||||
"-DLIBRARY_PREFIXES=${library_prefixes}"
|
||||
"-DLIBRARY_SUFFIXES=${library_suffixes}"
|
||||
"-DLINK_LIBRARY_FLAG=${CMAKE_LINK_LIBRARY_FLAG}"
|
||||
"-DCONFIGS=${configs}"
|
||||
-P "${QT_CMAKE_DIR}/QtGenerateLibPri.cmake"
|
||||
VERBATIM)
|
||||
|
@ -4,10 +4,16 @@
|
||||
# IN_FILES: path to the qt_lib_XXX.cmake files
|
||||
# OUT_FILE: path to the generated qt_lib_XXX.pri file
|
||||
# CONFIGS: the configurations Qt is being built with
|
||||
# LIBRARY_SUFFIXES: list of known library extensions, e.g. .so;.a on Linux
|
||||
# LIBRARY_PREFIXES: list of known library prefies, e.g. the "lib" in "libz" on on Linux
|
||||
# LINK_LIBRARY_FLAG: flag used to link a shared library to an executable, e.g. -l on UNIX
|
||||
#
|
||||
# QMAKE_LIBS_XXX values are split into QMAKE_LIBS_XXX_DEBUG and QMAKE_LIBS_XXX_RELEASE if
|
||||
# debug_and_release was detected. The CMake configuration "Debug" is considered for the _DEBUG
|
||||
# values. The first config that is not "Debug" is treated as _RELEASE.
|
||||
#
|
||||
# The library values are transformed from an absolute path into link flags
|
||||
# aka from "/usr/lib/x86_64-linux-gnu/libcups.so" to "-lcups".
|
||||
|
||||
cmake_policy(SET CMP0057 NEW)
|
||||
|
||||
@ -27,6 +33,80 @@ function(qmake_list out_var)
|
||||
set(${out_var} ${result} PARENT_SCOPE)
|
||||
endfunction()
|
||||
|
||||
# Given "/usr/lib/x86_64-linux-gnu/libcups.so"
|
||||
# Returns "cups" or an empty string if the file is not an absolute library path.
|
||||
# Aka it strips the "lib" prefix, the .so extension and the base path.
|
||||
function(qt_get_library_name_without_prefix_and_suffix out_var file_path)
|
||||
set(out_value "")
|
||||
if(IS_ABSOLUTE "${file_path}")
|
||||
get_filename_component(basename "${file_path}" NAME_WE)
|
||||
get_filename_component(ext "${file_path}" EXT)
|
||||
foreach(libsuffix ${LIBRARY_SUFFIXES})
|
||||
# Handle weird prefix extensions like in the case of
|
||||
# "/usr/lib/x86_64-linux-gnu/libglib-2.0.so"
|
||||
# it's ".0.so".
|
||||
if(ext MATCHES "^(\\.[0-9]+)*${libsuffix}(\\.[0-9]+)*")
|
||||
set(is_linkable_library TRUE)
|
||||
set(weird_numbered_extension "${CMAKE_MATCH_1}")
|
||||
break()
|
||||
endif()
|
||||
endforeach()
|
||||
if(is_linkable_library)
|
||||
set(out_value "${basename}")
|
||||
if(LIBRARY_PREFIXES)
|
||||
foreach(libprefix ${LIBRARY_PREFIXES})
|
||||
# Strip any library prefix like "lib" for a library that we will use with a link
|
||||
# flag.
|
||||
if(libprefix AND out_value MATCHES "^${libprefix}(.+)")
|
||||
set(out_value "${CMAKE_MATCH_1}")
|
||||
break()
|
||||
endif()
|
||||
endforeach()
|
||||
endif()
|
||||
if(weird_numbered_extension)
|
||||
set(out_value "${out_value}${weird_numbered_extension}")
|
||||
endif()
|
||||
endif()
|
||||
endif()
|
||||
|
||||
# Reverse the dependency order to be in sync with what qmake generated .pri files
|
||||
# have.
|
||||
list(REVERSE out_list)
|
||||
|
||||
set(${out_var} "${out_value}" PARENT_SCOPE)
|
||||
endfunction()
|
||||
|
||||
# Given "/usr/lib/x86_64-linux-gnu/libcups.so"
|
||||
# Returns "-lcups" or an empty string if the file is not an absolute library path.
|
||||
function(qt_get_library_with_link_flag out_var file_path)
|
||||
qt_get_library_name_without_prefix_and_suffix(lib_name "${file_path}")
|
||||
|
||||
set(out_value "")
|
||||
if(lib_name)
|
||||
set(out_value "${lib_name}")
|
||||
if(LINK_LIBRARY_FLAG)
|
||||
string(PREPEND out_value "${LINK_LIBRARY_FLAG}")
|
||||
endif()
|
||||
endif()
|
||||
|
||||
set(${out_var} "${out_value}" PARENT_SCOPE)
|
||||
endfunction()
|
||||
|
||||
# Given a list of potential library paths, returns a transformed list where absolute library paths
|
||||
# are replaced with library link flags.
|
||||
function(qt_transform_absolute_library_paths_to_link_flags out_var library_path_list)
|
||||
set(out_list "")
|
||||
foreach(library_path ${library_path_list})
|
||||
qt_get_library_with_link_flag(lib_name_with_link_flag "${library_path}")
|
||||
if(lib_name_with_link_flag)
|
||||
list(APPEND out_list "${lib_name_with_link_flag}")
|
||||
else()
|
||||
list(APPEND out_list "${library_path}")
|
||||
endif()
|
||||
endforeach()
|
||||
set(${out_var} "${out_list}" PARENT_SCOPE)
|
||||
endfunction()
|
||||
|
||||
list(POP_FRONT IN_FILES in_pri_file)
|
||||
file(READ ${in_pri_file} content)
|
||||
string(APPEND content "\n")
|
||||
@ -50,6 +130,9 @@ foreach(lib ${known_libs})
|
||||
if(is_debug_and_release)
|
||||
set(value_debug ${QMAKE_LIBS_${lib}_DEBUG})
|
||||
set(value_release ${QMAKE_LIBS_${lib}_${release_cfg}})
|
||||
qt_transform_absolute_library_paths_to_link_flags(value_debug "${value_debug}")
|
||||
qt_transform_absolute_library_paths_to_link_flags(value_release "${value_release}")
|
||||
|
||||
if(value_debug STREQUAL value_release)
|
||||
if(value_debug)
|
||||
qmake_list(value_debug ${value_debug})
|
||||
@ -75,6 +158,9 @@ foreach(lib ${known_libs})
|
||||
string(TOUPPER ${cfg} cfg)
|
||||
foreach(infix ${configuration_independent_infixes})
|
||||
set(value ${QMAKE_${infix}_${lib}_${cfg}})
|
||||
if(infix STREQUAL "LIBS")
|
||||
qt_transform_absolute_library_paths_to_link_flags(value "${value}")
|
||||
endif()
|
||||
if(value)
|
||||
qmake_list(value ${value})
|
||||
string(APPEND content "QMAKE_${infix}_${lib} = ${value}\n")
|
||||
|
Loading…
Reference in New Issue
Block a user