From fdc6601733240f4d9d8808d9f2783e58010ca447 Mon Sep 17 00:00:00 2001 From: Simon Grondin Date: Sun, 31 Jul 2022 10:30:48 -0500 Subject: [PATCH] Better error reporting --- src/cli/strings.ml | 5 +++-- src/parsing/js_ast.ml | 27 +++++++++++++++++---------- 2 files changed, 20 insertions(+), 12 deletions(-) diff --git a/src/cli/strings.ml b/src/cli/strings.ml index 0ab69c5..9a00739 100644 --- a/src/cli/strings.ml +++ b/src/cli/strings.ml @@ -3,7 +3,7 @@ open Core open Lwt.Infix open Lwt.Syntax -let version = "1.2.0" +let version = "1.3.1" let header = sprintf "/* Generated by okTurtles/strings v%s */\n\n" version @@ -243,7 +243,8 @@ let main args = |> Array.map ~f:(fun { filename; _ } -> sprintf "- %s" filename) |> String.concat_array ~sep:"\n" in - Lwt_io.printlf "❌ Encountered %d JS parsing errors. Files:\n%s\n" len files + let plural = if len = 1 then "" else "s" in + Lwt_io.printlf "❌ Encountered %d JS parsing error%s. File%s:\n%s\n" len plural plural files in let t1 = Time_now.nanoseconds_since_unix_epoch () in Lwt_io.write_line Lwt_io.stdout diff --git a/src/parsing/js_ast.ml b/src/parsing/js_ast.ml index 666f934..0198bca 100644 --- a/src/parsing/js_ast.ml +++ b/src/parsing/js_ast.ml @@ -449,18 +449,23 @@ let extract strings stmts = let errors_to_string errors = let buf = Buffer.create 128 in - List.iter errors ~f:(fun (loc, err) -> - Buffer.add_string buf "Error at line "; - Loc.show loc |> Buffer.add_string buf; - Buffer.add_string buf ":\n"; - Parse_error.PP.error err |> Buffer.add_string buf; - Buffer.add_char buf '\n'); + List.iter errors ~f:(function + | Loc.{ source = _; start = { line = sl; column = sc }; _end = { line = el; column = ec } }, err + when sl = el -> + bprintf buf "Line %d (%d-%d): %s\n" sl sc ec (Parse_error.PP.error err) + | Loc.{ source = _; start = { line = sl; column = sc }; _end = { line = el; column = ec } }, err -> + bprintf buf "Line %d (%d) to line %d (%d): %s\n" sl sc el ec (Parse_error.PP.error err)); Buffer.contents buf -let parse_error ~filename js_file_errors errors = +let parse_error ~filename js_file_errors error = let open Lwt.Syntax in - let message = errors_to_string errors in - let+ () = Lwt_io.eprintlf "Parsing error in %s:\n%s" filename message in + let message = + match error with + | First (_ :: _ :: _ as ll) -> sprintf !"Parsing errors in %s:\n%{errors_to_string}" filename ll + | First ll -> sprintf !"Parsing error in %s:\n%{errors_to_string}" filename ll + | Second msg -> sprintf "%s in %s\n" msg filename + in + let+ () = Lwt_io.eprintlf "%s------\n" message in Queue.enqueue js_file_errors Failed.{ filename; message } let debug statements = @@ -489,7 +494,9 @@ let strings_from_js ~filename parsed js_file_errors source = (* debug statements; *) extract parsed statements; Lwt.return_unit) - | exception Parse_error.Error (_, (_ :: _ as errors)) -> parse_error ~filename js_file_errors errors + | exception Parse_error.Error (_, (_ :: _ as errors)) -> + parse_error ~filename js_file_errors (First errors) + | exception Parse_error.Error (_, []) -> parse_error ~filename js_file_errors (Second "Syntax error") | exception exn -> print_endline (sprintf "Unexpected error in %s\nPlease report this bug." filename); raise exn