CMake Deployment: Fix deployment / rpath handing on Linux

Change-Id: Ic8eb8665e4ac43a49ecbf07f2a92873453c9faca
Reviewed-by: Alessandro Portale <alessandro.portale@qt.io>
This commit is contained in:
Cristian Adam
2020-02-04 13:22:28 +01:00
parent fcfb0fbf80
commit decb6866b9
2 changed files with 76 additions and 42 deletions

View File

@@ -86,6 +86,8 @@ list(APPEND DEFAULT_DEFINES
)
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")
@@ -97,8 +99,8 @@ elseif (WIN32)
set(_PLUGIN_RPATH "")
else()
set(_RPATH_BASE "\$ORIGIN")
set(_LIB_RPATH "\$ORIGIN")
set(_PLUGIN_RPATH "\$ORIGIN;\$ORIGIN/${_PLUGIN_TO_LIB}")
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 ***")
@@ -907,8 +909,6 @@ function(add_qtc_executable name)
endif()
endif()
file(RELATIVE_PATH _RELATIVE_LIB_PATH "/${_EXECUTABLE_PATH}" "/${IDE_LIBRARY_PATH}")
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} )
@@ -919,10 +919,20 @@ function(add_qtc_executable name)
set(skip_translation ON)
endif()
file(RELATIVE_PATH relative_lib_path "/${_EXECUTABLE_PATH}" "/${IDE_LIBRARY_PATH}")
set(build_rpath "${_RPATH_BASE}/${relative_lib_path}")
set(install_rpath "${_RPATH_BASE}/${relative_lib_path}")
if (NOT WIN32 AND NOT APPLE)
file(RELATIVE_PATH relative_qt_path "/${_EXECUTABLE_PATH}" "/${IDE_LIBRARY_BASE_PATH}/Qt/lib")
file(RELATIVE_PATH relative_plugins_path "/${_EXECUTABLE_PATH}" "/${IDE_PLUGIN_PATH}")
set(install_rpath "${install_rpath};${_RPATH_BASE}/${relative_qt_path};${_RPATH_BASE}/${relative_plugins_path}")
endif()
qtc_output_binary_dir(_output_binary_dir)
set_target_properties("${name}" PROPERTIES
BUILD_RPATH "${_RPATH_BASE}/${_RELATIVE_LIB_PATH}"
INSTALL_RPATH "${_RPATH_BASE}/${_RELATIVE_LIB_PATH}"
BUILD_RPATH "${build_rpath}"
INSTALL_RPATH "${install_rpath}"
RUNTIME_OUTPUT_DIRECTORY "${_output_binary_dir}/${_DESTINATION}"
QT_SKIP_TRANSLATION "${skip_translation}"
CXX_VISIBILITY_PRESET hidden

View File

@@ -89,10 +89,9 @@ if (CMAKE_VERSION VERSION_GREATER_EQUAL 3.16)
set(CMAKE_GET_RUNTIME_DEPENDENCIES_TOOL objdump)
endif()
if (WIN32)
set(pre_exclude_regexes PRE_EXCLUDE_REGEXES \"api-ms-.*|ext-ms-\.*\")
endif()
if (APPLE)
set(pre_exclude_regexes PRE_EXCLUDE_REGEXES \"libiodbc\.*|libpq\.*\")
set(filter_regex PRE_EXCLUDE_REGEXES \"api-ms-.*|ext-ms-\.*\")
elseif (APPLE)
set(filter_regex PRE_EXCLUDE_REGEXES \"libiodbc\.*|libpq\.*\")
endif()
get_filename_component(install_prefix \"\${CMAKE_INSTALL_PREFIX}\" ABSOLUTE)
@@ -133,14 +132,17 @@ if (CMAKE_VERSION VERSION_GREATER_EQUAL 3.16)
file(GET_RUNTIME_DEPENDENCIES
UNRESOLVED_DEPENDENCIES_VAR unresolved_deps
RESOLVED_DEPENDENCIES_VAR resolved_deps
CONFLICTING_DEPENDENCIES_PREFIX conflicts
\${EXECUTABLES_TO_ANALYZE}
\${LIBRARIES_TO_ANALYZE}
\${MODULES_TO_ANALYZE}
DIRECTORIES
\"\${install_prefix}/${IDE_BIN_PATH}\"
\"\${install_prefix}/${IDE_PLUGIN_PATH}\"
\"\${install_prefix}/${IDE_LIBEXEC_PATH}\"
\"\${install_prefix}/${IDE_LIBRARY_PATH}\"
\${pre_exclude_regexes}
\"\${install_prefix}/${IDE_LIBRARY_BASE_PATH}/Qt/lib\"
\${filter_regex}
)
# Clear for second step
@@ -149,6 +151,7 @@ if (CMAKE_VERSION VERSION_GREATER_EQUAL 3.16)
set(installed_MODULES \"\${qt5_plugin_files}\")
list(REMOVE_DUPLICATES unresolved_deps)
list(REMOVE_DUPLICATES resolved_deps)
if (WIN32)
# Needed by QmlDesigner, QmlProfiler, but they are not referenced directly.
@@ -158,40 +161,61 @@ if (CMAKE_VERSION VERSION_GREATER_EQUAL 3.16)
file(TO_CMAKE_PATH \"${CMAKE_PREFIX_PATH}\" prefix_path)
# Add parent link directory paths. Needed for e.g. MinGW choco libstdc++-6.dll
foreach(path \"${CMAKE_CXX_IMPLICIT_LINK_DIRECTORIES}\")
get_filename_component(parent_path \"\${path}\" DIRECTORY)
list(APPEND prefix_path \"\${parent_path}\")
endforeach()
if (WIN32)
foreach(path \"${CMAKE_CXX_IMPLICIT_LINK_DIRECTORIES}\")
get_filename_component(parent_path \"\${path}\" DIRECTORY)
list(APPEND prefix_path \"\${parent_path}\")
endforeach()
endif()
foreach(so IN LISTS unresolved_deps)
string(REPLACE \"@rpath/\" \"\" so \"\${so}\")
get_filename_component(so_dir \"\${so}\" DIRECTORY)
message(STATUS \"Unresolved dependency: \${so}\")
# On Linux the Qt libraries might exist in the system, and they are passed
# as resolved, therefore scan the resolved dependencies too
foreach(so IN LISTS unresolved_deps resolved_deps)
# Skip the installed dependencies
string(FIND \"\${so}\" \"\${install_prefix}\" found_prefix_path)
if (NOT found_prefix_path EQUAL -1)
continue()
endif()
# On Linux get the name of the resolved Qt dependency, this would come from ldconfig
# with the full path on the system
if (NOT APPLE AND NOT WIN32)
get_filename_component(so \"\${so}\" NAME)
endif()
if (APPLE)
string(REPLACE \"@rpath/\" \"\" so \"\${so}\")
get_filename_component(so_dir \"\${so}\" DIRECTORY)
endif()
message(STATUS \"Dependency: \${so}\")
foreach(p IN LISTS prefix_path)
message(STATUS \"Trying: \${p}/\${so}\")
if (EXISTS \"\${p}/\${so}\")
file(INSTALL \"\${p}/\${so}\"
DESTINATION \"\${install_prefix}/${IDE_APP_PATH}/\${so_dir}\"
FOLLOW_SYMLINK_CHAIN)
list(APPEND installed_LIBRARIES \"\${install_prefix}/${IDE_APP_PATH}/\${so}\")
break()
endif()
message(STATUS \"Trying: \${p}/bin/\${so}\")
if (EXISTS \"\${p}/bin/\${so}\")
file(INSTALL \"\${p}/bin/\${so}\"
DESTINATION \"\${install_prefix}/${IDE_BIN_PATH}/\${so_dir}\"
FOLLOW_SYMLINK_CHAIN)
list(APPEND installed_LIBRARIES \"\${install_prefix}/${IDE_BIN_PATH}/\${so}\")
break()
endif()
message(STATUS \"Trying: \${p}/lib/\${so}\")
if (EXISTS \"\${p}/lib/\${so}\")
file(INSTALL \"\${p}/lib/\${so}\"
DESTINATION \"\${install_prefix}/${IDE_LIBRARY_PATH}/\${so_dir}\"
FOLLOW_SYMLINK_CHAIN)
list(APPEND installed_LIBRARIES \"\${install_prefix}/${IDE_LIBRARY_PATH}/\${so}\")
if (WIN32)
set(so_src \"\${p}/bin/\${so}\")
set(so_dest \"\${install_prefix}/${IDE_BIN_PATH}\")
elseif(APPLE)
set(so_src \"\${p}/lib/\${so}\")
set(so_dest \"\${install_prefix}/${IDE_LIBRARY_PATH}/\${so_dir}\")
else()
set(so_src \"\${p}/lib/\${so}\")
if (p STREQUAL \"${qt5_base_dir}\")
set(so_dest \"\${install_prefix}/${IDE_LIBRARY_BASE_PATH}/Qt/lib\")
else()
set(so_dest \"\${install_prefix}/${IDE_LIBRARY_PATH}\")
endif()
endif()
message(STATUS \"Looking at: \${so_src}\")
if (EXISTS \"\${so_src}\")
file(INSTALL \"\${so_src}\" DESTINATION \"\${so_dest}\" FOLLOW_SYMLINK_CHAIN)
if (APPLE)
get_filename_component(so \"\${so}\" NAME)
endif()
list(APPEND installed_LIBRARIES \"\${so_dest}/\${so}\")
break()
endif()
endforeach()
endforeach()
endforeach()