#!/bin/bash

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

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

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

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

FPGA_CHIP="$4"
if [ -z "$FPGA_CHIP" ]; then
	die "Missing FPGA_CHIP"
fi

shift 4

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 ! "${BITGEN}" -f ${PROJECT}.ut ${PROJECT}.ncd > "${PROJECT}.bitgen.log"; then
	cp -- "${PROJECT}".bitgen.log "$DIR"/logs
	cat ${PROJECT}.bitgen.log
	exit 128
fi

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

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

exit 0
