(***********************************************************************) (* *) (* Objective Caml *) (* *) (* Xavier Leroy, projet Cristal, INRIA Rocquencourt *) (* *) (* Copyright 1996 Institut National de Recherche en Informatique et *) (* Automatique. Distributed only by permission. *) (* *) (***********************************************************************) (* $Id$ *) (* The lexer generator. Command-line parsing. *) open Syntax open Lexgen open Output let main () = if Array.length Sys.argv != 2 then begin prerr_endline "Usage: ocamllex "; exit 2 end; let source_name = Sys.argv.(1) in let dest_name = if Filename.check_suffix source_name ".mll" then Filename.chop_suffix source_name ".mll" ^ ".ml" else source_name ^ ".ml" in let ic = open_in_bin source_name in let oc = open_out dest_name in let lexbuf = Lexing.from_channel ic in try let def = Parser.lexer_definition Lexer.main lexbuf in let (entries, transitions) = Lexgen.make_dfa def in let tables = Compact.compact_tables transitions in Output.output_lexdef source_name ic oc def.header tables entries def.trailer; close_in ic; close_out oc with exn -> close_in ic; close_out oc; Sys.remove dest_name; begin match exn with Parsing.Parse_error -> Printf.fprintf stderr "File \"%s\", line %d, character %d: syntax error.\n" source_name !Lexer.line_num (Lexing.lexeme_start lexbuf - !Lexer.line_start_pos) | Lexer.Lexical_error(msg, line, col) -> Printf.fprintf stderr "File \"%s\", line %d, character %d: %s.\n" source_name line col msg | Output.Table_overflow -> Printf.fprintf stderr "File \"%s\":\ntransition table overflow, automaton is too big\n" source_name | _ -> raise exn end; exit 3 let _ = Printexc.catch main (); exit 0