Please wait. This can take some minutes ...
Many resources are needed to download a project. Please understand that we have to compensate our server costs. Thank you in advance.
Project price only 1 $
You can buy this project and download/modify it how often you want.
org.antlr.grammar.v3.CodeGenTreeWalker Maven / Gradle / Ivy
// $ANTLR 3.5 org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g 2013-09-27 18:41:09
package org.antlr.grammar.v3;
import org.antlr.analysis.*;
import org.antlr.misc.*;
import org.antlr.tool.*;
import org.antlr.codegen.*;
import java.util.HashSet;
import java.util.Set;
import java.util.Collection;
import org.antlr.runtime.BitSet;
import org.antlr.runtime.DFA;
import org.stringtemplate.v4.ST;
import org.stringtemplate.v4.STGroup;
import org.antlr.runtime.*;
import org.antlr.runtime.tree.*;
import java.util.Stack;
import java.util.List;
import java.util.ArrayList;
import java.util.Map;
import java.util.HashMap;
/** Walk a grammar and generate code by gradually building up
* a bigger and bigger ST.
*
* Terence Parr
* University of San Francisco
* June 15, 2004
*/
@SuppressWarnings("all")
public class CodeGenTreeWalker extends TreeParser {
public static final String[] tokenNames = new String[] {
"", "", "", "", "ACTION", "ACTION_CHAR_LITERAL",
"ACTION_ESC", "ACTION_STRING_LITERAL", "ALT", "AMPERSAND", "ARG", "ARGLIST",
"ARG_ACTION", "ASSIGN", "BACKTRACK_SEMPRED", "BANG", "BLOCK", "CATCH",
"CHAR_LITERAL", "CHAR_RANGE", "CLOSE_ELEMENT_OPTION", "CLOSURE", "COLON",
"COMBINED_GRAMMAR", "COMMA", "COMMENT", "DIGIT", "DOC_COMMENT", "DOLLAR",
"DOT", "DOUBLE_ANGLE_STRING_LITERAL", "DOUBLE_QUOTE_STRING_LITERAL", "EOA",
"EOB", "EOR", "EPSILON", "ESC", "ETC", "FINALLY", "FORCED_ACTION", "FRAGMENT",
"GATED_SEMPRED", "GRAMMAR", "ID", "IMPLIES", "IMPORT", "INITACTION", "INT",
"LABEL", "LEXER", "LEXER_GRAMMAR", "LPAREN", "ML_COMMENT", "NESTED_ACTION",
"NESTED_ARG_ACTION", "NOT", "OPEN_ELEMENT_OPTION", "OPTIONAL", "OPTIONS",
"OR", "PARSER", "PARSER_GRAMMAR", "PLUS", "PLUS_ASSIGN", "POSITIVE_CLOSURE",
"PREC_RULE", "PRIVATE", "PROTECTED", "PUBLIC", "QUESTION", "RANGE", "RCURLY",
"RECURSIVE_RULE_REF", "RET", "RETURNS", "REWRITE", "REWRITES", "ROOT",
"RPAREN", "RULE", "RULE_REF", "SCOPE", "SEMI", "SEMPRED", "SL_COMMENT",
"SRC", "STAR", "STRAY_BRACKET", "STRING_LITERAL", "SYNPRED", "SYN_SEMPRED",
"TEMPLATE", "THROWS", "TOKENS", "TOKEN_REF", "TREE", "TREE_BEGIN", "TREE_GRAMMAR",
"WILDCARD", "WS", "WS_LOOP", "WS_OPT", "XDIGIT"
};
public static final int EOF=-1;
public static final int ACTION=4;
public static final int ACTION_CHAR_LITERAL=5;
public static final int ACTION_ESC=6;
public static final int ACTION_STRING_LITERAL=7;
public static final int ALT=8;
public static final int AMPERSAND=9;
public static final int ARG=10;
public static final int ARGLIST=11;
public static final int ARG_ACTION=12;
public static final int ASSIGN=13;
public static final int BACKTRACK_SEMPRED=14;
public static final int BANG=15;
public static final int BLOCK=16;
public static final int CATCH=17;
public static final int CHAR_LITERAL=18;
public static final int CHAR_RANGE=19;
public static final int CLOSE_ELEMENT_OPTION=20;
public static final int CLOSURE=21;
public static final int COLON=22;
public static final int COMBINED_GRAMMAR=23;
public static final int COMMA=24;
public static final int COMMENT=25;
public static final int DIGIT=26;
public static final int DOC_COMMENT=27;
public static final int DOLLAR=28;
public static final int DOT=29;
public static final int DOUBLE_ANGLE_STRING_LITERAL=30;
public static final int DOUBLE_QUOTE_STRING_LITERAL=31;
public static final int EOA=32;
public static final int EOB=33;
public static final int EOR=34;
public static final int EPSILON=35;
public static final int ESC=36;
public static final int ETC=37;
public static final int FINALLY=38;
public static final int FORCED_ACTION=39;
public static final int FRAGMENT=40;
public static final int GATED_SEMPRED=41;
public static final int GRAMMAR=42;
public static final int ID=43;
public static final int IMPLIES=44;
public static final int IMPORT=45;
public static final int INITACTION=46;
public static final int INT=47;
public static final int LABEL=48;
public static final int LEXER=49;
public static final int LEXER_GRAMMAR=50;
public static final int LPAREN=51;
public static final int ML_COMMENT=52;
public static final int NESTED_ACTION=53;
public static final int NESTED_ARG_ACTION=54;
public static final int NOT=55;
public static final int OPEN_ELEMENT_OPTION=56;
public static final int OPTIONAL=57;
public static final int OPTIONS=58;
public static final int OR=59;
public static final int PARSER=60;
public static final int PARSER_GRAMMAR=61;
public static final int PLUS=62;
public static final int PLUS_ASSIGN=63;
public static final int POSITIVE_CLOSURE=64;
public static final int PREC_RULE=65;
public static final int PRIVATE=66;
public static final int PROTECTED=67;
public static final int PUBLIC=68;
public static final int QUESTION=69;
public static final int RANGE=70;
public static final int RCURLY=71;
public static final int RECURSIVE_RULE_REF=72;
public static final int RET=73;
public static final int RETURNS=74;
public static final int REWRITE=75;
public static final int REWRITES=76;
public static final int ROOT=77;
public static final int RPAREN=78;
public static final int RULE=79;
public static final int RULE_REF=80;
public static final int SCOPE=81;
public static final int SEMI=82;
public static final int SEMPRED=83;
public static final int SL_COMMENT=84;
public static final int SRC=85;
public static final int STAR=86;
public static final int STRAY_BRACKET=87;
public static final int STRING_LITERAL=88;
public static final int SYNPRED=89;
public static final int SYN_SEMPRED=90;
public static final int TEMPLATE=91;
public static final int THROWS=92;
public static final int TOKENS=93;
public static final int TOKEN_REF=94;
public static final int TREE=95;
public static final int TREE_BEGIN=96;
public static final int TREE_GRAMMAR=97;
public static final int WILDCARD=98;
public static final int WS=99;
public static final int WS_LOOP=100;
public static final int WS_OPT=101;
public static final int XDIGIT=102;
// delegates
public TreeParser[] getDelegates() {
return new TreeParser[] {};
}
// delegators
public CodeGenTreeWalker(TreeNodeStream input) {
this(input, new RecognizerSharedState());
}
public CodeGenTreeWalker(TreeNodeStream input, RecognizerSharedState state) {
super(input, state);
}
@Override public String[] getTokenNames() { return CodeGenTreeWalker.tokenNames; }
@Override public String getGrammarFileName() { return "org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g"; }
protected static final int RULE_BLOCK_NESTING_LEVEL = 0;
protected static final int OUTER_REWRITE_NESTING_LEVEL = 0;
private String currentRuleName = null;
protected int blockNestingLevel = 0;
protected int rewriteBlockNestingLevel = 0;
private int outerAltNum = 0;
protected ST currentBlockST = null;
protected boolean currentAltHasASTRewrite = false;
protected int rewriteTreeNestingLevel = 0;
protected HashSet rewriteRuleRefs = null;
public String getCurrentRuleName() {
return currentRuleName;
}
public void setCurrentRuleName(String value) {
currentRuleName = value;
}
public int getOuterAltNum() {
return outerAltNum;
}
public void setOuterAltNum(int value) {
outerAltNum = value;
}
@Override
public void reportError(RecognitionException ex) {
Token token = null;
if (ex instanceof MismatchedTokenException) {
token = ((MismatchedTokenException)ex).token;
} else if (ex instanceof NoViableAltException) {
token = ((NoViableAltException)ex).token;
}
ErrorManager.syntaxError(
ErrorManager.MSG_SYNTAX_ERROR,
grammar,
token,
"codegen: " + ex.toString(),
ex );
}
public final void reportError(String s) {
System.out.println("codegen: error: " + s);
}
protected CodeGenerator generator;
protected Grammar grammar;
protected STGroup templates;
/** The overall lexer/parser template; simulate dynamically scoped
* attributes by making this an instance var of the walker.
*/
protected ST recognizerST;
protected ST outputFileST;
protected ST headerFileST;
protected String outputOption = "";
protected final ST getWildcardST(GrammarAST elementAST, GrammarAST ast_suffix, String label) {
String name = "wildcard";
if (grammar.type == Grammar.LEXER) {
name = "wildcardChar";
}
return getTokenElementST(name, name, elementAST, ast_suffix, label);
}
protected final ST getRuleElementST( String name,
String ruleTargetName,
GrammarAST elementAST,
GrammarAST ast_suffix,
String label ) {
Rule r = grammar.getRule( currentRuleName );
String suffix = getSTSuffix(elementAST, ast_suffix, label);
if ( !r.isSynPred ) {
name += suffix;
}
// if we're building trees and there is no label, gen a label
// unless we're in a synpred rule.
if ( ( grammar.buildAST() || suffix.length() > 0 ) && label == null &&
( r == null || !r.isSynPred ) ) {
// we will need a label to do the AST or tracking, make one
label = generator.createUniqueLabel( ruleTargetName );
CommonToken labelTok = new CommonToken( ANTLRParser.ID, label );
grammar.defineRuleRefLabel( currentRuleName, labelTok, elementAST );
}
ST elementST = templates.getInstanceOf( name );
if ( label != null ) {
elementST.add( "label", label );
}
return elementST;
}
protected final ST getTokenElementST( String name,
String elementName,
GrammarAST elementAST,
GrammarAST ast_suffix,
String label ) {
boolean tryUnchecked = false;
if (name == "matchSet" && elementAST.enclosingRuleName != null && elementAST.enclosingRuleName.length() > 0 && Rule.getRuleType(elementAST.enclosingRuleName) == Grammar.LEXER)
{
if ( ( elementAST.getParent().getType() == ANTLRLexer.ALT && elementAST.getParent().getParent().getParent().getType() == RULE && elementAST.getParent().getParent().getChildCount() == 2 )
|| ( elementAST.getParent().getType() == ANTLRLexer.NOT && elementAST.getParent().getParent().getParent().getParent().getType() == RULE && elementAST.getParent().getParent().getParent().getChildCount() == 2 ) ) {
// single alt at the start of the rule needs to be checked
} else {
tryUnchecked = true;
}
}
String suffix = getSTSuffix( elementAST, ast_suffix, label );
// if we're building trees and there is no label, gen a label
// unless we're in a synpred rule.
Rule r = grammar.getRule( currentRuleName );
if ( ( grammar.buildAST() || suffix.length() > 0 ) && label == null &&
( r == null || !r.isSynPred ) )
{
label = generator.createUniqueLabel( elementName );
CommonToken labelTok = new CommonToken( ANTLRParser.ID, label );
grammar.defineTokenRefLabel( currentRuleName, labelTok, elementAST );
}
ST elementST = null;
if ( tryUnchecked && templates.isDefined( name + "Unchecked" + suffix ) )
elementST = templates.getInstanceOf( name + "Unchecked" + suffix );
if ( elementST == null )
elementST = templates.getInstanceOf( name + suffix );
if ( label != null )
{
elementST.add( "label", label );
}
return elementST;
}
public final boolean isListLabel(String label) {
boolean hasListLabel = false;
if ( label != null ) {
Rule r = grammar.getRule( currentRuleName );
//String stName = null;
if ( r != null )
{
Grammar.LabelElementPair pair = r.getLabel( label );
if ( pair != null &&
( pair.type == Grammar.TOKEN_LIST_LABEL ||
pair.type == Grammar.RULE_LIST_LABEL ||
pair.type == Grammar.WILDCARD_TREE_LIST_LABEL ) )
{
hasListLabel = true;
}
}
}
return hasListLabel;
}
/** Return a non-empty template name suffix if the token is to be
* tracked, added to a tree, or both.
*/
protected final String getSTSuffix(GrammarAST elementAST, GrammarAST ast_suffix, String label) {
if ( grammar.type == Grammar.LEXER )
{
return "";
}
// handle list label stuff; make element use "Track"
String operatorPart = "";
String rewritePart = "";
String listLabelPart = "";
Rule ruleDescr = grammar.getRule( currentRuleName );
if ( ast_suffix != null && !ruleDescr.isSynPred )
{
if ( ast_suffix.getType() == ANTLRParser.ROOT )
{
operatorPart = "RuleRoot";
}
else if ( ast_suffix.getType() == ANTLRParser.BANG )
{
operatorPart = "Bang";
}
}
if ( currentAltHasASTRewrite && elementAST.getType() != WILDCARD )
{
rewritePart = "Track";
}
if ( isListLabel( label ) )
{
listLabelPart = "AndListLabel";
}
String STsuffix = operatorPart + rewritePart + listLabelPart;
//[email protected] ("suffix = "+STsuffix);
return STsuffix;
}
/** Convert rewrite AST lists to target labels list */
protected final List getTokenTypesAsTargetLabels(Collection refs)
{
if ( refs == null || refs.size() == 0 )
return null;
List labels = new ArrayList( refs.size() );
for ( GrammarAST t : refs )
{
String label;
if ( t.getType() == ANTLRParser.RULE_REF || t.getType() == ANTLRParser.TOKEN_REF || t.getType() == ANTLRParser.LABEL)
{
label = t.getText();
}
else
{
// must be char or String literal
label = generator.getTokenTypeAsTargetLabel(grammar.getTokenType(t.getText()));
}
labels.add( label );
}
return labels;
}
public final void init( Grammar g ) {
this.grammar = g;
this.generator = grammar.getCodeGenerator();
this.templates = generator.getTemplates();
}
// $ANTLR start "grammar_"
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:298:1: public grammar_[Grammar g,\r\n\t\tST recognizerST,\r\n\t\tST outputFileST,\r\n\t\tST headerFileST] : ( ^( LEXER_GRAMMAR grammarSpec ) | ^( PARSER_GRAMMAR grammarSpec ) | ^( TREE_GRAMMAR grammarSpec ) | ^( COMBINED_GRAMMAR grammarSpec ) ) ;
public final void grammar_(Grammar g, ST recognizerST, ST outputFileST, ST headerFileST) throws RecognitionException {
if ( state.backtracking == 0 )
{
init(g);
this.recognizerST = recognizerST;
this.outputFileST = outputFileST;
this.headerFileST = headerFileST;
String superClass = (String)g.getOption("superClass");
outputOption = (String)g.getOption("output");
if ( superClass!=null ) recognizerST.add("superClass", superClass);
if ( g.type!=Grammar.LEXER ) {
Object lt = g.getOption("ASTLabelType");
if ( lt!=null ) recognizerST.add("ASTLabelType", lt);
}
if ( g.type==Grammar.TREE_PARSER && g.getOption("ASTLabelType")==null ) {
ErrorManager.grammarWarning(ErrorManager.MSG_MISSING_AST_TYPE_IN_TREE_GRAMMAR,
g,
null,
g.name);
}
if ( g.type!=Grammar.TREE_PARSER ) {
Object lt = g.getOption("TokenLabelType");
if ( lt!=null ) recognizerST.add("labelType", lt);
}
recognizerST.add("numRules", grammar.getRules().size());
outputFileST.add("numRules", grammar.getRules().size());
headerFileST.add("numRules", grammar.getRules().size());
}
try {
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:332:2: ( ( ^( LEXER_GRAMMAR grammarSpec ) | ^( PARSER_GRAMMAR grammarSpec ) | ^( TREE_GRAMMAR grammarSpec ) | ^( COMBINED_GRAMMAR grammarSpec ) ) )
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:332:4: ( ^( LEXER_GRAMMAR grammarSpec ) | ^( PARSER_GRAMMAR grammarSpec ) | ^( TREE_GRAMMAR grammarSpec ) | ^( COMBINED_GRAMMAR grammarSpec ) )
{
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:332:4: ( ^( LEXER_GRAMMAR grammarSpec ) | ^( PARSER_GRAMMAR grammarSpec ) | ^( TREE_GRAMMAR grammarSpec ) | ^( COMBINED_GRAMMAR grammarSpec ) )
int alt1=4;
switch ( input.LA(1) ) {
case LEXER_GRAMMAR:
{
alt1=1;
}
break;
case PARSER_GRAMMAR:
{
alt1=2;
}
break;
case TREE_GRAMMAR:
{
alt1=3;
}
break;
case COMBINED_GRAMMAR:
{
alt1=4;
}
break;
default:
if (state.backtracking>0) {state.failed=true; return;}
NoViableAltException nvae =
new NoViableAltException("", 1, 0, input);
throw nvae;
}
switch (alt1) {
case 1 :
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:332:6: ^( LEXER_GRAMMAR grammarSpec )
{
match(input,LEXER_GRAMMAR,FOLLOW_LEXER_GRAMMAR_in_grammar_67); if (state.failed) return;
match(input, Token.DOWN, null); if (state.failed) return;
pushFollow(FOLLOW_grammarSpec_in_grammar_69);
grammarSpec();
state._fsp--;
if (state.failed) return;
match(input, Token.UP, null); if (state.failed) return;
}
break;
case 2 :
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:333:5: ^( PARSER_GRAMMAR grammarSpec )
{
match(input,PARSER_GRAMMAR,FOLLOW_PARSER_GRAMMAR_in_grammar_79); if (state.failed) return;
match(input, Token.DOWN, null); if (state.failed) return;
pushFollow(FOLLOW_grammarSpec_in_grammar_81);
grammarSpec();
state._fsp--;
if (state.failed) return;
match(input, Token.UP, null); if (state.failed) return;
}
break;
case 3 :
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:334:5: ^( TREE_GRAMMAR grammarSpec )
{
match(input,TREE_GRAMMAR,FOLLOW_TREE_GRAMMAR_in_grammar_91); if (state.failed) return;
match(input, Token.DOWN, null); if (state.failed) return;
pushFollow(FOLLOW_grammarSpec_in_grammar_93);
grammarSpec();
state._fsp--;
if (state.failed) return;
match(input, Token.UP, null); if (state.failed) return;
}
break;
case 4 :
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:335:5: ^( COMBINED_GRAMMAR grammarSpec )
{
match(input,COMBINED_GRAMMAR,FOLLOW_COMBINED_GRAMMAR_in_grammar_103); if (state.failed) return;
match(input, Token.DOWN, null); if (state.failed) return;
pushFollow(FOLLOW_grammarSpec_in_grammar_105);
grammarSpec();
state._fsp--;
if (state.failed) return;
match(input, Token.UP, null); if (state.failed) return;
}
break;
}
}
}
catch (RecognitionException re) {
reportError(re);
recover(input,re);
}
finally {
// do for sure before leaving
}
}
// $ANTLR end "grammar_"
// $ANTLR start "attrScope"
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:339:1: attrScope : ^( 'scope' ID ( ^( AMPERSAND ( . )* ) )* ACTION ) ;
public final void attrScope() throws RecognitionException {
try {
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:340:2: ( ^( 'scope' ID ( ^( AMPERSAND ( . )* ) )* ACTION ) )
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:340:4: ^( 'scope' ID ( ^( AMPERSAND ( . )* ) )* ACTION )
{
match(input,SCOPE,FOLLOW_SCOPE_in_attrScope124); if (state.failed) return;
match(input, Token.DOWN, null); if (state.failed) return;
match(input,ID,FOLLOW_ID_in_attrScope126); if (state.failed) return;
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:340:18: ( ^( AMPERSAND ( . )* ) )*
loop3:
while (true) {
int alt3=2;
int LA3_0 = input.LA(1);
if ( (LA3_0==AMPERSAND) ) {
alt3=1;
}
switch (alt3) {
case 1 :
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:340:20: ^( AMPERSAND ( . )* )
{
match(input,AMPERSAND,FOLLOW_AMPERSAND_in_attrScope131); if (state.failed) return;
if ( input.LA(1)==Token.DOWN ) {
match(input, Token.DOWN, null); if (state.failed) return;
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:340:32: ( . )*
loop2:
while (true) {
int alt2=2;
int LA2_0 = input.LA(1);
if ( ((LA2_0 >= ACTION && LA2_0 <= XDIGIT)) ) {
alt2=1;
}
else if ( (LA2_0==UP) ) {
alt2=2;
}
switch (alt2) {
case 1 :
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:340:32: .
{
matchAny(input); if (state.failed) return;
}
break;
default :
break loop2;
}
}
match(input, Token.UP, null); if (state.failed) return;
}
}
break;
default :
break loop3;
}
}
match(input,ACTION,FOLLOW_ACTION_in_attrScope140); if (state.failed) return;
match(input, Token.UP, null); if (state.failed) return;
}
}
catch (RecognitionException re) {
reportError(re);
recover(input,re);
}
finally {
// do for sure before leaving
}
}
// $ANTLR end "attrScope"
// $ANTLR start "grammarSpec"
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:343:1: grammarSpec : name= ID (cmt= DOC_COMMENT )? ( ^( OPTIONS ( . )* ) )? ( ^( IMPORT ( . )* ) )? ( ^( TOKENS ( . )* ) )? ( attrScope )* ( ^( AMPERSAND ( . )* ) )* rules[recognizerST] ;
public final void grammarSpec() throws RecognitionException {
GrammarAST name=null;
GrammarAST cmt=null;
try {
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:344:2: (name= ID (cmt= DOC_COMMENT )? ( ^( OPTIONS ( . )* ) )? ( ^( IMPORT ( . )* ) )? ( ^( TOKENS ( . )* ) )? ( attrScope )* ( ^( AMPERSAND ( . )* ) )* rules[recognizerST] )
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:344:6: name= ID (cmt= DOC_COMMENT )? ( ^( OPTIONS ( . )* ) )? ( ^( IMPORT ( . )* ) )? ( ^( TOKENS ( . )* ) )? ( attrScope )* ( ^( AMPERSAND ( . )* ) )* rules[recognizerST]
{
name=(GrammarAST)match(input,ID,FOLLOW_ID_in_grammarSpec157); if (state.failed) return;
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:345:3: (cmt= DOC_COMMENT )?
int alt4=2;
int LA4_0 = input.LA(1);
if ( (LA4_0==DOC_COMMENT) ) {
alt4=1;
}
switch (alt4) {
case 1 :
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:345:5: cmt= DOC_COMMENT
{
cmt=(GrammarAST)match(input,DOC_COMMENT,FOLLOW_DOC_COMMENT_in_grammarSpec165); if (state.failed) return;
if ( state.backtracking==0 ) {
outputFileST.add("docComment", (cmt!=null?cmt.getText():null));
headerFileST.add("docComment", (cmt!=null?cmt.getText():null));
}
}
break;
}
if ( state.backtracking==0 ) {
recognizerST.add("name", grammar.getRecognizerName());
outputFileST.add("name", grammar.getRecognizerName());
headerFileST.add("name", grammar.getRecognizerName());
recognizerST.add("scopes", grammar.getGlobalScopes());
headerFileST.add("scopes", grammar.getGlobalScopes());
}
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:358:3: ( ^( OPTIONS ( . )* ) )?
int alt6=2;
int LA6_0 = input.LA(1);
if ( (LA6_0==OPTIONS) ) {
alt6=1;
}
switch (alt6) {
case 1 :
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:358:5: ^( OPTIONS ( . )* )
{
match(input,OPTIONS,FOLLOW_OPTIONS_in_grammarSpec186); if (state.failed) return;
if ( input.LA(1)==Token.DOWN ) {
match(input, Token.DOWN, null); if (state.failed) return;
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:358:15: ( . )*
loop5:
while (true) {
int alt5=2;
int LA5_0 = input.LA(1);
if ( ((LA5_0 >= ACTION && LA5_0 <= XDIGIT)) ) {
alt5=1;
}
else if ( (LA5_0==UP) ) {
alt5=2;
}
switch (alt5) {
case 1 :
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:358:15: .
{
matchAny(input); if (state.failed) return;
}
break;
default :
break loop5;
}
}
match(input, Token.UP, null); if (state.failed) return;
}
}
break;
}
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:359:3: ( ^( IMPORT ( . )* ) )?
int alt8=2;
int LA8_0 = input.LA(1);
if ( (LA8_0==IMPORT) ) {
alt8=1;
}
switch (alt8) {
case 1 :
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:359:5: ^( IMPORT ( . )* )
{
match(input,IMPORT,FOLLOW_IMPORT_in_grammarSpec200); if (state.failed) return;
if ( input.LA(1)==Token.DOWN ) {
match(input, Token.DOWN, null); if (state.failed) return;
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:359:14: ( . )*
loop7:
while (true) {
int alt7=2;
int LA7_0 = input.LA(1);
if ( ((LA7_0 >= ACTION && LA7_0 <= XDIGIT)) ) {
alt7=1;
}
else if ( (LA7_0==UP) ) {
alt7=2;
}
switch (alt7) {
case 1 :
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:359:14: .
{
matchAny(input); if (state.failed) return;
}
break;
default :
break loop7;
}
}
match(input, Token.UP, null); if (state.failed) return;
}
}
break;
}
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:360:3: ( ^( TOKENS ( . )* ) )?
int alt10=2;
int LA10_0 = input.LA(1);
if ( (LA10_0==TOKENS) ) {
alt10=1;
}
switch (alt10) {
case 1 :
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:360:5: ^( TOKENS ( . )* )
{
match(input,TOKENS,FOLLOW_TOKENS_in_grammarSpec214); if (state.failed) return;
if ( input.LA(1)==Token.DOWN ) {
match(input, Token.DOWN, null); if (state.failed) return;
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:360:14: ( . )*
loop9:
while (true) {
int alt9=2;
int LA9_0 = input.LA(1);
if ( ((LA9_0 >= ACTION && LA9_0 <= XDIGIT)) ) {
alt9=1;
}
else if ( (LA9_0==UP) ) {
alt9=2;
}
switch (alt9) {
case 1 :
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:360:14: .
{
matchAny(input); if (state.failed) return;
}
break;
default :
break loop9;
}
}
match(input, Token.UP, null); if (state.failed) return;
}
}
break;
}
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:361:3: ( attrScope )*
loop11:
while (true) {
int alt11=2;
int LA11_0 = input.LA(1);
if ( (LA11_0==SCOPE) ) {
alt11=1;
}
switch (alt11) {
case 1 :
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:361:4: attrScope
{
pushFollow(FOLLOW_attrScope_in_grammarSpec226);
attrScope();
state._fsp--;
if (state.failed) return;
}
break;
default :
break loop11;
}
}
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:362:3: ( ^( AMPERSAND ( . )* ) )*
loop13:
while (true) {
int alt13=2;
int LA13_0 = input.LA(1);
if ( (LA13_0==AMPERSAND) ) {
alt13=1;
}
switch (alt13) {
case 1 :
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:362:5: ^( AMPERSAND ( . )* )
{
match(input,AMPERSAND,FOLLOW_AMPERSAND_in_grammarSpec235); if (state.failed) return;
if ( input.LA(1)==Token.DOWN ) {
match(input, Token.DOWN, null); if (state.failed) return;
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:362:17: ( . )*
loop12:
while (true) {
int alt12=2;
int LA12_0 = input.LA(1);
if ( ((LA12_0 >= ACTION && LA12_0 <= XDIGIT)) ) {
alt12=1;
}
else if ( (LA12_0==UP) ) {
alt12=2;
}
switch (alt12) {
case 1 :
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:362:17: .
{
matchAny(input); if (state.failed) return;
}
break;
default :
break loop12;
}
}
match(input, Token.UP, null); if (state.failed) return;
}
}
break;
default :
break loop13;
}
}
pushFollow(FOLLOW_rules_in_grammarSpec246);
rules(recognizerST);
state._fsp--;
if (state.failed) return;
}
}
catch (RecognitionException re) {
reportError(re);
recover(input,re);
}
finally {
// do for sure before leaving
}
}
// $ANTLR end "grammarSpec"
// $ANTLR start "rules"
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:366:1: rules[ST recognizerST] : ( ( options {k=1; } :{...}? =>rST= rule | ^( RULE ( . )* ) | ^( PREC_RULE ( . )* ) ) )+ ;
public final void rules(ST recognizerST) throws RecognitionException {
TreeRuleReturnScope rST =null;
String ruleName = ((GrammarAST)input.LT(1)).getChild(0).getText();
boolean generated = grammar.generateMethodForRule(ruleName);
try {
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:372:2: ( ( ( options {k=1; } :{...}? =>rST= rule | ^( RULE ( . )* ) | ^( PREC_RULE ( . )* ) ) )+ )
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:372:4: ( ( options {k=1; } :{...}? =>rST= rule | ^( RULE ( . )* ) | ^( PREC_RULE ( . )* ) ) )+
{
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:372:4: ( ( options {k=1; } :{...}? =>rST= rule | ^( RULE ( . )* ) | ^( PREC_RULE ( . )* ) ) )+
int cnt17=0;
loop17:
while (true) {
int alt17=2;
int LA17_0 = input.LA(1);
if ( (LA17_0==PREC_RULE||LA17_0==RULE) ) {
alt17=1;
}
switch (alt17) {
case 1 :
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:372:6: ( options {k=1; } :{...}? =>rST= rule | ^( RULE ( . )* ) | ^( PREC_RULE ( . )* ) )
{
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:372:6: ( options {k=1; } :{...}? =>rST= rule | ^( RULE ( . )* ) | ^( PREC_RULE ( . )* ) )
int alt16=3;
int LA16_0 = input.LA(1);
if ( (LA16_0==RULE) ) {
int LA16_1 = input.LA(2);
if ( ((generated)) ) {
alt16=1;
}
else if ( (true) ) {
alt16=2;
}
}
else if ( (LA16_0==PREC_RULE) ) {
alt16=3;
}
else {
if (state.backtracking>0) {state.failed=true; return;}
NoViableAltException nvae =
new NoViableAltException("", 16, 0, input);
throw nvae;
}
switch (alt16) {
case 1 :
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:373:5: {...}? =>rST= rule
{
if ( !((generated)) ) {
if (state.backtracking>0) {state.failed=true; return;}
throw new FailedPredicateException(input, "rules", "generated");
}
pushFollow(FOLLOW_rule_in_rules291);
rST=rule();
state._fsp--;
if (state.failed) return;
if ( state.backtracking==0 ) {
if ( (rST!=null?((CodeGenTreeWalker.rule_return)rST).code:null) != null )
{
recognizerST.add("rules", (rST!=null?((CodeGenTreeWalker.rule_return)rST).code:null));
outputFileST.add("rules", (rST!=null?((CodeGenTreeWalker.rule_return)rST).code:null));
headerFileST.add("rules", (rST!=null?((CodeGenTreeWalker.rule_return)rST).code:null));
}
}
}
break;
case 2 :
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:383:6: ^( RULE ( . )* )
{
match(input,RULE,FOLLOW_RULE_in_rules305); if (state.failed) return;
if ( input.LA(1)==Token.DOWN ) {
match(input, Token.DOWN, null); if (state.failed) return;
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:383:13: ( . )*
loop14:
while (true) {
int alt14=2;
int LA14_0 = input.LA(1);
if ( ((LA14_0 >= ACTION && LA14_0 <= XDIGIT)) ) {
alt14=1;
}
else if ( (LA14_0==UP) ) {
alt14=2;
}
switch (alt14) {
case 1 :
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:383:13: .
{
matchAny(input); if (state.failed) return;
}
break;
default :
break loop14;
}
}
match(input, Token.UP, null); if (state.failed) return;
}
}
break;
case 3 :
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:384:6: ^( PREC_RULE ( . )* )
{
match(input,PREC_RULE,FOLLOW_PREC_RULE_in_rules317); if (state.failed) return;
if ( input.LA(1)==Token.DOWN ) {
match(input, Token.DOWN, null); if (state.failed) return;
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:384:18: ( . )*
loop15:
while (true) {
int alt15=2;
int LA15_0 = input.LA(1);
if ( ((LA15_0 >= ACTION && LA15_0 <= XDIGIT)) ) {
alt15=1;
}
else if ( (LA15_0==UP) ) {
alt15=2;
}
switch (alt15) {
case 1 :
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:384:18: .
{
matchAny(input); if (state.failed) return;
}
break;
default :
break loop15;
}
}
match(input, Token.UP, null); if (state.failed) return;
}
}
break;
}
if ( input.LA(1) == RULE )
{
ruleName = ((GrammarAST)input.LT(1)).getChild(0).getText();
//System.Diagnostics.Debug.Assert( ruleName == ((GrammarAST)input.LT(1)).enclosingRuleName );
generated = grammar.generateMethodForRule(ruleName);
}
}
break;
default :
if ( cnt17 >= 1 ) break loop17;
if (state.backtracking>0) {state.failed=true; return;}
EarlyExitException eee = new EarlyExitException(17, input);
throw eee;
}
cnt17++;
}
}
}
catch (RecognitionException re) {
reportError(re);
recover(input,re);
}
finally {
// do for sure before leaving
}
}
// $ANTLR end "rules"
public static class rule_return extends TreeRuleReturnScope {
public ST code=null;
};
// $ANTLR start "rule"
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:397:1: rule returns [ST code=null] : ^( RULE id= ID (mod= modifier )? ^( ARG ( ARG_ACTION )? ) ^( RET ( ARG_ACTION )? ) ( throwsSpec )? ( ^( OPTIONS ( . )* ) )? ( ruleScopeSpec )? ( ^( AMPERSAND ( . )* ) )* b= block[\"ruleBlock\", dfa, null] ( exceptionGroup[$code] )? EOR ) ;
public final CodeGenTreeWalker.rule_return rule() throws RecognitionException {
CodeGenTreeWalker.rule_return retval = new CodeGenTreeWalker.rule_return();
retval.start = input.LT(1);
GrammarAST id=null;
TreeRuleReturnScope mod =null;
TreeRuleReturnScope b =null;
String initAction = null;
// get the dfa for the BLOCK
GrammarAST block2=(GrammarAST)((GrammarAST)retval.start).getFirstChildWithType(BLOCK);
org.antlr.analysis.DFA dfa = block2.getLookaheadDFA();
// init blockNestingLevel so it's block level RULE_BLOCK_NESTING_LEVEL
// for alts of rule
blockNestingLevel = RULE_BLOCK_NESTING_LEVEL-1;
Rule ruleDescr = grammar.getRule(((GrammarAST)retval.start).getChild(0).getText());
currentRuleName = ((GrammarAST)retval.start).getChild(0).getText();
// For syn preds, we don't want any AST code etc... in there.
// Save old templates ptr and restore later. Base templates include Dbg.
STGroup saveGroup = templates;
if ( ruleDescr.isSynPred && generator.target.useBaseTemplatesForSynPredFragments() )
{
templates = generator.getBaseTemplates();
}
String description = "";
try {
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:420:2: ( ^( RULE id= ID (mod= modifier )? ^( ARG ( ARG_ACTION )? ) ^( RET ( ARG_ACTION )? ) ( throwsSpec )? ( ^( OPTIONS ( . )* ) )? ( ruleScopeSpec )? ( ^( AMPERSAND ( . )* ) )* b= block[\"ruleBlock\", dfa, null] ( exceptionGroup[$code] )? EOR ) )
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:420:4: ^( RULE id= ID (mod= modifier )? ^( ARG ( ARG_ACTION )? ) ^( RET ( ARG_ACTION )? ) ( throwsSpec )? ( ^( OPTIONS ( . )* ) )? ( ruleScopeSpec )? ( ^( AMPERSAND ( . )* ) )* b= block[\"ruleBlock\", dfa, null] ( exceptionGroup[$code] )? EOR )
{
match(input,RULE,FOLLOW_RULE_in_rule359); if (state.failed) return retval;
match(input, Token.DOWN, null); if (state.failed) return retval;
id=(GrammarAST)match(input,ID,FOLLOW_ID_in_rule363); if (state.failed) return retval;
if ( state.backtracking==0 ) {assert currentRuleName == (id!=null?id.getText():null);}
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:422:4: (mod= modifier )?
int alt18=2;
int LA18_0 = input.LA(1);
if ( (LA18_0==FRAGMENT||(LA18_0 >= PRIVATE && LA18_0 <= PUBLIC)) ) {
alt18=1;
}
switch (alt18) {
case 1 :
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:422:5: mod= modifier
{
pushFollow(FOLLOW_modifier_in_rule376);
mod=modifier();
state._fsp--;
if (state.failed) return retval;
}
break;
}
match(input,ARG,FOLLOW_ARG_in_rule384); if (state.failed) return retval;
if ( input.LA(1)==Token.DOWN ) {
match(input, Token.DOWN, null); if (state.failed) return retval;
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:423:10: ( ARG_ACTION )?
int alt19=2;
int LA19_0 = input.LA(1);
if ( (LA19_0==ARG_ACTION) ) {
alt19=1;
}
switch (alt19) {
case 1 :
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:423:11: ARG_ACTION
{
match(input,ARG_ACTION,FOLLOW_ARG_ACTION_in_rule387); if (state.failed) return retval;
}
break;
}
match(input, Token.UP, null); if (state.failed) return retval;
}
match(input,RET,FOLLOW_RET_in_rule396); if (state.failed) return retval;
if ( input.LA(1)==Token.DOWN ) {
match(input, Token.DOWN, null); if (state.failed) return retval;
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:424:10: ( ARG_ACTION )?
int alt20=2;
int LA20_0 = input.LA(1);
if ( (LA20_0==ARG_ACTION) ) {
alt20=1;
}
switch (alt20) {
case 1 :
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:424:11: ARG_ACTION
{
match(input,ARG_ACTION,FOLLOW_ARG_ACTION_in_rule399); if (state.failed) return retval;
}
break;
}
match(input, Token.UP, null); if (state.failed) return retval;
}
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:425:4: ( throwsSpec )?
int alt21=2;
int LA21_0 = input.LA(1);
if ( (LA21_0==THROWS) ) {
alt21=1;
}
switch (alt21) {
case 1 :
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:425:5: throwsSpec
{
pushFollow(FOLLOW_throwsSpec_in_rule408);
throwsSpec();
state._fsp--;
if (state.failed) return retval;
}
break;
}
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:426:4: ( ^( OPTIONS ( . )* ) )?
int alt23=2;
int LA23_0 = input.LA(1);
if ( (LA23_0==OPTIONS) ) {
alt23=1;
}
switch (alt23) {
case 1 :
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:426:6: ^( OPTIONS ( . )* )
{
match(input,OPTIONS,FOLLOW_OPTIONS_in_rule418); if (state.failed) return retval;
if ( input.LA(1)==Token.DOWN ) {
match(input, Token.DOWN, null); if (state.failed) return retval;
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:426:16: ( . )*
loop22:
while (true) {
int alt22=2;
int LA22_0 = input.LA(1);
if ( ((LA22_0 >= ACTION && LA22_0 <= XDIGIT)) ) {
alt22=1;
}
else if ( (LA22_0==UP) ) {
alt22=2;
}
switch (alt22) {
case 1 :
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:426:16: .
{
matchAny(input); if (state.failed) return retval;
}
break;
default :
break loop22;
}
}
match(input, Token.UP, null); if (state.failed) return retval;
}
}
break;
}
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:427:4: ( ruleScopeSpec )?
int alt24=2;
int LA24_0 = input.LA(1);
if ( (LA24_0==SCOPE) ) {
alt24=1;
}
switch (alt24) {
case 1 :
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:427:5: ruleScopeSpec
{
pushFollow(FOLLOW_ruleScopeSpec_in_rule431);
ruleScopeSpec();
state._fsp--;
if (state.failed) return retval;
}
break;
}
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:428:4: ( ^( AMPERSAND ( . )* ) )*
loop26:
while (true) {
int alt26=2;
int LA26_0 = input.LA(1);
if ( (LA26_0==AMPERSAND) ) {
alt26=1;
}
switch (alt26) {
case 1 :
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:428:6: ^( AMPERSAND ( . )* )
{
match(input,AMPERSAND,FOLLOW_AMPERSAND_in_rule441); if (state.failed) return retval;
if ( input.LA(1)==Token.DOWN ) {
match(input, Token.DOWN, null); if (state.failed) return retval;
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:428:18: ( . )*
loop25:
while (true) {
int alt25=2;
int LA25_0 = input.LA(1);
if ( ((LA25_0 >= ACTION && LA25_0 <= XDIGIT)) ) {
alt25=1;
}
else if ( (LA25_0==UP) ) {
alt25=2;
}
switch (alt25) {
case 1 :
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:428:18: .
{
matchAny(input); if (state.failed) return retval;
}
break;
default :
break loop25;
}
}
match(input, Token.UP, null); if (state.failed) return retval;
}
}
break;
default :
break loop26;
}
}
pushFollow(FOLLOW_block_in_rule455);
b=block("ruleBlock", dfa, null);
state._fsp--;
if (state.failed) return retval;
if ( state.backtracking==0 ) {
description =
grammar.grammarTreeToString((GrammarAST)((GrammarAST)retval.start).getFirstChildWithType(BLOCK),
false);
description =
generator.target.getTargetStringLiteralFromString(description);
(b!=null?((CodeGenTreeWalker.block_return)b).code:null).add("description", description);
// do not generate lexer rules in combined grammar
String stName = null;
if ( ruleDescr.isSynPred )
{
stName = "synpredRule";
}
else if ( grammar.type==Grammar.LEXER )
{
if ( currentRuleName.equals(Grammar.ARTIFICIAL_TOKENS_RULENAME) )
{
stName = "tokensRule";
}
else
{
stName = "lexerRule";
}
}
else
{
if ( !(grammar.type==Grammar.COMBINED &&
Rule.getRuleType(currentRuleName) == Grammar.LEXER) )
{
stName = "rule";
}
}
retval.code = templates.getInstanceOf(stName);
if ( retval.code.getName().equals("/rule") )
{
retval.code.add("emptyRule", grammar.isEmptyRule(block2));
}
retval.code.add("ruleDescriptor", ruleDescr);
String memo = (String)grammar.getBlockOption(((GrammarAST)retval.start),"memoize");
if ( memo==null )
{
memo = (String)grammar.getOption("memoize");
}
if ( memo!=null && memo.equals("true") &&
(stName.equals("rule")||stName.equals("lexerRule")) )
{
retval.code.add("memoize", memo!=null && memo.equals("true"));
}
}
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:480:4: ( exceptionGroup[$code] )?
int alt27=2;
int LA27_0 = input.LA(1);
if ( (LA27_0==CATCH||LA27_0==FINALLY) ) {
alt27=1;
}
switch (alt27) {
case 1 :
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:480:5: exceptionGroup[$code]
{
pushFollow(FOLLOW_exceptionGroup_in_rule468);
exceptionGroup(retval.code);
state._fsp--;
if (state.failed) return retval;
}
break;
}
match(input,EOR,FOLLOW_EOR_in_rule476); if (state.failed) return retval;
match(input, Token.UP, null); if (state.failed) return retval;
if ( state.backtracking==0 ) {
if ( retval.code!=null )
{
if ( grammar.type==Grammar.LEXER )
{
boolean naked =
currentRuleName.equals(Grammar.ARTIFICIAL_TOKENS_RULENAME) ||
((mod!=null?((GrammarAST)mod.start):null)!=null&&(mod!=null?((GrammarAST)mod.start):null).getText().equals(Grammar.FRAGMENT_RULE_MODIFIER));
retval.code.add("nakedBlock", naked);
}
else
{
description = grammar.grammarTreeToString(((GrammarAST)retval.start),false);
description = generator.target.getTargetStringLiteralFromString(description);
retval.code.add("description", description);
}
Rule theRule = grammar.getRule(currentRuleName);
generator.translateActionAttributeReferencesForSingleScope(
theRule,
theRule.getActions()
);
retval.code.add("ruleName", currentRuleName);
retval.code.add("block", (b!=null?((CodeGenTreeWalker.block_return)b).code:null));
if ( initAction!=null )
{
retval.code.add("initAction", initAction);
}
}
}
}
}
catch (RecognitionException re) {
reportError(re);
recover(input,re);
}
finally {
// do for sure before leaving
templates = saveGroup;
}
return retval;
}
// $ANTLR end "rule"
public static class modifier_return extends TreeRuleReturnScope {
};
// $ANTLR start "modifier"
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:515:1: modifier : ( 'protected' | 'public' | 'private' | 'fragment' );
public final CodeGenTreeWalker.modifier_return modifier() throws RecognitionException {
CodeGenTreeWalker.modifier_return retval = new CodeGenTreeWalker.modifier_return();
retval.start = input.LT(1);
try {
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:516:2: ( 'protected' | 'public' | 'private' | 'fragment' )
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:
{
if ( input.LA(1)==FRAGMENT||(input.LA(1) >= PRIVATE && input.LA(1) <= PUBLIC) ) {
input.consume();
state.errorRecovery=false;
state.failed=false;
}
else {
if (state.backtracking>0) {state.failed=true; return retval;}
MismatchedSetException mse = new MismatchedSetException(null,input);
throw mse;
}
}
}
catch (RecognitionException re) {
reportError(re);
recover(input,re);
}
finally {
// do for sure before leaving
}
return retval;
}
// $ANTLR end "modifier"
// $ANTLR start "throwsSpec"
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:522:1: throwsSpec : ^( 'throws' ( ID )+ ) ;
public final void throwsSpec() throws RecognitionException {
try {
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:523:2: ( ^( 'throws' ( ID )+ ) )
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:523:4: ^( 'throws' ( ID )+ )
{
match(input,THROWS,FOLLOW_THROWS_in_throwsSpec526); if (state.failed) return;
match(input, Token.DOWN, null); if (state.failed) return;
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:523:15: ( ID )+
int cnt28=0;
loop28:
while (true) {
int alt28=2;
int LA28_0 = input.LA(1);
if ( (LA28_0==ID) ) {
alt28=1;
}
switch (alt28) {
case 1 :
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:523:15: ID
{
match(input,ID,FOLLOW_ID_in_throwsSpec528); if (state.failed) return;
}
break;
default :
if ( cnt28 >= 1 ) break loop28;
if (state.backtracking>0) {state.failed=true; return;}
EarlyExitException eee = new EarlyExitException(28, input);
throw eee;
}
cnt28++;
}
match(input, Token.UP, null); if (state.failed) return;
}
}
catch (RecognitionException re) {
reportError(re);
recover(input,re);
}
finally {
// do for sure before leaving
}
}
// $ANTLR end "throwsSpec"
// $ANTLR start "ruleScopeSpec"
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:526:1: ruleScopeSpec : ^( 'scope' ( ^( AMPERSAND ( . )* ) )* ( ACTION )? ( ID )* ) ;
public final void ruleScopeSpec() throws RecognitionException {
try {
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:527:2: ( ^( 'scope' ( ^( AMPERSAND ( . )* ) )* ( ACTION )? ( ID )* ) )
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:527:4: ^( 'scope' ( ^( AMPERSAND ( . )* ) )* ( ACTION )? ( ID )* )
{
match(input,SCOPE,FOLLOW_SCOPE_in_ruleScopeSpec543); if (state.failed) return;
if ( input.LA(1)==Token.DOWN ) {
match(input, Token.DOWN, null); if (state.failed) return;
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:527:15: ( ^( AMPERSAND ( . )* ) )*
loop30:
while (true) {
int alt30=2;
int LA30_0 = input.LA(1);
if ( (LA30_0==AMPERSAND) ) {
alt30=1;
}
switch (alt30) {
case 1 :
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:527:17: ^( AMPERSAND ( . )* )
{
match(input,AMPERSAND,FOLLOW_AMPERSAND_in_ruleScopeSpec548); if (state.failed) return;
if ( input.LA(1)==Token.DOWN ) {
match(input, Token.DOWN, null); if (state.failed) return;
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:527:29: ( . )*
loop29:
while (true) {
int alt29=2;
int LA29_0 = input.LA(1);
if ( ((LA29_0 >= ACTION && LA29_0 <= XDIGIT)) ) {
alt29=1;
}
else if ( (LA29_0==UP) ) {
alt29=2;
}
switch (alt29) {
case 1 :
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:527:29: .
{
matchAny(input); if (state.failed) return;
}
break;
default :
break loop29;
}
}
match(input, Token.UP, null); if (state.failed) return;
}
}
break;
default :
break loop30;
}
}
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:527:36: ( ACTION )?
int alt31=2;
int LA31_0 = input.LA(1);
if ( (LA31_0==ACTION) ) {
alt31=1;
}
switch (alt31) {
case 1 :
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:527:37: ACTION
{
match(input,ACTION,FOLLOW_ACTION_in_ruleScopeSpec558); if (state.failed) return;
}
break;
}
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:527:46: ( ID )*
loop32:
while (true) {
int alt32=2;
int LA32_0 = input.LA(1);
if ( (LA32_0==ID) ) {
alt32=1;
}
switch (alt32) {
case 1 :
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:527:48: ID
{
match(input,ID,FOLLOW_ID_in_ruleScopeSpec564); if (state.failed) return;
}
break;
default :
break loop32;
}
}
match(input, Token.UP, null); if (state.failed) return;
}
}
}
catch (RecognitionException re) {
reportError(re);
recover(input,re);
}
finally {
// do for sure before leaving
}
}
// $ANTLR end "ruleScopeSpec"
public static class block_return extends TreeRuleReturnScope {
public ST code=null;
};
// $ANTLR start "block"
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:530:1: block[String blockTemplateName, org.antlr.analysis.DFA dfa, GrammarAST label] returns [ST code=null] options {k=1; } : ({...}? => setBlock | ^( BLOCK ( ^( OPTIONS ( . )* ) )? (alt= alternative[$label] rew= rewrite )+ EOB ) );
public final CodeGenTreeWalker.block_return block(String blockTemplateName, org.antlr.analysis.DFA dfa, GrammarAST label) throws RecognitionException {
CodeGenTreeWalker.block_return retval = new CodeGenTreeWalker.block_return();
retval.start = input.LT(1);
TreeRuleReturnScope alt =null;
TreeRuleReturnScope rew =null;
TreeRuleReturnScope setBlock1 =null;
int altNum = 0;
blockNestingLevel++;
if ( state.backtracking == 0 )
{
ST decision = null;
if ( dfa != null )
{
retval.code = templates.getInstanceOf(blockTemplateName);
decision = generator.genLookaheadDecision(recognizerST,dfa);
retval.code.add("decision", decision);
retval.code.add("decisionNumber", dfa.getDecisionNumber());
retval.code.add("maxK",dfa.getMaxLookaheadDepth());
retval.code.add("maxAlt",dfa.getNumberOfAlts());
}
else
{
retval.code = templates.getInstanceOf(blockTemplateName+"SingleAlt");
}
retval.code.add("blockLevel", blockNestingLevel);
retval.code.add("enclosingBlockLevel", blockNestingLevel-1);
altNum = 1;
if ( this.blockNestingLevel==RULE_BLOCK_NESTING_LEVEL ) {
this.outerAltNum=1;
}
}
try {
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:562:2: ({...}? => setBlock | ^( BLOCK ( ^( OPTIONS ( . )* ) )? (alt= alternative[$label] rew= rewrite )+ EOB ) )
int alt36=2;
int LA36_0 = input.LA(1);
if ( (LA36_0==BLOCK) ) {
int LA36_1 = input.LA(2);
if ( ((((GrammarAST)retval.start).getSetValue()!=null)) ) {
alt36=1;
}
else if ( (true) ) {
alt36=2;
}
}
else {
if (state.backtracking>0) {state.failed=true; return retval;}
NoViableAltException nvae =
new NoViableAltException("", 36, 0, input);
throw nvae;
}
switch (alt36) {
case 1 :
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:562:4: {...}? => setBlock
{
if ( !((((GrammarAST)retval.start).getSetValue()!=null)) ) {
if (state.backtracking>0) {state.failed=true; return retval;}
throw new FailedPredicateException(input, "block", "$start.getSetValue()!=null");
}
pushFollow(FOLLOW_setBlock_in_block605);
setBlock1=setBlock();
state._fsp--;
if (state.failed) return retval;
if ( state.backtracking==0 ) {
retval.code.add("alts",(setBlock1!=null?((CodeGenTreeWalker.setBlock_return)setBlock1).code:null));
}
}
break;
case 2 :
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:567:4: ^( BLOCK ( ^( OPTIONS ( . )* ) )? (alt= alternative[$label] rew= rewrite )+ EOB )
{
match(input,BLOCK,FOLLOW_BLOCK_in_block618); if (state.failed) return retval;
match(input, Token.DOWN, null); if (state.failed) return retval;
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:568:4: ( ^( OPTIONS ( . )* ) )?
int alt34=2;
int LA34_0 = input.LA(1);
if ( (LA34_0==OPTIONS) ) {
alt34=1;
}
switch (alt34) {
case 1 :
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:568:6: ^( OPTIONS ( . )* )
{
match(input,OPTIONS,FOLLOW_OPTIONS_in_block626); if (state.failed) return retval;
if ( input.LA(1)==Token.DOWN ) {
match(input, Token.DOWN, null); if (state.failed) return retval;
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:568:16: ( . )*
loop33:
while (true) {
int alt33=2;
int LA33_0 = input.LA(1);
if ( ((LA33_0 >= ACTION && LA33_0 <= XDIGIT)) ) {
alt33=1;
}
else if ( (LA33_0==UP) ) {
alt33=2;
}
switch (alt33) {
case 1 :
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:568:16: .
{
matchAny(input); if (state.failed) return retval;
}
break;
default :
break loop33;
}
}
match(input, Token.UP, null); if (state.failed) return retval;
}
}
break;
}
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:569:4: (alt= alternative[$label] rew= rewrite )+
int cnt35=0;
loop35:
while (true) {
int alt35=2;
int LA35_0 = input.LA(1);
if ( (LA35_0==ALT) ) {
alt35=1;
}
switch (alt35) {
case 1 :
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:569:6: alt= alternative[$label] rew= rewrite
{
pushFollow(FOLLOW_alternative_in_block643);
alt=alternative(label);
state._fsp--;
if (state.failed) return retval;
pushFollow(FOLLOW_rewrite_in_block648);
rew=rewrite();
state._fsp--;
if (state.failed) return retval;
if ( state.backtracking==0 ) {
if ( this.blockNestingLevel==RULE_BLOCK_NESTING_LEVEL )
{
this.outerAltNum++;
}
// add the rewrite code as just another element in the alt :)
// (unless it's a " -> ..." rewrite
// ( -> ... )
GrammarAST firstRewriteAST = (rew!=null?((GrammarAST)rew.start):null).findFirstType(REWRITE);
boolean etc =
(rew!=null?((GrammarAST)rew.start):null).getType()==REWRITES &&
firstRewriteAST.getChild(0)!=null &&
firstRewriteAST.getChild(0).getType()==ETC;
if ( (rew!=null?((CodeGenTreeWalker.rewrite_return)rew).code:null)!=null && !etc )
{
(alt!=null?((CodeGenTreeWalker.alternative_return)alt).code:null).add("rew", (rew!=null?((CodeGenTreeWalker.rewrite_return)rew).code:null));
}
// add this alt to the list of alts for this block
retval.code.add("alts",(alt!=null?((CodeGenTreeWalker.alternative_return)alt).code:null));
(alt!=null?((CodeGenTreeWalker.alternative_return)alt).code:null).add("altNum", altNum);
(alt!=null?((CodeGenTreeWalker.alternative_return)alt).code:null).add("outerAlt", blockNestingLevel==RULE_BLOCK_NESTING_LEVEL);
altNum++;
}
}
break;
default :
if ( cnt35 >= 1 ) break loop35;
if (state.backtracking>0) {state.failed=true; return retval;}
EarlyExitException eee = new EarlyExitException(35, input);
throw eee;
}
cnt35++;
}
match(input,EOB,FOLLOW_EOB_in_block665); if (state.failed) return retval;
match(input, Token.UP, null); if (state.failed) return retval;
}
break;
}
}
catch (RecognitionException re) {
reportError(re);
recover(input,re);
}
finally {
// do for sure before leaving
blockNestingLevel--;
}
return retval;
}
// $ANTLR end "block"
public static class setBlock_return extends TreeRuleReturnScope {
public ST code=null;
};
// $ANTLR start "setBlock"
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:599:1: setBlock returns [ST code=null] : ^(s= BLOCK ( . )* ) ;
public final CodeGenTreeWalker.setBlock_return setBlock() throws RecognitionException {
CodeGenTreeWalker.setBlock_return retval = new CodeGenTreeWalker.setBlock_return();
retval.start = input.LT(1);
GrammarAST s=null;
ST setcode = null;
if ( state.backtracking == 0 )
{
if ( blockNestingLevel==RULE_BLOCK_NESTING_LEVEL && grammar.buildAST() )
{
Rule r = grammar.getRule(currentRuleName);
currentAltHasASTRewrite = r.hasRewrite(outerAltNum);
if ( currentAltHasASTRewrite )
{
r.trackTokenReferenceInAlt(((GrammarAST)retval.start), outerAltNum);
}
}
}
try {
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:616:2: ( ^(s= BLOCK ( . )* ) )
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:616:4: ^(s= BLOCK ( . )* )
{
s=(GrammarAST)match(input,BLOCK,FOLLOW_BLOCK_in_setBlock697); if (state.failed) return retval;
if ( input.LA(1)==Token.DOWN ) {
match(input, Token.DOWN, null); if (state.failed) return retval;
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:616:14: ( . )*
loop37:
while (true) {
int alt37=2;
int LA37_0 = input.LA(1);
if ( ((LA37_0 >= ACTION && LA37_0 <= XDIGIT)) ) {
alt37=1;
}
else if ( (LA37_0==UP) ) {
alt37=2;
}
switch (alt37) {
case 1 :
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:616:14: .
{
matchAny(input); if (state.failed) return retval;
}
break;
default :
break loop37;
}
}
match(input, Token.UP, null); if (state.failed) return retval;
}
if ( state.backtracking==0 ) {
int i = ((CommonToken)s.getToken()).getTokenIndex();
if ( blockNestingLevel==RULE_BLOCK_NESTING_LEVEL )
{
setcode = getTokenElementST("matchRuleBlockSet", "set", s, null, null);
}
else
{
setcode = getTokenElementST("matchSet", "set", s, null, null);
}
setcode.add("elementIndex", i);
//if ( grammar.type!=Grammar.LEXER )
//{
// generator.generateLocalFOLLOW(s,"set",currentRuleName,i);
//}
setcode.add("s",
generator.genSetExpr(templates,s.getSetValue(),1,false));
ST altcode=templates.getInstanceOf("alt");
altcode.addAggr("elements.{el,line,pos}",
setcode,
s.getLine(),
s.getCharPositionInLine() + 1
);
altcode.add("altNum", 1);
altcode.add("outerAlt", blockNestingLevel==RULE_BLOCK_NESTING_LEVEL);
if ( !currentAltHasASTRewrite && grammar.buildAST() )
{
altcode.add("autoAST", true);
}
altcode.add("treeLevel", rewriteTreeNestingLevel);
retval.code = altcode;
}
}
}
catch (RecognitionException re) {
reportError(re);
recover(input,re);
}
finally {
// do for sure before leaving
}
return retval;
}
// $ANTLR end "setBlock"
// $ANTLR start "setAlternative"
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:651:1: setAlternative : ^( ALT ( setElement )+ EOA ) ;
public final void setAlternative() throws RecognitionException {
try {
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:652:2: ( ^( ALT ( setElement )+ EOA ) )
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:652:4: ^( ALT ( setElement )+ EOA )
{
match(input,ALT,FOLLOW_ALT_in_setAlternative717); if (state.failed) return;
match(input, Token.DOWN, null); if (state.failed) return;
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:652:10: ( setElement )+
int cnt38=0;
loop38:
while (true) {
int alt38=2;
int LA38_0 = input.LA(1);
if ( ((LA38_0 >= CHAR_LITERAL && LA38_0 <= CHAR_RANGE)||LA38_0==STRING_LITERAL||LA38_0==TOKEN_REF) ) {
alt38=1;
}
switch (alt38) {
case 1 :
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:652:10: setElement
{
pushFollow(FOLLOW_setElement_in_setAlternative719);
setElement();
state._fsp--;
if (state.failed) return;
}
break;
default :
if ( cnt38 >= 1 ) break loop38;
if (state.backtracking>0) {state.failed=true; return;}
EarlyExitException eee = new EarlyExitException(38, input);
throw eee;
}
cnt38++;
}
match(input,EOA,FOLLOW_EOA_in_setAlternative722); if (state.failed) return;
match(input, Token.UP, null); if (state.failed) return;
}
}
catch (RecognitionException re) {
reportError(re);
recover(input,re);
}
finally {
// do for sure before leaving
}
}
// $ANTLR end "setAlternative"
// $ANTLR start "exceptionGroup"
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:655:1: exceptionGroup[ST ruleST] : ( ( exceptionHandler[$ruleST] )+ ( finallyClause[$ruleST] )? | finallyClause[$ruleST] );
public final void exceptionGroup(ST ruleST) throws RecognitionException {
try {
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:656:2: ( ( exceptionHandler[$ruleST] )+ ( finallyClause[$ruleST] )? | finallyClause[$ruleST] )
int alt41=2;
int LA41_0 = input.LA(1);
if ( (LA41_0==CATCH) ) {
alt41=1;
}
else if ( (LA41_0==FINALLY) ) {
alt41=2;
}
else {
if (state.backtracking>0) {state.failed=true; return;}
NoViableAltException nvae =
new NoViableAltException("", 41, 0, input);
throw nvae;
}
switch (alt41) {
case 1 :
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:656:4: ( exceptionHandler[$ruleST] )+ ( finallyClause[$ruleST] )?
{
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:656:4: ( exceptionHandler[$ruleST] )+
int cnt39=0;
loop39:
while (true) {
int alt39=2;
int LA39_0 = input.LA(1);
if ( (LA39_0==CATCH) ) {
alt39=1;
}
switch (alt39) {
case 1 :
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:656:6: exceptionHandler[$ruleST]
{
pushFollow(FOLLOW_exceptionHandler_in_exceptionGroup737);
exceptionHandler(ruleST);
state._fsp--;
if (state.failed) return;
}
break;
default :
if ( cnt39 >= 1 ) break loop39;
if (state.backtracking>0) {state.failed=true; return;}
EarlyExitException eee = new EarlyExitException(39, input);
throw eee;
}
cnt39++;
}
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:656:35: ( finallyClause[$ruleST] )?
int alt40=2;
int LA40_0 = input.LA(1);
if ( (LA40_0==FINALLY) ) {
alt40=1;
}
switch (alt40) {
case 1 :
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:656:36: finallyClause[$ruleST]
{
pushFollow(FOLLOW_finallyClause_in_exceptionGroup744);
finallyClause(ruleST);
state._fsp--;
if (state.failed) return;
}
break;
}
}
break;
case 2 :
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:657:4: finallyClause[$ruleST]
{
pushFollow(FOLLOW_finallyClause_in_exceptionGroup752);
finallyClause(ruleST);
state._fsp--;
if (state.failed) return;
}
break;
}
}
catch (RecognitionException re) {
reportError(re);
recover(input,re);
}
finally {
// do for sure before leaving
}
}
// $ANTLR end "exceptionGroup"
// $ANTLR start "exceptionHandler"
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:660:1: exceptionHandler[ST ruleST] : ^( 'catch' ARG_ACTION ACTION ) ;
public final void exceptionHandler(ST ruleST) throws RecognitionException {
GrammarAST ACTION2=null;
GrammarAST ARG_ACTION3=null;
try {
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:661:2: ( ^( 'catch' ARG_ACTION ACTION ) )
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:661:4: ^( 'catch' ARG_ACTION ACTION )
{
match(input,CATCH,FOLLOW_CATCH_in_exceptionHandler766); if (state.failed) return;
match(input, Token.DOWN, null); if (state.failed) return;
ARG_ACTION3=(GrammarAST)match(input,ARG_ACTION,FOLLOW_ARG_ACTION_in_exceptionHandler768); if (state.failed) return;
ACTION2=(GrammarAST)match(input,ACTION,FOLLOW_ACTION_in_exceptionHandler770); if (state.failed) return;
match(input, Token.UP, null); if (state.failed) return;
if ( state.backtracking==0 ) {
List extends Object> chunks = generator.translateAction(currentRuleName,ACTION2);
ruleST.addAggr("exceptions.{decl,action}",(ARG_ACTION3!=null?ARG_ACTION3.getText():null),chunks);
}
}
}
catch (RecognitionException re) {
reportError(re);
recover(input,re);
}
finally {
// do for sure before leaving
}
}
// $ANTLR end "exceptionHandler"
// $ANTLR start "finallyClause"
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:668:1: finallyClause[ST ruleST] : ^( 'finally' ACTION ) ;
public final void finallyClause(ST ruleST) throws RecognitionException {
GrammarAST ACTION4=null;
try {
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:669:2: ( ^( 'finally' ACTION ) )
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:669:4: ^( 'finally' ACTION )
{
match(input,FINALLY,FOLLOW_FINALLY_in_finallyClause788); if (state.failed) return;
match(input, Token.DOWN, null); if (state.failed) return;
ACTION4=(GrammarAST)match(input,ACTION,FOLLOW_ACTION_in_finallyClause790); if (state.failed) return;
match(input, Token.UP, null); if (state.failed) return;
if ( state.backtracking==0 ) {
List extends Object> chunks = generator.translateAction(currentRuleName,ACTION4);
ruleST.add("finally",chunks);
}
}
}
catch (RecognitionException re) {
reportError(re);
recover(input,re);
}
finally {
// do for sure before leaving
}
}
// $ANTLR end "finallyClause"
public static class alternative_return extends TreeRuleReturnScope {
public ST code;
};
// $ANTLR start "alternative"
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:676:1: alternative[GrammarAST label] returns [ST code] : ^(a= ALT (e= element[$label,null] )+ EOA ) ;
public final CodeGenTreeWalker.alternative_return alternative(GrammarAST label) throws RecognitionException {
CodeGenTreeWalker.alternative_return retval = new CodeGenTreeWalker.alternative_return();
retval.start = input.LT(1);
GrammarAST a=null;
TreeRuleReturnScope e =null;
if ( state.backtracking == 0 )
{
retval.code = templates.getInstanceOf("alt");
if ( blockNestingLevel==RULE_BLOCK_NESTING_LEVEL && grammar.buildAST() )
{
Rule r = grammar.getRule(currentRuleName);
currentAltHasASTRewrite = r.hasRewrite(outerAltNum);
}
String description = grammar.grammarTreeToString(((GrammarAST)retval.start), false);
description = generator.target.getTargetStringLiteralFromString(description);
retval.code.add("description", description);
retval.code.add("treeLevel", rewriteTreeNestingLevel);
if ( !currentAltHasASTRewrite && grammar.buildAST() )
{
retval.code.add("autoAST", true);
}
}
try {
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:697:2: ( ^(a= ALT (e= element[$label,null] )+ EOA ) )
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:697:4: ^(a= ALT (e= element[$label,null] )+ EOA )
{
a=(GrammarAST)match(input,ALT,FOLLOW_ALT_in_alternative820); if (state.failed) return retval;
match(input, Token.DOWN, null); if (state.failed) return retval;
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:698:4: (e= element[$label,null] )+
int cnt42=0;
loop42:
while (true) {
int alt42=2;
int LA42_0 = input.LA(1);
if ( (LA42_0==ACTION||(LA42_0 >= ASSIGN && LA42_0 <= BLOCK)||(LA42_0 >= CHAR_LITERAL && LA42_0 <= CHAR_RANGE)||LA42_0==CLOSURE||LA42_0==DOT||LA42_0==EPSILON||LA42_0==FORCED_ACTION||LA42_0==GATED_SEMPRED||LA42_0==NOT||LA42_0==OPTIONAL||(LA42_0 >= PLUS_ASSIGN && LA42_0 <= POSITIVE_CLOSURE)||LA42_0==ROOT||LA42_0==RULE_REF||LA42_0==SEMPRED||(LA42_0 >= STRING_LITERAL && LA42_0 <= SYN_SEMPRED)||LA42_0==TOKEN_REF||LA42_0==TREE_BEGIN||LA42_0==WILDCARD) ) {
alt42=1;
}
switch (alt42) {
case 1 :
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:699:5: e= element[$label,null]
{
pushFollow(FOLLOW_element_in_alternative833);
e=element(label, null);
state._fsp--;
if (state.failed) return retval;
if ( state.backtracking==0 ) {
if ((e!=null?((CodeGenTreeWalker.element_return)e).code:null) != null)
{
retval.code.addAggr("elements.{el,line,pos}",
(e!=null?((CodeGenTreeWalker.element_return)e).code:null),
(e!=null?((GrammarAST)e.start):null).getLine(),
(e!=null?((GrammarAST)e.start):null).getCharPositionInLine() + 1
);
}
}
}
break;
default :
if ( cnt42 >= 1 ) break loop42;
if (state.backtracking>0) {state.failed=true; return retval;}
EarlyExitException eee = new EarlyExitException(42, input);
throw eee;
}
cnt42++;
}
match(input,EOA,FOLLOW_EOA_in_alternative851); if (state.failed) return retval;
match(input, Token.UP, null); if (state.failed) return retval;
}
}
catch (RecognitionException re) {
reportError(re);
recover(input,re);
}
finally {
// do for sure before leaving
}
return retval;
}
// $ANTLR end "alternative"
public static class element_return extends TreeRuleReturnScope {
public ST code=null;
};
// $ANTLR start "element"
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:715:1: element[GrammarAST label, GrammarAST astSuffix] returns [ST code=null] options {k=1; } : ( ^( ROOT e= element[$label,$ROOT] ) | ^( BANG e= element[$label,$BANG] ) | ^(n= NOT ne= notElement[$n, $label, $astSuffix] ) | ^( ASSIGN alabel= ID e= element[$alabel,$astSuffix] ) | ^( PLUS_ASSIGN label2= ID e= element[$label2,$astSuffix] ) | ^( CHAR_RANGE a= CHAR_LITERAL b= CHAR_LITERAL ) | ({...}? ( BLOCK | OPTIONAL | CLOSURE | POSITIVE_CLOSURE ) )=> ebnf[$label] | atom[null, $label, $astSuffix] | tree_ | element_action | (sp= SEMPRED |sp= GATED_SEMPRED ) | SYN_SEMPRED | ^( SYNPRED ( . )* ) | ^( BACKTRACK_SEMPRED ( . )* ) | EPSILON );
public final CodeGenTreeWalker.element_return element(GrammarAST label, GrammarAST astSuffix) throws RecognitionException {
CodeGenTreeWalker.element_return retval = new CodeGenTreeWalker.element_return();
retval.start = input.LT(1);
GrammarAST n=null;
GrammarAST alabel=null;
GrammarAST label2=null;
GrammarAST a=null;
GrammarAST b=null;
GrammarAST sp=null;
GrammarAST ROOT5=null;
GrammarAST BANG6=null;
TreeRuleReturnScope e =null;
ST ne =null;
TreeRuleReturnScope ebnf7 =null;
TreeRuleReturnScope atom8 =null;
TreeRuleReturnScope tree_9 =null;
TreeRuleReturnScope element_action10 =null;
IntSet elements=null;
GrammarAST ast = null;
try {
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:722:2: ( ^( ROOT e= element[$label,$ROOT] ) | ^( BANG e= element[$label,$BANG] ) | ^(n= NOT ne= notElement[$n, $label, $astSuffix] ) | ^( ASSIGN alabel= ID e= element[$alabel,$astSuffix] ) | ^( PLUS_ASSIGN label2= ID e= element[$label2,$astSuffix] ) | ^( CHAR_RANGE a= CHAR_LITERAL b= CHAR_LITERAL ) | ({...}? ( BLOCK | OPTIONAL | CLOSURE | POSITIVE_CLOSURE ) )=> ebnf[$label] | atom[null, $label, $astSuffix] | tree_ | element_action | (sp= SEMPRED |sp= GATED_SEMPRED ) | SYN_SEMPRED | ^( SYNPRED ( . )* ) | ^( BACKTRACK_SEMPRED ( . )* ) | EPSILON )
int alt46=15;
int LA46_0 = input.LA(1);
if ( (LA46_0==ROOT) ) {
alt46=1;
}
else if ( (LA46_0==BANG) ) {
alt46=2;
}
else if ( (LA46_0==NOT) ) {
alt46=3;
}
else if ( (LA46_0==ASSIGN) ) {
alt46=4;
}
else if ( (LA46_0==PLUS_ASSIGN) ) {
alt46=5;
}
else if ( (LA46_0==CHAR_RANGE) ) {
alt46=6;
}
else if ( (LA46_0==BLOCK) ) {
int LA46_7 = input.LA(2);
if ( (synpred1_CodeGenTreeWalker()) ) {
alt46=7;
}
else if ( (true) ) {
alt46=8;
}
}
else if ( (LA46_0==OPTIONAL) && (synpred1_CodeGenTreeWalker())) {
alt46=7;
}
else if ( (LA46_0==CLOSURE) && (synpred1_CodeGenTreeWalker())) {
alt46=7;
}
else if ( (LA46_0==POSITIVE_CLOSURE) && (synpred1_CodeGenTreeWalker())) {
alt46=7;
}
else if ( (LA46_0==CHAR_LITERAL||LA46_0==DOT||LA46_0==RULE_REF||LA46_0==STRING_LITERAL||LA46_0==TOKEN_REF||LA46_0==WILDCARD) ) {
alt46=8;
}
else if ( (LA46_0==TREE_BEGIN) ) {
alt46=9;
}
else if ( (LA46_0==ACTION||LA46_0==FORCED_ACTION) ) {
alt46=10;
}
else if ( (LA46_0==GATED_SEMPRED||LA46_0==SEMPRED) ) {
alt46=11;
}
else if ( (LA46_0==SYN_SEMPRED) ) {
alt46=12;
}
else if ( (LA46_0==SYNPRED) ) {
alt46=13;
}
else if ( (LA46_0==BACKTRACK_SEMPRED) ) {
alt46=14;
}
else if ( (LA46_0==EPSILON) ) {
alt46=15;
}
else {
if (state.backtracking>0) {state.failed=true; return retval;}
NoViableAltException nvae =
new NoViableAltException("", 46, 0, input);
throw nvae;
}
switch (alt46) {
case 1 :
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:722:4: ^( ROOT e= element[$label,$ROOT] )
{
ROOT5=(GrammarAST)match(input,ROOT,FOLLOW_ROOT_in_element886); if (state.failed) return retval;
match(input, Token.DOWN, null); if (state.failed) return retval;
pushFollow(FOLLOW_element_in_element890);
e=element(label, ROOT5);
state._fsp--;
if (state.failed) return retval;
match(input, Token.UP, null); if (state.failed) return retval;
if ( state.backtracking==0 ) { retval.code = (e!=null?((CodeGenTreeWalker.element_return)e).code:null); }
}
break;
case 2 :
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:725:4: ^( BANG e= element[$label,$BANG] )
{
BANG6=(GrammarAST)match(input,BANG,FOLLOW_BANG_in_element903); if (state.failed) return retval;
match(input, Token.DOWN, null); if (state.failed) return retval;
pushFollow(FOLLOW_element_in_element907);
e=element(label, BANG6);
state._fsp--;
if (state.failed) return retval;
match(input, Token.UP, null); if (state.failed) return retval;
if ( state.backtracking==0 ) { retval.code = (e!=null?((CodeGenTreeWalker.element_return)e).code:null); }
}
break;
case 3 :
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:728:4: ^(n= NOT ne= notElement[$n, $label, $astSuffix] )
{
n=(GrammarAST)match(input,NOT,FOLLOW_NOT_in_element923); if (state.failed) return retval;
match(input, Token.DOWN, null); if (state.failed) return retval;
pushFollow(FOLLOW_notElement_in_element927);
ne=notElement(n, label, astSuffix);
state._fsp--;
if (state.failed) return retval;
match(input, Token.UP, null); if (state.failed) return retval;
if ( state.backtracking==0 ) { retval.code = ne; }
}
break;
case 4 :
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:731:4: ^( ASSIGN alabel= ID e= element[$alabel,$astSuffix] )
{
match(input,ASSIGN,FOLLOW_ASSIGN_in_element942); if (state.failed) return retval;
match(input, Token.DOWN, null); if (state.failed) return retval;
alabel=(GrammarAST)match(input,ID,FOLLOW_ID_in_element946); if (state.failed) return retval;
pushFollow(FOLLOW_element_in_element950);
e=element(alabel, astSuffix);
state._fsp--;
if (state.failed) return retval;
match(input, Token.UP, null); if (state.failed) return retval;
if ( state.backtracking==0 ) { retval.code = (e!=null?((CodeGenTreeWalker.element_return)e).code:null); }
}
break;
case 5 :
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:734:4: ^( PLUS_ASSIGN label2= ID e= element[$label2,$astSuffix] )
{
match(input,PLUS_ASSIGN,FOLLOW_PLUS_ASSIGN_in_element965); if (state.failed) return retval;
match(input, Token.DOWN, null); if (state.failed) return retval;
label2=(GrammarAST)match(input,ID,FOLLOW_ID_in_element969); if (state.failed) return retval;
pushFollow(FOLLOW_element_in_element973);
e=element(label2, astSuffix);
state._fsp--;
if (state.failed) return retval;
match(input, Token.UP, null); if (state.failed) return retval;
if ( state.backtracking==0 ) { retval.code = (e!=null?((CodeGenTreeWalker.element_return)e).code:null); }
}
break;
case 6 :
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:737:4: ^( CHAR_RANGE a= CHAR_LITERAL b= CHAR_LITERAL )
{
match(input,CHAR_RANGE,FOLLOW_CHAR_RANGE_in_element987); if (state.failed) return retval;
match(input, Token.DOWN, null); if (state.failed) return retval;
a=(GrammarAST)match(input,CHAR_LITERAL,FOLLOW_CHAR_LITERAL_in_element991); if (state.failed) return retval;
b=(GrammarAST)match(input,CHAR_LITERAL,FOLLOW_CHAR_LITERAL_in_element995); if (state.failed) return retval;
match(input, Token.UP, null); if (state.failed) return retval;
if ( state.backtracking==0 ) {
retval.code = templates.getInstanceOf("charRangeRef");
String low = generator.target.getTargetCharLiteralFromANTLRCharLiteral(generator,(a!=null?a.getText():null));
String high = generator.target.getTargetCharLiteralFromANTLRCharLiteral(generator,(b!=null?b.getText():null));
retval.code.add("a", low);
retval.code.add("b", high);
if ( label!=null )
{
retval.code.add("label", label.getText());
}
}
}
break;
case 7 :
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:750:4: ({...}? ( BLOCK | OPTIONAL | CLOSURE | POSITIVE_CLOSURE ) )=> ebnf[$label]
{
pushFollow(FOLLOW_ebnf_in_element1024);
ebnf7=ebnf(label);
state._fsp--;
if (state.failed) return retval;
if ( state.backtracking==0 ) { retval.code = (ebnf7!=null?((CodeGenTreeWalker.ebnf_return)ebnf7).code:null); }
}
break;
case 8 :
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:753:4: atom[null, $label, $astSuffix]
{
pushFollow(FOLLOW_atom_in_element1035);
atom8=atom(null, label, astSuffix);
state._fsp--;
if (state.failed) return retval;
if ( state.backtracking==0 ) { retval.code = (atom8!=null?((CodeGenTreeWalker.atom_return)atom8).code:null); }
}
break;
case 9 :
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:756:4: tree_
{
pushFollow(FOLLOW_tree__in_element1046);
tree_9=tree_();
state._fsp--;
if (state.failed) return retval;
if ( state.backtracking==0 ) { retval.code = (tree_9!=null?((CodeGenTreeWalker.tree__return)tree_9).code:null); }
}
break;
case 10 :
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:759:4: element_action
{
pushFollow(FOLLOW_element_action_in_element1056);
element_action10=element_action();
state._fsp--;
if (state.failed) return retval;
if ( state.backtracking==0 ) { retval.code = (element_action10!=null?((CodeGenTreeWalker.element_action_return)element_action10).code:null); }
}
break;
case 11 :
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:762:6: (sp= SEMPRED |sp= GATED_SEMPRED )
{
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:762:6: (sp= SEMPRED |sp= GATED_SEMPRED )
int alt43=2;
int LA43_0 = input.LA(1);
if ( (LA43_0==SEMPRED) ) {
alt43=1;
}
else if ( (LA43_0==GATED_SEMPRED) ) {
alt43=2;
}
else {
if (state.backtracking>0) {state.failed=true; return retval;}
NoViableAltException nvae =
new NoViableAltException("", 43, 0, input);
throw nvae;
}
switch (alt43) {
case 1 :
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:762:7: sp= SEMPRED
{
sp=(GrammarAST)match(input,SEMPRED,FOLLOW_SEMPRED_in_element1071); if (state.failed) return retval;
}
break;
case 2 :
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:762:18: sp= GATED_SEMPRED
{
sp=(GrammarAST)match(input,GATED_SEMPRED,FOLLOW_GATED_SEMPRED_in_element1075); if (state.failed) return retval;
}
break;
}
if ( state.backtracking==0 ) {
retval.code = templates.getInstanceOf("validateSemanticPredicate");
retval.code.add("pred", generator.translateAction(currentRuleName,sp));
String description = generator.target.getTargetStringLiteralFromString((sp!=null?sp.getText():null));
retval.code.add("description", description);
}
}
break;
case 12 :
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:770:4: SYN_SEMPRED
{
match(input,SYN_SEMPRED,FOLLOW_SYN_SEMPRED_in_element1086); if (state.failed) return retval;
}
break;
case 13 :
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:772:4: ^( SYNPRED ( . )* )
{
match(input,SYNPRED,FOLLOW_SYNPRED_in_element1094); if (state.failed) return retval;
if ( input.LA(1)==Token.DOWN ) {
match(input, Token.DOWN, null); if (state.failed) return retval;
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:772:14: ( . )*
loop44:
while (true) {
int alt44=2;
int LA44_0 = input.LA(1);
if ( ((LA44_0 >= ACTION && LA44_0 <= XDIGIT)) ) {
alt44=1;
}
else if ( (LA44_0==UP) ) {
alt44=2;
}
switch (alt44) {
case 1 :
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:772:14: .
{
matchAny(input); if (state.failed) return retval;
}
break;
default :
break loop44;
}
}
match(input, Token.UP, null); if (state.failed) return retval;
}
}
break;
case 14 :
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:774:4: ^( BACKTRACK_SEMPRED ( . )* )
{
match(input,BACKTRACK_SEMPRED,FOLLOW_BACKTRACK_SEMPRED_in_element1105); if (state.failed) return retval;
if ( input.LA(1)==Token.DOWN ) {
match(input, Token.DOWN, null); if (state.failed) return retval;
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:774:24: ( . )*
loop45:
while (true) {
int alt45=2;
int LA45_0 = input.LA(1);
if ( ((LA45_0 >= ACTION && LA45_0 <= XDIGIT)) ) {
alt45=1;
}
else if ( (LA45_0==UP) ) {
alt45=2;
}
switch (alt45) {
case 1 :
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:774:24: .
{
matchAny(input); if (state.failed) return retval;
}
break;
default :
break loop45;
}
}
match(input, Token.UP, null); if (state.failed) return retval;
}
}
break;
case 15 :
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:776:6: EPSILON
{
match(input,EPSILON,FOLLOW_EPSILON_in_element1117); if (state.failed) return retval;
}
break;
}
}
catch (RecognitionException re) {
reportError(re);
recover(input,re);
}
finally {
// do for sure before leaving
}
return retval;
}
// $ANTLR end "element"
public static class element_action_return extends TreeRuleReturnScope {
public ST code=null;
};
// $ANTLR start "element_action"
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:779:1: element_action returns [ST code=null] : (act= ACTION |act2= FORCED_ACTION );
public final CodeGenTreeWalker.element_action_return element_action() throws RecognitionException {
CodeGenTreeWalker.element_action_return retval = new CodeGenTreeWalker.element_action_return();
retval.start = input.LT(1);
GrammarAST act=null;
GrammarAST act2=null;
try {
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:780:2: (act= ACTION |act2= FORCED_ACTION )
int alt47=2;
int LA47_0 = input.LA(1);
if ( (LA47_0==ACTION) ) {
alt47=1;
}
else if ( (LA47_0==FORCED_ACTION) ) {
alt47=2;
}
else {
if (state.backtracking>0) {state.failed=true; return retval;}
NoViableAltException nvae =
new NoViableAltException("", 47, 0, input);
throw nvae;
}
switch (alt47) {
case 1 :
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:780:4: act= ACTION
{
act=(GrammarAST)match(input,ACTION,FOLLOW_ACTION_in_element_action1134); if (state.failed) return retval;
if ( state.backtracking==0 ) {
retval.code = templates.getInstanceOf("execAction");
retval.code.add("action", generator.translateAction(currentRuleName,act));
}
}
break;
case 2 :
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:785:4: act2= FORCED_ACTION
{
act2=(GrammarAST)match(input,FORCED_ACTION,FOLLOW_FORCED_ACTION_in_element_action1145); if (state.failed) return retval;
if ( state.backtracking==0 ) {
retval.code = templates.getInstanceOf("execForcedAction");
retval.code.add("action", generator.translateAction(currentRuleName,act2));
}
}
break;
}
}
catch (RecognitionException re) {
reportError(re);
recover(input,re);
}
finally {
// do for sure before leaving
}
return retval;
}
// $ANTLR end "element_action"
// $ANTLR start "notElement"
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:792:1: notElement[GrammarAST n, GrammarAST label, GrammarAST astSuffix] returns [ST code=null] : (assign_c= CHAR_LITERAL |assign_s= STRING_LITERAL |assign_t= TOKEN_REF | ^(assign_st= BLOCK ( . )* ) ) ;
public final ST notElement(GrammarAST n, GrammarAST label, GrammarAST astSuffix) throws RecognitionException {
ST code = null;
GrammarAST assign_c=null;
GrammarAST assign_s=null;
GrammarAST assign_t=null;
GrammarAST assign_st=null;
IntSet elements=null;
String labelText = null;
if ( label!=null )
{
labelText = label.getText();
}
try {
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:802:2: ( (assign_c= CHAR_LITERAL |assign_s= STRING_LITERAL |assign_t= TOKEN_REF | ^(assign_st= BLOCK ( . )* ) ) )
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:802:4: (assign_c= CHAR_LITERAL |assign_s= STRING_LITERAL |assign_t= TOKEN_REF | ^(assign_st= BLOCK ( . )* ) )
{
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:802:4: (assign_c= CHAR_LITERAL |assign_s= STRING_LITERAL |assign_t= TOKEN_REF | ^(assign_st= BLOCK ( . )* ) )
int alt49=4;
switch ( input.LA(1) ) {
case CHAR_LITERAL:
{
alt49=1;
}
break;
case STRING_LITERAL:
{
alt49=2;
}
break;
case TOKEN_REF:
{
alt49=3;
}
break;
case BLOCK:
{
alt49=4;
}
break;
default:
if (state.backtracking>0) {state.failed=true; return code;}
NoViableAltException nvae =
new NoViableAltException("", 49, 0, input);
throw nvae;
}
switch (alt49) {
case 1 :
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:802:6: assign_c= CHAR_LITERAL
{
assign_c=(GrammarAST)match(input,CHAR_LITERAL,FOLLOW_CHAR_LITERAL_in_notElement1174); if (state.failed) return code;
if ( state.backtracking==0 ) {
int ttype=0;
if ( grammar.type==Grammar.LEXER )
{
ttype = Grammar.getCharValueFromGrammarCharLiteral((assign_c!=null?assign_c.getText():null));
}
else
{
ttype = grammar.getTokenType((assign_c!=null?assign_c.getText():null));
}
elements = grammar.complement(ttype);
}
}
break;
case 2 :
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:815:5: assign_s= STRING_LITERAL
{
assign_s=(GrammarAST)match(input,STRING_LITERAL,FOLLOW_STRING_LITERAL_in_notElement1187); if (state.failed) return code;
if ( state.backtracking==0 ) {
int ttype=0;
if ( grammar.type==Grammar.LEXER )
{
// TODO: error!
}
else
{
ttype = grammar.getTokenType((assign_s!=null?assign_s.getText():null));
}
elements = grammar.complement(ttype);
}
}
break;
case 3 :
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:828:5: assign_t= TOKEN_REF
{
assign_t=(GrammarAST)match(input,TOKEN_REF,FOLLOW_TOKEN_REF_in_notElement1200); if (state.failed) return code;
if ( state.backtracking==0 ) {
int ttype = grammar.getTokenType((assign_t!=null?assign_t.getText():null));
elements = grammar.complement(ttype);
}
}
break;
case 4 :
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:833:5: ^(assign_st= BLOCK ( . )* )
{
assign_st=(GrammarAST)match(input,BLOCK,FOLLOW_BLOCK_in_notElement1214); if (state.failed) return code;
if ( input.LA(1)==Token.DOWN ) {
match(input, Token.DOWN, null); if (state.failed) return code;
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:833:23: ( . )*
loop48:
while (true) {
int alt48=2;
int LA48_0 = input.LA(1);
if ( ((LA48_0 >= ACTION && LA48_0 <= XDIGIT)) ) {
alt48=1;
}
else if ( (LA48_0==UP) ) {
alt48=2;
}
switch (alt48) {
case 1 :
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:833:23: .
{
matchAny(input); if (state.failed) return code;
}
break;
default :
break loop48;
}
}
match(input, Token.UP, null); if (state.failed) return code;
}
if ( state.backtracking==0 ) {
elements = assign_st.getSetValue();
elements = grammar.complement(elements);
}
}
break;
}
if ( state.backtracking==0 ) {
code = getTokenElementST("matchSet",
"set",
(GrammarAST)n.getChild(0),
astSuffix,
labelText);
code.add("s",generator.genSetExpr(templates,elements,1,false));
int i = ((CommonToken)n.getToken()).getTokenIndex();
code.add("elementIndex", i);
if ( grammar.type!=Grammar.LEXER )
{
generator.generateLocalFOLLOW(n,"set",currentRuleName,i);
}
}
}
}
catch (RecognitionException re) {
reportError(re);
recover(input,re);
}
finally {
// do for sure before leaving
}
return code;
}
// $ANTLR end "notElement"
public static class ebnf_return extends TreeRuleReturnScope {
public ST code=null;
};
// $ANTLR start "ebnf"
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:855:1: ebnf[GrammarAST label] returns [ST code=null] : (blk= block[\"block\", dfa, $label] | ^( OPTIONAL blk= block[\"optionalBlock\", dfa, $label] ) | ^( CLOSURE blk= block[\"closureBlock\", dfa, $label] ) | ^( POSITIVE_CLOSURE blk= block[\"positiveClosureBlock\", dfa, $label] ) ) ;
public final CodeGenTreeWalker.ebnf_return ebnf(GrammarAST label) throws RecognitionException {
CodeGenTreeWalker.ebnf_return retval = new CodeGenTreeWalker.ebnf_return();
retval.start = input.LT(1);
TreeRuleReturnScope blk =null;
org.antlr.analysis.DFA dfa=null;
GrammarAST b = (GrammarAST)((GrammarAST)retval.start).getChild(0);
GrammarAST eob = b.getLastChild(); // loops will use EOB DFA
try {
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:862:2: ( (blk= block[\"block\", dfa, $label] | ^( OPTIONAL blk= block[\"optionalBlock\", dfa, $label] ) | ^( CLOSURE blk= block[\"closureBlock\", dfa, $label] ) | ^( POSITIVE_CLOSURE blk= block[\"positiveClosureBlock\", dfa, $label] ) ) )
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:862:4: (blk= block[\"block\", dfa, $label] | ^( OPTIONAL blk= block[\"optionalBlock\", dfa, $label] ) | ^( CLOSURE blk= block[\"closureBlock\", dfa, $label] ) | ^( POSITIVE_CLOSURE blk= block[\"positiveClosureBlock\", dfa, $label] ) )
{
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:862:4: (blk= block[\"block\", dfa, $label] | ^( OPTIONAL blk= block[\"optionalBlock\", dfa, $label] ) | ^( CLOSURE blk= block[\"closureBlock\", dfa, $label] ) | ^( POSITIVE_CLOSURE blk= block[\"positiveClosureBlock\", dfa, $label] ) )
int alt50=4;
switch ( input.LA(1) ) {
case BLOCK:
{
alt50=1;
}
break;
case OPTIONAL:
{
alt50=2;
}
break;
case CLOSURE:
{
alt50=3;
}
break;
case POSITIVE_CLOSURE:
{
alt50=4;
}
break;
default:
if (state.backtracking>0) {state.failed=true; return retval;}
NoViableAltException nvae =
new NoViableAltException("", 50, 0, input);
throw nvae;
}
switch (alt50) {
case 1 :
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:862:6: blk= block[\"block\", dfa, $label]
{
if ( state.backtracking==0 ) { dfa = ((GrammarAST)retval.start).getLookaheadDFA(); }
pushFollow(FOLLOW_block_in_ebnf1261);
blk=block("block", dfa, label);
state._fsp--;
if (state.failed) return retval;
if ( state.backtracking==0 ) { retval.code = (blk!=null?((CodeGenTreeWalker.block_return)blk).code:null); }
}
break;
case 2 :
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:865:5: ^( OPTIONAL blk= block[\"optionalBlock\", dfa, $label] )
{
if ( state.backtracking==0 ) { dfa = ((GrammarAST)retval.start).getLookaheadDFA(); }
match(input,OPTIONAL,FOLLOW_OPTIONAL_in_ebnf1280); if (state.failed) return retval;
match(input, Token.DOWN, null); if (state.failed) return retval;
pushFollow(FOLLOW_block_in_ebnf1284);
blk=block("optionalBlock", dfa, label);
state._fsp--;
if (state.failed) return retval;
match(input, Token.UP, null); if (state.failed) return retval;
if ( state.backtracking==0 ) { retval.code = (blk!=null?((CodeGenTreeWalker.block_return)blk).code:null); }
}
break;
case 3 :
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:868:5: ^( CLOSURE blk= block[\"closureBlock\", dfa, $label] )
{
if ( state.backtracking==0 ) { dfa = eob.getLookaheadDFA(); }
match(input,CLOSURE,FOLLOW_CLOSURE_in_ebnf1305); if (state.failed) return retval;
match(input, Token.DOWN, null); if (state.failed) return retval;
pushFollow(FOLLOW_block_in_ebnf1309);
blk=block("closureBlock", dfa, label);
state._fsp--;
if (state.failed) return retval;
match(input, Token.UP, null); if (state.failed) return retval;
if ( state.backtracking==0 ) { retval.code = (blk!=null?((CodeGenTreeWalker.block_return)blk).code:null); }
}
break;
case 4 :
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:871:5: ^( POSITIVE_CLOSURE blk= block[\"positiveClosureBlock\", dfa, $label] )
{
if ( state.backtracking==0 ) { dfa = eob.getLookaheadDFA(); }
match(input,POSITIVE_CLOSURE,FOLLOW_POSITIVE_CLOSURE_in_ebnf1330); if (state.failed) return retval;
match(input, Token.DOWN, null); if (state.failed) return retval;
pushFollow(FOLLOW_block_in_ebnf1334);
blk=block("positiveClosureBlock", dfa, label);
state._fsp--;
if (state.failed) return retval;
match(input, Token.UP, null); if (state.failed) return retval;
if ( state.backtracking==0 ) { retval.code = (blk!=null?((CodeGenTreeWalker.block_return)blk).code:null); }
}
break;
}
if ( state.backtracking==0 ) {
String description = grammar.grammarTreeToString(((GrammarAST)retval.start), false);
description = generator.target.getTargetStringLiteralFromString(description);
retval.code.add("description", description);
}
}
}
catch (RecognitionException re) {
reportError(re);
recover(input,re);
}
finally {
// do for sure before leaving
}
return retval;
}
// $ANTLR end "ebnf"
public static class tree__return extends TreeRuleReturnScope {
public ST code;
};
// $ANTLR start "tree_"
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:882:1: tree_ returns [ST code] : ^( TREE_BEGIN el= element[null,rootSuffix] ( ( element_action )=>act= element_action )* (el= element[null,null] )* ) ;
public final CodeGenTreeWalker.tree__return tree_() throws RecognitionException {
CodeGenTreeWalker.tree__return retval = new CodeGenTreeWalker.tree__return();
retval.start = input.LT(1);
TreeRuleReturnScope el =null;
TreeRuleReturnScope act =null;
rewriteTreeNestingLevel++;
GrammarAST rootSuffix = null;
if ( state.backtracking == 0 )
{
retval.code = templates.getInstanceOf("tree");
NFAState afterDOWN = (NFAState)((GrammarAST)retval.start).NFATreeDownState.transition(0).target;
LookaheadSet s = grammar.LOOK(afterDOWN);
if ( s.member(Label.UP) ) {
// nullable child list if we can see the UP as the next token
// we need an "if ( input.LA(1)==Token.DOWN )" gate around
// the child list.
retval.code.add("nullableChildList", "true");
}
retval.code.add("enclosingTreeLevel", rewriteTreeNestingLevel-1);
retval.code.add("treeLevel", rewriteTreeNestingLevel);
Rule r = grammar.getRule(currentRuleName);
if ( grammar.buildAST() && !r.hasRewrite(outerAltNum) ) {
rootSuffix = new GrammarAST(ROOT,"ROOT");
}
}
try {
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:906:2: ( ^( TREE_BEGIN el= element[null,rootSuffix] ( ( element_action )=>act= element_action )* (el= element[null,null] )* ) )
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:906:4: ^( TREE_BEGIN el= element[null,rootSuffix] ( ( element_action )=>act= element_action )* (el= element[null,null] )* )
{
match(input,TREE_BEGIN,FOLLOW_TREE_BEGIN_in_tree_1372); if (state.failed) return retval;
match(input, Token.DOWN, null); if (state.failed) return retval;
pushFollow(FOLLOW_element_in_tree_1379);
el=element(null, rootSuffix);
state._fsp--;
if (state.failed) return retval;
if ( state.backtracking==0 ) {
retval.code.addAggr("root.{el,line,pos}",
(el!=null?((CodeGenTreeWalker.element_return)el).code:null),
(el!=null?((GrammarAST)el.start):null).getLine(),
(el!=null?((GrammarAST)el.start):null).getCharPositionInLine() + 1
);
}
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:918:4: ( ( element_action )=>act= element_action )*
loop51:
while (true) {
int alt51=2;
int LA51_0 = input.LA(1);
if ( (LA51_0==ACTION) ) {
int LA51_2 = input.LA(2);
if ( (synpred2_CodeGenTreeWalker()) ) {
alt51=1;
}
}
else if ( (LA51_0==FORCED_ACTION) ) {
int LA51_3 = input.LA(2);
if ( (synpred2_CodeGenTreeWalker()) ) {
alt51=1;
}
}
switch (alt51) {
case 1 :
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:918:6: ( element_action )=>act= element_action
{
pushFollow(FOLLOW_element_action_in_tree_1416);
act=element_action();
state._fsp--;
if (state.failed) return retval;
if ( state.backtracking==0 ) {
retval.code.addAggr("actionsAfterRoot.{el,line,pos}",
(act!=null?((CodeGenTreeWalker.element_action_return)act).code:null),
(act!=null?((GrammarAST)act.start):null).getLine(),
(act!=null?((GrammarAST)act.start):null).getCharPositionInLine() + 1
);
}
}
break;
default :
break loop51;
}
}
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:928:4: (el= element[null,null] )*
loop52:
while (true) {
int alt52=2;
int LA52_0 = input.LA(1);
if ( (LA52_0==ACTION||(LA52_0 >= ASSIGN && LA52_0 <= BLOCK)||(LA52_0 >= CHAR_LITERAL && LA52_0 <= CHAR_RANGE)||LA52_0==CLOSURE||LA52_0==DOT||LA52_0==EPSILON||LA52_0==FORCED_ACTION||LA52_0==GATED_SEMPRED||LA52_0==NOT||LA52_0==OPTIONAL||(LA52_0 >= PLUS_ASSIGN && LA52_0 <= POSITIVE_CLOSURE)||LA52_0==ROOT||LA52_0==RULE_REF||LA52_0==SEMPRED||(LA52_0 >= STRING_LITERAL && LA52_0 <= SYN_SEMPRED)||LA52_0==TOKEN_REF||LA52_0==TREE_BEGIN||LA52_0==WILDCARD) ) {
alt52=1;
}
switch (alt52) {
case 1 :
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:928:7: el= element[null,null]
{
pushFollow(FOLLOW_element_in_tree_1438);
el=element(null, null);
state._fsp--;
if (state.failed) return retval;
if ( state.backtracking==0 ) {
retval.code.addAggr("children.{el,line,pos}",
(el!=null?((CodeGenTreeWalker.element_return)el).code:null),
(el!=null?((GrammarAST)el.start):null).getLine(),
(el!=null?((GrammarAST)el.start):null).getCharPositionInLine() + 1
);
}
}
break;
default :
break loop52;
}
}
match(input, Token.UP, null); if (state.failed) return retval;
}
}
catch (RecognitionException re) {
reportError(re);
recover(input,re);
}
finally {
// do for sure before leaving
rewriteTreeNestingLevel--;
}
return retval;
}
// $ANTLR end "tree_"
public static class atom_return extends TreeRuleReturnScope {
public ST code=null;
};
// $ANTLR start "atom"
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:941:1: atom[GrammarAST scope, GrammarAST label, GrammarAST astSuffix] returns [ST code=null] : ( ^(r= RULE_REF (rarg= ARG_ACTION )? ) | ^(t= TOKEN_REF (targ= ARG_ACTION )? ) |c= CHAR_LITERAL |s= STRING_LITERAL |w= WILDCARD | ^( DOT ID a= atom[$ID, label, astSuffix] ) | set[label,astSuffix] );
public final CodeGenTreeWalker.atom_return atom(GrammarAST scope, GrammarAST label, GrammarAST astSuffix) throws RecognitionException {
CodeGenTreeWalker.atom_return retval = new CodeGenTreeWalker.atom_return();
retval.start = input.LT(1);
GrammarAST r=null;
GrammarAST rarg=null;
GrammarAST t=null;
GrammarAST targ=null;
GrammarAST c=null;
GrammarAST s=null;
GrammarAST w=null;
GrammarAST ID11=null;
TreeRuleReturnScope a =null;
ST set12 =null;
String labelText=null;
if ( state.backtracking == 0 )
{
if ( label!=null )
{
labelText = label.getText();
}
if ( grammar.type!=Grammar.LEXER &&
(((GrammarAST)retval.start).getType()==RULE_REF||((GrammarAST)retval.start).getType()==TOKEN_REF||
((GrammarAST)retval.start).getType()==CHAR_LITERAL||((GrammarAST)retval.start).getType()==STRING_LITERAL) )
{
Rule encRule = grammar.getRule(((GrammarAST)retval.start).enclosingRuleName);
if ( encRule!=null && encRule.hasRewrite(outerAltNum) && astSuffix!=null )
{
ErrorManager.grammarError(ErrorManager.MSG_AST_OP_IN_ALT_WITH_REWRITE,
grammar,
((GrammarAST)retval.start).getToken(),
((GrammarAST)retval.start).enclosingRuleName,
outerAltNum);
astSuffix = null;
}
}
}
try {
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:969:2: ( ^(r= RULE_REF (rarg= ARG_ACTION )? ) | ^(t= TOKEN_REF (targ= ARG_ACTION )? ) |c= CHAR_LITERAL |s= STRING_LITERAL |w= WILDCARD | ^( DOT ID a= atom[$ID, label, astSuffix] ) | set[label,astSuffix] )
int alt55=7;
switch ( input.LA(1) ) {
case RULE_REF:
{
alt55=1;
}
break;
case TOKEN_REF:
{
alt55=2;
}
break;
case CHAR_LITERAL:
{
alt55=3;
}
break;
case STRING_LITERAL:
{
alt55=4;
}
break;
case WILDCARD:
{
alt55=5;
}
break;
case DOT:
{
alt55=6;
}
break;
case BLOCK:
{
alt55=7;
}
break;
default:
if (state.backtracking>0) {state.failed=true; return retval;}
NoViableAltException nvae =
new NoViableAltException("", 55, 0, input);
throw nvae;
}
switch (alt55) {
case 1 :
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:969:6: ^(r= RULE_REF (rarg= ARG_ACTION )? )
{
r=(GrammarAST)match(input,RULE_REF,FOLLOW_RULE_REF_in_atom1488); if (state.failed) return retval;
if ( input.LA(1)==Token.DOWN ) {
match(input, Token.DOWN, null); if (state.failed) return retval;
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:969:20: (rarg= ARG_ACTION )?
int alt53=2;
int LA53_0 = input.LA(1);
if ( (LA53_0==ARG_ACTION) ) {
alt53=1;
}
switch (alt53) {
case 1 :
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:969:21: rarg= ARG_ACTION
{
rarg=(GrammarAST)match(input,ARG_ACTION,FOLLOW_ARG_ACTION_in_atom1493); if (state.failed) return retval;
}
break;
}
match(input, Token.UP, null); if (state.failed) return retval;
}
if ( state.backtracking==0 ) {
grammar.checkRuleReference(scope, r, rarg, currentRuleName);
String scopeName = null;
if ( scope!=null ) {
scopeName = scope.getText();
}
Rule rdef = grammar.getRule(scopeName, (r!=null?r.getText():null));
// don't insert label=r() if label.attr not used, no ret value, ...
if ( !rdef.getHasReturnValue() ) {
labelText = null;
}
retval.code = getRuleElementST("ruleRef", (r!=null?r.getText():null), r, astSuffix, labelText);
retval.code.add("rule", rdef);
if ( scope!=null ) { // scoped rule ref
Grammar scopeG = grammar.composite.getGrammar(scope.getText());
retval.code.add("scope", scopeG);
}
else if ( rdef.grammar != this.grammar ) { // nonlocal
// if rule definition is not in this grammar, it's nonlocal
List rdefDelegates = rdef.grammar.getDelegates();
if ( rdefDelegates.contains(this.grammar) ) {
retval.code.add("scope", rdef.grammar);
}
else {
// defining grammar is not a delegate, scope all the
// back to root, which has delegate methods for all
// rules. Don't use scope if we are root.
if ( this.grammar != rdef.grammar.composite.delegateGrammarTreeRoot.grammar ) {
retval.code.add("scope",
rdef.grammar.composite.delegateGrammarTreeRoot.grammar);
}
}
}
if ( rarg!=null ) {
List extends Object> args = generator.translateAction(currentRuleName,rarg);
retval.code.add("args", args);
}
int i = ((CommonToken)r.getToken()).getTokenIndex();
retval.code.add("elementIndex", i);
generator.generateLocalFOLLOW(r,(r!=null?r.getText():null),currentRuleName,i);
r.code = retval.code;
}
}
break;
case 2 :
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:1014:4: ^(t= TOKEN_REF (targ= ARG_ACTION )? )
{
t=(GrammarAST)match(input,TOKEN_REF,FOLLOW_TOKEN_REF_in_atom1511); if (state.failed) return retval;
if ( input.LA(1)==Token.DOWN ) {
match(input, Token.DOWN, null); if (state.failed) return retval;
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:1014:19: (targ= ARG_ACTION )?
int alt54=2;
int LA54_0 = input.LA(1);
if ( (LA54_0==ARG_ACTION) ) {
alt54=1;
}
switch (alt54) {
case 1 :
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:1014:20: targ= ARG_ACTION
{
targ=(GrammarAST)match(input,ARG_ACTION,FOLLOW_ARG_ACTION_in_atom1516); if (state.failed) return retval;
}
break;
}
match(input, Token.UP, null); if (state.failed) return retval;
}
if ( state.backtracking==0 ) {
if ( currentAltHasASTRewrite && t.terminalOptions!=null &&
t.terminalOptions.get(Grammar.defaultTokenOption)!=null )
{
ErrorManager.grammarError(ErrorManager.MSG_HETERO_ILLEGAL_IN_REWRITE_ALT,
grammar,
t.getToken(),
(t!=null?t.getText():null));
}
grammar.checkRuleReference(scope, t, targ, currentRuleName);
if ( grammar.type==Grammar.LEXER )
{
if ( grammar.getTokenType((t!=null?t.getText():null))==Label.EOF )
{
retval.code = templates.getInstanceOf("lexerMatchEOF");
}
else
{
retval.code = templates.getInstanceOf("lexerRuleRef");
if ( isListLabel(labelText) )
{
retval.code = templates.getInstanceOf("lexerRuleRefAndListLabel");
}
String scopeName = null;
if ( scope!=null )
{
scopeName = scope.getText();
}
Rule rdef2 = grammar.getRule(scopeName, (t!=null?t.getText():null));
retval.code.add("rule", rdef2);
if ( scope!=null )
{ // scoped rule ref
Grammar scopeG = grammar.composite.getGrammar(scope.getText());
retval.code.add("scope", scopeG);
}
else if ( rdef2.grammar != this.grammar )
{ // nonlocal
// if rule definition is not in this grammar, it's nonlocal
retval.code.add("scope", rdef2.grammar);
}
if ( targ!=null )
{
List extends Object> args = generator.translateAction(currentRuleName,targ);
retval.code.add("args", args);
}
}
int i = ((CommonToken)t.getToken()).getTokenIndex();
retval.code.add("elementIndex", i);
if ( label!=null )
retval.code.add("label", labelText);
}
else
{
retval.code = getTokenElementST("tokenRef", (t!=null?t.getText():null), t, astSuffix, labelText);
String tokenLabel =
generator.getTokenTypeAsTargetLabel(grammar.getTokenType(t.getText()));
retval.code.add("token",tokenLabel);
if ( !currentAltHasASTRewrite && t.terminalOptions!=null )
{
retval.code.add("terminalOptions", t.terminalOptions);
}
int i = ((CommonToken)t.getToken()).getTokenIndex();
retval.code.add("elementIndex", i);
generator.generateLocalFOLLOW(t,tokenLabel,currentRuleName,i);
}
t.code = retval.code;
}
}
break;
case 3 :
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:1083:4: c= CHAR_LITERAL
{
c=(GrammarAST)match(input,CHAR_LITERAL,FOLLOW_CHAR_LITERAL_in_atom1532); if (state.failed) return retval;
if ( state.backtracking==0 ) {
if ( grammar.type==Grammar.LEXER )
{
retval.code = templates.getInstanceOf("charRef");
retval.code.add("char",
generator.target.getTargetCharLiteralFromANTLRCharLiteral(generator,(c!=null?c.getText():null)));
if ( label!=null )
{
retval.code.add("label", labelText);
}
}
else { // else it's a token type reference
retval.code = getTokenElementST("tokenRef", "char_literal", c, astSuffix, labelText);
String tokenLabel = generator.getTokenTypeAsTargetLabel(grammar.getTokenType((c!=null?c.getText():null)));
retval.code.add("token",tokenLabel);
if ( c.terminalOptions!=null ) {
retval.code.add("terminalOptions",c.terminalOptions);
}
int i = ((CommonToken)c.getToken()).getTokenIndex();
retval.code.add("elementIndex", i);
generator.generateLocalFOLLOW(c,tokenLabel,currentRuleName,i);
}
}
}
break;
case 4 :
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:1108:4: s= STRING_LITERAL
{
s=(GrammarAST)match(input,STRING_LITERAL,FOLLOW_STRING_LITERAL_in_atom1544); if (state.failed) return retval;
if ( state.backtracking==0 ) {
int i = ((CommonToken)s.getToken()).getTokenIndex();
if ( grammar.type==Grammar.LEXER )
{
retval.code = templates.getInstanceOf("lexerStringRef");
retval.code.add("string",
generator.target.getTargetStringLiteralFromANTLRStringLiteral(generator,(s!=null?s.getText():null)));
retval.code.add("elementIndex", i);
if ( label!=null )
{
retval.code.add("label", labelText);
}
}
else
{
// else it's a token type reference
retval.code = getTokenElementST("tokenRef", "string_literal", s, astSuffix, labelText);
String tokenLabel =
generator.getTokenTypeAsTargetLabel(grammar.getTokenType((s!=null?s.getText():null)));
retval.code.add("token",tokenLabel);
if ( s.terminalOptions!=null )
{
retval.code.add("terminalOptions",s.terminalOptions);
}
retval.code.add("elementIndex", i);
generator.generateLocalFOLLOW(s,tokenLabel,currentRuleName,i);
}
}
}
break;
case 5 :
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:1138:4: w= WILDCARD
{
w=(GrammarAST)match(input,WILDCARD,FOLLOW_WILDCARD_in_atom1556); if (state.failed) return retval;
if ( state.backtracking==0 ) {
retval.code = getWildcardST(w,astSuffix,labelText);
retval.code.add("elementIndex", ((CommonToken)w.getToken()).getTokenIndex());
}
}
break;
case 6 :
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:1144:4: ^( DOT ID a= atom[$ID, label, astSuffix] )
{
match(input,DOT,FOLLOW_DOT_in_atom1567); if (state.failed) return retval;
match(input, Token.DOWN, null); if (state.failed) return retval;
ID11=(GrammarAST)match(input,ID,FOLLOW_ID_in_atom1569); if (state.failed) return retval;
pushFollow(FOLLOW_atom_in_atom1573);
a=atom(ID11, label, astSuffix);
state._fsp--;
if (state.failed) return retval;
match(input, Token.UP, null); if (state.failed) return retval;
if ( state.backtracking==0 ) { retval.code = (a!=null?((CodeGenTreeWalker.atom_return)a).code:null); }
}
break;
case 7 :
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:1147:4: set[label,astSuffix]
{
pushFollow(FOLLOW_set_in_atom1586);
set12=set(label, astSuffix);
state._fsp--;
if (state.failed) return retval;
if ( state.backtracking==0 ) { retval.code = set12; }
}
break;
}
}
catch (RecognitionException re) {
reportError(re);
recover(input,re);
}
finally {
// do for sure before leaving
}
return retval;
}
// $ANTLR end "atom"
// $ANTLR start "ast_suffix"
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:1151:1: ast_suffix : ( ROOT | BANG );
public final void ast_suffix() throws RecognitionException {
try {
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:1152:2: ( ROOT | BANG )
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:
{
if ( input.LA(1)==BANG||input.LA(1)==ROOT ) {
input.consume();
state.errorRecovery=false;
state.failed=false;
}
else {
if (state.backtracking>0) {state.failed=true; return;}
MismatchedSetException mse = new MismatchedSetException(null,input);
throw mse;
}
}
}
catch (RecognitionException re) {
reportError(re);
recover(input,re);
}
finally {
// do for sure before leaving
}
}
// $ANTLR end "ast_suffix"
// $ANTLR start "set"
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:1156:1: set[GrammarAST label, GrammarAST astSuffix] returns [ST code=null] : ^(s= BLOCK ( . )* ) ;
public final ST set(GrammarAST label, GrammarAST astSuffix) throws RecognitionException {
ST code = null;
GrammarAST s=null;
String labelText=null;
if ( label!=null )
{
labelText = label.getText();
}
try {
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:1165:2: ( ^(s= BLOCK ( . )* ) )
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:1165:4: ^(s= BLOCK ( . )* )
{
s=(GrammarAST)match(input,BLOCK,FOLLOW_BLOCK_in_set1631); if (state.failed) return code;
if ( input.LA(1)==Token.DOWN ) {
match(input, Token.DOWN, null); if (state.failed) return code;
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:1165:14: ( . )*
loop56:
while (true) {
int alt56=2;
int LA56_0 = input.LA(1);
if ( ((LA56_0 >= ACTION && LA56_0 <= XDIGIT)) ) {
alt56=1;
}
else if ( (LA56_0==UP) ) {
alt56=2;
}
switch (alt56) {
case 1 :
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:1165:14: .
{
matchAny(input); if (state.failed) return code;
}
break;
default :
break loop56;
}
}
match(input, Token.UP, null); if (state.failed) return code;
}
if ( state.backtracking==0 ) {
code = getTokenElementST("matchSet", "set", s, astSuffix, labelText);
int i = ((CommonToken)s.getToken()).getTokenIndex();
code.add("elementIndex", i);
if ( grammar.type!=Grammar.LEXER )
{
generator.generateLocalFOLLOW(s,"set",currentRuleName,i);
}
code.add("s", generator.genSetExpr(templates,s.getSetValue(),1,false));
}
}
}
catch (RecognitionException re) {
reportError(re);
recover(input,re);
}
finally {
// do for sure before leaving
}
return code;
}
// $ANTLR end "set"
// $ANTLR start "setElement"
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:1178:1: setElement : ( CHAR_LITERAL | TOKEN_REF | STRING_LITERAL | ^( CHAR_RANGE CHAR_LITERAL CHAR_LITERAL ) );
public final void setElement() throws RecognitionException {
try {
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:1179:2: ( CHAR_LITERAL | TOKEN_REF | STRING_LITERAL | ^( CHAR_RANGE CHAR_LITERAL CHAR_LITERAL ) )
int alt57=4;
switch ( input.LA(1) ) {
case CHAR_LITERAL:
{
alt57=1;
}
break;
case TOKEN_REF:
{
alt57=2;
}
break;
case STRING_LITERAL:
{
alt57=3;
}
break;
case CHAR_RANGE:
{
alt57=4;
}
break;
default:
if (state.backtracking>0) {state.failed=true; return;}
NoViableAltException nvae =
new NoViableAltException("", 57, 0, input);
throw nvae;
}
switch (alt57) {
case 1 :
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:1179:4: CHAR_LITERAL
{
match(input,CHAR_LITERAL,FOLLOW_CHAR_LITERAL_in_setElement1651); if (state.failed) return;
}
break;
case 2 :
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:1180:4: TOKEN_REF
{
match(input,TOKEN_REF,FOLLOW_TOKEN_REF_in_setElement1656); if (state.failed) return;
}
break;
case 3 :
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:1181:4: STRING_LITERAL
{
match(input,STRING_LITERAL,FOLLOW_STRING_LITERAL_in_setElement1661); if (state.failed) return;
}
break;
case 4 :
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:1182:4: ^( CHAR_RANGE CHAR_LITERAL CHAR_LITERAL )
{
match(input,CHAR_RANGE,FOLLOW_CHAR_RANGE_in_setElement1667); if (state.failed) return;
match(input, Token.DOWN, null); if (state.failed) return;
match(input,CHAR_LITERAL,FOLLOW_CHAR_LITERAL_in_setElement1669); if (state.failed) return;
match(input,CHAR_LITERAL,FOLLOW_CHAR_LITERAL_in_setElement1671); if (state.failed) return;
match(input, Token.UP, null); if (state.failed) return;
}
break;
}
}
catch (RecognitionException re) {
reportError(re);
recover(input,re);
}
finally {
// do for sure before leaving
}
}
// $ANTLR end "setElement"
public static class rewrite_return extends TreeRuleReturnScope {
public ST code=null;
};
// $ANTLR start "rewrite"
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:1187:1: rewrite returns [ST code=null] : ( ^( REWRITES ( ^(r= REWRITE (pred= SEMPRED )? alt= rewrite_alternative ) )* ) |);
public final CodeGenTreeWalker.rewrite_return rewrite() throws RecognitionException {
CodeGenTreeWalker.rewrite_return retval = new CodeGenTreeWalker.rewrite_return();
retval.start = input.LT(1);
GrammarAST r=null;
GrammarAST pred=null;
ST alt =null;
if ( state.backtracking == 0 )
{
if ( ((GrammarAST)retval.start).getType()==REWRITES )
{
if ( generator.grammar.buildTemplate() )
{
retval.code = templates.getInstanceOf("rewriteTemplate");
}
else
{
retval.code = templates.getInstanceOf("rewriteCode");
retval.code.add("treeLevel", OUTER_REWRITE_NESTING_LEVEL);
retval.code.add("rewriteBlockLevel", OUTER_REWRITE_NESTING_LEVEL);
retval.code.add("referencedElementsDeep",
getTokenTypesAsTargetLabels(((GrammarAST)retval.start).rewriteRefsDeep));
Set tokenLabels =
grammar.getLabels(((GrammarAST)retval.start).rewriteRefsDeep, Grammar.TOKEN_LABEL);
Set tokenListLabels =
grammar.getLabels(((GrammarAST)retval.start).rewriteRefsDeep, Grammar.TOKEN_LIST_LABEL);
Set ruleLabels =
grammar.getLabels(((GrammarAST)retval.start).rewriteRefsDeep, Grammar.RULE_LABEL);
Set ruleListLabels =
grammar.getLabels(((GrammarAST)retval.start).rewriteRefsDeep, Grammar.RULE_LIST_LABEL);
Set wildcardLabels =
grammar.getLabels(((GrammarAST)retval.start).rewriteRefsDeep, Grammar.WILDCARD_TREE_LABEL);
Set wildcardListLabels =
grammar.getLabels(((GrammarAST)retval.start).rewriteRefsDeep, Grammar.WILDCARD_TREE_LIST_LABEL);
// just in case they ref r for "previous value", make a stream
// from retval.tree
ST retvalST = templates.getInstanceOf("prevRuleRootRef");
ruleLabels.add(retvalST.render());
retval.code.add("referencedTokenLabels", tokenLabels);
retval.code.add("referencedTokenListLabels", tokenListLabels);
retval.code.add("referencedRuleLabels", ruleLabels);
retval.code.add("referencedRuleListLabels", ruleListLabels);
retval.code.add("referencedWildcardLabels", wildcardLabels);
retval.code.add("referencedWildcardListLabels", wildcardListLabels);
}
}
else
{
retval.code = templates.getInstanceOf("noRewrite");
retval.code.add("treeLevel", OUTER_REWRITE_NESTING_LEVEL);
retval.code.add("rewriteBlockLevel", OUTER_REWRITE_NESTING_LEVEL);
}
}
try {
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:1237:2: ( ^( REWRITES ( ^(r= REWRITE (pred= SEMPRED )? alt= rewrite_alternative ) )* ) |)
int alt60=2;
int LA60_0 = input.LA(1);
if ( (LA60_0==REWRITES) ) {
alt60=1;
}
else if ( (LA60_0==ALT||LA60_0==EOB) ) {
alt60=2;
}
else {
if (state.backtracking>0) {state.failed=true; return retval;}
NoViableAltException nvae =
new NoViableAltException("", 60, 0, input);
throw nvae;
}
switch (alt60) {
case 1 :
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:1237:4: ^( REWRITES ( ^(r= REWRITE (pred= SEMPRED )? alt= rewrite_alternative ) )* )
{
match(input,REWRITES,FOLLOW_REWRITES_in_rewrite1696); if (state.failed) return retval;
if ( input.LA(1)==Token.DOWN ) {
match(input, Token.DOWN, null); if (state.failed) return retval;
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:1238:4: ( ^(r= REWRITE (pred= SEMPRED )? alt= rewrite_alternative ) )*
loop59:
while (true) {
int alt59=2;
int LA59_0 = input.LA(1);
if ( (LA59_0==REWRITE) ) {
alt59=1;
}
switch (alt59) {
case 1 :
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:1239:5: ^(r= REWRITE (pred= SEMPRED )? alt= rewrite_alternative )
{
if ( state.backtracking==0 ) {rewriteRuleRefs = new HashSet();}
r=(GrammarAST)match(input,REWRITE,FOLLOW_REWRITE_in_rewrite1717); if (state.failed) return retval;
match(input, Token.DOWN, null); if (state.failed) return retval;
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:1240:18: (pred= SEMPRED )?
int alt58=2;
int LA58_0 = input.LA(1);
if ( (LA58_0==SEMPRED) ) {
alt58=1;
}
switch (alt58) {
case 1 :
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:1240:19: pred= SEMPRED
{
pred=(GrammarAST)match(input,SEMPRED,FOLLOW_SEMPRED_in_rewrite1722); if (state.failed) return retval;
}
break;
}
pushFollow(FOLLOW_rewrite_alternative_in_rewrite1728);
alt=rewrite_alternative();
state._fsp--;
if (state.failed) return retval;
match(input, Token.UP, null); if (state.failed) return retval;
if ( state.backtracking==0 ) {
rewriteBlockNestingLevel = OUTER_REWRITE_NESTING_LEVEL;
List extends Object> predChunks = null;
if ( pred!=null )
{
//predText = #pred.getText();
predChunks = generator.translateAction(currentRuleName,pred);
}
String description =
grammar.grammarTreeToString(r,false);
description = generator.target.getTargetStringLiteralFromString(description);
retval.code.addAggr("alts.{pred,alt,description}",
predChunks,
alt,
description);
pred=null;
}
}
break;
default :
break loop59;
}
}
match(input, Token.UP, null); if (state.failed) return retval;
}
}
break;
case 2 :
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:1261:2:
{
}
break;
}
}
catch (RecognitionException re) {
reportError(re);
recover(input,re);
}
finally {
// do for sure before leaving
}
return retval;
}
// $ANTLR end "rewrite"
// $ANTLR start "rewrite_block"
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:1263:1: rewrite_block[String blockTemplateName] returns [ST code=null] : ^( BLOCK alt= rewrite_alternative EOB ) ;
public final ST rewrite_block(String blockTemplateName) throws RecognitionException {
ST code = null;
GrammarAST BLOCK13=null;
ST alt =null;
rewriteBlockNestingLevel++;
ST save_currentBlockST = currentBlockST;
if ( state.backtracking == 0 )
{
code = templates.getInstanceOf(blockTemplateName);
currentBlockST = code;
code.add("rewriteBlockLevel", rewriteBlockNestingLevel);
}
try {
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:1275:2: ( ^( BLOCK alt= rewrite_alternative EOB ) )
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:1275:4: ^( BLOCK alt= rewrite_alternative EOB )
{
BLOCK13=(GrammarAST)match(input,BLOCK,FOLLOW_BLOCK_in_rewrite_block1771); if (state.failed) return code;
if ( state.backtracking==0 ) {
currentBlockST.add("referencedElementsDeep",
getTokenTypesAsTargetLabels(BLOCK13.rewriteRefsDeep));
currentBlockST.add("referencedElements",
getTokenTypesAsTargetLabels(BLOCK13.rewriteRefsShallow));
}
match(input, Token.DOWN, null); if (state.failed) return code;
pushFollow(FOLLOW_rewrite_alternative_in_rewrite_block1783);
alt=rewrite_alternative();
state._fsp--;
if (state.failed) return code;
match(input,EOB,FOLLOW_EOB_in_rewrite_block1788); if (state.failed) return code;
match(input, Token.UP, null); if (state.failed) return code;
if ( state.backtracking==0 ) {
code.add("alt", alt);
}
}
}
catch (RecognitionException re) {
reportError(re);
recover(input,re);
}
finally {
// do for sure before leaving
rewriteBlockNestingLevel--; currentBlockST = save_currentBlockST;
}
return code;
}
// $ANTLR end "rewrite_block"
// $ANTLR start "rewrite_alternative"
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:1291:1: rewrite_alternative returns [ST code=null] : ({...}? ^(a= ALT ( (el= rewrite_element )+ | EPSILON ) EOA ) |{...}? rewrite_template | ETC );
public final ST rewrite_alternative() throws RecognitionException {
ST code = null;
GrammarAST a=null;
TreeRuleReturnScope el =null;
ST rewrite_template14 =null;
try {
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:1292:2: ({...}? ^(a= ALT ( (el= rewrite_element )+ | EPSILON ) EOA ) |{...}? rewrite_template | ETC )
int alt63=3;
switch ( input.LA(1) ) {
case ALT:
{
int LA63_1 = input.LA(2);
if ( (LA63_1==DOWN) ) {
int LA63_4 = input.LA(3);
if ( (LA63_4==EPSILON) ) {
int LA63_5 = input.LA(4);
if ( (LA63_5==EOA) ) {
int LA63_7 = input.LA(5);
if ( (LA63_7==UP) ) {
int LA63_8 = input.LA(6);
if ( ((generator.grammar.buildAST())) ) {
alt63=1;
}
else if ( ((generator.grammar.buildTemplate())) ) {
alt63=2;
}
else {
if (state.backtracking>0) {state.failed=true; return code;}
int nvaeMark = input.mark();
try {
for (int nvaeConsume = 0; nvaeConsume < 6 - 1; nvaeConsume++) {
input.consume();
}
NoViableAltException nvae =
new NoViableAltException("", 63, 8, input);
throw nvae;
} finally {
input.rewind(nvaeMark);
}
}
}
else {
if (state.backtracking>0) {state.failed=true; return code;}
int nvaeMark = input.mark();
try {
for (int nvaeConsume = 0; nvaeConsume < 5 - 1; nvaeConsume++) {
input.consume();
}
NoViableAltException nvae =
new NoViableAltException("", 63, 7, input);
throw nvae;
} finally {
input.rewind(nvaeMark);
}
}
}
else {
if (state.backtracking>0) {state.failed=true; return code;}
int nvaeMark = input.mark();
try {
for (int nvaeConsume = 0; nvaeConsume < 4 - 1; nvaeConsume++) {
input.consume();
}
NoViableAltException nvae =
new NoViableAltException("", 63, 5, input);
throw nvae;
} finally {
input.rewind(nvaeMark);
}
}
}
else if ( (LA63_4==ACTION||LA63_4==CHAR_LITERAL||LA63_4==CLOSURE||LA63_4==LABEL||LA63_4==OPTIONAL||LA63_4==POSITIVE_CLOSURE||LA63_4==RULE_REF||LA63_4==STRING_LITERAL||LA63_4==TOKEN_REF||LA63_4==TREE_BEGIN) ) {
alt63=1;
}
else {
if (state.backtracking>0) {state.failed=true; return code;}
int nvaeMark = input.mark();
try {
for (int nvaeConsume = 0; nvaeConsume < 3 - 1; nvaeConsume++) {
input.consume();
}
NoViableAltException nvae =
new NoViableAltException("", 63, 4, input);
throw nvae;
} finally {
input.rewind(nvaeMark);
}
}
}
else {
if (state.backtracking>0) {state.failed=true; return code;}
int nvaeMark = input.mark();
try {
input.consume();
NoViableAltException nvae =
new NoViableAltException("", 63, 1, input);
throw nvae;
} finally {
input.rewind(nvaeMark);
}
}
}
break;
case ACTION:
case TEMPLATE:
{
alt63=2;
}
break;
case ETC:
{
alt63=3;
}
break;
default:
if (state.backtracking>0) {state.failed=true; return code;}
NoViableAltException nvae =
new NoViableAltException("", 63, 0, input);
throw nvae;
}
switch (alt63) {
case 1 :
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:1292:4: {...}? ^(a= ALT ( (el= rewrite_element )+ | EPSILON ) EOA )
{
if ( !((generator.grammar.buildAST())) ) {
if (state.backtracking>0) {state.failed=true; return code;}
throw new FailedPredicateException(input, "rewrite_alternative", "generator.grammar.buildAST()");
}
a=(GrammarAST)match(input,ALT,FOLLOW_ALT_in_rewrite_alternative1823); if (state.failed) return code;
if ( state.backtracking==0 ) {code =templates.getInstanceOf("rewriteElementList");}
match(input, Token.DOWN, null); if (state.failed) return code;
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:1294:4: ( (el= rewrite_element )+ | EPSILON )
int alt62=2;
int LA62_0 = input.LA(1);
if ( (LA62_0==ACTION||LA62_0==CHAR_LITERAL||LA62_0==CLOSURE||LA62_0==LABEL||LA62_0==OPTIONAL||LA62_0==POSITIVE_CLOSURE||LA62_0==RULE_REF||LA62_0==STRING_LITERAL||LA62_0==TOKEN_REF||LA62_0==TREE_BEGIN) ) {
alt62=1;
}
else if ( (LA62_0==EPSILON) ) {
alt62=2;
}
else {
if (state.backtracking>0) {state.failed=true; return code;}
NoViableAltException nvae =
new NoViableAltException("", 62, 0, input);
throw nvae;
}
switch (alt62) {
case 1 :
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:1294:6: (el= rewrite_element )+
{
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:1294:6: (el= rewrite_element )+
int cnt61=0;
loop61:
while (true) {
int alt61=2;
int LA61_0 = input.LA(1);
if ( (LA61_0==ACTION||LA61_0==CHAR_LITERAL||LA61_0==CLOSURE||LA61_0==LABEL||LA61_0==OPTIONAL||LA61_0==POSITIVE_CLOSURE||LA61_0==RULE_REF||LA61_0==STRING_LITERAL||LA61_0==TOKEN_REF||LA61_0==TREE_BEGIN) ) {
alt61=1;
}
switch (alt61) {
case 1 :
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:1295:6: el= rewrite_element
{
pushFollow(FOLLOW_rewrite_element_in_rewrite_alternative1841);
el=rewrite_element();
state._fsp--;
if (state.failed) return code;
if ( state.backtracking==0 ) {code.addAggr("elements.{el,line,pos}",
(el!=null?((CodeGenTreeWalker.rewrite_element_return)el).code:null),
(el!=null?((GrammarAST)el.start):null).getLine(),
(el!=null?((GrammarAST)el.start):null).getCharPositionInLine() + 1
);
}
}
break;
default :
if ( cnt61 >= 1 ) break loop61;
if (state.backtracking>0) {state.failed=true; return code;}
EarlyExitException eee = new EarlyExitException(61, input);
throw eee;
}
cnt61++;
}
}
break;
case 2 :
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:1303:6: EPSILON
{
match(input,EPSILON,FOLLOW_EPSILON_in_rewrite_alternative1862); if (state.failed) return code;
if ( state.backtracking==0 ) {code.addAggr("elements.{el,line,pos}",
templates.getInstanceOf("rewriteEmptyAlt"),
a.getLine(),
a.getCharPositionInLine() + 1
);
}
}
break;
}
match(input,EOA,FOLLOW_EOA_in_rewrite_alternative1878); if (state.failed) return code;
match(input, Token.UP, null); if (state.failed) return code;
}
break;
case 2 :
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:1314:4: {...}? rewrite_template
{
if ( !((generator.grammar.buildTemplate())) ) {
if (state.backtracking>0) {state.failed=true; return code;}
throw new FailedPredicateException(input, "rewrite_alternative", "generator.grammar.buildTemplate()");
}
pushFollow(FOLLOW_rewrite_template_in_rewrite_alternative1891);
rewrite_template14=rewrite_template();
state._fsp--;
if (state.failed) return code;
if ( state.backtracking==0 ) { code = rewrite_template14; }
}
break;
case 3 :
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:1318:3: ETC
{
match(input,ETC,FOLLOW_ETC_in_rewrite_alternative1904); if (state.failed) return code;
}
break;
}
}
catch (RecognitionException re) {
reportError(re);
recover(input,re);
}
finally {
// do for sure before leaving
}
return code;
}
// $ANTLR end "rewrite_alternative"
public static class rewrite_element_return extends TreeRuleReturnScope {
public ST code=null;
};
// $ANTLR start "rewrite_element"
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:1321:1: rewrite_element returns [ST code=null] : ( rewrite_atom[false] | rewrite_ebnf | rewrite_tree );
public final CodeGenTreeWalker.rewrite_element_return rewrite_element() throws RecognitionException {
CodeGenTreeWalker.rewrite_element_return retval = new CodeGenTreeWalker.rewrite_element_return();
retval.start = input.LT(1);
TreeRuleReturnScope rewrite_atom15 =null;
TreeRuleReturnScope rewrite_ebnf16 =null;
TreeRuleReturnScope rewrite_tree17 =null;
IntSet elements=null;
GrammarAST ast = null;
try {
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:1327:2: ( rewrite_atom[false] | rewrite_ebnf | rewrite_tree )
int alt64=3;
switch ( input.LA(1) ) {
case ACTION:
case CHAR_LITERAL:
case LABEL:
case RULE_REF:
case STRING_LITERAL:
case TOKEN_REF:
{
alt64=1;
}
break;
case CLOSURE:
case OPTIONAL:
case POSITIVE_CLOSURE:
{
alt64=2;
}
break;
case TREE_BEGIN:
{
alt64=3;
}
break;
default:
if (state.backtracking>0) {state.failed=true; return retval;}
NoViableAltException nvae =
new NoViableAltException("", 64, 0, input);
throw nvae;
}
switch (alt64) {
case 1 :
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:1327:4: rewrite_atom[false]
{
pushFollow(FOLLOW_rewrite_atom_in_rewrite_element1924);
rewrite_atom15=rewrite_atom(false);
state._fsp--;
if (state.failed) return retval;
if ( state.backtracking==0 ) { retval.code = (rewrite_atom15!=null?((CodeGenTreeWalker.rewrite_atom_return)rewrite_atom15).code:null); }
}
break;
case 2 :
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:1329:4: rewrite_ebnf
{
pushFollow(FOLLOW_rewrite_ebnf_in_rewrite_element1934);
rewrite_ebnf16=rewrite_ebnf();
state._fsp--;
if (state.failed) return retval;
if ( state.backtracking==0 ) { retval.code = (rewrite_ebnf16!=null?((CodeGenTreeWalker.rewrite_ebnf_return)rewrite_ebnf16).code:null); }
}
break;
case 3 :
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:1331:4: rewrite_tree
{
pushFollow(FOLLOW_rewrite_tree_in_rewrite_element1943);
rewrite_tree17=rewrite_tree();
state._fsp--;
if (state.failed) return retval;
if ( state.backtracking==0 ) { retval.code = (rewrite_tree17!=null?((CodeGenTreeWalker.rewrite_tree_return)rewrite_tree17).code:null); }
}
break;
}
}
catch (RecognitionException re) {
reportError(re);
recover(input,re);
}
finally {
// do for sure before leaving
}
return retval;
}
// $ANTLR end "rewrite_element"
public static class rewrite_ebnf_return extends TreeRuleReturnScope {
public ST code=null;
};
// $ANTLR start "rewrite_ebnf"
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:1335:1: rewrite_ebnf returns [ST code=null] : ( ^( OPTIONAL rewrite_block[\"rewriteOptionalBlock\"] ) | ^( CLOSURE rewrite_block[\"rewriteClosureBlock\"] ) | ^( POSITIVE_CLOSURE rewrite_block[\"rewritePositiveClosureBlock\"] ) );
public final CodeGenTreeWalker.rewrite_ebnf_return rewrite_ebnf() throws RecognitionException {
CodeGenTreeWalker.rewrite_ebnf_return retval = new CodeGenTreeWalker.rewrite_ebnf_return();
retval.start = input.LT(1);
ST rewrite_block18 =null;
ST rewrite_block19 =null;
ST rewrite_block20 =null;
try {
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:1336:2: ( ^( OPTIONAL rewrite_block[\"rewriteOptionalBlock\"] ) | ^( CLOSURE rewrite_block[\"rewriteClosureBlock\"] ) | ^( POSITIVE_CLOSURE rewrite_block[\"rewritePositiveClosureBlock\"] ) )
int alt65=3;
switch ( input.LA(1) ) {
case OPTIONAL:
{
alt65=1;
}
break;
case CLOSURE:
{
alt65=2;
}
break;
case POSITIVE_CLOSURE:
{
alt65=3;
}
break;
default:
if (state.backtracking>0) {state.failed=true; return retval;}
NoViableAltException nvae =
new NoViableAltException("", 65, 0, input);
throw nvae;
}
switch (alt65) {
case 1 :
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:1336:4: ^( OPTIONAL rewrite_block[\"rewriteOptionalBlock\"] )
{
match(input,OPTIONAL,FOLLOW_OPTIONAL_in_rewrite_ebnf1964); if (state.failed) return retval;
match(input, Token.DOWN, null); if (state.failed) return retval;
pushFollow(FOLLOW_rewrite_block_in_rewrite_ebnf1966);
rewrite_block18=rewrite_block("rewriteOptionalBlock");
state._fsp--;
if (state.failed) return retval;
match(input, Token.UP, null); if (state.failed) return retval;
if ( state.backtracking==0 ) { retval.code = rewrite_block18; }
if ( state.backtracking==0 ) {
String description = grammar.grammarTreeToString(((GrammarAST)retval.start), false);
description = generator.target.getTargetStringLiteralFromString(description);
retval.code.add("description", description);
}
}
break;
case 2 :
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:1343:4: ^( CLOSURE rewrite_block[\"rewriteClosureBlock\"] )
{
match(input,CLOSURE,FOLLOW_CLOSURE_in_rewrite_ebnf1984); if (state.failed) return retval;
match(input, Token.DOWN, null); if (state.failed) return retval;
pushFollow(FOLLOW_rewrite_block_in_rewrite_ebnf1986);
rewrite_block19=rewrite_block("rewriteClosureBlock");
state._fsp--;
if (state.failed) return retval;
match(input, Token.UP, null); if (state.failed) return retval;
if ( state.backtracking==0 ) { retval.code = rewrite_block19; }
if ( state.backtracking==0 ) {
String description = grammar.grammarTreeToString(((GrammarAST)retval.start), false);
description = generator.target.getTargetStringLiteralFromString(description);
retval.code.add("description", description);
}
}
break;
case 3 :
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:1350:4: ^( POSITIVE_CLOSURE rewrite_block[\"rewritePositiveClosureBlock\"] )
{
match(input,POSITIVE_CLOSURE,FOLLOW_POSITIVE_CLOSURE_in_rewrite_ebnf2004); if (state.failed) return retval;
match(input, Token.DOWN, null); if (state.failed) return retval;
pushFollow(FOLLOW_rewrite_block_in_rewrite_ebnf2006);
rewrite_block20=rewrite_block("rewritePositiveClosureBlock");
state._fsp--;
if (state.failed) return retval;
match(input, Token.UP, null); if (state.failed) return retval;
if ( state.backtracking==0 ) { retval.code = rewrite_block20; }
if ( state.backtracking==0 ) {
String description = grammar.grammarTreeToString(((GrammarAST)retval.start), false);
description = generator.target.getTargetStringLiteralFromString(description);
retval.code.add("description", description);
}
}
break;
}
}
catch (RecognitionException re) {
reportError(re);
recover(input,re);
}
finally {
// do for sure before leaving
}
return retval;
}
// $ANTLR end "rewrite_ebnf"
public static class rewrite_tree_return extends TreeRuleReturnScope {
public ST code;
};
// $ANTLR start "rewrite_tree"
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:1359:1: rewrite_tree returns [ST code] : ^( TREE_BEGIN r= rewrite_atom[true] (el= rewrite_element )* ) ;
public final CodeGenTreeWalker.rewrite_tree_return rewrite_tree() throws RecognitionException {
CodeGenTreeWalker.rewrite_tree_return retval = new CodeGenTreeWalker.rewrite_tree_return();
retval.start = input.LT(1);
TreeRuleReturnScope r =null;
TreeRuleReturnScope el =null;
rewriteTreeNestingLevel++;
if ( state.backtracking == 0 )
{
retval.code = templates.getInstanceOf("rewriteTree");
retval.code.add("treeLevel", rewriteTreeNestingLevel);
retval.code.add("enclosingTreeLevel", rewriteTreeNestingLevel-1);
}
try {
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:1370:2: ( ^( TREE_BEGIN r= rewrite_atom[true] (el= rewrite_element )* ) )
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:1370:4: ^( TREE_BEGIN r= rewrite_atom[true] (el= rewrite_element )* )
{
match(input,TREE_BEGIN,FOLLOW_TREE_BEGIN_in_rewrite_tree2039); if (state.failed) return retval;
match(input, Token.DOWN, null); if (state.failed) return retval;
pushFollow(FOLLOW_rewrite_atom_in_rewrite_tree2046);
r=rewrite_atom(true);
state._fsp--;
if (state.failed) return retval;
if ( state.backtracking==0 ) {
retval.code.addAggr("root.{el,line,pos}",
(r!=null?((CodeGenTreeWalker.rewrite_atom_return)r).code:null),
(r!=null?((GrammarAST)r.start):null).getLine(),
(r!=null?((GrammarAST)r.start):null).getCharPositionInLine() + 1
);
}
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:1379:4: (el= rewrite_element )*
loop66:
while (true) {
int alt66=2;
int LA66_0 = input.LA(1);
if ( (LA66_0==ACTION||LA66_0==CHAR_LITERAL||LA66_0==CLOSURE||LA66_0==LABEL||LA66_0==OPTIONAL||LA66_0==POSITIVE_CLOSURE||LA66_0==RULE_REF||LA66_0==STRING_LITERAL||LA66_0==TOKEN_REF||LA66_0==TREE_BEGIN) ) {
alt66=1;
}
switch (alt66) {
case 1 :
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:1380:6: el= rewrite_element
{
pushFollow(FOLLOW_rewrite_element_in_rewrite_tree2066);
el=rewrite_element();
state._fsp--;
if (state.failed) return retval;
if ( state.backtracking==0 ) {
retval.code.addAggr("children.{el,line,pos}",
(el!=null?((CodeGenTreeWalker.rewrite_element_return)el).code:null),
(el!=null?((GrammarAST)el.start):null).getLine(),
(el!=null?((GrammarAST)el.start):null).getCharPositionInLine() + 1
);
}
}
break;
default :
break loop66;
}
}
match(input, Token.UP, null); if (state.failed) return retval;
if ( state.backtracking==0 ) {
String description = grammar.grammarTreeToString(((GrammarAST)retval.start), false);
description = generator.target.getTargetStringLiteralFromString(description);
retval.code.add("description", description);
}
}
}
catch (RecognitionException re) {
reportError(re);
recover(input,re);
}
finally {
// do for sure before leaving
rewriteTreeNestingLevel--;
}
return retval;
}
// $ANTLR end "rewrite_tree"
public static class rewrite_atom_return extends TreeRuleReturnScope {
public ST code=null;
};
// $ANTLR start "rewrite_atom"
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:1398:1: rewrite_atom[boolean isRoot] returns [ST code=null] : (r= RULE_REF | ( ^(tk= TOKEN_REF (arg= ARG_ACTION )? ) |cl= CHAR_LITERAL |sl= STRING_LITERAL ) | LABEL | ACTION );
public final CodeGenTreeWalker.rewrite_atom_return rewrite_atom(boolean isRoot) throws RecognitionException {
CodeGenTreeWalker.rewrite_atom_return retval = new CodeGenTreeWalker.rewrite_atom_return();
retval.start = input.LT(1);
GrammarAST r=null;
GrammarAST tk=null;
GrammarAST arg=null;
GrammarAST cl=null;
GrammarAST sl=null;
GrammarAST LABEL21=null;
GrammarAST ACTION22=null;
try {
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:1399:2: (r= RULE_REF | ( ^(tk= TOKEN_REF (arg= ARG_ACTION )? ) |cl= CHAR_LITERAL |sl= STRING_LITERAL ) | LABEL | ACTION )
int alt69=4;
switch ( input.LA(1) ) {
case RULE_REF:
{
alt69=1;
}
break;
case CHAR_LITERAL:
case STRING_LITERAL:
case TOKEN_REF:
{
alt69=2;
}
break;
case LABEL:
{
alt69=3;
}
break;
case ACTION:
{
alt69=4;
}
break;
default:
if (state.backtracking>0) {state.failed=true; return retval;}
NoViableAltException nvae =
new NoViableAltException("", 69, 0, input);
throw nvae;
}
switch (alt69) {
case 1 :
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:1399:6: r= RULE_REF
{
r=(GrammarAST)match(input,RULE_REF,FOLLOW_RULE_REF_in_rewrite_atom2111); if (state.failed) return retval;
if ( state.backtracking==0 ) {
String ruleRefName = (r!=null?r.getText():null);
String stName = "rewriteRuleRef";
if ( isRoot )
{
stName += "Root";
}
retval.code = templates.getInstanceOf(stName);
retval.code.add("rule", ruleRefName);
if ( grammar.getRule(ruleRefName)==null )
{
ErrorManager.grammarError(ErrorManager.MSG_UNDEFINED_RULE_REF,
grammar,
r.getToken(),
ruleRefName);
retval.code = new ST(""); // blank; no code gen
}
else if ( grammar.getRule(currentRuleName)
.getRuleRefsInAlt(ruleRefName,outerAltNum)==null )
{
ErrorManager.grammarError(ErrorManager.MSG_REWRITE_ELEMENT_NOT_PRESENT_ON_LHS,
grammar,
r.getToken(),
ruleRefName);
retval.code = new ST(""); // blank; no code gen
}
else
{
// track all rule refs as we must copy 2nd ref to rule and beyond
if ( !rewriteRuleRefs.contains(ruleRefName) )
{
rewriteRuleRefs.add(ruleRefName);
}
}
}
}
break;
case 2 :
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:1437:3: ( ^(tk= TOKEN_REF (arg= ARG_ACTION )? ) |cl= CHAR_LITERAL |sl= STRING_LITERAL )
{
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:1437:3: ( ^(tk= TOKEN_REF (arg= ARG_ACTION )? ) |cl= CHAR_LITERAL |sl= STRING_LITERAL )
int alt68=3;
switch ( input.LA(1) ) {
case TOKEN_REF:
{
alt68=1;
}
break;
case CHAR_LITERAL:
{
alt68=2;
}
break;
case STRING_LITERAL:
{
alt68=3;
}
break;
default:
if (state.backtracking>0) {state.failed=true; return retval;}
NoViableAltException nvae =
new NoViableAltException("", 68, 0, input);
throw nvae;
}
switch (alt68) {
case 1 :
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:1437:5: ^(tk= TOKEN_REF (arg= ARG_ACTION )? )
{
tk=(GrammarAST)match(input,TOKEN_REF,FOLLOW_TOKEN_REF_in_rewrite_atom2128); if (state.failed) return retval;
if ( input.LA(1)==Token.DOWN ) {
match(input, Token.DOWN, null); if (state.failed) return retval;
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:1437:20: (arg= ARG_ACTION )?
int alt67=2;
int LA67_0 = input.LA(1);
if ( (LA67_0==ARG_ACTION) ) {
alt67=1;
}
switch (alt67) {
case 1 :
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:1437:21: arg= ARG_ACTION
{
arg=(GrammarAST)match(input,ARG_ACTION,FOLLOW_ARG_ACTION_in_rewrite_atom2133); if (state.failed) return retval;
}
break;
}
match(input, Token.UP, null); if (state.failed) return retval;
}
}
break;
case 2 :
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:1438:5: cl= CHAR_LITERAL
{
cl=(GrammarAST)match(input,CHAR_LITERAL,FOLLOW_CHAR_LITERAL_in_rewrite_atom2144); if (state.failed) return retval;
}
break;
case 3 :
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:1439:5: sl= STRING_LITERAL
{
sl=(GrammarAST)match(input,STRING_LITERAL,FOLLOW_STRING_LITERAL_in_rewrite_atom2152); if (state.failed) return retval;
}
break;
}
if ( state.backtracking==0 ) {
GrammarAST term = tk;
if (term == null) term = cl;
if (term == null) term = sl;
String tokenName = ((GrammarAST)retval.start).getToken().getText();
String stName = "rewriteTokenRef";
Rule rule = grammar.getRule(currentRuleName);
Collection tokenRefsInAlt = rule.getTokenRefsInAlt(outerAltNum);
boolean createNewNode = !tokenRefsInAlt.contains(tokenName) || arg!=null;
if ( createNewNode )
{
stName = "rewriteImaginaryTokenRef";
}
if ( isRoot )
{
stName += "Root";
}
retval.code = templates.getInstanceOf(stName);
if (term.terminalOptions != null) {
retval.code.add("terminalOptions",term.terminalOptions);
}
if ( arg!=null )
{
List extends Object> args = generator.translateAction(currentRuleName,arg);
retval.code.add("args", args);
}
retval.code.add("elementIndex", ((CommonToken)((GrammarAST)retval.start).getToken()).getTokenIndex());
int ttype = grammar.getTokenType(tokenName);
String tok = generator.getTokenTypeAsTargetLabel(ttype);
retval.code.add("token", tok);
if ( grammar.getTokenType(tokenName)==Label.INVALID )
{
ErrorManager.grammarError(ErrorManager.MSG_UNDEFINED_TOKEN_REF_IN_REWRITE,
grammar,
((GrammarAST)retval.start).getToken(),
tokenName);
retval.code = new ST(""); // blank; no code gen
}
}
}
break;
case 3 :
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:1481:4: LABEL
{
LABEL21=(GrammarAST)match(input,LABEL,FOLLOW_LABEL_in_rewrite_atom2166); if (state.failed) return retval;
if ( state.backtracking==0 ) {
String labelName = (LABEL21!=null?LABEL21.getText():null);
Rule rule = grammar.getRule(currentRuleName);
Grammar.LabelElementPair pair = rule.getLabel(labelName);
if ( labelName.equals(currentRuleName) )
{
// special case; ref to old value via $ rule
if ( rule.hasRewrite(outerAltNum) &&
rule.getRuleRefsInAlt(outerAltNum).contains(labelName) )
{
ErrorManager.grammarError(ErrorManager.MSG_RULE_REF_AMBIG_WITH_RULE_IN_ALT,
grammar,
LABEL21.getToken(),
labelName);
}
ST labelST = templates.getInstanceOf("prevRuleRootRef");
retval.code = templates.getInstanceOf("rewriteRuleLabelRef"+(isRoot?"Root":""));
retval.code.add("label", labelST);
}
else if ( pair==null )
{
ErrorManager.grammarError(ErrorManager.MSG_UNDEFINED_LABEL_REF_IN_REWRITE,
grammar,
LABEL21.getToken(),
labelName);
retval.code = new ST("");
}
else
{
String stName = null;
switch ( pair.type )
{
case Grammar.TOKEN_LABEL :
stName = "rewriteTokenLabelRef";
break;
case Grammar.WILDCARD_TREE_LABEL :
stName = "rewriteWildcardLabelRef";
break;
case Grammar.WILDCARD_TREE_LIST_LABEL:
stName = "rewriteRuleListLabelRef"; // acts like rule ref list for ref
break;
case Grammar.RULE_LABEL :
stName = "rewriteRuleLabelRef";
break;
case Grammar.TOKEN_LIST_LABEL :
stName = "rewriteTokenListLabelRef";
break;
case Grammar.RULE_LIST_LABEL :
stName = "rewriteRuleListLabelRef";
break;
}
if ( isRoot )
{
stName += "Root";
}
retval.code = templates.getInstanceOf(stName);
retval.code.add("label", labelName);
}
}
}
break;
case 4 :
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:1542:4: ACTION
{
ACTION22=(GrammarAST)match(input,ACTION,FOLLOW_ACTION_in_rewrite_atom2176); if (state.failed) return retval;
if ( state.backtracking==0 ) {
// actions in rewrite rules yield a tree object
String actText = (ACTION22!=null?ACTION22.getText():null);
List extends Object> chunks = generator.translateAction(currentRuleName,ACTION22);
retval.code = templates.getInstanceOf("rewriteNodeAction"+(isRoot?"Root":""));
retval.code.add("action", chunks);
}
}
break;
}
}
catch (RecognitionException re) {
reportError(re);
recover(input,re);
}
finally {
// do for sure before leaving
}
return retval;
}
// $ANTLR end "rewrite_atom"
// $ANTLR start "rewrite_template"
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:1553:1: public rewrite_template returns [ST code=null] : ( ^( ALT EPSILON EOA ) | ^( TEMPLATE (id= ID |ind= ACTION ) ^( ARGLIST ( ^( ARG arg= ID a= ACTION ) )* ) ( DOUBLE_QUOTE_STRING_LITERAL | DOUBLE_ANGLE_STRING_LITERAL )? ) |act= ACTION );
public final ST rewrite_template() throws RecognitionException {
ST code = null;
GrammarAST id=null;
GrammarAST ind=null;
GrammarAST arg=null;
GrammarAST a=null;
GrammarAST act=null;
GrammarAST DOUBLE_QUOTE_STRING_LITERAL23=null;
GrammarAST DOUBLE_ANGLE_STRING_LITERAL24=null;
try {
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:1554:2: ( ^( ALT EPSILON EOA ) | ^( TEMPLATE (id= ID |ind= ACTION ) ^( ARGLIST ( ^( ARG arg= ID a= ACTION ) )* ) ( DOUBLE_QUOTE_STRING_LITERAL | DOUBLE_ANGLE_STRING_LITERAL )? ) |act= ACTION )
int alt73=3;
switch ( input.LA(1) ) {
case ALT:
{
alt73=1;
}
break;
case TEMPLATE:
{
alt73=2;
}
break;
case ACTION:
{
alt73=3;
}
break;
default:
if (state.backtracking>0) {state.failed=true; return code;}
NoViableAltException nvae =
new NoViableAltException("", 73, 0, input);
throw nvae;
}
switch (alt73) {
case 1 :
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:1554:4: ^( ALT EPSILON EOA )
{
match(input,ALT,FOLLOW_ALT_in_rewrite_template2199); if (state.failed) return code;
match(input, Token.DOWN, null); if (state.failed) return code;
match(input,EPSILON,FOLLOW_EPSILON_in_rewrite_template2201); if (state.failed) return code;
match(input,EOA,FOLLOW_EOA_in_rewrite_template2203); if (state.failed) return code;
match(input, Token.UP, null); if (state.failed) return code;
if ( state.backtracking==0 ) {code =templates.getInstanceOf("rewriteEmptyTemplate");}
}
break;
case 2 :
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:1555:4: ^( TEMPLATE (id= ID |ind= ACTION ) ^( ARGLIST ( ^( ARG arg= ID a= ACTION ) )* ) ( DOUBLE_QUOTE_STRING_LITERAL | DOUBLE_ANGLE_STRING_LITERAL )? )
{
match(input,TEMPLATE,FOLLOW_TEMPLATE_in_rewrite_template2214); if (state.failed) return code;
match(input, Token.DOWN, null); if (state.failed) return code;
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:1555:16: (id= ID |ind= ACTION )
int alt70=2;
int LA70_0 = input.LA(1);
if ( (LA70_0==ID) ) {
alt70=1;
}
else if ( (LA70_0==ACTION) ) {
alt70=2;
}
else {
if (state.backtracking>0) {state.failed=true; return code;}
NoViableAltException nvae =
new NoViableAltException("", 70, 0, input);
throw nvae;
}
switch (alt70) {
case 1 :
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:1555:17: id= ID
{
id=(GrammarAST)match(input,ID,FOLLOW_ID_in_rewrite_template2219); if (state.failed) return code;
}
break;
case 2 :
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:1555:23: ind= ACTION
{
ind=(GrammarAST)match(input,ACTION,FOLLOW_ACTION_in_rewrite_template2223); if (state.failed) return code;
}
break;
}
if ( state.backtracking==0 ) {
if ( id!=null && (id!=null?id.getText():null).equals("template") )
{
code = templates.getInstanceOf("rewriteInlineTemplate");
}
else if ( id!=null )
{
code = templates.getInstanceOf("rewriteExternalTemplate");
code.add("name", (id!=null?id.getText():null));
}
else if ( ind!=null )
{ // must be %({expr})(args)
code = templates.getInstanceOf("rewriteIndirectTemplate");
List extends Object> chunks=generator.translateAction(currentRuleName,ind);
code.add("expr", chunks);
}
}
match(input,ARGLIST,FOLLOW_ARGLIST_in_rewrite_template2236); if (state.failed) return code;
if ( input.LA(1)==Token.DOWN ) {
match(input, Token.DOWN, null); if (state.failed) return code;
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:1574:5: ( ^( ARG arg= ID a= ACTION ) )*
loop71:
while (true) {
int alt71=2;
int LA71_0 = input.LA(1);
if ( (LA71_0==ARG) ) {
alt71=1;
}
switch (alt71) {
case 1 :
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:1574:7: ^( ARG arg= ID a= ACTION )
{
match(input,ARG,FOLLOW_ARG_in_rewrite_template2246); if (state.failed) return code;
match(input, Token.DOWN, null); if (state.failed) return code;
arg=(GrammarAST)match(input,ID,FOLLOW_ID_in_rewrite_template2250); if (state.failed) return code;
a=(GrammarAST)match(input,ACTION,FOLLOW_ACTION_in_rewrite_template2254); if (state.failed) return code;
if ( state.backtracking==0 ) {
// must set alt num here rather than in define.g
// because actions like %foo(name={$ID.text}) aren't
// broken up yet into trees.
a.outerAltNum = this.outerAltNum;
List extends Object> chunks = generator.translateAction(currentRuleName,a);
code.addAggr("args.{name,value}", (arg!=null?arg.getText():null), chunks);
}
match(input, Token.UP, null); if (state.failed) return code;
}
break;
default :
break loop71;
}
}
match(input, Token.UP, null); if (state.failed) return code;
}
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:1586:4: ( DOUBLE_QUOTE_STRING_LITERAL | DOUBLE_ANGLE_STRING_LITERAL )?
int alt72=3;
int LA72_0 = input.LA(1);
if ( (LA72_0==DOUBLE_QUOTE_STRING_LITERAL) ) {
alt72=1;
}
else if ( (LA72_0==DOUBLE_ANGLE_STRING_LITERAL) ) {
alt72=2;
}
switch (alt72) {
case 1 :
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:1586:6: DOUBLE_QUOTE_STRING_LITERAL
{
DOUBLE_QUOTE_STRING_LITERAL23=(GrammarAST)match(input,DOUBLE_QUOTE_STRING_LITERAL,FOLLOW_DOUBLE_QUOTE_STRING_LITERAL_in_rewrite_template2287); if (state.failed) return code;
if ( state.backtracking==0 ) {
String sl = (DOUBLE_QUOTE_STRING_LITERAL23!=null?DOUBLE_QUOTE_STRING_LITERAL23.getText():null);
String t = sl.substring( 1, sl.length() - 1 ); // strip quotes
t = generator.target.getTargetStringLiteralFromString(t);
code.add("template",t);
}
}
break;
case 2 :
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:1593:6: DOUBLE_ANGLE_STRING_LITERAL
{
DOUBLE_ANGLE_STRING_LITERAL24=(GrammarAST)match(input,DOUBLE_ANGLE_STRING_LITERAL,FOLLOW_DOUBLE_ANGLE_STRING_LITERAL_in_rewrite_template2300); if (state.failed) return code;
if ( state.backtracking==0 ) {
String sl = (DOUBLE_ANGLE_STRING_LITERAL24!=null?DOUBLE_ANGLE_STRING_LITERAL24.getText():null);
String t = sl.substring( 2, sl.length() - 2 ); // strip double angle quotes
t = generator.target.getTargetStringLiteralFromString(t);
code.add("template",t);
}
}
break;
}
match(input, Token.UP, null); if (state.failed) return code;
}
break;
case 3 :
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:1603:4: act= ACTION
{
act=(GrammarAST)match(input,ACTION,FOLLOW_ACTION_in_rewrite_template2324); if (state.failed) return code;
if ( state.backtracking==0 ) {
// set alt num for same reason as ARGLIST above
act.outerAltNum = this.outerAltNum;
code =templates.getInstanceOf("rewriteAction");
code.add("action",
generator.translateAction(currentRuleName,act));
}
}
break;
}
}
catch (RecognitionException re) {
reportError(re);
recover(input,re);
}
finally {
// do for sure before leaving
}
return code;
}
// $ANTLR end "rewrite_template"
// $ANTLR start synpred1_CodeGenTreeWalker
public final void synpred1_CodeGenTreeWalker_fragment() throws RecognitionException {
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:750:4: ({...}? ( BLOCK | OPTIONAL | CLOSURE | POSITIVE_CLOSURE ) )
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:750:5: {...}? ( BLOCK | OPTIONAL | CLOSURE | POSITIVE_CLOSURE )
{
if ( !((((GrammarAST)input.LT(1)).getSetValue()==null)) ) {
if (state.backtracking>0) {state.failed=true; return;}
throw new FailedPredicateException(input, "synpred1_CodeGenTreeWalker", "((GrammarAST)input.LT(1)).getSetValue()==null");
}
if ( input.LA(1)==BLOCK||input.LA(1)==CLOSURE||input.LA(1)==OPTIONAL||input.LA(1)==POSITIVE_CLOSURE ) {
input.consume();
state.errorRecovery=false;
state.failed=false;
}
else {
if (state.backtracking>0) {state.failed=true; return;}
MismatchedSetException mse = new MismatchedSetException(null,input);
throw mse;
}
}
}
// $ANTLR end synpred1_CodeGenTreeWalker
// $ANTLR start synpred2_CodeGenTreeWalker
public final void synpred2_CodeGenTreeWalker_fragment() throws RecognitionException {
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:918:6: ( element_action )
// org\\antlr\\grammar\\v3\\CodeGenTreeWalker.g:918:7: element_action
{
pushFollow(FOLLOW_element_action_in_synpred2_CodeGenTreeWalker1405);
element_action();
state._fsp--;
if (state.failed) return;
}
}
// $ANTLR end synpred2_CodeGenTreeWalker
// Delegated rules
public final boolean synpred1_CodeGenTreeWalker() {
state.backtracking++;
int start = input.mark();
try {
synpred1_CodeGenTreeWalker_fragment(); // can never throw exception
} catch (RecognitionException re) {
System.err.println("impossible: "+re);
}
boolean success = !state.failed;
input.rewind(start);
state.backtracking--;
state.failed=false;
return success;
}
public final boolean synpred2_CodeGenTreeWalker() {
state.backtracking++;
int start = input.mark();
try {
synpred2_CodeGenTreeWalker_fragment(); // can never throw exception
} catch (RecognitionException re) {
System.err.println("impossible: "+re);
}
boolean success = !state.failed;
input.rewind(start);
state.backtracking--;
state.failed=false;
return success;
}
public static final BitSet FOLLOW_LEXER_GRAMMAR_in_grammar_67 = new BitSet(new long[]{0x0000000000000004L});
public static final BitSet FOLLOW_grammarSpec_in_grammar_69 = new BitSet(new long[]{0x0000000000000008L});
public static final BitSet FOLLOW_PARSER_GRAMMAR_in_grammar_79 = new BitSet(new long[]{0x0000000000000004L});
public static final BitSet FOLLOW_grammarSpec_in_grammar_81 = new BitSet(new long[]{0x0000000000000008L});
public static final BitSet FOLLOW_TREE_GRAMMAR_in_grammar_91 = new BitSet(new long[]{0x0000000000000004L});
public static final BitSet FOLLOW_grammarSpec_in_grammar_93 = new BitSet(new long[]{0x0000000000000008L});
public static final BitSet FOLLOW_COMBINED_GRAMMAR_in_grammar_103 = new BitSet(new long[]{0x0000000000000004L});
public static final BitSet FOLLOW_grammarSpec_in_grammar_105 = new BitSet(new long[]{0x0000000000000008L});
public static final BitSet FOLLOW_SCOPE_in_attrScope124 = new BitSet(new long[]{0x0000000000000004L});
public static final BitSet FOLLOW_ID_in_attrScope126 = new BitSet(new long[]{0x0000000000000210L});
public static final BitSet FOLLOW_AMPERSAND_in_attrScope131 = new BitSet(new long[]{0x0000000000000004L});
public static final BitSet FOLLOW_ACTION_in_attrScope140 = new BitSet(new long[]{0x0000000000000008L});
public static final BitSet FOLLOW_ID_in_grammarSpec157 = new BitSet(new long[]{0x0400200008000200L,0x0000000020028002L});
public static final BitSet FOLLOW_DOC_COMMENT_in_grammarSpec165 = new BitSet(new long[]{0x0400200000000200L,0x0000000020028002L});
public static final BitSet FOLLOW_OPTIONS_in_grammarSpec186 = new BitSet(new long[]{0x0000000000000004L});
public static final BitSet FOLLOW_IMPORT_in_grammarSpec200 = new BitSet(new long[]{0x0000000000000004L});
public static final BitSet FOLLOW_TOKENS_in_grammarSpec214 = new BitSet(new long[]{0x0000000000000004L});
public static final BitSet FOLLOW_attrScope_in_grammarSpec226 = new BitSet(new long[]{0x0000000000000200L,0x0000000000028002L});
public static final BitSet FOLLOW_AMPERSAND_in_grammarSpec235 = new BitSet(new long[]{0x0000000000000004L});
public static final BitSet FOLLOW_rules_in_grammarSpec246 = new BitSet(new long[]{0x0000000000000002L});
public static final BitSet FOLLOW_rule_in_rules291 = new BitSet(new long[]{0x0000000000000002L,0x0000000000008002L});
public static final BitSet FOLLOW_RULE_in_rules305 = new BitSet(new long[]{0x0000000000000004L});
public static final BitSet FOLLOW_PREC_RULE_in_rules317 = new BitSet(new long[]{0x0000000000000004L});
public static final BitSet FOLLOW_RULE_in_rule359 = new BitSet(new long[]{0x0000000000000004L});
public static final BitSet FOLLOW_ID_in_rule363 = new BitSet(new long[]{0x0000010000000400L,0x000000000000001CL});
public static final BitSet FOLLOW_modifier_in_rule376 = new BitSet(new long[]{0x0000000000000400L});
public static final BitSet FOLLOW_ARG_in_rule384 = new BitSet(new long[]{0x0000000000000004L});
public static final BitSet FOLLOW_ARG_ACTION_in_rule387 = new BitSet(new long[]{0x0000000000000008L});
public static final BitSet FOLLOW_RET_in_rule396 = new BitSet(new long[]{0x0000000000000004L});
public static final BitSet FOLLOW_ARG_ACTION_in_rule399 = new BitSet(new long[]{0x0000000000000008L});
public static final BitSet FOLLOW_throwsSpec_in_rule408 = new BitSet(new long[]{0x0400000000010200L,0x0000000000020000L});
public static final BitSet FOLLOW_OPTIONS_in_rule418 = new BitSet(new long[]{0x0000000000000004L});
public static final BitSet FOLLOW_ruleScopeSpec_in_rule431 = new BitSet(new long[]{0x0000000000010200L});
public static final BitSet FOLLOW_AMPERSAND_in_rule441 = new BitSet(new long[]{0x0000000000000004L});
public static final BitSet FOLLOW_block_in_rule455 = new BitSet(new long[]{0x0000004400020000L});
public static final BitSet FOLLOW_exceptionGroup_in_rule468 = new BitSet(new long[]{0x0000000400000000L});
public static final BitSet FOLLOW_EOR_in_rule476 = new BitSet(new long[]{0x0000000000000008L});
public static final BitSet FOLLOW_THROWS_in_throwsSpec526 = new BitSet(new long[]{0x0000000000000004L});
public static final BitSet FOLLOW_ID_in_throwsSpec528 = new BitSet(new long[]{0x0000080000000008L});
public static final BitSet FOLLOW_SCOPE_in_ruleScopeSpec543 = new BitSet(new long[]{0x0000000000000004L});
public static final BitSet FOLLOW_AMPERSAND_in_ruleScopeSpec548 = new BitSet(new long[]{0x0000000000000004L});
public static final BitSet FOLLOW_ACTION_in_ruleScopeSpec558 = new BitSet(new long[]{0x0000080000000008L});
public static final BitSet FOLLOW_ID_in_ruleScopeSpec564 = new BitSet(new long[]{0x0000080000000008L});
public static final BitSet FOLLOW_setBlock_in_block605 = new BitSet(new long[]{0x0000000000000002L});
public static final BitSet FOLLOW_BLOCK_in_block618 = new BitSet(new long[]{0x0000000000000004L});
public static final BitSet FOLLOW_OPTIONS_in_block626 = new BitSet(new long[]{0x0000000000000004L});
public static final BitSet FOLLOW_alternative_in_block643 = new BitSet(new long[]{0x0000000200000100L,0x0000000000001000L});
public static final BitSet FOLLOW_rewrite_in_block648 = new BitSet(new long[]{0x0000000200000100L});
public static final BitSet FOLLOW_EOB_in_block665 = new BitSet(new long[]{0x0000000000000008L});
public static final BitSet FOLLOW_BLOCK_in_setBlock697 = new BitSet(new long[]{0x0000000000000004L});
public static final BitSet FOLLOW_ALT_in_setAlternative717 = new BitSet(new long[]{0x0000000000000004L});
public static final BitSet FOLLOW_setElement_in_setAlternative719 = new BitSet(new long[]{0x00000001000C0000L,0x0000000041000000L});
public static final BitSet FOLLOW_EOA_in_setAlternative722 = new BitSet(new long[]{0x0000000000000008L});
public static final BitSet FOLLOW_exceptionHandler_in_exceptionGroup737 = new BitSet(new long[]{0x0000004000020002L});
public static final BitSet FOLLOW_finallyClause_in_exceptionGroup744 = new BitSet(new long[]{0x0000000000000002L});
public static final BitSet FOLLOW_finallyClause_in_exceptionGroup752 = new BitSet(new long[]{0x0000000000000002L});
public static final BitSet FOLLOW_CATCH_in_exceptionHandler766 = new BitSet(new long[]{0x0000000000000004L});
public static final BitSet FOLLOW_ARG_ACTION_in_exceptionHandler768 = new BitSet(new long[]{0x0000000000000010L});
public static final BitSet FOLLOW_ACTION_in_exceptionHandler770 = new BitSet(new long[]{0x0000000000000008L});
public static final BitSet FOLLOW_FINALLY_in_finallyClause788 = new BitSet(new long[]{0x0000000000000004L});
public static final BitSet FOLLOW_ACTION_in_finallyClause790 = new BitSet(new long[]{0x0000000000000008L});
public static final BitSet FOLLOW_ALT_in_alternative820 = new BitSet(new long[]{0x0000000000000004L});
public static final BitSet FOLLOW_element_in_alternative833 = new BitSet(new long[]{0x82800289202DE010L,0x0000000547092001L});
public static final BitSet FOLLOW_EOA_in_alternative851 = new BitSet(new long[]{0x0000000000000008L});
public static final BitSet FOLLOW_ROOT_in_element886 = new BitSet(new long[]{0x0000000000000004L});
public static final BitSet FOLLOW_element_in_element890 = new BitSet(new long[]{0x0000000000000008L});
public static final BitSet FOLLOW_BANG_in_element903 = new BitSet(new long[]{0x0000000000000004L});
public static final BitSet FOLLOW_element_in_element907 = new BitSet(new long[]{0x0000000000000008L});
public static final BitSet FOLLOW_NOT_in_element923 = new BitSet(new long[]{0x0000000000000004L});
public static final BitSet FOLLOW_notElement_in_element927 = new BitSet(new long[]{0x0000000000000008L});
public static final BitSet FOLLOW_ASSIGN_in_element942 = new BitSet(new long[]{0x0000000000000004L});
public static final BitSet FOLLOW_ID_in_element946 = new BitSet(new long[]{0x82800288202DE010L,0x0000000547092001L});
public static final BitSet FOLLOW_element_in_element950 = new BitSet(new long[]{0x0000000000000008L});
public static final BitSet FOLLOW_PLUS_ASSIGN_in_element965 = new BitSet(new long[]{0x0000000000000004L});
public static final BitSet FOLLOW_ID_in_element969 = new BitSet(new long[]{0x82800288202DE010L,0x0000000547092001L});
public static final BitSet FOLLOW_element_in_element973 = new BitSet(new long[]{0x0000000000000008L});
public static final BitSet FOLLOW_CHAR_RANGE_in_element987 = new BitSet(new long[]{0x0000000000000004L});
public static final BitSet FOLLOW_CHAR_LITERAL_in_element991 = new BitSet(new long[]{0x0000000000040000L});
public static final BitSet FOLLOW_CHAR_LITERAL_in_element995 = new BitSet(new long[]{0x0000000000000008L});
public static final BitSet FOLLOW_ebnf_in_element1024 = new BitSet(new long[]{0x0000000000000002L});
public static final BitSet FOLLOW_atom_in_element1035 = new BitSet(new long[]{0x0000000000000002L});
public static final BitSet FOLLOW_tree__in_element1046 = new BitSet(new long[]{0x0000000000000002L});
public static final BitSet FOLLOW_element_action_in_element1056 = new BitSet(new long[]{0x0000000000000002L});
public static final BitSet FOLLOW_SEMPRED_in_element1071 = new BitSet(new long[]{0x0000000000000002L});
public static final BitSet FOLLOW_GATED_SEMPRED_in_element1075 = new BitSet(new long[]{0x0000000000000002L});
public static final BitSet FOLLOW_SYN_SEMPRED_in_element1086 = new BitSet(new long[]{0x0000000000000002L});
public static final BitSet FOLLOW_SYNPRED_in_element1094 = new BitSet(new long[]{0x0000000000000004L});
public static final BitSet FOLLOW_BACKTRACK_SEMPRED_in_element1105 = new BitSet(new long[]{0x0000000000000004L});
public static final BitSet FOLLOW_EPSILON_in_element1117 = new BitSet(new long[]{0x0000000000000002L});
public static final BitSet FOLLOW_ACTION_in_element_action1134 = new BitSet(new long[]{0x0000000000000002L});
public static final BitSet FOLLOW_FORCED_ACTION_in_element_action1145 = new BitSet(new long[]{0x0000000000000002L});
public static final BitSet FOLLOW_CHAR_LITERAL_in_notElement1174 = new BitSet(new long[]{0x0000000000000002L});
public static final BitSet FOLLOW_STRING_LITERAL_in_notElement1187 = new BitSet(new long[]{0x0000000000000002L});
public static final BitSet FOLLOW_TOKEN_REF_in_notElement1200 = new BitSet(new long[]{0x0000000000000002L});
public static final BitSet FOLLOW_BLOCK_in_notElement1214 = new BitSet(new long[]{0x0000000000000004L});
public static final BitSet FOLLOW_block_in_ebnf1261 = new BitSet(new long[]{0x0000000000000002L});
public static final BitSet FOLLOW_OPTIONAL_in_ebnf1280 = new BitSet(new long[]{0x0000000000000004L});
public static final BitSet FOLLOW_block_in_ebnf1284 = new BitSet(new long[]{0x0000000000000008L});
public static final BitSet FOLLOW_CLOSURE_in_ebnf1305 = new BitSet(new long[]{0x0000000000000004L});
public static final BitSet FOLLOW_block_in_ebnf1309 = new BitSet(new long[]{0x0000000000000008L});
public static final BitSet FOLLOW_POSITIVE_CLOSURE_in_ebnf1330 = new BitSet(new long[]{0x0000000000000004L});
public static final BitSet FOLLOW_block_in_ebnf1334 = new BitSet(new long[]{0x0000000000000008L});
public static final BitSet FOLLOW_TREE_BEGIN_in_tree_1372 = new BitSet(new long[]{0x0000000000000004L});
public static final BitSet FOLLOW_element_in_tree_1379 = new BitSet(new long[]{0x82800288202DE018L,0x0000000547092001L});
public static final BitSet FOLLOW_element_action_in_tree_1416 = new BitSet(new long[]{0x82800288202DE018L,0x0000000547092001L});
public static final BitSet FOLLOW_element_in_tree_1438 = new BitSet(new long[]{0x82800288202DE018L,0x0000000547092001L});
public static final BitSet FOLLOW_RULE_REF_in_atom1488 = new BitSet(new long[]{0x0000000000000004L});
public static final BitSet FOLLOW_ARG_ACTION_in_atom1493 = new BitSet(new long[]{0x0000000000000008L});
public static final BitSet FOLLOW_TOKEN_REF_in_atom1511 = new BitSet(new long[]{0x0000000000000004L});
public static final BitSet FOLLOW_ARG_ACTION_in_atom1516 = new BitSet(new long[]{0x0000000000000008L});
public static final BitSet FOLLOW_CHAR_LITERAL_in_atom1532 = new BitSet(new long[]{0x0000000000000002L});
public static final BitSet FOLLOW_STRING_LITERAL_in_atom1544 = new BitSet(new long[]{0x0000000000000002L});
public static final BitSet FOLLOW_WILDCARD_in_atom1556 = new BitSet(new long[]{0x0000000000000002L});
public static final BitSet FOLLOW_DOT_in_atom1567 = new BitSet(new long[]{0x0000000000000004L});
public static final BitSet FOLLOW_ID_in_atom1569 = new BitSet(new long[]{0x0000000020050000L,0x0000000441010000L});
public static final BitSet FOLLOW_atom_in_atom1573 = new BitSet(new long[]{0x0000000000000008L});
public static final BitSet FOLLOW_set_in_atom1586 = new BitSet(new long[]{0x0000000000000002L});
public static final BitSet FOLLOW_BLOCK_in_set1631 = new BitSet(new long[]{0x0000000000000004L});
public static final BitSet FOLLOW_CHAR_LITERAL_in_setElement1651 = new BitSet(new long[]{0x0000000000000002L});
public static final BitSet FOLLOW_TOKEN_REF_in_setElement1656 = new BitSet(new long[]{0x0000000000000002L});
public static final BitSet FOLLOW_STRING_LITERAL_in_setElement1661 = new BitSet(new long[]{0x0000000000000002L});
public static final BitSet FOLLOW_CHAR_RANGE_in_setElement1667 = new BitSet(new long[]{0x0000000000000004L});
public static final BitSet FOLLOW_CHAR_LITERAL_in_setElement1669 = new BitSet(new long[]{0x0000000000040000L});
public static final BitSet FOLLOW_CHAR_LITERAL_in_setElement1671 = new BitSet(new long[]{0x0000000000000008L});
public static final BitSet FOLLOW_REWRITES_in_rewrite1696 = new BitSet(new long[]{0x0000000000000004L});
public static final BitSet FOLLOW_REWRITE_in_rewrite1717 = new BitSet(new long[]{0x0000000000000004L});
public static final BitSet FOLLOW_SEMPRED_in_rewrite1722 = new BitSet(new long[]{0x0000002000000110L,0x0000000008000000L});
public static final BitSet FOLLOW_rewrite_alternative_in_rewrite1728 = new BitSet(new long[]{0x0000000000000008L});
public static final BitSet FOLLOW_BLOCK_in_rewrite_block1771 = new BitSet(new long[]{0x0000000000000004L});
public static final BitSet FOLLOW_rewrite_alternative_in_rewrite_block1783 = new BitSet(new long[]{0x0000000200000000L});
public static final BitSet FOLLOW_EOB_in_rewrite_block1788 = new BitSet(new long[]{0x0000000000000008L});
public static final BitSet FOLLOW_ALT_in_rewrite_alternative1823 = new BitSet(new long[]{0x0000000000000004L});
public static final BitSet FOLLOW_rewrite_element_in_rewrite_alternative1841 = new BitSet(new long[]{0x0201000100240010L,0x0000000141010001L});
public static final BitSet FOLLOW_EPSILON_in_rewrite_alternative1862 = new BitSet(new long[]{0x0000000100000000L});
public static final BitSet FOLLOW_EOA_in_rewrite_alternative1878 = new BitSet(new long[]{0x0000000000000008L});
public static final BitSet FOLLOW_rewrite_template_in_rewrite_alternative1891 = new BitSet(new long[]{0x0000000000000002L});
public static final BitSet FOLLOW_ETC_in_rewrite_alternative1904 = new BitSet(new long[]{0x0000000000000002L});
public static final BitSet FOLLOW_rewrite_atom_in_rewrite_element1924 = new BitSet(new long[]{0x0000000000000002L});
public static final BitSet FOLLOW_rewrite_ebnf_in_rewrite_element1934 = new BitSet(new long[]{0x0000000000000002L});
public static final BitSet FOLLOW_rewrite_tree_in_rewrite_element1943 = new BitSet(new long[]{0x0000000000000002L});
public static final BitSet FOLLOW_OPTIONAL_in_rewrite_ebnf1964 = new BitSet(new long[]{0x0000000000000004L});
public static final BitSet FOLLOW_rewrite_block_in_rewrite_ebnf1966 = new BitSet(new long[]{0x0000000000000008L});
public static final BitSet FOLLOW_CLOSURE_in_rewrite_ebnf1984 = new BitSet(new long[]{0x0000000000000004L});
public static final BitSet FOLLOW_rewrite_block_in_rewrite_ebnf1986 = new BitSet(new long[]{0x0000000000000008L});
public static final BitSet FOLLOW_POSITIVE_CLOSURE_in_rewrite_ebnf2004 = new BitSet(new long[]{0x0000000000000004L});
public static final BitSet FOLLOW_rewrite_block_in_rewrite_ebnf2006 = new BitSet(new long[]{0x0000000000000008L});
public static final BitSet FOLLOW_TREE_BEGIN_in_rewrite_tree2039 = new BitSet(new long[]{0x0000000000000004L});
public static final BitSet FOLLOW_rewrite_atom_in_rewrite_tree2046 = new BitSet(new long[]{0x0201000000240018L,0x0000000141010001L});
public static final BitSet FOLLOW_rewrite_element_in_rewrite_tree2066 = new BitSet(new long[]{0x0201000000240018L,0x0000000141010001L});
public static final BitSet FOLLOW_RULE_REF_in_rewrite_atom2111 = new BitSet(new long[]{0x0000000000000002L});
public static final BitSet FOLLOW_TOKEN_REF_in_rewrite_atom2128 = new BitSet(new long[]{0x0000000000000004L});
public static final BitSet FOLLOW_ARG_ACTION_in_rewrite_atom2133 = new BitSet(new long[]{0x0000000000000008L});
public static final BitSet FOLLOW_CHAR_LITERAL_in_rewrite_atom2144 = new BitSet(new long[]{0x0000000000000002L});
public static final BitSet FOLLOW_STRING_LITERAL_in_rewrite_atom2152 = new BitSet(new long[]{0x0000000000000002L});
public static final BitSet FOLLOW_LABEL_in_rewrite_atom2166 = new BitSet(new long[]{0x0000000000000002L});
public static final BitSet FOLLOW_ACTION_in_rewrite_atom2176 = new BitSet(new long[]{0x0000000000000002L});
public static final BitSet FOLLOW_ALT_in_rewrite_template2199 = new BitSet(new long[]{0x0000000000000004L});
public static final BitSet FOLLOW_EPSILON_in_rewrite_template2201 = new BitSet(new long[]{0x0000000100000000L});
public static final BitSet FOLLOW_EOA_in_rewrite_template2203 = new BitSet(new long[]{0x0000000000000008L});
public static final BitSet FOLLOW_TEMPLATE_in_rewrite_template2214 = new BitSet(new long[]{0x0000000000000004L});
public static final BitSet FOLLOW_ID_in_rewrite_template2219 = new BitSet(new long[]{0x0000000000000800L});
public static final BitSet FOLLOW_ACTION_in_rewrite_template2223 = new BitSet(new long[]{0x0000000000000800L});
public static final BitSet FOLLOW_ARGLIST_in_rewrite_template2236 = new BitSet(new long[]{0x0000000000000004L});
public static final BitSet FOLLOW_ARG_in_rewrite_template2246 = new BitSet(new long[]{0x0000000000000004L});
public static final BitSet FOLLOW_ID_in_rewrite_template2250 = new BitSet(new long[]{0x0000000000000010L});
public static final BitSet FOLLOW_ACTION_in_rewrite_template2254 = new BitSet(new long[]{0x0000000000000008L});
public static final BitSet FOLLOW_DOUBLE_QUOTE_STRING_LITERAL_in_rewrite_template2287 = new BitSet(new long[]{0x0000000000000008L});
public static final BitSet FOLLOW_DOUBLE_ANGLE_STRING_LITERAL_in_rewrite_template2300 = new BitSet(new long[]{0x0000000000000008L});
public static final BitSet FOLLOW_ACTION_in_rewrite_template2324 = new BitSet(new long[]{0x0000000000000002L});
public static final BitSet FOLLOW_set_in_synpred1_CodeGenTreeWalker1009 = new BitSet(new long[]{0x0000000000000002L});
public static final BitSet FOLLOW_element_action_in_synpred2_CodeGenTreeWalker1405 = new BitSet(new long[]{0x0000000000000002L});
}