aboutsummaryrefslogtreecommitdiffhomepage
path: root/tools
diff options
context:
space:
mode:
authorGravatar letouzey <letouzey@85f007b7-540e-0410-9357-904b9bb8a0f7>2010-09-17 14:12:50 +0000
committerGravatar letouzey <letouzey@85f007b7-540e-0410-9357-904b9bb8a0f7>2010-09-17 14:12:50 +0000
commit7bc7fc79e719202c84e7c60f1f4ab42f5e9bcf8f (patch)
tree1e3996204eea985915969ea425fdb7ca30bc5311 /tools
parent3111aa5721db71d0d4bb2f9717d61723f76bf97e (diff)
Coqdep_boot : misc improvements
- modules names can include quote ' - errors when parsing .mllib files are now properly reported instead of dying ugly on some sort of Failure - same when coqdep has to parse the output of ocamldep -modules - lib/lib.mllib contains a typo (lowercase ident) git-svn-id: svn+ssh://scm.gforge.inria.fr/svn/coq/trunk@13423 85f007b7-540e-0410-9357-904b9bb8a0f7
Diffstat (limited to 'tools')
-rw-r--r--tools/coqdep_common.ml14
-rw-r--r--tools/coqdep_lexer.mll6
2 files changed, 16 insertions, 4 deletions
diff --git a/tools/coqdep_common.ml b/tools/coqdep_common.ml
index 295b7c519..797c25ccc 100644
--- a/tools/coqdep_common.ml
+++ b/tools/coqdep_common.ml
@@ -190,7 +190,11 @@ let soustraite_fichier_ML dep md ext =
a_faire_opt := !a_faire_opt ^ opt)
(List.rev list);
(!a_faire, !a_faire_opt)
- with Sys_error _ -> ("","")
+ with
+ | Sys_error _ -> ("","")
+ | _ ->
+ Printf.eprintf "Coqdep: subprocess %s failed on file %s%s\n" dep md ext;
+ exit 1
let autotraite_fichier_ML md ext =
try
@@ -236,7 +240,13 @@ let traite_fichier_mllib md ext =
a_faire_opt := !a_faire_opt^" "^file^".cmx"
| None -> ()) list;
(!a_faire, !a_faire_opt)
- with Sys_error _ -> ("","")
+ with
+ | Sys_error _ -> ("","")
+ | Syntax_error (i,j) ->
+ Printf.eprintf "File \"%s%s\", characters %i-%i:\nError: Syntax error\n"
+ md ext i j;
+ exit 1
+
(* Makefile's escaping rules are awful: $ is escaped by doubling and
other special characters are escaped by backslash prefixing while
diff --git a/tools/coqdep_lexer.mll b/tools/coqdep_lexer.mll
index 0e7467eb0..09433ff76 100644
--- a/tools/coqdep_lexer.mll
+++ b/tools/coqdep_lexer.mll
@@ -24,6 +24,7 @@
let comment_depth = ref 0
exception Fin_fichier
+ exception Syntax_error of int*int
let module_current_name = ref []
let module_names = ref []
@@ -221,12 +222,13 @@ and qual_id = parse
| _ { caml_action lexbuf }
and mllib_list = parse
- | coq_ident { let s = String.uncapitalize (Lexing.lexeme lexbuf)
+ | caml_up_ident { let s = String.uncapitalize (Lexing.lexeme lexbuf)
in s :: mllib_list lexbuf }
| "*predef*" { mllib_list lexbuf }
| space+ { mllib_list lexbuf }
| eof { [] }
+ | _ { raise (Syntax_error (Lexing.lexeme_start lexbuf,
+ Lexing.lexeme_end lexbuf)) }
and ocamldep_parse = parse
| [^ ':' ]* ':' { mllib_list lexbuf }
- | _ { [] }