#!/usr/bin/env bash
set -euo pipefail

ROOT="$(cd "$(dirname "$0")/.." && pwd)"

usage() {
  cat <<'EOF'
Run FINAL (stage3) sequentially over all .lean files in a Question_bench subdirectory.

Usage:
  ./scripts/run_final_bench_dir.sh --dir Question_bench/FATEX [--prefix FATEX] [--] <extra FINAL args...>

Examples:
  ./scripts/run_final_bench_dir.sh --dir Question_bench/FATEX --prefix FATEX -- --bad-statement-policy skip

Notes:
  - Pass paths relative to M2F/ (e.g. Question_bench/FATEX).
  - This script assigns a per-file --job-name to isolate logs.
EOF
}

bench_dir=""
job_prefix=""
extra_args=()

while [[ $# -gt 0 ]]; do
  case "$1" in
    -h|--help)
      usage
      exit 0
      ;;
    --dir)
      bench_dir="${2:-}"
      shift 2
      ;;
    --dir=*)
      bench_dir="${1#--dir=}"
      shift 1
      ;;
    --prefix)
      job_prefix="${2:-}"
      shift 2
      ;;
    --prefix=*)
      job_prefix="${1#--prefix=}"
      shift 1
      ;;
    --)
      shift 1
      extra_args+=("$@")
      break
      ;;
    *)
      echo "Unknown argument: $1" >&2
      echo >&2
      usage >&2
      exit 2
      ;;
  esac
done

if [[ -z "$bench_dir" ]]; then
  echo "Missing required --dir (e.g. Question_bench/FATEX)." >&2
  usage >&2
  exit 2
fi

bench_dir="${bench_dir#./}"
if [[ "$bench_dir" == M2F/* ]]; then
  bench_dir="${bench_dir#M2F/}"
fi

if [[ -z "$job_prefix" ]]; then
  job_prefix="$(basename "$bench_dir")"
fi

shopt -s nullglob
files=( "$ROOT/M2F/$bench_dir"/*.lean )
shopt -u nullglob

if [[ ${#files[@]} -eq 0 ]]; then
  echo "No .lean files found under M2F/$bench_dir" >&2
  exit 1
fi

IFS=$'\n' files_sorted=( $(printf '%s\n' "${files[@]}" | sort -V) )
unset IFS

for abs in "${files_sorted[@]}"; do
  rel="${abs#$ROOT/M2F/}"
  base="$(basename "${abs%.lean}")"
  job="${job_prefix}_${base}"
  echo "=== FINAL bench: $rel (job=$job) ==="
  "$ROOT/scripts/run_final_pipeline.sh" \
    --only-file "$rel" \
    --job-name "$job" \
    --max-sorries-per-file 20 \
    --max-c-replans 10 \
    --max-b-retries 10 \
    --max-no-progress-retries 2 \
    --no-clean-warnings-with-agent-b \
    --history-max-records 5 \
    "${extra_args[@]}"
done

