This PR sets up the new integrated test/bench suite. It then migrates all benchmarks and some related tests to the new suite. There's also some documentation and some linting. For now, a lot of the old tests are left alone so this PR doesn't become even larger than it already is. Eventually, all tests should be migrated to the new suite though so there isn't a confusing mix of two systems.
34 lines
1.2 KiB
Text
34 lines
1.2 KiB
Text
import Lean.PrettyPrinter
|
||
/-! Parse and reformat file -/
|
||
|
||
open Lean
|
||
open Lean.Elab
|
||
open Lean.Elab.Term
|
||
open Std.Format open Std
|
||
|
||
unsafe def main (args : List String) : IO Unit := do
|
||
let (debug, fn) : Bool × String := match args with
|
||
| [f, "-d"] => (true, f)
|
||
| [f] => (false, f)
|
||
| _ => panic! "usage: file [-d]"
|
||
let env ← mkEmptyEnvironment
|
||
let stx ← Lean.Parser.testParseFile env fn
|
||
let act : CoreM Format := do
|
||
withOptions (fun opts =>
|
||
opts
|
||
-- Name sanitization clears inline comments attached to identifiers.
|
||
|>.set `pp.sanitizeNames false
|
||
|>.set `trace.PrettyPrinter.format debug) do
|
||
tryFinally (PrettyPrinter.ppModule stx) printTraces
|
||
let (f, _) ← act.toIO { fileName := "", fileMap := default } { env := env }
|
||
IO.print f
|
||
let stx' ← Lean.Parser.testParseModule env fn (toString f)
|
||
if stx' != stx then
|
||
let stx := stx.raw.getArg 1
|
||
let stx' := stx'.raw.getArg 1
|
||
stx.getArgs.size.forM fun i _ => do
|
||
if stx.getArg i != stx'.getArg i then
|
||
throw $ IO.userError s!"reparsing failed:\n{stx.getArg i}\n{stx'.getArg i}"
|
||
|
||
-- abbreviated Prelude.lean, which can be parsed without elaboration
|
||
#eval main ["Reformat.lean.input"]
|