# Reviewer Quickstart

This file gives the shortest path for verifying the submitted Lean artifact and
the workflow counts.

## Expected Result

- `lake build FormalSLT` succeeds.
- The axiom audit reports only `propext`, `Classical.choice`, and
  `Quot.sound`.
- The snapshot and ledger scripts reproduce the counts in Table 1 of the paper.

## Requirements

- Lean/Lake through elan.
- Python 3.
- Network access for `lake exe cache get` unless the Mathlib cache is already
  present.

If `lake` is not on `PATH`, add elan first:

```bash
export PATH="$HOME/.elan/bin:$PATH"
```

## Minimal Commands

From this supplement directory:

```bash
export PATH="$HOME/.elan/bin:$PATH"
tar -xzf formalslt_anonymized.tar.gz
cd formalslt
lake exe cache get
lake build FormalSLT
python3 scripts/axiom_audit.py \
  --manifest examples/CheckShowcaseTheorems.lean \
  --allow propext Classical.choice Quot.sound \
  --write-log SHOWCASE_AXIOMS.txt
```

Expected output from the audit:

```text
Checked 107 showcase theorem axiom traces.
Allowed axiom set: Classical.choice, Quot.sound, propext
```

## Regenerate Counts

From the extracted `formalslt/` directory:

```bash
python3 scripts/audit_formalslt_snapshot.py .
python3 scripts/summarize_ledger.py ../workflow_ledger.csv
```

Expected inventory:

```text
Library modules under FormalSLT/: 45
Source files including FormalSLT.lean: 46
Source lines including FormalSLT.lean: 20080
Comment-skipped line-leading declarations: 267 theorem + 145 lemma = 412
Showcase #print axioms commands: 107
```

Expected ledger summary:

```text
Total PRs opened: 67
PRs merged: 60
PRs closed without merge: 7
Merge rate: 60/67 = 89.6%
Window length: 61h39m
Max simultaneously open PRs: 8
Mean open PRs over window: 2.96
Median merged-PR open-to-close time: 6 min
```

## Run All Example Files

This is slower than the showcase audit but checks every example file:

```bash
for f in examples/*.lean; do
  echo "== $f =="
  lake env lean "$f"
done
```

## Proof-Hygiene Checks

These checks mirror the CI defense-in-depth regexes:

```bash
grep -rnE --include="*.lean" \
  '^[[:space:]]*(by[[:space:]]+)?(sorry|admit)([[:space:]]|$)|:=[[:space:]]*(by[[:space:]]+)?(sorry|admit)([[:space:]]|$)' \
  FormalSLT/ FormalSLT.lean examples/

grep -rnE --include="*.lean" \
  '^[[:space:]]*((axiom|constant|opaque)[[:space:]]+[^[:space:]`({:]+[[:space:]]*[:({]|unsafe[[:space:]]+(def|theorem|lemma|instance|abbrev)[[:space:]]+)' \
  FormalSLT/ FormalSLT.lean examples/
```

Expected: both commands produce no matches.

These regexes are not the soundness proof. They are defense in depth. The
load-bearing checks are Lean's kernel, `warningAsError`, and the blocking axiom
audit.
