diff options
author | Chimrod <> | 2023-12-08 15:03:22 +0100 |
---|---|---|
committer | Chimrod <> | 2023-12-08 15:03:22 +0100 |
commit | 6dc8d7789aa165663d135c62a9f766b6b26c4920 (patch) | |
tree | 9aeff14fe33c7ea899ef233e0e8daa75aba47efb /lib/qparser/lexer.ml | |
parent | cb5dba7e1ad74f81294b8f48b84cab7683059afa (diff) |
Better error recovery after an error in one source file
Diffstat (limited to 'lib/qparser/lexer.ml')
-rw-r--r-- | lib/qparser/lexer.ml | 33 |
1 files changed, 25 insertions, 8 deletions
diff --git a/lib/qparser/lexer.ml b/lib/qparser/lexer.ml index a1dbba1..5741b7a 100644 --- a/lib/qparser/lexer.ml +++ b/lib/qparser/lexer.ml @@ -106,7 +106,14 @@ let rec read_long_string ?(nested = false) level buf buffer = read_long_string ~nested level buf buffer | _ -> raise Not_found -(** Read the text inside a ['] *) +(** Read the text inside a ['] or ['"'] + + The function return the parsed string, but the closing token has been + rollbacked, leaving the state in [Lexbuf.EndString _]. + + The next call to [main] will call the associated function, effectively + leaving the string mode in the parser. + *) let rec read_quoted_string : Lexbuf.stringWraper -> Lexbuf.buffer_builder = fun f ?(nested = false) buf buffer -> let lexbuf = Lexbuf.buffer buffer in @@ -264,24 +271,33 @@ let rec discard buffer = match%sedlex lexbuf with | '\'' -> ( match Lexbuf.state buffer with - | Some (Lexbuf.String _) -> - (* If we are inside a string, close it. *) + | Some (Lexbuf.String _) | Some (Lexbuf.EndString _) -> + (* If we are inside a string, or just beforce closing it, close it. + *) Lexbuf.leave_state buffer; discard buffer | _ -> (* Otherwise wait skip until the end of the starting one *) - ignore - (read_quoted_string Lex_state.quotedStringWraper (Buffer.create 16) - buffer); + Lexbuf.enter_state buffer (Lexbuf.String Lex_state.quotedStringWraper); + (try + ignore + (read_quoted_string Lex_state.quotedStringWraper + (Buffer.create 16) buffer) + with e -> + Printexc.print_backtrace stdout; + + raise e); discard buffer) | '"' -> ( match Lexbuf.state buffer with - | Some (Lexbuf.String _) -> + | Some (Lexbuf.String _) | Some (Lexbuf.EndString _) -> Lexbuf.leave_state buffer; discard buffer | _ -> + Lexbuf.enter_state buffer + (Lexbuf.String Lex_state.dQuotedStringWraper); ignore - (read_quoted_string Lex_state.quotedStringWraper (Buffer.create 16) + (read_quoted_string Lex_state.dQuotedStringWraper (Buffer.create 16) buffer); discard buffer) | '}' -> ( @@ -294,6 +310,7 @@ let rec discard buffer = discard buffer) | '{' -> ignore (read_long_string 0 (Buffer.create 16) buffer); + Lexbuf.leave_state buffer; discard buffer | '-', Plus '-', Star (Sub (any, ('\r' | '\n'))) -> leave_expression buffer; |