X-Git-Url: http://matita.cs.unibo.it/gitweb/?a=blobdiff_plain;f=helm%2Focaml%2Fcic_notation%2Ftest_lexer.ml;h=569e86e442ae20383cb7b63a6ce1769391f1fa23;hb=97c2d258a5c524eb5c4b85208899d80751a2c82f;hp=b41f7f6b8e34355f31d290840eb497b95fae9dba;hpb=31d7f139796d6597915cd430baf37552dc26511c;p=helm.git diff --git a/helm/ocaml/cic_notation/test_lexer.ml b/helm/ocaml/cic_notation/test_lexer.ml index b41f7f6b8..569e86e44 100644 --- a/helm/ocaml/cic_notation/test_lexer.ml +++ b/helm/ocaml/cic_notation/test_lexer.ml @@ -24,10 +24,10 @@ *) let _ = - let level = ref ~-1 in + let level = ref "2@" in let ic = ref stdin in - let arg_spec = [ "-level", Arg.Set_int level, "set the notation level" ] in - let usage = "test_lexer -level { 1 | 2 | 3 } [ file ]" in + let arg_spec = [ "-level", Arg.Set_string level, "set the notation level" ] in + let usage = "test_lexer [ -level level ] [ file ]" in let open_file fname = if !ic <> stdin then close_in !ic; ic := open_in fname @@ -35,12 +35,17 @@ let _ = Arg.parse arg_spec open_file usage; let lexer = match !level with - | 1 -> CicNotationLexer.syntax_pattern_lexer - | 2 -> CicNotationLexer.ast_pattern_lexer - | _ -> Arg.usage arg_spec usage; exit 1 + "1" -> CicNotationLexer.level1_pattern_lexer + | "2@" -> CicNotationLexer.level2_ast_lexer + | "2$" -> CicNotationLexer.level2_meta_lexer + | l -> + prerr_endline (Printf.sprintf "Unsupported level %s" l); + exit 2 in - let token_stream = fst (lexer.Token.tok_func (Stream.of_channel !ic)) in - Printf.printf "Lexing notation level %d\n" !level; flush stdout; + let token_stream = + fst (lexer.Token.tok_func (Obj.magic (Ulexing.from_utf8_channel !ic))) + in + Printf.printf "Lexing notation level %s\n" !level; flush stdout; let rec dump () = let (a,b) = Stream.next token_stream in if a = "EOI" then raise Stream.Failure;