bscpkgs/garlic/sh/garlic

195 lines
5.1 KiB
Bash
Executable File

#!/bin/bash -e
garlicPrefix=@garlicPrefix@
garlicTemp=@garlicTemp@
sshHost=@sshHost@
PATH=@PATH@
#garlicPrefix=/mnt/garlic
#garlicTemp=/tmp/garlic
#sshHost=mn1
#PATH=/nix/store/yjkcxbf0y1jdlbj0axghlg2fndc4dqkz-patchelf-0.11/bin:/nix/store/6is25fyx29d731idycngl7qmgcax5xng-gcc-wrapper-9.3.0/bin:/nix/store/h986r9i2j9x5z8i5g8aj0z8jdd129wyx-gcc-9.3.0/bin:/nix/store/48dypl6qdsj3vdzh7hjg5qnngfpdcz7h-glibc-2.31-bin/bin:/nix/store/zmac3n79ayg4fdqgznmi2v3lmcprzx4g-coreutils-8.31/bin:/nix/store/dmnnqr6j7kqgcr357b5qwiwvjvg2yyhd-binutils-wrapper-2.31.1/bin:/nix/store/gmi6xrkl95h6iypv00dvdpm3f4md9i6i-binutils-2.31.1/bin:/nix/store/48dypl6qdsj3vdzh7hjg5qnngfpdcz7h-glibc-2.31-bin/bin:/nix/store/zmac3n79ayg4fdqgznmi2v3lmcprzx4g-coreutils-8.31/bin:/nix/store/a41ky6icdgxa54jzps32gfgcrdyx94hs-rsync-3.1.3/bin:/nix/store/sxll2dlamfm32xd2nyfx7v8mlnx0gxks-openssh-8.3p1/bin:/nix/store/3gp7gv5z9jj3g92czxadvgphpwiviv28-nix-2.3.7/bin:/nix/store/zmac3n79ayg4fdqgznmi2v3lmcprzx4g-coreutils-8.31/bin:/nix/store/f2hn65ksj194nmy58nrjikv9r9w25irh-findutils-4.7.0/bin:/nix/store/m39n3m5c7r22b3ma2phnwmp0jj8a5jja-diffutils-3.7/bin:/nix/store/ray7jgwsr5xbxp28wvr427vywd08nz9s-gnused-4.8/bin:/nix/store/gzc092gzsanvym4c6sjgh22dsh9fzj4s-gnugrep-3.4/bin:/nix/store/mn412q9rz9afdrhl9v2ybf605r91wzl2-gawk-5.1.0/bin:/nix/store/xca341k5x5b4hcmi310gjhdlgqm4l56m-gnutar-1.32/bin:/nix/store/zvb8qad72bz6j7ia60dcsf3dfncxxqc7-gzip-1.10/bin:/nix/store/9pb8zp3zyykw09rg60f2nv32plamhd7h-bzip2-1.0.6.0.1-bin/bin:/nix/store/fm2p1d8w9sx4gbaf8qfv2rsailsyhvm3-gnumake-4.3/bin:/nix/store/npfsrhkjww5q7sax7p7ijcrj3wlbrxn7-bash-4.4-p23/bin:/nix/store/72m0m8v6mbp58vbngjgv5pn2scqhs6kk-patch-2.7.6/bin:/nix/store/7vh7fckk2srlkmmkfhs9y85icwm9rhj5-xz-5.2.5-bin/bin
usage() { echo "Usage: garlic [-RFwv] trebuchet" 1>&2; exit 1; }
findClosure() {
what=$1
from=$2
mexp=$(nix-store -qR "$from" | grep -E -- "$what")
n=$(echo "$mexp" | awk 'BEGIN { count=0 } NF { count++ } END { print count }')
if [ $n -eq 0 ]; then
>&2 echo "$exp: $what not found"
exit 1
fi
if [ $n -gt 1 ]; then
>&2 echo "$exp: multiple $what found"
exit 1
fi
echo "$mexp"
}
findExperiment() {
grep -o -- "/nix/store/.*-experiment" "$1"
}
drvFromOutput() {
nix-store -q --deriver $1
}
checkTrebuchet() {
if [ ! -e "$trebuchet" ]; then
>&2 echo "$trebuchet: not found"
exit 1
fi
if [ ! -f "$trebuchet" ]; then
>&2 echo "$trebuchet: not a file"
exit 1
fi
# FIXME: We need a better way to determine a trebuchet
if [ -z "$(grep "This trebuchet launches" $trebuchet)" ]; then
>&2 echo "$trebuchet: not a trebuchet"
exit 1
fi
return 0
}
checkExperiment() {
if [ ! -e "$experiment" ]; then
>&2 echo "$experiment: not found"
exit 1
fi
if [ ! -f "$experiment" ]; then
>&2 echo "$experiment: not a file"
exit 1
fi
# FIXME: We need a better way to determine a experiment
if [ -z "$(grep "This is an experiment" $experiment)" ]; then
>&2 echo "$experiment: not an experiment"
exit 1
fi
return 0
}
do_fetch() {
expName=$(basename $experiment)
user=$(ssh -G "$sshHost" | awk '/^user /{print $2}')
exp=$garlicPrefix/$user/out/$expName
if [ ! -e "$exp" ]; then
echo "missing experiment: $exp"
exit 1
fi
cwd=$(pwd)
repeat=1
while [ 1 ]; do
repeat=0
cd $exp
test $verbose && >&2 echo "$exp: checking units"
for unit in *-unit; do
cd $exp/$unit
if [ ! -e status ]; then
test $verbose && >&2 echo "$unit: no status"
repeat=1
else
st=$(cat status)
test $verbose && >&2 echo "$unit: $st"
if [ "$st" != "completed" ]; then
repeat=1
fi
fi
done
if [ $repeat -eq 0 ]; then
break
fi
if [ $waitResults -eq 1 ]; then
#echo "waiting 3 seconds to try again"
sleep 3
else
break
fi
done
if [ $repeat -eq 1 ]; then
>&2 echo "$exp: execution incomplete"
exit 1
fi
cd "$cwd"
test $verbose && >&2 echo "$exp: execution complete, fetching results"
mkdir -p $garlicTemp
rsync -rt --copy-links \
--include='*/*/garlic_config.json' \
--include='*/*/std*.log' \
--include='*/*/*/std*.log' \
--exclude='*/*/*/*' \
$exp $garlicTemp
nix-build -E "(with import ./default.nix; \
garlic.pp.store { \
experimentStage = import \"$experimentDrv\";
trebuchetStage = import \"$trebuchetDrv\";
})"
rm -rf $garlicTemp/$expName
}
do_run() {
$trebuchet
}
waitResults=1
verbose=
operation=
target=
enableRun=
enableFetch=
while getopts "vwRF" o; do
case "${o}" in
R) enableRun=1 ;;
F) enableFetch=1 ;;
w) waitResults=0 ;;
v) verbose=1 ;;
*) usage ;;
esac
done
shift $((OPTIND-1))
trebuchet="$1"
if [ -z "$enableRun" -a -z "$enableFetch" ]; then
>&2 echo "missing operation"
usage
fi
if [ -z "$trebuchet" ]; then
>&2 echo "missing experiment"
usage
fi
checkTrebuchet $trebuchet
experiment=$(findExperiment "$trebuchet")
checkExperiment $experiment
trebuchetDrv=$(drvFromOutput $trebuchet)
experimentDrv=$(drvFromOutput $experiment)
if [ $enableRun ]; then do_run; fi
if [ $enableFetch ]; then do_fetch; fi