CMake: Use custom install script to support Ninja Multi-Config builds
Calling cmake --install . only installs a single configuration. To install both debug and release artifacts, the install invocation needs to be done for each configuration. To keep the Coin instruction code simpler, delegate the looping over configurations to a custom CMake script, and use it in the Coin instructions. Replace all cmake --install calls in the instructions with calls to either call_host_install.yaml or call_target_install.yaml. The path to the script depends on whether we are building qtbase or another module. In the former case the script should be called from the build dir, otherwise from the install dir. The other distinction is whether the host or target env prefix needs to be added. Task-number: QTBUG-80900 Change-Id: Ied4bf739e2b1a2307f22fc79c1cfad746c8cbc44 Reviewed-by: Joerg Bornemann <joerg.bornemann@qt.io>
This commit is contained in:
parent
f240d94f14
commit
b3e01d608e
19
bin/qt-cmake-private-install.cmake.in
Normal file
19
bin/qt-cmake-private-install.cmake.in
Normal file
@ -0,0 +1,19 @@
|
|||||||
|
# Calls cmake --install ${QT_BUILD_DIR} --config <config> for each config
|
||||||
|
# with which Qt was built with.
|
||||||
|
# This is required to enable installation of all configurations of
|
||||||
|
# a Qt built with Ninja Multi-Config until the following issue is fixed.
|
||||||
|
# https://gitlab.kitware.com/cmake/cmake/-/issues/20713
|
||||||
|
set(configs "@__qt_configured_configs@")
|
||||||
|
if(NOT QT_BUILD_DIR)
|
||||||
|
message(FATAL_ERROR "No QT_BUILD_DIR value provided to qt-cmake-private-install.")
|
||||||
|
endif()
|
||||||
|
foreach(config ${configs})
|
||||||
|
message(STATUS "Installing configuration: '${config}'")
|
||||||
|
set(args "${CMAKE_COMMAND}" --install ${QT_BUILD_DIR} --config "${config}")
|
||||||
|
execute_process(COMMAND ${args}
|
||||||
|
COMMAND_ECHO STDOUT
|
||||||
|
RESULT_VARIABLE result)
|
||||||
|
if(NOT "${result}" STREQUAL "0")
|
||||||
|
message(FATAL_ERROR "Installing configuration '${config}' failed with exit code: ${result}.")
|
||||||
|
endif()
|
||||||
|
endforeach()
|
@ -224,6 +224,19 @@ configure_file("${CMAKE_CURRENT_SOURCE_DIR}/bin/qt-cmake-standalone-test.in"
|
|||||||
qt_install(PROGRAMS "${QT_BUILD_DIR}/${INSTALL_BINDIR}/${__qt_cmake_standalone_test_bin_name}"
|
qt_install(PROGRAMS "${QT_BUILD_DIR}/${INSTALL_BINDIR}/${__qt_cmake_standalone_test_bin_name}"
|
||||||
DESTINATION "${INSTALL_BINDIR}")
|
DESTINATION "${INSTALL_BINDIR}")
|
||||||
|
|
||||||
|
# Create an installation script that the CI can use to handle installation for both
|
||||||
|
# single and multiple configurations.
|
||||||
|
set(__qt_cmake_install_script_name "qt-cmake-private-install.cmake")
|
||||||
|
if(CMAKE_CONFIGURATION_TYPES)
|
||||||
|
set(__qt_configured_configs "${CMAKE_CONFIGURATION_TYPES}")
|
||||||
|
elseif(CMAKE_BUILD_TYPE)
|
||||||
|
set(__qt_configured_configs "${CMAKE_BUILD_TYPE}")
|
||||||
|
endif()
|
||||||
|
configure_file("${CMAKE_CURRENT_SOURCE_DIR}/bin/${__qt_cmake_install_script_name}.in"
|
||||||
|
"${QT_BUILD_DIR}/${INSTALL_BINDIR}/${__qt_cmake_install_script_name}" @ONLY)
|
||||||
|
qt_install(PROGRAMS "${QT_BUILD_DIR}/${INSTALL_BINDIR}/${__qt_cmake_install_script_name}"
|
||||||
|
DESTINATION "${INSTALL_BINDIR}")
|
||||||
|
|
||||||
## Library to hold global features:
|
## Library to hold global features:
|
||||||
## These features are stored and accessed via Qt::GlobalConfig, but the
|
## These features are stored and accessed via Qt::GlobalConfig, but the
|
||||||
## files always lived in Qt::Core, so we keep it that way
|
## files always lived in Qt::Core, so we keep it that way
|
||||||
|
9
coin/instructions/call_host_install.yaml
Normal file
9
coin/instructions/call_host_install.yaml
Normal file
@ -0,0 +1,9 @@
|
|||||||
|
type: Group
|
||||||
|
instructions:
|
||||||
|
- type: ExecuteCommand
|
||||||
|
command: "{{.Env.ENV_PREFIX}} cmake -DQT_BUILD_DIR={{.BuildDir}} -P {{.Env.COIN_CMAKE_INSTALL_SCRIPT_PATH}}/bin/qt-cmake-private-install.cmake"
|
||||||
|
executeCommandArgumentSplitingBehavior: SplitAfterVariableSubstitution
|
||||||
|
maxTimeInSeconds: 6000
|
||||||
|
maxTimeBetweenOutput: 1200
|
||||||
|
userMessageOnFailure: >
|
||||||
|
Failed to install package.
|
9
coin/instructions/call_target_install.yaml
Normal file
9
coin/instructions/call_target_install.yaml
Normal file
@ -0,0 +1,9 @@
|
|||||||
|
type: Group
|
||||||
|
instructions:
|
||||||
|
- type: ExecuteCommand
|
||||||
|
command: "{{.Env.TARGET_ENV_PREFIX}} cmake -DQT_BUILD_DIR={{.BuildDir}} -P {{.Env.COIN_CMAKE_INSTALL_SCRIPT_PATH}}/bin/qt-cmake-private-install.cmake"
|
||||||
|
executeCommandArgumentSplitingBehavior: SplitAfterVariableSubstitution
|
||||||
|
maxTimeInSeconds: 6000
|
||||||
|
maxTimeBetweenOutput: 1200
|
||||||
|
userMessageOnFailure: >
|
||||||
|
Failed to install package.
|
@ -24,21 +24,14 @@ instructions:
|
|||||||
maxTimeBetweenOutput: 1200
|
maxTimeBetweenOutput: 1200
|
||||||
userMessageOnFailure: >
|
userMessageOnFailure: >
|
||||||
Failed to build sources. In the current state bug can be everywhere.
|
Failed to build sources. In the current state bug can be everywhere.
|
||||||
- type: ExecuteCommand
|
- type: EnvironmentVariable
|
||||||
command: "{{.Env.ENV_PREFIX}} cmake --install ."
|
variableName: COIN_CMAKE_INSTALL_SCRIPT_PATH
|
||||||
maxTimeInSeconds: 6000
|
variableValue: "{{.InstallDir}}/host"
|
||||||
maxTimeBetweenOutput: 1200
|
- !include "{{qt/qtbase}}/call_host_install.yaml"
|
||||||
userMessageOnFailure: >
|
|
||||||
Failed to install package.
|
|
||||||
- type: EnvironmentVariable
|
- type: EnvironmentVariable
|
||||||
variableName: DESTDIR
|
variableName: DESTDIR
|
||||||
variableValue: "{{.InstallRoot}}"
|
variableValue: "{{.InstallRoot}}"
|
||||||
- type: ExecuteCommand
|
- !include "{{qt/qtbase}}/call_host_install.yaml"
|
||||||
command: "{{.Env.ENV_PREFIX}} cmake --install ."
|
|
||||||
maxTimeInSeconds: 6000
|
|
||||||
maxTimeBetweenOutput: 1200
|
|
||||||
userMessageOnFailure: >
|
|
||||||
Failed to install package for archiving.
|
|
||||||
- type: EnvironmentVariable
|
- type: EnvironmentVariable
|
||||||
variableName: DESTDIR
|
variableName: DESTDIR
|
||||||
variableValue: ""
|
variableValue: ""
|
||||||
@ -56,21 +49,14 @@ instructions:
|
|||||||
maxTimeBetweenOutput: 1200
|
maxTimeBetweenOutput: 1200
|
||||||
userMessageOnFailure: >
|
userMessageOnFailure: >
|
||||||
Failed to build sources. In the current state bug can be everywhere.
|
Failed to build sources. In the current state bug can be everywhere.
|
||||||
- type: ExecuteCommand
|
- type: EnvironmentVariable
|
||||||
command: "{{.Env.TARGET_ENV_PREFIX}} cmake --install ."
|
variableName: COIN_CMAKE_INSTALL_SCRIPT_PATH
|
||||||
maxTimeInSeconds: 6000
|
variableValue: "{{.InstallDir}}/target"
|
||||||
maxTimeBetweenOutput: 1200
|
- !include "{{qt/qtbase}}/call_target_install.yaml"
|
||||||
userMessageOnFailure: >
|
|
||||||
Failed to install package.
|
|
||||||
- type: EnvironmentVariable
|
- type: EnvironmentVariable
|
||||||
variableName: DESTDIR
|
variableName: DESTDIR
|
||||||
variableValue: "{{.InstallRoot}}"
|
variableValue: "{{.InstallRoot}}"
|
||||||
- type: ExecuteCommand
|
- !include "{{qt/qtbase}}/call_target_install.yaml"
|
||||||
command: "{{.Env.TARGET_ENV_PREFIX}} cmake --install ."
|
|
||||||
maxTimeInSeconds: 6000
|
|
||||||
maxTimeBetweenOutput: 1200
|
|
||||||
userMessageOnFailure: >
|
|
||||||
Failed to install package for archiving.
|
|
||||||
- type: EnvironmentVariable
|
- type: EnvironmentVariable
|
||||||
variableName: DESTDIR
|
variableName: DESTDIR
|
||||||
variableValue: ""
|
variableValue: ""
|
||||||
|
@ -27,21 +27,14 @@ instructions:
|
|||||||
maxTimeBetweenOutput: 1200
|
maxTimeBetweenOutput: 1200
|
||||||
userMessageOnFailure: >
|
userMessageOnFailure: >
|
||||||
Failed to build sources. In the current state bug can be everywhere.
|
Failed to build sources. In the current state bug can be everywhere.
|
||||||
- type: ExecuteCommand
|
- type: EnvironmentVariable
|
||||||
command: "{{.Env.ENV_PREFIX}} cmake --install ."
|
variableName: COIN_CMAKE_INSTALL_SCRIPT_PATH
|
||||||
maxTimeInSeconds: 6000
|
variableValue: "{{.BuildDir}}"
|
||||||
maxTimeBetweenOutput: 1200
|
- !include "{{qt/qtbase}}/call_host_install.yaml"
|
||||||
userMessageOnFailure: >
|
|
||||||
Failed to install package.
|
|
||||||
- type: EnvironmentVariable
|
- type: EnvironmentVariable
|
||||||
variableName: DESTDIR
|
variableName: DESTDIR
|
||||||
variableValue: "{{.InstallRoot}}"
|
variableValue: "{{.InstallRoot}}"
|
||||||
- type: ExecuteCommand
|
- !include "{{qt/qtbase}}/call_host_install.yaml"
|
||||||
command: "{{.Env.ENV_PREFIX}} cmake --install ."
|
|
||||||
maxTimeInSeconds: 6000
|
|
||||||
maxTimeBetweenOutput: 1200
|
|
||||||
userMessageOnFailure: >
|
|
||||||
Failed to install package for archiving.
|
|
||||||
- type: EnvironmentVariable
|
- type: EnvironmentVariable
|
||||||
variableName: DESTDIR
|
variableName: DESTDIR
|
||||||
variableValue: ""
|
variableValue: ""
|
||||||
@ -62,21 +55,14 @@ instructions:
|
|||||||
maxTimeBetweenOutput: 1200
|
maxTimeBetweenOutput: 1200
|
||||||
userMessageOnFailure: >
|
userMessageOnFailure: >
|
||||||
Failed to build sources. In the current state bug can be everywhere.
|
Failed to build sources. In the current state bug can be everywhere.
|
||||||
- type: ExecuteCommand
|
- type: EnvironmentVariable
|
||||||
command: "{{.Env.TARGET_ENV_PREFIX}} cmake --install ."
|
variableName: COIN_CMAKE_INSTALL_SCRIPT_PATH
|
||||||
maxTimeInSeconds: 6000
|
variableValue: "{{.BuildDir}}"
|
||||||
maxTimeBetweenOutput: 1200
|
- !include "{{qt/qtbase}}/call_target_install.yaml"
|
||||||
userMessageOnFailure: >
|
|
||||||
Failed to install package.
|
|
||||||
- type: EnvironmentVariable
|
- type: EnvironmentVariable
|
||||||
variableName: DESTDIR
|
variableName: DESTDIR
|
||||||
variableValue: "{{.InstallRoot}}"
|
variableValue: "{{.InstallRoot}}"
|
||||||
- type: ExecuteCommand
|
- !include "{{qt/qtbase}}/call_target_install.yaml"
|
||||||
command: "{{.Env.TARGET_ENV_PREFIX}} cmake --install ."
|
|
||||||
maxTimeInSeconds: 6000
|
|
||||||
maxTimeBetweenOutput: 1200
|
|
||||||
userMessageOnFailure: >
|
|
||||||
Failed to install package for archiving.
|
|
||||||
- type: EnvironmentVariable
|
- type: EnvironmentVariable
|
||||||
variableName: DESTDIR
|
variableName: DESTDIR
|
||||||
variableValue: ""
|
variableValue: ""
|
||||||
|
@ -16,21 +16,14 @@ instructions:
|
|||||||
maxTimeBetweenOutput: 1200
|
maxTimeBetweenOutput: 1200
|
||||||
userMessageOnFailure: >
|
userMessageOnFailure: >
|
||||||
Failed to build sources. In the current state bug can be everywhere.
|
Failed to build sources. In the current state bug can be everywhere.
|
||||||
- type: ExecuteCommand
|
- type: EnvironmentVariable
|
||||||
command: "{{.Env.ENV_PREFIX}} cmake --install ."
|
variableName: COIN_CMAKE_INSTALL_SCRIPT_PATH
|
||||||
maxTimeInSeconds: 6000
|
variableValue: "{{.InstallDir}}"
|
||||||
maxTimeBetweenOutput: 1200
|
- !include "{{qt/qtbase}}/call_host_install.yaml"
|
||||||
userMessageOnFailure: >
|
|
||||||
Failed to install package.
|
|
||||||
- type: EnvironmentVariable
|
- type: EnvironmentVariable
|
||||||
variableName: DESTDIR
|
variableName: DESTDIR
|
||||||
variableValue: "{{.InstallRoot}}"
|
variableValue: "{{.InstallRoot}}"
|
||||||
- type: ExecuteCommand
|
- !include "{{qt/qtbase}}/call_host_install.yaml"
|
||||||
command: "{{.Env.ENV_PREFIX}} cmake --install ."
|
|
||||||
maxTimeInSeconds: 6000
|
|
||||||
maxTimeBetweenOutput: 1200
|
|
||||||
userMessageOnFailure: >
|
|
||||||
Failed to install package for archiving.
|
|
||||||
- type: SignPackage
|
- type: SignPackage
|
||||||
enable_if:
|
enable_if:
|
||||||
condition: property
|
condition: property
|
||||||
|
@ -19,21 +19,14 @@ instructions:
|
|||||||
maxTimeBetweenOutput: 1200
|
maxTimeBetweenOutput: 1200
|
||||||
userMessageOnFailure: >
|
userMessageOnFailure: >
|
||||||
Failed to build sources. In the current state bug can be everywhere.
|
Failed to build sources. In the current state bug can be everywhere.
|
||||||
- type: ExecuteCommand
|
- type: EnvironmentVariable
|
||||||
command: "{{.Env.ENV_PREFIX}} cmake --install ."
|
variableName: COIN_CMAKE_INSTALL_SCRIPT_PATH
|
||||||
maxTimeInSeconds: 6000
|
variableValue: "{{.BuildDir}}"
|
||||||
maxTimeBetweenOutput: 1200
|
- !include "{{qt/qtbase}}/call_host_install.yaml"
|
||||||
userMessageOnFailure: >
|
|
||||||
Failed to install package.
|
|
||||||
- type: EnvironmentVariable
|
- type: EnvironmentVariable
|
||||||
variableName: DESTDIR
|
variableName: DESTDIR
|
||||||
variableValue: "{{.InstallRoot}}"
|
variableValue: "{{.InstallRoot}}"
|
||||||
- type: ExecuteCommand
|
- !include "{{qt/qtbase}}/call_host_install.yaml"
|
||||||
command: "{{.Env.ENV_PREFIX}} cmake --install ."
|
|
||||||
maxTimeInSeconds: 6000
|
|
||||||
maxTimeBetweenOutput: 1200
|
|
||||||
userMessageOnFailure: >
|
|
||||||
Failed to install package for archiving.
|
|
||||||
- type: SignPackage
|
- type: SignPackage
|
||||||
enable_if:
|
enable_if:
|
||||||
condition: property
|
condition: property
|
||||||
|
Loading…
Reference in New Issue
Block a user