2017-08-31 20:43:09 +02:00
|
|
|
mangleVarList() {
|
2017-08-31 21:29:03 +02:00
|
|
|
local var="$1"
|
2017-08-31 20:43:09 +02:00
|
|
|
shift
|
2017-08-31 21:29:03 +02:00
|
|
|
local -a role_infixes=("$@")
|
2017-08-31 20:43:09 +02:00
|
|
|
|
2017-08-31 21:29:03 +02:00
|
|
|
local outputVar="${var/+/_@infixSalt@_}"
|
|
|
|
declare -gx ${outputVar}+=''
|
2017-08-31 20:43:09 +02:00
|
|
|
# For each role we serve, we accumulate the input parameters into our own
|
|
|
|
# cc-wrapper-derivation-specific environment variables.
|
|
|
|
for infix in "${role_infixes[@]}"; do
|
2017-08-31 21:29:03 +02:00
|
|
|
local inputVar="${var/+/${infix}}"
|
2017-08-31 20:43:09 +02:00
|
|
|
if [ -v "$inputVar" ]; then
|
|
|
|
export ${outputVar}+="${!outputVar:+ }${!inputVar}"
|
|
|
|
fi
|
|
|
|
done
|
|
|
|
}
|
|
|
|
|
2017-08-31 21:29:03 +02:00
|
|
|
mangleVarBool() {
|
|
|
|
local var="$1"
|
|
|
|
shift
|
|
|
|
local -a role_infixes=("$@")
|
|
|
|
|
|
|
|
local outputVar="${var/+/_@infixSalt@_}"
|
|
|
|
declare -gxi ${outputVar}+=0
|
|
|
|
for infix in "${role_infixes[@]}"; do
|
|
|
|
local inputVar="${var/+/${infix}}"
|
|
|
|
if [ -v "$inputVar" ]; then
|
2018-02-21 09:56:06 +01:00
|
|
|
# "1" in the end makes `let` return success error code when
|
|
|
|
# expression itself evaluates to zero.
|
|
|
|
# We don't use `|| true` because that would silence actual
|
|
|
|
# syntax errors from bad variable values.
|
|
|
|
let "${outputVar} |= ${!inputVar:-0}" "1"
|
2017-08-31 21:29:03 +02:00
|
|
|
fi
|
|
|
|
done
|
|
|
|
}
|
|
|
|
|
2004-03-12 12:12:18 +01:00
|
|
|
skip () {
|
2017-09-20 01:10:49 +02:00
|
|
|
if (( "${NIX_DEBUG:-0}" >= 1 )); then
|
2004-03-12 12:12:18 +01:00
|
|
|
echo "skipping impure path $1" >&2
|
|
|
|
fi
|
|
|
|
}
|
|
|
|
|
2004-04-07 16:15:54 +02:00
|
|
|
|
|
|
|
# Checks whether a path is impure. E.g., `/lib/foo.so' is impure, but
|
|
|
|
# `/nix/store/.../lib/foo.so' isn't.
|
2004-03-12 12:12:18 +01:00
|
|
|
badPath() {
|
|
|
|
local p=$1
|
2014-10-10 14:25:23 +02:00
|
|
|
|
2004-04-07 16:15:54 +02:00
|
|
|
# Relative paths are okay (since they're presumably relative to
|
|
|
|
# the temporary build directory).
|
2014-10-10 14:25:23 +02:00
|
|
|
if [ "${p:0:1}" != / ]; then return 1; fi
|
|
|
|
|
2004-04-07 16:15:54 +02:00
|
|
|
# Otherwise, the path should refer to the store or some temporary
|
|
|
|
# directory (including the build directory).
|
2004-03-12 12:12:18 +01:00
|
|
|
test \
|
2012-07-02 17:04:56 +02:00
|
|
|
"$p" != "/dev/null" -a \
|
2004-03-12 12:12:18 +01:00
|
|
|
"${p:0:${#NIX_STORE}}" != "$NIX_STORE" -a \
|
|
|
|
"${p:0:4}" != "/tmp" -a \
|
|
|
|
"${p:0:${#NIX_BUILD_TOP}}" != "$NIX_BUILD_TOP"
|
|
|
|
}
|
2016-10-30 14:41:41 +01:00
|
|
|
|
|
|
|
expandResponseParams() {
|
2017-08-14 20:34:12 +02:00
|
|
|
declare -ga params=("$@")
|
2017-07-01 02:27:48 +02:00
|
|
|
local arg
|
|
|
|
for arg in "$@"; do
|
|
|
|
if [[ "$arg" == @* ]]; then
|
2017-08-02 18:48:51 +02:00
|
|
|
# phase separation makes this look useless
|
|
|
|
# shellcheck disable=SC2157
|
2017-08-23 22:39:15 +02:00
|
|
|
if [ -x "@expandResponseParams@" ]; then
|
2017-08-02 18:48:51 +02:00
|
|
|
# params is used by caller
|
|
|
|
#shellcheck disable=SC2034
|
2017-07-01 02:27:48 +02:00
|
|
|
readarray -d '' params < <("@expandResponseParams@" "$@")
|
|
|
|
return 0
|
|
|
|
else
|
|
|
|
echo "Response files aren't supported during bootstrapping" >&2
|
|
|
|
return 1
|
|
|
|
fi
|
|
|
|
fi
|
2016-10-30 14:41:41 +01:00
|
|
|
done
|
|
|
|
}
|