aboutsummaryrefslogtreecommitdiff
path: root/src/bin/main.ml
diff options
context:
space:
mode:
Diffstat (limited to 'src/bin/main.ml')
-rw-r--r--src/bin/main.ml19
1 files changed, 19 insertions, 0 deletions
diff --git a/src/bin/main.ml b/src/bin/main.ml
new file mode 100644
index 0000000..f762d26
--- /dev/null
+++ b/src/bin/main.ml
@@ -0,0 +1,19 @@
+module Term = Asai.Tty.Make(Reporter.Message)
+
+let ep input =
+ let ast = Parser.parse_expr input in
+ let (tp, tm) = Elaborator.infer_toplevel ast in
+ let value = NbE.eval ~env:Emp tm in
+ Format.printf "%a : %a\n%!"
+ (Pretty.pp ~names:Emp) (NbE.quote ~size:0 value)
+ (Pretty.pp ~names:Emp) (NbE.quote ~size:0 tp)
+
+let rec repl () =
+ match LNoise.linenoise "toytt> " with
+ | Some input ->
+ Reporter.run ~emit:Term.display ~fatal:Term.display (fun () -> ep input);
+ let _ = LNoise.history_add input in
+ repl ()
+ | None -> repl ()
+
+let () = repl ();