lean4-htt/tests/lean/run/Reformat.lean
Leonardo de Moura 916b395d1b chore: cleanup
2020-08-21 09:29:09 -07:00

30 lines
1.1 KiB
Text
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

/-! Parse and reformat file -/
import Lean.PrettyPrinter
open Lean
open Lean.Elab
open Lean.Elab.Term
open Lean.Format
unsafe def main (args : List String) : IO Unit := do
let (debug, f) : Bool × String := match args with
| [f, "-d"] => (true, f)
| [f] => (false, f)
| _ => panic! "usage: file [-d]";
env ← mkEmptyEnvironment;
stx ← Lean.Parser.parseFile env args.head!;
(f, _) ← (PrettyPrinter.ppModule stx).toIO { options := Options.empty.setBool `trace.PrettyPrinter.format debug } { env := env };
IO.print f;
let inputCtx := Parser.mkInputContext (toString f) "<foo>";
let (stx', state, messages) := Parser.parseHeader env inputCtx;
stx' ← Parser.parseFileAux env inputCtx state messages #[stx'];
pure ()
-- TODO: this doesn't quite work yet because the parenthesizer adds unnecessary parentheses in one case
/-
when (stx' != stx) $
stx.getArgs.size.forM fun i =>
when (stx.getArg i != stx'.getArg i) $
throw $ IO.userError $ "reparsing failed:\n" ++ toString (stx.getArg i) ++ "\n" ++ toString (stx'.getArg i)
-/
#eval main ["../../../src/Init/Core.lean"]