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