2023-10-25 12:27:09 +00:00
|
|
|
|
# shellcheck shell=bash disable=SC2206
|
|
|
|
|
|
2017-08-27 17:42:21 +00:00
|
|
|
|
mesonConfigurePhase() {
|
|
|
|
|
runHook preConfigure
|
|
|
|
|
|
2023-10-25 12:27:09 +00:00
|
|
|
|
local flagsArray=()
|
|
|
|
|
|
2019-10-30 15:16:20 +00:00
|
|
|
|
if [ -z "${dontAddPrefix-}" ]; then
|
2023-10-25 12:27:09 +00:00
|
|
|
|
flagsArray+=("--prefix=$prefix")
|
2017-08-27 17:42:21 +00:00
|
|
|
|
fi
|
|
|
|
|
|
2018-03-05 06:08:18 +00:00
|
|
|
|
# See multiple-outputs.sh and meson’s coredata.py
|
2023-10-25 12:27:09 +00:00
|
|
|
|
flagsArray+=(
|
|
|
|
|
"--libdir=${!outputLib}/lib"
|
|
|
|
|
"--libexecdir=${!outputLib}/libexec"
|
|
|
|
|
"--bindir=${!outputBin}/bin"
|
|
|
|
|
"--sbindir=${!outputBin}/sbin"
|
|
|
|
|
"--includedir=${!outputInclude}/include"
|
|
|
|
|
"--mandir=${!outputMan}/share/man"
|
|
|
|
|
"--infodir=${!outputInfo}/share/info"
|
|
|
|
|
"--localedir=${!outputLib}/share/locale"
|
|
|
|
|
"-Dauto_features=${mesonAutoFeatures:-enabled}"
|
|
|
|
|
"-Dwrap_mode=${mesonWrapMode:-nodownload}"
|
|
|
|
|
${crossMesonFlags}
|
|
|
|
|
"--buildtype=${mesonBuildType:-plain}"
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
flagsArray+=(
|
|
|
|
|
$mesonFlags
|
|
|
|
|
"${mesonFlagsArray[@]}"
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
echoCmd 'mesonConfigurePhase flags' "${flagsArray[@]}"
|
|
|
|
|
|
|
|
|
|
meson setup build "${flagsArray[@]}"
|
|
|
|
|
cd build || { echoCmd 'mesonConfigurePhase' "could not cd to build"; exit 1; }
|
2017-08-27 17:42:21 +00:00
|
|
|
|
|
2017-12-02 06:49:59 +00:00
|
|
|
|
if ! [[ -v enableParallelBuilding ]]; then
|
|
|
|
|
enableParallelBuilding=1
|
2023-10-25 12:27:09 +00:00
|
|
|
|
echoCmd 'mesonConfigurePhase' "enabled parallel building"
|
2017-12-02 06:49:59 +00:00
|
|
|
|
fi
|
|
|
|
|
|
meson.setupHook: prefer meson commands over ninja
Meson now comes with its own set of commands for building, testing,
installing etc., that by default wrap around Ninja. The reason to
prefer using the Meson commands is that they take additional
options (e.g. setting custom timeouts for tests — my motivation for
this change).
Here, I've modified the Meson setup hook so that Meson's test and
install commands will be used instead of Ninja's when Meson's
configurePhase is used. This restriction is to avoid starting to run
Meson directly when dealing with custom build systems that wrap around
Meson, like QEMU's. We don't use meson's compile command, as it just
runs ninja, and that's handled fine by the existing Ninja setup hook.
Naturally the Meson commands don't support entirely the same set of
options that the Ninja ones did, but I checked through Nixpkgs to find
any packages using Meson that used any options that wouldn't be picked
up by this new system. I only found one, and it was just setting
checkTarget = "test", which is the default value for Ninja and has no
Meson equivalent (because we directly tell Meson to run the tests
rather than going through a generic job system like Ninja).
Link: https://github.com/NixOS/nixpkgs/issues/113829
Co-authored-by: Jan Tojnar <jtojnar@gmail.com>
2023-10-06 08:09:52 +00:00
|
|
|
|
if [[ ${checkPhase-ninjaCheckPhase} = ninjaCheckPhase && -z $dontUseMesonCheck ]]; then
|
|
|
|
|
checkPhase=mesonCheckPhase
|
|
|
|
|
fi
|
|
|
|
|
if [[ ${installPhase-ninjaInstallPhase} = ninjaInstallPhase && -z $dontUseMesonInstall ]]; then
|
|
|
|
|
installPhase=mesonInstallPhase
|
2023-02-21 19:50:48 +00:00
|
|
|
|
fi
|
|
|
|
|
|
2017-08-27 17:42:21 +00:00
|
|
|
|
runHook postConfigure
|
|
|
|
|
}
|
|
|
|
|
|
meson.setupHook: prefer meson commands over ninja
Meson now comes with its own set of commands for building, testing,
installing etc., that by default wrap around Ninja. The reason to
prefer using the Meson commands is that they take additional
options (e.g. setting custom timeouts for tests — my motivation for
this change).
Here, I've modified the Meson setup hook so that Meson's test and
install commands will be used instead of Ninja's when Meson's
configurePhase is used. This restriction is to avoid starting to run
Meson directly when dealing with custom build systems that wrap around
Meson, like QEMU's. We don't use meson's compile command, as it just
runs ninja, and that's handled fine by the existing Ninja setup hook.
Naturally the Meson commands don't support entirely the same set of
options that the Ninja ones did, but I checked through Nixpkgs to find
any packages using Meson that used any options that wouldn't be picked
up by this new system. I only found one, and it was just setting
checkTarget = "test", which is the default value for Ninja and has no
Meson equivalent (because we directly tell Meson to run the tests
rather than going through a generic job system like Ninja).
Link: https://github.com/NixOS/nixpkgs/issues/113829
Co-authored-by: Jan Tojnar <jtojnar@gmail.com>
2023-10-06 08:09:52 +00:00
|
|
|
|
mesonCheckPhase() {
|
|
|
|
|
runHook preCheck
|
|
|
|
|
|
|
|
|
|
local flagsArray=($mesonCheckFlags "${mesonCheckFlagsArray[@]}")
|
|
|
|
|
|
2023-10-25 12:27:09 +00:00
|
|
|
|
echoCmd 'mesonCheckPhase flags' "${flagsArray[@]}"
|
meson.setupHook: prefer meson commands over ninja
Meson now comes with its own set of commands for building, testing,
installing etc., that by default wrap around Ninja. The reason to
prefer using the Meson commands is that they take additional
options (e.g. setting custom timeouts for tests — my motivation for
this change).
Here, I've modified the Meson setup hook so that Meson's test and
install commands will be used instead of Ninja's when Meson's
configurePhase is used. This restriction is to avoid starting to run
Meson directly when dealing with custom build systems that wrap around
Meson, like QEMU's. We don't use meson's compile command, as it just
runs ninja, and that's handled fine by the existing Ninja setup hook.
Naturally the Meson commands don't support entirely the same set of
options that the Ninja ones did, but I checked through Nixpkgs to find
any packages using Meson that used any options that wouldn't be picked
up by this new system. I only found one, and it was just setting
checkTarget = "test", which is the default value for Ninja and has no
Meson equivalent (because we directly tell Meson to run the tests
rather than going through a generic job system like Ninja).
Link: https://github.com/NixOS/nixpkgs/issues/113829
Co-authored-by: Jan Tojnar <jtojnar@gmail.com>
2023-10-06 08:09:52 +00:00
|
|
|
|
meson test --no-rebuild "${flagsArray[@]}"
|
|
|
|
|
|
|
|
|
|
runHook postCheck
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
mesonInstallPhase() {
|
|
|
|
|
runHook preInstall
|
|
|
|
|
|
2023-10-25 12:27:09 +00:00
|
|
|
|
local flagsArray=()
|
meson.setupHook: prefer meson commands over ninja
Meson now comes with its own set of commands for building, testing,
installing etc., that by default wrap around Ninja. The reason to
prefer using the Meson commands is that they take additional
options (e.g. setting custom timeouts for tests — my motivation for
this change).
Here, I've modified the Meson setup hook so that Meson's test and
install commands will be used instead of Ninja's when Meson's
configurePhase is used. This restriction is to avoid starting to run
Meson directly when dealing with custom build systems that wrap around
Meson, like QEMU's. We don't use meson's compile command, as it just
runs ninja, and that's handled fine by the existing Ninja setup hook.
Naturally the Meson commands don't support entirely the same set of
options that the Ninja ones did, but I checked through Nixpkgs to find
any packages using Meson that used any options that wouldn't be picked
up by this new system. I only found one, and it was just setting
checkTarget = "test", which is the default value for Ninja and has no
Meson equivalent (because we directly tell Meson to run the tests
rather than going through a generic job system like Ninja).
Link: https://github.com/NixOS/nixpkgs/issues/113829
Co-authored-by: Jan Tojnar <jtojnar@gmail.com>
2023-10-06 08:09:52 +00:00
|
|
|
|
|
2023-10-19 10:23:31 +00:00
|
|
|
|
if [[ -n "$mesonInstallTags" ]]; then
|
|
|
|
|
flagsArray+=("--tags" "${mesonInstallTags// /,}")
|
|
|
|
|
fi
|
2023-10-25 12:27:09 +00:00
|
|
|
|
flagsArray+=(
|
|
|
|
|
$mesonInstallFlags
|
|
|
|
|
"${mesonInstallFlagsArray[@]}"
|
|
|
|
|
)
|
2023-10-19 10:23:31 +00:00
|
|
|
|
|
2023-10-25 12:27:09 +00:00
|
|
|
|
echoCmd 'mesonInstallPhase flags' "${flagsArray[@]}"
|
meson.setupHook: prefer meson commands over ninja
Meson now comes with its own set of commands for building, testing,
installing etc., that by default wrap around Ninja. The reason to
prefer using the Meson commands is that they take additional
options (e.g. setting custom timeouts for tests — my motivation for
this change).
Here, I've modified the Meson setup hook so that Meson's test and
install commands will be used instead of Ninja's when Meson's
configurePhase is used. This restriction is to avoid starting to run
Meson directly when dealing with custom build systems that wrap around
Meson, like QEMU's. We don't use meson's compile command, as it just
runs ninja, and that's handled fine by the existing Ninja setup hook.
Naturally the Meson commands don't support entirely the same set of
options that the Ninja ones did, but I checked through Nixpkgs to find
any packages using Meson that used any options that wouldn't be picked
up by this new system. I only found one, and it was just setting
checkTarget = "test", which is the default value for Ninja and has no
Meson equivalent (because we directly tell Meson to run the tests
rather than going through a generic job system like Ninja).
Link: https://github.com/NixOS/nixpkgs/issues/113829
Co-authored-by: Jan Tojnar <jtojnar@gmail.com>
2023-10-06 08:09:52 +00:00
|
|
|
|
meson install --no-rebuild "${flagsArray[@]}"
|
|
|
|
|
|
|
|
|
|
runHook postInstall
|
|
|
|
|
}
|
|
|
|
|
|
2023-10-25 12:27:09 +00:00
|
|
|
|
if [ -z "${dontUseMesonConfigure-}" ] && [ -z "${configurePhase-}" ]; then
|
|
|
|
|
# shellcheck disable=SC2034
|
2017-08-27 17:42:21 +00:00
|
|
|
|
setOutputFlags=
|
|
|
|
|
configurePhase=mesonConfigurePhase
|
|
|
|
|
fi
|