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