

# This is a dependency-free script to list key artifacts with SHA-256, so reviewers can verify integrity.

#!/usr/bin/env python3
import hashlib
import pathlib
import csv
import os

# Which files to include in the manifest
INCLUDE = [
    "../figures/safety_margins.pdf",
    "../data/calibration_table.tex",
    "../data/alpha_sweep_table.tex",
    "../thresholds/thresholds_per_trait_dual_bounds_verified.json",
    "../thresholds/calibration_thresholds.json",
]

def sha256_of(path: pathlib.Path) -> str:
    h = hashlib.sha256()
    with open(path, "rb") as f:
        for chunk in iter(lambda: f.read(8192), b""):
            h.update(chunk)
    return h.hexdigest()

def main():
    root = pathlib.Path(__file__).resolve().parent.parent  # supplement/
    outdir = root / "build"
    outdir.mkdir(parents=True, exist_ok=True)
    rows = []
    for rel in INCLUDE:
        p = (root / rel).resolve()
        if not p.exists():
            rows.append([rel, "MISSING", ""])
            continue
        rows.append([rel, str(p), sha256_of(p)])
    with open(outdir / "manifest.tsv", "w", newline="") as f:
        w = csv.writer(f, delimiter="\t")
        w.writerow(["relative_path", "absolute_path", "sha256"])
        w.writerows(rows)
    print(f"Wrote {outdir / 'manifest.tsv'}")

if __name__ == "__main__":
    main()
