-
Notifications
You must be signed in to change notification settings - Fork 28
/
dpd_parse.mly
63 lines (47 loc) · 1.63 KB
/
dpd_parse.mly
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
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
%{
(*~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~*)
(* This file is part of the DpdGraph tools. *)
(* Copyright (C) 2009-2015 Anne Pacalet ([email protected]) *)
(* ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ *)
(* This file is distributed under the terms of the *)
(* GNU Lesser General Public License Version 2.1 *)
(* (see the enclosed LICENSE file for mode details) *)
(*~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~*)
%}
%token <string> IDENT
%token <string> STRING
%token <int> NUM
%token LBRACKET RBRACKET
%token NODE EDGE EQUAL COMMA SEMICOL EOF
%left LBRACKET
%nonassoc IDENT
%type <Dpd_compute.t_obj list> graph
%start graph
%%
graph : obj_list EOF { $1 }
obj_list :
| obj { [$1] }
| obj obj_list { $1::$2 }
obj :
| node SEMICOL { $1 }
| edge SEMICOL { $1 }
| error { let p_start = symbol_start_pos () in
let p_end = symbol_end_pos () in
let err = Dpd_compute.ParsingError (p_start, p_end) in
raise (Dpd_compute.Error err)
}
node : NODE NUM STRING opt_attribs { Dpd_compute.N ($2, $3, $4) }
edge : EDGE NUM NUM opt_attribs { Dpd_compute.E ($2, $3, $4) }
opt_attribs :
| /* empty */ { [] }
| LBRACKET attribs RBRACKET { $2 }
attribs :
| /* empty */ { [] }
| attrib COMMA attribs { $1::$3 }
attrib :
| IDENT EQUAL attrib_value { ($1, $3) }
attrib_value:
| IDENT { $1 }
| STRING { $1 }
| NUM { string_of_int $1 }
%%