xref: /aosp_15_r20/external/antlr/runtime/Cpp/tests/t018llstar.g (revision 16467b971bd3e2009fad32dd79016f2c7e421deb)
1*16467b97STreehugger Robotgrammar t018llstar;
2*16467b97STreehugger Robot
3*16467b97STreehugger Robotoptions {
4*16467b97STreehugger Robot    language =Cpp;
5*16467b97STreehugger Robot}
6*16467b97STreehugger Robot
7*16467b97STreehugger Robot@lexer::includes
8*16467b97STreehugger Robot{
9*16467b97STreehugger Robot#include "UserTestTraits.hpp"
10*16467b97STreehugger Robot}
11*16467b97STreehugger Robot@lexer::namespace
12*16467b97STreehugger Robot{ Antlr3Test }
13*16467b97STreehugger Robot
14*16467b97STreehugger Robot@parser::includes {
15*16467b97STreehugger Robot#include "UserTestTraits.hpp"
16*16467b97STreehugger Robot}
17*16467b97STreehugger Robot@parser::namespace
18*16467b97STreehugger Robot{ Antlr3Test }
19*16467b97STreehugger Robot
20*16467b97STreehugger Robot@header {
21*16467b97STreehugger Robotfrom io import StringIO
22*16467b97STreehugger Robot}
23*16467b97STreehugger Robot
24*16467b97STreehugger Robot@init {
25*16467b97STreehugger Robotself.output = StringIO()
26*16467b97STreehugger Robot}
27*16467b97STreehugger Robot
28*16467b97STreehugger Robotprogram
29*16467b97STreehugger Robot    :   declaration+
30*16467b97STreehugger Robot    ;
31*16467b97STreehugger Robot
32*16467b97STreehugger Robot/** In this rule, the functionHeader left prefix on the last two
33*16467b97STreehugger Robot *  alternatives is not LL(k) for a fixed k.  However, it is
34*16467b97STreehugger Robot *  LL(*).  The LL(*) algorithm simply scans ahead until it sees
35*16467b97STreehugger Robot *  either the ';' or the '{' of the block and then it picks
36*16467b97STreehugger Robot *  the appropriate alternative.  Lookhead can be arbitrarily
37*16467b97STreehugger Robot *  long in theory, but is <=10 in most cases.  Works great.
38*16467b97STreehugger Robot *  Use ANTLRWorks to see the lookahead use (step by Location)
39*16467b97STreehugger Robot *  and look for blue tokens in the input window pane. :)
40*16467b97STreehugger Robot */
41*16467b97STreehugger Robotdeclaration
42*16467b97STreehugger Robot    :   variable
43*16467b97STreehugger Robot    |   functionHeader ';'
44*16467b97STreehugger Robot	{self.output.write($functionHeader.name+" is a declaration\n")}
45*16467b97STreehugger Robot    |   functionHeader block
46*16467b97STreehugger Robot	{self.output.write($functionHeader.name+" is a definition\n")}
47*16467b97STreehugger Robot    ;
48*16467b97STreehugger Robot
49*16467b97STreehugger Robotvariable
50*16467b97STreehugger Robot    :   type declarator ';'
51*16467b97STreehugger Robot    ;
52*16467b97STreehugger Robot
53*16467b97STreehugger Robotdeclarator
54*16467b97STreehugger Robot    :   ID
55*16467b97STreehugger Robot    ;
56*16467b97STreehugger Robot
57*16467b97STreehugger RobotfunctionHeader returns [name]
58*16467b97STreehugger Robot    :   type ID '(' ( formalParameter ( ',' formalParameter )* )? ')'
59*16467b97STreehugger Robot	{$name = $ID.text}
60*16467b97STreehugger Robot    ;
61*16467b97STreehugger Robot
62*16467b97STreehugger RobotformalParameter
63*16467b97STreehugger Robot    :   type declarator
64*16467b97STreehugger Robot    ;
65*16467b97STreehugger Robot
66*16467b97STreehugger Robottype
67*16467b97STreehugger Robot    :   'int'
68*16467b97STreehugger Robot    |   'char'
69*16467b97STreehugger Robot    |   'void'
70*16467b97STreehugger Robot    |   ID
71*16467b97STreehugger Robot    ;
72*16467b97STreehugger Robot
73*16467b97STreehugger Robotblock
74*16467b97STreehugger Robot    :   '{'
75*16467b97STreehugger Robot            variable*
76*16467b97STreehugger Robot            stat*
77*16467b97STreehugger Robot        '}'
78*16467b97STreehugger Robot    ;
79*16467b97STreehugger Robot
80*16467b97STreehugger Robotstat: forStat
81*16467b97STreehugger Robot    | expr ';'
82*16467b97STreehugger Robot    | block
83*16467b97STreehugger Robot    | assignStat ';'
84*16467b97STreehugger Robot    | ';'
85*16467b97STreehugger Robot    ;
86*16467b97STreehugger Robot
87*16467b97STreehugger RobotforStat
88*16467b97STreehugger Robot    :   'for' '(' assignStat ';' expr ';' assignStat ')' block
89*16467b97STreehugger Robot    ;
90*16467b97STreehugger Robot
91*16467b97STreehugger RobotassignStat
92*16467b97STreehugger Robot    :   ID '=' expr
93*16467b97STreehugger Robot    ;
94*16467b97STreehugger Robot
95*16467b97STreehugger Robotexpr:   condExpr
96*16467b97STreehugger Robot    ;
97*16467b97STreehugger Robot
98*16467b97STreehugger RobotcondExpr
99*16467b97STreehugger Robot    :   aexpr ( ('==' | '<') aexpr )?
100*16467b97STreehugger Robot    ;
101*16467b97STreehugger Robot
102*16467b97STreehugger Robotaexpr
103*16467b97STreehugger Robot    :   atom ( '+' atom )*
104*16467b97STreehugger Robot    ;
105*16467b97STreehugger Robot
106*16467b97STreehugger Robotatom
107*16467b97STreehugger Robot    : ID
108*16467b97STreehugger Robot    | INT
109*16467b97STreehugger Robot    | '(' expr ')'
110*16467b97STreehugger Robot    ;
111*16467b97STreehugger Robot
112*16467b97STreehugger RobotID  :   ('a'..'z'|'A'..'Z'|'_') ('a'..'z'|'A'..'Z'|'0'..'9'|'_')*
113*16467b97STreehugger Robot    ;
114*16467b97STreehugger Robot
115*16467b97STreehugger RobotINT :	('0'..'9')+
116*16467b97STreehugger Robot    ;
117*16467b97STreehugger Robot
118*16467b97STreehugger RobotWS  :   (   ' '
119*16467b97STreehugger Robot        |   '\t'
120*16467b97STreehugger Robot        |   '\r'
121*16467b97STreehugger Robot        |   '\n'
122*16467b97STreehugger Robot        )+
123*16467b97STreehugger Robot        {$channel=HIDDEN}
124*16467b97STreehugger Robot    ;
125