-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathmain.ml
36 lines (35 loc) · 1.28 KB
/
main.ml
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
open Ast
open Eval
open Lexer
open Pretty
let () =
let _ =
if Array.length Sys.argv < 2 || Array.length Sys.argv > 3 then
(Printf.printf "Usage: ./whitespace [file] <option>\n";
exit 0) in
let filename = Sys.argv.(1) in
let _ = if Array.length Sys.argv = 3 && Sys.argv.(2) = "--debug" then
ignore (Parsing.set_trace true);
Printexc.record_backtrace true; in
let lexbuf =
try Lexing.from_channel (open_in filename)
with e ->
match e with
| Sys_error s -> Printf.printf "%s\n" s; exit 1
| _ -> let msg = Printexc.to_string e in
Printf.printf "Whitespace: Unexpected error occured - %s\n" msg; exit 1
in
let statements =
try Parser.program Lexer.token lexbuf
with e ->
match e with
| LexingError msg -> Printf.printf "Whitespace: %s" msg; exit 1
| Parsing.Parse_error -> let stack = Printexc.get_backtrace () in
Printf.printf "Whitespace: Parse_error\n%s" stack; exit 1
| _ -> let msg = Printexc.to_string e in
Printf.printf "Whitespace: Unexpected error occured - %s\n" msg; exit 1
in
(* List.iter (fun stmt -> Printf.printf "%s\n" (string_of_stmt stmt)) statements; *)
match eval statements with
| Error e -> print_endline e
| _ -> ()