-
Notifications
You must be signed in to change notification settings - Fork 454
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
Showing
10 changed files
with
149 additions
and
125 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,28 +1,66 @@ | ||
type 'a start = | ||
| Module : (Script.var option * Script.definition) start | ||
| Script : Script.script start | ||
| Script1 : Script.script start | ||
|
||
exception Syntax = Script.Syntax | ||
|
||
let parse' name lexbuf start = | ||
lexbuf.Lexing.lex_curr_p <- | ||
{lexbuf.Lexing.lex_curr_p with Lexing.pos_fname = name}; | ||
try start Lexer.token lexbuf | ||
with Syntax (region, s) -> | ||
let region' = if region <> Source.no_region then region else | ||
{Source.left = Lexer.convert_pos lexbuf.Lexing.lex_start_p; | ||
Source.right = Lexer.convert_pos lexbuf.Lexing.lex_curr_p} in | ||
raise (Syntax (region', s)) | ||
|
||
let parse (type a) name lexbuf : a start -> a = function | ||
| Module -> parse' name lexbuf Parser.module1 | ||
| Script -> parse' name lexbuf Parser.script | ||
| Script1 -> parse' name lexbuf Parser.script1 | ||
|
||
let string_to start s = | ||
let lexbuf = Lexing.from_string s in | ||
parse "string" lexbuf start | ||
|
||
let string_to_script s = string_to Script s | ||
let string_to_module s = snd (string_to Module s) | ||
module type S = | ||
sig | ||
type t | ||
val from_lexbuf : Lexing.lexbuf -> t | ||
val from_file : string -> t | ||
val from_string : string -> t | ||
val from_channel : in_channel -> t | ||
end | ||
|
||
module type Rule = | ||
sig | ||
type t | ||
val rule : (Lexing.lexbuf -> Parser.token) -> Lexing.lexbuf -> t | ||
end | ||
|
||
module Make (M : Rule) : S with type t = M.t = | ||
struct | ||
type t = M.t | ||
|
||
let provider buf () = | ||
let tok = Lexer.token buf in | ||
let start = Lexing.lexeme_start_p buf in | ||
let stop = Lexing.lexeme_end_p buf in | ||
tok, start, stop | ||
|
||
let convert_pos buf = | ||
{ Source.left = Lexer.convert_pos buf.Lexing.lex_start_p; | ||
Source.right = Lexer.convert_pos buf.Lexing.lex_curr_p | ||
} | ||
|
||
let from_lexbuf buf = | ||
try | ||
MenhirLib.Convert.Simplified.traditional2revised M.rule (provider buf) | ||
with | ||
| Parser.Error -> | ||
raise (Syntax (convert_pos buf, "unexpected token")) | ||
| Syntax (region, s) when region <> Source.no_region -> | ||
raise (Syntax (convert_pos buf, s)) | ||
|
||
let from_string s = from_lexbuf (Lexing.from_string ~with_positions:true s) | ||
let from_channel c = from_lexbuf (Lexing.from_channel ~with_positions:true c) | ||
let from_file name = | ||
let chan = open_in name in | ||
Fun.protect ~finally:(fun () -> close_in chan) (fun () -> | ||
let buf = Lexing.from_channel ~with_positions:true chan in | ||
Lexing.set_filename buf name; | ||
from_lexbuf buf | ||
) | ||
end | ||
|
||
module Module = Make (struct | ||
type t = Script.var option * Script.definition | ||
let rule = Parser.module1 | ||
end) | ||
|
||
module Script1 = Make (struct | ||
type t = Script.script | ||
let rule = Parser.script1 | ||
end) | ||
|
||
module Script = Make (struct | ||
type t = Script.script | ||
let rule = Parser.script | ||
end) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,11 +1,14 @@ | ||
type 'a start = | ||
| Module : (Script.var option * Script.definition) start | ||
| Script : Script.script start | ||
| Script1 : Script.script start | ||
|
||
exception Syntax of Source.region * string | ||
|
||
val parse : string -> Lexing.lexbuf -> 'a start -> 'a (* raises Syntax *) | ||
module type S = | ||
sig | ||
type t | ||
val from_lexbuf : Lexing.lexbuf -> t | ||
val from_file : string -> t | ||
val from_string : string -> t | ||
val from_channel : in_channel -> t | ||
end | ||
|
||
val string_to_script : string -> Script.script (* raises Syntax *) | ||
val string_to_module : string -> Script.definition (* raises Syntax *) | ||
module Module : S with type t = Script.var option * Script.definition | ||
module Script1 : S with type t = Script.script | ||
module Script : S with type t = Script.script |
Oops, something went wrong.