Skip to content

Commit

Permalink
cmake: fix deploy of qtwebengine w/ qt 5.15.1
Browse files Browse the repository at this point in the history
see QTBUG-86759 and issue supercollider#5175 for background

we solve this by removing the unexpectedly empty directory, copying it back from the Qt installation, then fixing up loader paths using some hyper-specific hardcoded assumptions that should hold since this is for a single version of Qt
  • Loading branch information
mossheim committed Sep 26, 2020
1 parent 46b3a0d commit ee1df9b
Showing 1 changed file with 40 additions and 1 deletion.
41 changes: 40 additions & 1 deletion editors/sc-ide/CMakeLists.txt
Original file line number Diff line number Diff line change
Expand Up @@ -477,6 +477,8 @@ if(APPLE OR WIN32)
# to get QtWebEngine, libsndfile, and other libs. also force scanning of QtWebEngineProcess
# because macdeployqt is a fickle beast.
set(CONTENTS_DIR ${CMAKE_INSTALL_PREFIX}/SuperCollider/SuperCollider.app/Contents)
set(QT_WEBENGINE_PROCESS
"${CONTENTS_DIR}/Frameworks/QtWebEngineCore.framework/Versions/5/Helpers/QtWebEngineProcess.app/Contents/MacOS/QtWebEngineProcess")
set(DEPLOY_CMD "\"${DEPLOY_PROG}\"
\"${CMAKE_INSTALL_PREFIX}/SuperCollider/SuperCollider.app\"
-verbose=1
Expand All @@ -485,7 +487,7 @@ if(APPLE OR WIN32)
-executable=${CONTENTS_DIR}/Resources/supernova
-executable=${CONTENTS_DIR}/Resources/plugins/DiskIO_UGens.scx
-executable=${CONTENTS_DIR}/Resources/plugins/DiskIO_UGens_supernova.scx
-executable=${CONTENTS_DIR}/Frameworks/QtWebEngineCore.framework/Versions/5/Helpers/QtWebEngineProcess.app/Contents/MacOS/QtWebEngineProcess
-executable=${QT_WEBENGINE_PROCESS}
")
set(VERIFY_CMD "include(BundleUtilities)")
if(SUPERNOVA)
Expand All @@ -503,6 +505,43 @@ if(APPLE OR WIN32)
")
endif()
endif()

if(SC_USE_QTWEBENGINE AND ${Qt5_VERSION} VERSION_EQUAL 5.15.1)
# QTBUG-86759 / #5175 -- macdeployqt fails to copy part of QtWebEngineCore that contains QtWebEngineProcess.app.
message(STATUS "macdeployqt: will fix deploying QtWebEngineProcess.app for Qt 5.15.1")

# Assume that QtWebEngine and QtWebEngineCore frameworks live in the same directory. Using
# Qt5::WebEngineCore doesn't work here; even requesting that component explicitly above doesn't fix it.
get_target_property(QT_WEBENGINE_LOCATION Qt5::WebEngine LOCATION)
get_filename_component(QT_WEBENGINE_DIR "${QT_WEBENGINE_LOCATION}" DIRECTORY)
get_filename_component(QT_WEBENGINECORE_COPY_FROM ../QtWebEngineCore.framework/Versions/5/Helpers ABSOLUTE BASE_DIR "${QT_WEBENGINE_DIR}")
set(QT_WEBENGINECORE_COPY_TO "${CONTENTS_DIR}/Frameworks/QtWebEngineCore.framework/Versions/5/Helpers")

# Construct a call to install_name_tool that fixes up Qt lib dependencies. We can't use fixup_bundle for
# this because it copies all the dependencies (~200MB) into this nested bundle.
set(QT_WEBENGINE_FIXUP_COMMAND "install_name_tool ${QT_WEBENGINE_PROCESS}")
foreach(component Gui Core WebEngineCore Quick QmlModels WebChannel Qml Network Positioning)
get_target_property(component_location Qt5::${component} LOCATION)
get_filename_component(component_location "${component_location}" DIRECTORY)
get_filename_component(component_location Versions/5/Qt${component} REALPATH BASE_DIR "${component_location}")
# If qt is installed through homebrew, `component_location` will look like
# /usr/local/Cellar/qt/5.15.1/lib/QtFoo.framework/Versions/5/QtFoo
set(component_load_path "@loader_path/../../../../../../../Qt${component}.framework/Versions/5/Qt${component}")
string(APPEND QT_WEBENGINE_FIXUP_COMMAND " -change \"${component_location}\" ${component_load_path}")
endforeach()

string(APPEND VERIFY_CMD "
message(STATUS \"Fixing up bad deployment of QtWebEngineProcess with Qt 5.15.1\")
execute_process(COMMAND \"${CMAKE_COMMAND}\" -E remove_directory \"${QT_WEBENGINECORE_COPY_TO}\")
execute_process(COMMAND \"${CMAKE_COMMAND}\" -E copy_directory \"${QT_WEBENGINECORE_COPY_FROM}\"
\"${QT_WEBENGINECORE_COPY_TO}\")
# copied process is not writable at first. Other copied files in the bundle also are not writable
# (plist file for example), but this doesn't seem to create an issue.
execute_process(COMMAND chmod +w ${QT_WEBENGINE_PROCESS})
execute_process(COMMAND ${QT_WEBENGINE_FIXUP_COMMAND})
")
endif()

string(APPEND VERIFY_CMD "
message(STATUS \"Verifying app\")
verify_app(\"${CMAKE_INSTALL_PREFIX}/SuperCollider/SuperCollider.app\")")
Expand Down

0 comments on commit ee1df9b

Please sign in to comment.