bscpkgs/garlic/pp/timetable.nix

34 lines
838 B
Nix
Raw Normal View History

{
stdenv
, jq
}:
inputResult:
stdenv.mkDerivation {
name = "timetable.json";
preferLocalBuild = true;
phases = [ "installPhase" ];
buildInputs = [ jq ];
installPhase = ''
touch $out
cd ${inputResult}
for exp in *-experiment; do
cd ${inputResult}/$exp
for unit in *-unit; do
cd ${inputResult}/$exp/$unit
conf=garlic_config.json
for run in $(ls -d [0-9]* | sort -n); do
time=$(awk '/^ ?time /{print $2}' $run/stdout.log)
2021-02-03 19:27:23 +08:00
if [ -z "$time" ]; then
2021-02-03 20:51:24 +08:00
echo "error: cannot match \"time\" line"
2021-02-03 19:27:23 +08:00
echo "check stdout log file: ${inputResult}/$exp/$unit/$run/stdout.log"
exit 1
fi
jq -cn "{ exp:\"$exp\", unit:\"$unit\", config:inputs, time:$time, run:$run }" $conf >> $out
done
done
done
'';
}