#!/bin/bash

die () {
	echo "error: $@" >&2
	exit 128
}

IMPACT="$1"
if [ -z "$IMPACT" ]; then
	die "Missing IMPACT"
fi

DIR="$2"
if [ -z "$DIR" ]; then
	die "Missing directory"
fi
DIR="$(realpath "$DIR")"

PROJECT="$3"
if [ -z "$PROJECT" ]; then
	die "Missing directory"
fi

shift 3

t=
trap "rm -rf -- \"\$t\"" EXIT
t="$(mktemp -d)" || die "can't create temp dir"

cp -- "$@" "$t"

cd "$t" || die "cd"

mkdir -p xilinx/projnav.tmp
mkdir -p xilinx/_ngo

mkdir -p "$DIR"/logs

if ! "${IMPACT}" -batch "${PROJECT}.cmd" > "${PROJECT}.svf.log" 2>&1; then
	cp -- "${PROJECT}".svf.log "$DIR"/logs
	cat ${PROJECT}.svf.log
	exit 128
fi

cp -- "${PROJECT}".svf.log "$DIR"/logs

[ -r "${PROJECT}".svf ] || die "missing svf file"
cp -- "${PROJECT}".svf "$DIR"

exit 0
