import os
import argparse
from eval.core import evaluate

def main():
    parser = argparse.ArgumentParser(description="Evaluate predictions (step-level & operator-level).")
    parser.add_argument("root_dir", nargs="?", default="data/full-trace-dataset")
    parser.add_argument("--out", default="result")
    parser.add_argument("--kind", choices=["all","vertical","horizontal"], default="horizontal")
    parser.add_argument("--pred-prefix", default="pred")
    args = parser.parse_args()

    prefixes = [s.strip() for s in args.pred_prefix.split(",") if s.strip()]
    prefix_key = "+".join(prefixes) if prefixes else "pred"

    out_root = os.path.join(args.out, prefix_key)

    print(f"[INFO] root_dir={args.root_dir}")
    print(f"[INFO] out_root={out_root}")
    print(f"[INFO] kind={args.kind}")
    print(f"[INFO] pred_prefixes={prefixes}")

    result = evaluate(args.root_dir, out_root, args.kind, pred_prefixes=prefixes)
    print("[INFO] written:")
    for k, v in result["files"].items():
        print(f" - {k}: {v}")

if __name__ == "__main__":
    main()
