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