Merge branch 'rinderknecht@fix-verbatim' into 'dev'
Improved the lexing of verbatim strings for Michelson inclusion See merge request ligolang/ligo!713
This commit is contained in:
commit
0b0de1ea59
@ -516,9 +516,20 @@ and scan_string thread state = parse
|
|||||||
scan_string (thread#push_char c) state lexbuf }
|
scan_string (thread#push_char c) state lexbuf }
|
||||||
|
|
||||||
and scan_verbatim thread state = parse
|
and scan_verbatim thread state = parse
|
||||||
|
nl as nl { let () = Lexing.new_line lexbuf
|
||||||
|
and state = state#set_pos (state#pos#new_line nl)
|
||||||
|
in scan_verbatim (thread#push_string nl) state lexbuf }
|
||||||
|
| '#' blank* (natural as line) blank+ '"' (string as file) '"' {
|
||||||
|
let _, _, state = state#sync lexbuf in
|
||||||
|
let flags, state = scan_flags state [] lexbuf in
|
||||||
|
let () = ignore flags in
|
||||||
|
let line = int_of_string line
|
||||||
|
and file = Filename.basename file in
|
||||||
|
let pos = state#pos#set ~file ~line ~offset:0 in
|
||||||
|
let state = state#set_pos pos in
|
||||||
|
scan_verbatim thread state lexbuf }
|
||||||
| eof { fail thread#opening Unterminated_verbatim }
|
| eof { fail thread#opening Unterminated_verbatim }
|
||||||
| "|}" { let _, _, state = state#sync lexbuf
|
| "|}" { let _, _, state = state#sync lexbuf in thread, state }
|
||||||
in thread, state }
|
|
||||||
| _ as c { let _, _, state = state#sync lexbuf in
|
| _ as c { let _, _, state = state#sync lexbuf in
|
||||||
scan_verbatim (thread#push_char c) state lexbuf }
|
scan_verbatim (thread#push_char c) state lexbuf }
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user