blob: d2216a6a23d27116531824e27768751bdaad2bcf (
plain) (
blame)
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
64
65
66
67
68
69
70
71
72
73
74
75
76
77
|
(*
* Menhir wygeneruje funkcję o nazwie file
*)
%start <Xi_lib.Ast.module_definition> file
%{
open Xi_lib
open Ast
open Parser_utils
(* Generator znaczników *)
let mkTag =
let i = ref 0 in
fun () ->
let tag = !i in
incr i;
NodeTag tag
(* vvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvv
* Miejsce na twój kod w Ocamlu
*)
(* ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
----------------------------------------------------------------------------- *)
%}
(* vvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvv
* Miejsce na dyrektywy
*)
%token EOF
%token LPAREN
%token RPAREN
%token LBRACKET
%token RBRACKET
%token <int>INT
%token <string>IDENTIFIER
%token <char>CHAR
%token <bool>BOOL
(* ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
----------------------------------------------------------------------------- *)
%%
(* vvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvv
* Miejsce na gramatykę
*)
(* Obecnie potrafimy sparsować tylko pusty plik (wymagamy od razu tokena EOF) *)
file:
| EOF
{ ModuleDefinition {global_declarations=[] } }
identifier:
| IDENTIFIER
{ Identifier $1 }
(*
** przykład użycia mkLocation
use_declaration:
| USE suffix(identifier, opt(SEMICOLON))
{ GDECL_Use {loc=mkLocation $startpos; id=$2} }
** przykład użycia mkTag
atomic_expression:
| identifier
{ EXPR_Id {loc=mkLocation $startpos; id=$1; tag=mkTag ()} }
*)
(* ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
----------------------------------------------------------------------------- *)
|