blob: b334a20eda2967cd3703d5383d1292a3fa502323 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
|
open Util
open Lexing
module I = Vyos1x_parser.MenhirInterpreter
let rec parse lexbuf (checkpoint : Config_tree.t I.checkpoint) =
match checkpoint with
| I.InputNeeded _env ->
let token = Vyos1x_lexer.token lexbuf in
let startp = lexbuf.lex_start_p
and endp = lexbuf.lex_curr_p in
let checkpoint = I.offer checkpoint (token, startp, endp) in
parse lexbuf checkpoint
| I.Shifting _
| I.AboutToReduce _ ->
let checkpoint = I.resume checkpoint in
parse lexbuf checkpoint
| I.HandlingError _env ->
let line, pos = Util.get_lexing_position lexbuf in
raise (Syntax_error (Some (line, pos), "Invalid syntax."))
| I.Accepted v -> v
| I.Rejected ->
raise (Syntax_error (None, "invalid syntax (parser rejected the input)"))
let from_string s =
let lexbuf = Lexing.from_string s in
parse lexbuf (Vyos1x_parser.Incremental.config lexbuf.lex_curr_p)
|