2019-05-10 17:33:54 +02:00
|
|
|
/**
|
|
|
|
* Arguments:
|
|
|
|
* - pure - Use --pure mode with Nix for more deterministic behaviour
|
|
|
|
* - args - Map of arguments to provide to --argstr
|
2020-02-25 22:42:47 +01:00
|
|
|
* - keepEnv - List of env variables to keep even in pure mode
|
2019-05-10 17:33:54 +02:00
|
|
|
**/
|
|
|
|
def shell(Map opts = [:], String cmd) {
|
|
|
|
def defaults = [
|
|
|
|
pure: true,
|
2019-11-29 11:20:08 +01:00
|
|
|
args: ['target': env.TARGET ? env.TARGET : 'default'],
|
2020-02-25 22:42:47 +01:00
|
|
|
keepEnv: ['LOCALE_ARCHIVE_2_27'],
|
|
|
|
sandbox: true,
|
2019-05-10 17:33:54 +02:00
|
|
|
]
|
|
|
|
/* merge defaults with received opts */
|
|
|
|
opts = defaults + opts
|
2019-10-16 08:23:53 +02:00
|
|
|
/* previous merge overwrites the array */
|
2020-02-25 22:42:47 +01:00
|
|
|
opts.keepEnv = (opts.keepEnv + defaults.keepEnv).unique()
|
2019-10-16 08:23:53 +02:00
|
|
|
/* not all targets can use a pure build */
|
2019-11-29 11:20:08 +01:00
|
|
|
if (env.TARGET in ['windows', 'ios']) {
|
2019-06-04 18:50:29 +02:00
|
|
|
opts.pure = false
|
|
|
|
}
|
2019-09-03 10:48:11 -04:00
|
|
|
sh("""
|
2019-07-15 18:34:33 +02:00
|
|
|
set +x
|
|
|
|
. ~/.nix-profile/etc/profile.d/nix.sh
|
|
|
|
set -x
|
|
|
|
nix-shell --run \'${cmd}\' ${_getNixCommandArgs(opts, true)}
|
2019-09-03 10:48:11 -04:00
|
|
|
""")
|
2019-05-10 17:33:54 +02:00
|
|
|
}
|
|
|
|
|
2019-06-04 18:50:29 +02:00
|
|
|
/**
|
|
|
|
* Arguments:
|
|
|
|
* - pure - Use --pure mode with Nix for more deterministic behaviour
|
2019-07-15 18:34:33 +02:00
|
|
|
* - link - Bu default build creates a `result` directory, you can turn that off
|
2020-01-13 15:28:40 +01:00
|
|
|
* - conf - Map of config values to provide to --arg config
|
2019-06-04 18:50:29 +02:00
|
|
|
* - args - Map of arguments to provide to --argstr
|
|
|
|
* - attr - Name of attribute to use with --attr flag
|
2020-02-25 22:42:47 +01:00
|
|
|
* - keepEnv - List of env variables to pass through to Nix build
|
2019-07-15 18:34:33 +02:00
|
|
|
* - safeEnv - Name of env variables to pass securely through to Nix build (they won't get captured in Nix derivation file)
|
2020-02-25 22:42:47 +01:00
|
|
|
* - sandbox - If build process should run inside of a sandbox
|
|
|
|
* - sandboxPaths - List of file paths to make available in Nix sandbox
|
2019-06-04 18:50:29 +02:00
|
|
|
**/
|
|
|
|
def build(Map opts = [:]) {
|
|
|
|
def defaults = [
|
|
|
|
pure: true,
|
2019-07-15 18:34:33 +02:00
|
|
|
link: true,
|
2019-11-29 11:20:08 +01:00
|
|
|
args: ['target': env.TARGET],
|
2020-01-13 15:28:40 +01:00
|
|
|
conf: [:],
|
2019-06-04 18:50:29 +02:00
|
|
|
attr: null,
|
2020-02-25 22:42:47 +01:00
|
|
|
keepEnv: [],
|
2019-07-15 18:34:33 +02:00
|
|
|
safeEnv: [],
|
2020-02-25 22:42:47 +01:00
|
|
|
sandbox: true,
|
|
|
|
sandboxPaths: [],
|
2019-06-04 18:50:29 +02:00
|
|
|
]
|
|
|
|
/* merge defaults with received opts */
|
|
|
|
opts = defaults + opts
|
|
|
|
/* Previous merge overwrites the array */
|
|
|
|
opts.args = defaults.args + opts.args
|
2020-02-25 22:42:47 +01:00
|
|
|
opts.keepEnv = (opts.keepEnv + defaults.keepEnv).unique()
|
2019-06-04 18:50:29 +02:00
|
|
|
|
2019-08-28 11:39:27 -04:00
|
|
|
def nixPath = sh(
|
2019-06-04 18:50:29 +02:00
|
|
|
returnStdout: true,
|
|
|
|
script: """
|
|
|
|
set +x
|
|
|
|
. ~/.nix-profile/etc/profile.d/nix.sh
|
|
|
|
set -x
|
|
|
|
nix-build ${_getNixCommandArgs(opts, false)}
|
|
|
|
"""
|
2019-07-15 18:34:33 +02:00
|
|
|
).trim()
|
2019-08-28 11:39:27 -04:00
|
|
|
/* if not linking, copy results, but only if there's just one path */
|
|
|
|
if (!opts.link && nixPath && !nixPath.contains('\n')) {
|
|
|
|
copyResults(nixPath)
|
2019-08-26 12:56:55 -04:00
|
|
|
}
|
2019-08-28 11:39:27 -04:00
|
|
|
return nixPath
|
|
|
|
}
|
|
|
|
|
|
|
|
private def copyResults(path) {
|
|
|
|
def resultsPath = "${env.WORKSPACE}/result"
|
|
|
|
sh "rm -fr ${resultsPath}"
|
|
|
|
sh "mkdir -p ${resultsPath}"
|
|
|
|
sh "cp -fr ${path}/* ${resultsPath}/"
|
|
|
|
sh "chmod -R 755 ${resultsPath}"
|
2019-06-04 18:50:29 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
private makeNixBuildEnvFile(Map opts = [:]) {
|
|
|
|
File envFile = File.createTempFile("nix-env", ".tmp")
|
|
|
|
if (!opts.safeEnv.isEmpty()) {
|
|
|
|
// Export the environment variables we want to keep into a temporary script we can pass to Nix and source it from the build script
|
|
|
|
def exportCommandList = opts.safeEnv.collect { envVarName -> """
|
|
|
|
echo \"export ${envVarName}=\\\"\$(printenv ${envVarName})\\\"\" >> ${envFile.absolutePath}
|
|
|
|
""" }
|
|
|
|
def exportCommands = exportCommandList.join("")
|
|
|
|
sh """
|
|
|
|
${exportCommands}
|
|
|
|
chmod u+x ${envFile.absolutePath}
|
|
|
|
"""
|
|
|
|
|
|
|
|
opts.args = opts.args + [ 'secrets-file': envFile.absolutePath ]
|
2020-02-25 22:42:47 +01:00
|
|
|
opts.sandboxPaths = opts.sandboxPaths + envFile.absolutePath
|
2019-06-04 18:50:29 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
return envFile
|
|
|
|
}
|
|
|
|
|
|
|
|
private def _getNixCommandArgs(Map opts = [:], boolean isShell) {
|
|
|
|
def keepFlags = []
|
|
|
|
def entryPoint = "\'${env.WORKSPACE}/shell.nix\'"
|
|
|
|
if (!isShell || opts.attr != null) {
|
|
|
|
entryPoint = "\'${env.WORKSPACE}/default.nix\'"
|
|
|
|
}
|
2020-02-25 22:42:47 +01:00
|
|
|
/* don't let nix.conf control sandbox status */
|
|
|
|
def extraSandboxPathsFlag = "--option sandbox ${opts.sandbox}"
|
2019-06-04 18:50:29 +02:00
|
|
|
|
|
|
|
if (isShell) {
|
2020-02-25 22:42:47 +01:00
|
|
|
keepFlags = opts.keepEnv.collect { var -> "--keep ${var} " }
|
2019-06-04 18:50:29 +02:00
|
|
|
} else {
|
2020-02-25 22:42:47 +01:00
|
|
|
def envVarsList = opts.keepEnv.collect { var -> "${var}=\"${env[var]}\";" }
|
2019-06-04 18:50:29 +02:00
|
|
|
keepFlags = ["--arg env \'{${envVarsList.join("")}}\'"]
|
|
|
|
|
|
|
|
/* Export the environment variables we want to keep into
|
|
|
|
* a Nix attribute set we can pass to Nix and source it from the build script */
|
|
|
|
def envFile = makeNixBuildEnvFile(opts)
|
|
|
|
envFile.deleteOnExit()
|
|
|
|
}
|
|
|
|
|
2020-01-13 15:28:40 +01:00
|
|
|
def configFlag = ''
|
2019-06-04 18:50:29 +02:00
|
|
|
def argsFlags = opts.args.collect { key,val -> "--argstr ${key} \'${val}\'" }
|
|
|
|
def attrFlag = ''
|
|
|
|
if (opts.attr != null) {
|
|
|
|
attrFlag = "--attr '${opts.attr}'"
|
|
|
|
}
|
2020-01-13 15:28:40 +01:00
|
|
|
if (opts.conf != null && opts.conf != [:]) {
|
|
|
|
def configFlags = opts.conf.collect { key,val -> "${key}=\"${val}\";" }
|
|
|
|
configFlag = "--arg config \'{${configFlags.join('')}}\'"
|
|
|
|
}
|
2020-02-25 22:42:47 +01:00
|
|
|
if (opts.sandboxPaths != null && !opts.sandboxPaths.isEmpty()) {
|
|
|
|
extraSandboxPathsFlag += " --option extra-sandbox-paths \"${opts.sandboxPaths.join(' ')}\""
|
2019-06-04 18:50:29 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
return [
|
|
|
|
opts.pure ? "--pure" : "",
|
2019-07-15 18:34:33 +02:00
|
|
|
opts.link ? "" : "--no-out-link",
|
2020-01-13 15:28:40 +01:00
|
|
|
configFlag,
|
2019-06-04 18:50:29 +02:00
|
|
|
keepFlags.join(" "),
|
|
|
|
argsFlags.join(" "),
|
|
|
|
extraSandboxPathsFlag,
|
|
|
|
attrFlag,
|
|
|
|
entryPoint,
|
|
|
|
].join(" ")
|
|
|
|
}
|
|
|
|
|
2019-05-10 17:33:54 +02:00
|
|
|
def prepEnv() {
|
2019-11-29 11:20:08 +01:00
|
|
|
if (env.TARGET in ['linux', 'windows', 'android']) {
|
2019-05-10 17:33:54 +02:00
|
|
|
def glibcLocales = sh(
|
|
|
|
returnStdout: true,
|
|
|
|
script: """
|
|
|
|
. ~/.nix-profile/etc/profile.d/nix.sh && \\
|
|
|
|
nix-build --no-out-link '<nixpkgs>' -A glibcLocales
|
|
|
|
"""
|
|
|
|
).trim()
|
|
|
|
/**
|
|
|
|
* This is a hack to fix missing locale errors.
|
|
|
|
* See:
|
|
|
|
* - https://github.com/NixOS/nixpkgs/issues/38991
|
|
|
|
* - https://qiita.com/kimagure/items/4449ceb0bda5c10ca50f
|
|
|
|
**/
|
|
|
|
env.LOCALE_ARCHIVE_2_27 = "${glibcLocales}/lib/locale/locale-archive"
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return this
|