X-Git-Url: http://matita.cs.unibo.it/gitweb/?a=blobdiff_plain;f=helm%2Focaml%2Fcic_disambiguation%2Ftest_parser.ml;h=356c0a369e7b286aea1d00d92ab790e6aa99a714;hb=6912a028bef118d8e9d7c2847200510a9b055c6a;hp=fdab36ef329c589532acbe66bd7b497e75f6a93d;hpb=aba014724c9ad08f80944ec3021c9fa3826dca4a;p=helm.git diff --git a/helm/ocaml/cic_disambiguation/test_parser.ml b/helm/ocaml/cic_disambiguation/test_parser.ml index fdab36ef3..356c0a369 100644 --- a/helm/ocaml/cic_disambiguation/test_parser.ml +++ b/helm/ocaml/cic_disambiguation/test_parser.ml @@ -23,16 +23,64 @@ * http://helm.cs.unibo.it/ *) -try - let ic = open_in Sys.argv.(1) in - let term = Parser.parse_term (Stream.of_channel ic) in - close_in ic; - print_endline (Pp.pp_term term) -with Stdpp.Exc_located ((p_start, p_end), exn) -> - prerr_endline (Printf.sprintf "Exception at character %d-%d: %s" - p_start p_end (Printexc.to_string exn)) +open Printf -(* print_endline (Macro.expand "def") *) +let pp_tactical = TacticAst2Box.tacticalPp -(* Printf.printf "'%s'\n" (Macro.expand Sys.argv.(1)) *) +let mode = + try + match Sys.argv.(1) with + | "alias" -> prerr_endline "Alias"; `Alias + | "term" -> prerr_endline "Term"; `Term + | "tactic" -> prerr_endline "Tactic"; `Tactic + | "tactical" | "command" -> prerr_endline "Tactical"; `Tactical + | "script" -> prerr_endline "Script"; `Script + | _ -> + prerr_endline "What???????"; + exit 1 + with Invalid_argument _ -> prerr_endline "Term"; `Term + +let _ = + if mode = `Script then + let ic = open_in Sys.argv.(2) in + let istream = Stream.of_channel ic in + let (loc, script) = CicTextualParser2.parse_script istream in + List.iter + (function + | DisambiguateTypes.Command cmd -> print_endline (pp_tactical cmd) + | DisambiguateTypes.Comment (loc, s) -> print_endline s) + script + else + let ic = stdin in + try + while true do + let line = input_line ic in + let istream = Stream.of_string line in + try + (match mode with + | `Term -> + let term = CicTextualParser2.parse_term istream in + print_endline (BoxPp.pp_term term) + | `Tactic -> + let tac = CicTextualParser2.parse_tactic istream in + print_endline (TacticAstPp.pp_tactic tac) + | `Tactical -> + let tac = CicTextualParser2.parse_tactical istream in + print_endline (pp_tactical tac) + | `Alias -> + let env = CicTextualParser2.EnvironmentP3.of_string line in + print_endline (CicTextualParser2.EnvironmentP3.to_string env) + | _ -> assert false); + flush stdout + with + | CicTextualParser2.Parse_error (floc, msg) -> + let (x, y) = CicAst.loc_of_floc floc in + let before = String.sub line 0 x in + let error = String.sub line x (y - x) in + let after = String.sub line y (String.length line - y) in + eprintf "%s%s%s\n" before error after; + prerr_endline (sprintf "at character %d-%d: %s" x y msg) + done + with End_of_file -> + close_in ic