All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.antlr.grammar.v3.DefineGrammarItemsWalker Maven / Gradle / Ivy

// $ANTLR 3.5 org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g 2013-09-27 18:41:11

package org.antlr.grammar.v3;
import org.antlr.tool.*;
import java.util.HashSet;
import java.util.Set;


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;

@SuppressWarnings("all")
public class DefineGrammarItemsWalker 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

	protected static class AttributeScopeActions_scope {
		HashMap actions;
	}
	protected Stack AttributeScopeActions_stack = new Stack();


	public DefineGrammarItemsWalker(TreeNodeStream input) {
		this(input, new RecognizerSharedState());
	}
	public DefineGrammarItemsWalker(TreeNodeStream input, RecognizerSharedState state) {
		super(input, state);
	}

	@Override public String[] getTokenNames() { return DefineGrammarItemsWalker.tokenNames; }
	@Override public String getGrammarFileName() { return "org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g"; }


	protected Grammar grammar;
	protected GrammarAST root;
	protected String currentRuleName;
	protected GrammarAST currentRewriteBlock;
	protected GrammarAST currentRewriteRule;
	protected int outerAltNum = 0;
	protected int blockLevel = 0;

	public final int countAltsForRule( CommonTree t ) {
	    CommonTree block = (CommonTree)t.getFirstChildWithType(BLOCK);
	    int altCount = 0;
	    for (int i = 0; i < block.getChildCount(); i++) {
	        if (block.getChild(i).getType() == ALT)
	            altCount++;
	    }
	    return altCount;
	}

	protected final void finish() {
	    trimGrammar();
	}

	/** Remove any lexer rules from a COMBINED; already passed to lexer */
	protected final void trimGrammar() {
	    if ( grammar.type != Grammar.COMBINED ) {
	        return;
	    }
	    // form is (header ... ) ( grammar ID (scope ...) ... ( rule ... ) ( rule ... ) ... )
	    GrammarAST p = root;
	    // find the grammar spec
	    while ( !p.getText().equals( "grammar" ) ) {
	        p = p.getNextSibling();
	    }
	    for ( int i = 0; i < p.getChildCount(); i++ ) {
	        if ( p.getChild( i ).getType() != RULE )
	            continue;

	        String ruleName = p.getChild(i).getChild(0).getText();
	        //Console.Out.WriteLine( "rule " + ruleName + " prev=" + prev.getText() );
	        if (Rule.getRuleType(ruleName) == Grammar.LEXER) {
	            // remove lexer rule
	            p.deleteChild( i );
	            i--;
	        }
	    }
	    //Console.Out.WriteLine( "root after removal is: " + root.ToStringList() );
	}

	protected final void trackInlineAction( GrammarAST actionAST ) {
	    Rule r = grammar.getRule( currentRuleName );
	    if ( r != null ) {
	        r.trackInlineAction( actionAST );
	    }
	}


	public static class grammar__return extends TreeRuleReturnScope {
	};


	// $ANTLR start "grammar_"
	// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:109:1: public grammar_[Grammar g] : ( ^( LEXER_GRAMMAR grammarSpec ) | ^( PARSER_GRAMMAR grammarSpec ) | ^( TREE_GRAMMAR grammarSpec ) | ^( COMBINED_GRAMMAR grammarSpec ) );
	public final DefineGrammarItemsWalker.grammar__return grammar_(Grammar g) throws RecognitionException {
		DefineGrammarItemsWalker.grammar__return retval = new DefineGrammarItemsWalker.grammar__return();
		retval.start = input.LT(1);


		grammar = g;
		root = ((GrammarAST)retval.start);

		try {
			// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:119:2: ( ^( 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 retval;}
				NoViableAltException nvae =
					new NoViableAltException("", 1, 0, input);
				throw nvae;
			}
			switch (alt1) {
				case 1 :
					// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:119:4: ^( LEXER_GRAMMAR grammarSpec )
					{
					match(input,LEXER_GRAMMAR,FOLLOW_LEXER_GRAMMAR_in_grammar_76); if (state.failed) return retval;
					if ( state.backtracking==0 ) {grammar.type = Grammar.LEXER;}
					match(input, Token.DOWN, null); if (state.failed) return retval;
					pushFollow(FOLLOW_grammarSpec_in_grammar_82);
					grammarSpec();
					state._fsp--;
					if (state.failed) return retval;
					match(input, Token.UP, null); if (state.failed) return retval;

					}
					break;
				case 2 :
					// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:120:4: ^( PARSER_GRAMMAR grammarSpec )
					{
					match(input,PARSER_GRAMMAR,FOLLOW_PARSER_GRAMMAR_in_grammar_91); if (state.failed) return retval;
					if ( state.backtracking==0 ) {grammar.type = Grammar.PARSER;}
					match(input, Token.DOWN, null); if (state.failed) return retval;
					pushFollow(FOLLOW_grammarSpec_in_grammar_96);
					grammarSpec();
					state._fsp--;
					if (state.failed) return retval;
					match(input, Token.UP, null); if (state.failed) return retval;

					}
					break;
				case 3 :
					// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:121:4: ^( TREE_GRAMMAR grammarSpec )
					{
					match(input,TREE_GRAMMAR,FOLLOW_TREE_GRAMMAR_in_grammar_105); if (state.failed) return retval;
					if ( state.backtracking==0 ) {grammar.type = Grammar.TREE_PARSER;}
					match(input, Token.DOWN, null); if (state.failed) return retval;
					pushFollow(FOLLOW_grammarSpec_in_grammar_110);
					grammarSpec();
					state._fsp--;
					if (state.failed) return retval;
					match(input, Token.UP, null); if (state.failed) return retval;

					}
					break;
				case 4 :
					// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:122:4: ^( COMBINED_GRAMMAR grammarSpec )
					{
					match(input,COMBINED_GRAMMAR,FOLLOW_COMBINED_GRAMMAR_in_grammar_119); if (state.failed) return retval;
					if ( state.backtracking==0 ) {grammar.type = Grammar.COMBINED;}
					match(input, Token.DOWN, null); if (state.failed) return retval;
					pushFollow(FOLLOW_grammarSpec_in_grammar_124);
					grammarSpec();
					state._fsp--;
					if (state.failed) return retval;
					match(input, Token.UP, null); if (state.failed) return retval;

					}
					break;

			}
			if ( state.backtracking==0 ) {
			finish();
			}
		}
		catch (RecognitionException re) {
			reportError(re);
			recover(input,re);
		}
		finally {
			// do for sure before leaving
		}
		return retval;
	}
	// $ANTLR end "grammar_"



	// $ANTLR start "attrScope"
	// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:125:1: attrScope : ^( 'scope' name= ID ( attrScopeAction )* attrs= ACTION ) ;
	public final void attrScope() throws RecognitionException {
		AttributeScopeActions_stack.push(new AttributeScopeActions_scope());

		GrammarAST name=null;
		GrammarAST attrs=null;


			AttributeScopeActions_stack.peek().actions = new HashMap();

		try {
			// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:131:2: ( ^( 'scope' name= ID ( attrScopeAction )* attrs= ACTION ) )
			// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:131:4: ^( 'scope' name= ID ( attrScopeAction )* attrs= ACTION )
			{
			match(input,SCOPE,FOLLOW_SCOPE_in_attrScope149); if (state.failed) return;
			match(input, Token.DOWN, null); if (state.failed) return;
			name=(GrammarAST)match(input,ID,FOLLOW_ID_in_attrScope153); if (state.failed) return;
			// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:131:23: ( attrScopeAction )*
			loop2:
			while (true) {
				int alt2=2;
				int LA2_0 = input.LA(1);
				if ( (LA2_0==AMPERSAND) ) {
					alt2=1;
				}

				switch (alt2) {
				case 1 :
					// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:131:23: attrScopeAction
					{
					pushFollow(FOLLOW_attrScopeAction_in_attrScope155);
					attrScopeAction();
					state._fsp--;
					if (state.failed) return;
					}
					break;

				default :
					break loop2;
				}
			}

			attrs=(GrammarAST)match(input,ACTION,FOLLOW_ACTION_in_attrScope160); if (state.failed) return;
			match(input, Token.UP, null); if (state.failed) return;

			if ( state.backtracking==0 ) {
						AttributeScope scope = grammar.defineGlobalScope((name!=null?name.getText():null),attrs.getToken());
						scope.isDynamicGlobalScope = true;
						scope.addAttributes((attrs!=null?attrs.getText():null), ';');
						for (GrammarAST action : AttributeScopeActions_stack.peek().actions.keySet())
							scope.defineNamedAction(action, AttributeScopeActions_stack.peek().actions.get(action));
					}
			}

		}
		catch (RecognitionException re) {
			reportError(re);
			recover(input,re);
		}
		finally {
			// do for sure before leaving
			AttributeScopeActions_stack.pop();

		}
	}
	// $ANTLR end "attrScope"



	// $ANTLR start "attrScopeAction"
	// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:141:1: attrScopeAction : ^( AMPERSAND ID ACTION ) ;
	public final void attrScopeAction() throws RecognitionException {
		GrammarAST ID1=null;
		GrammarAST ACTION2=null;

		try {
			// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:142:2: ( ^( AMPERSAND ID ACTION ) )
			// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:142:4: ^( AMPERSAND ID ACTION )
			{
			match(input,AMPERSAND,FOLLOW_AMPERSAND_in_attrScopeAction178); if (state.failed) return;
			match(input, Token.DOWN, null); if (state.failed) return;
			ID1=(GrammarAST)match(input,ID,FOLLOW_ID_in_attrScopeAction180); if (state.failed) return;
			ACTION2=(GrammarAST)match(input,ACTION,FOLLOW_ACTION_in_attrScopeAction182); if (state.failed) return;
			match(input, Token.UP, null); if (state.failed) return;

			if ( state.backtracking==0 ) {
						AttributeScopeActions_stack.peek().actions.put( ID1, ACTION2 );
					}
			}

		}
		catch (RecognitionException re) {
			reportError(re);
			recover(input,re);
		}
		finally {
			// do for sure before leaving
		}
	}
	// $ANTLR end "attrScopeAction"



	// $ANTLR start "grammarSpec"
	// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:148:1: grammarSpec : id= ID (cmt= DOC_COMMENT )? ( optionsSpec )? ( delegateGrammars )? ( tokensSpec )? ( attrScope )* ( actions )? rules ;
	public final void grammarSpec() throws RecognitionException {
		GrammarAST id=null;
		GrammarAST cmt=null;

		try {
			// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:149:2: (id= ID (cmt= DOC_COMMENT )? ( optionsSpec )? ( delegateGrammars )? ( tokensSpec )? ( attrScope )* ( actions )? rules )
			// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:149:4: id= ID (cmt= DOC_COMMENT )? ( optionsSpec )? ( delegateGrammars )? ( tokensSpec )? ( attrScope )* ( actions )? rules
			{
			id=(GrammarAST)match(input,ID,FOLLOW_ID_in_grammarSpec200); if (state.failed) return;
			// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:150:3: (cmt= DOC_COMMENT )?
			int alt3=2;
			int LA3_0 = input.LA(1);
			if ( (LA3_0==DOC_COMMENT) ) {
				alt3=1;
			}
			switch (alt3) {
				case 1 :
					// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:150:4: cmt= DOC_COMMENT
					{
					cmt=(GrammarAST)match(input,DOC_COMMENT,FOLLOW_DOC_COMMENT_in_grammarSpec207); if (state.failed) return;
					}
					break;

			}

			// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:151:3: ( optionsSpec )?
			int alt4=2;
			int LA4_0 = input.LA(1);
			if ( (LA4_0==OPTIONS) ) {
				alt4=1;
			}
			switch (alt4) {
				case 1 :
					// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:151:5: optionsSpec
					{
					pushFollow(FOLLOW_optionsSpec_in_grammarSpec215);
					optionsSpec();
					state._fsp--;
					if (state.failed) return;
					}
					break;

			}

			// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:152:3: ( delegateGrammars )?
			int alt5=2;
			int LA5_0 = input.LA(1);
			if ( (LA5_0==IMPORT) ) {
				alt5=1;
			}
			switch (alt5) {
				case 1 :
					// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:152:4: delegateGrammars
					{
					pushFollow(FOLLOW_delegateGrammars_in_grammarSpec223);
					delegateGrammars();
					state._fsp--;
					if (state.failed) return;
					}
					break;

			}

			// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:153:3: ( tokensSpec )?
			int alt6=2;
			int LA6_0 = input.LA(1);
			if ( (LA6_0==TOKENS) ) {
				alt6=1;
			}
			switch (alt6) {
				case 1 :
					// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:153:4: tokensSpec
					{
					pushFollow(FOLLOW_tokensSpec_in_grammarSpec230);
					tokensSpec();
					state._fsp--;
					if (state.failed) return;
					}
					break;

			}

			// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:154:3: ( attrScope )*
			loop7:
			while (true) {
				int alt7=2;
				int LA7_0 = input.LA(1);
				if ( (LA7_0==SCOPE) ) {
					alt7=1;
				}

				switch (alt7) {
				case 1 :
					// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:154:4: attrScope
					{
					pushFollow(FOLLOW_attrScope_in_grammarSpec237);
					attrScope();
					state._fsp--;
					if (state.failed) return;
					}
					break;

				default :
					break loop7;
				}
			}

			// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:155:3: ( actions )?
			int alt8=2;
			int LA8_0 = input.LA(1);
			if ( (LA8_0==AMPERSAND) ) {
				alt8=1;
			}
			switch (alt8) {
				case 1 :
					// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:155:4: actions
					{
					pushFollow(FOLLOW_actions_in_grammarSpec244);
					actions();
					state._fsp--;
					if (state.failed) return;
					}
					break;

			}

			pushFollow(FOLLOW_rules_in_grammarSpec250);
			rules();
			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 "actions"
	// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:159:1: actions : ( action )+ ;
	public final void actions() throws RecognitionException {
		try {
			// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:160:2: ( ( action )+ )
			// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:160:4: ( action )+
			{
			// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:160:4: ( action )+
			int cnt9=0;
			loop9:
			while (true) {
				int alt9=2;
				int LA9_0 = input.LA(1);
				if ( (LA9_0==AMPERSAND) ) {
					alt9=1;
				}

				switch (alt9) {
				case 1 :
					// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:160:6: action
					{
					pushFollow(FOLLOW_action_in_actions263);
					action();
					state._fsp--;
					if (state.failed) return;
					}
					break;

				default :
					if ( cnt9 >= 1 ) break loop9;
					if (state.backtracking>0) {state.failed=true; return;}
					EarlyExitException eee = new EarlyExitException(9, input);
					throw eee;
				}
				cnt9++;
			}

			}

		}
		catch (RecognitionException re) {
			reportError(re);
			recover(input,re);
		}
		finally {
			// do for sure before leaving
		}
	}
	// $ANTLR end "actions"



	// $ANTLR start "action"
	// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:163:1: action : ^(amp= AMPERSAND id1= ID (id2= ID a1= ACTION |a2= ACTION ) ) ;
	public final void action() throws RecognitionException {
		GrammarAST amp=null;
		GrammarAST id1=null;
		GrammarAST id2=null;
		GrammarAST a1=null;
		GrammarAST a2=null;


			String scope=null;
			GrammarAST nameAST=null, actionAST=null;

		try {
			// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:169:2: ( ^(amp= AMPERSAND id1= ID (id2= ID a1= ACTION |a2= ACTION ) ) )
			// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:169:4: ^(amp= AMPERSAND id1= ID (id2= ID a1= ACTION |a2= ACTION ) )
			{
			amp=(GrammarAST)match(input,AMPERSAND,FOLLOW_AMPERSAND_in_action285); if (state.failed) return;
			match(input, Token.DOWN, null); if (state.failed) return;
			id1=(GrammarAST)match(input,ID,FOLLOW_ID_in_action289); if (state.failed) return;
			// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:170:4: (id2= ID a1= ACTION |a2= ACTION )
			int alt10=2;
			int LA10_0 = input.LA(1);
			if ( (LA10_0==ID) ) {
				alt10=1;
			}
			else if ( (LA10_0==ACTION) ) {
				alt10=2;
			}

			else {
				if (state.backtracking>0) {state.failed=true; return;}
				NoViableAltException nvae =
					new NoViableAltException("", 10, 0, input);
				throw nvae;
			}

			switch (alt10) {
				case 1 :
					// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:170:6: id2= ID a1= ACTION
					{
					id2=(GrammarAST)match(input,ID,FOLLOW_ID_in_action298); if (state.failed) return;
					a1=(GrammarAST)match(input,ACTION,FOLLOW_ACTION_in_action302); if (state.failed) return;
					if ( state.backtracking==0 ) {scope=(id1!=null?id1.getText():null); nameAST=id2; actionAST=a1;}
					}
					break;
				case 2 :
					// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:172:6: a2= ACTION
					{
					a2=(GrammarAST)match(input,ACTION,FOLLOW_ACTION_in_action318); if (state.failed) return;
					if ( state.backtracking==0 ) {scope=null; nameAST=id1; actionAST=a2;}
					}
					break;

			}

			match(input, Token.UP, null); if (state.failed) return;

			if ( state.backtracking==0 ) {
					 grammar.defineNamedAction(amp,scope,nameAST,actionAST);
					 }
			}

		}
		catch (RecognitionException re) {
			reportError(re);
			recover(input,re);
		}
		finally {
			// do for sure before leaving
		}
	}
	// $ANTLR end "action"



	// $ANTLR start "optionsSpec"
	// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:181:1: optionsSpec : ^( OPTIONS ( . )* ) ;
	public final void optionsSpec() throws RecognitionException {
		try {
			// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:182:2: ( ^( OPTIONS ( . )* ) )
			// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:182:4: ^( OPTIONS ( . )* )
			{
			match(input,OPTIONS,FOLLOW_OPTIONS_in_optionsSpec352); if (state.failed) return;
			if ( input.LA(1)==Token.DOWN ) {
				match(input, Token.DOWN, null); if (state.failed) return;
				// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:182:14: ( . )*
				loop11:
				while (true) {
					int alt11=2;
					int LA11_0 = input.LA(1);
					if ( ((LA11_0 >= ACTION && LA11_0 <= XDIGIT)) ) {
						alt11=1;
					}
					else if ( (LA11_0==UP) ) {
						alt11=2;
					}

					switch (alt11) {
					case 1 :
						// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:182:14: .
						{
						matchAny(input); if (state.failed) return;
						}
						break;

					default :
						break loop11;
					}
				}

				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 "optionsSpec"



	// $ANTLR start "delegateGrammars"
	// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:185:1: delegateGrammars : ^( 'import' ( ^( ASSIGN ID ID ) | ID )+ ) ;
	public final void delegateGrammars() throws RecognitionException {
		try {
			// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:186:2: ( ^( 'import' ( ^( ASSIGN ID ID ) | ID )+ ) )
			// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:186:4: ^( 'import' ( ^( ASSIGN ID ID ) | ID )+ )
			{
			match(input,IMPORT,FOLLOW_IMPORT_in_delegateGrammars369); if (state.failed) return;
			match(input, Token.DOWN, null); if (state.failed) return;
			// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:186:16: ( ^( ASSIGN ID ID ) | ID )+
			int cnt12=0;
			loop12:
			while (true) {
				int alt12=3;
				int LA12_0 = input.LA(1);
				if ( (LA12_0==ASSIGN) ) {
					alt12=1;
				}
				else if ( (LA12_0==ID) ) {
					alt12=2;
				}

				switch (alt12) {
				case 1 :
					// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:186:18: ^( ASSIGN ID ID )
					{
					match(input,ASSIGN,FOLLOW_ASSIGN_in_delegateGrammars374); if (state.failed) return;
					match(input, Token.DOWN, null); if (state.failed) return;
					match(input,ID,FOLLOW_ID_in_delegateGrammars376); if (state.failed) return;
					match(input,ID,FOLLOW_ID_in_delegateGrammars378); if (state.failed) return;
					match(input, Token.UP, null); if (state.failed) return;

					}
					break;
				case 2 :
					// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:186:36: ID
					{
					match(input,ID,FOLLOW_ID_in_delegateGrammars383); if (state.failed) return;
					}
					break;

				default :
					if ( cnt12 >= 1 ) break loop12;
					if (state.backtracking>0) {state.failed=true; return;}
					EarlyExitException eee = new EarlyExitException(12, input);
					throw eee;
				}
				cnt12++;
			}

			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 "delegateGrammars"



	// $ANTLR start "tokensSpec"
	// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:189:1: tokensSpec : ^( TOKENS ( tokenSpec )* ) ;
	public final void tokensSpec() throws RecognitionException {
		try {
			// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:190:2: ( ^( TOKENS ( tokenSpec )* ) )
			// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:190:4: ^( TOKENS ( tokenSpec )* )
			{
			match(input,TOKENS,FOLLOW_TOKENS_in_tokensSpec400); if (state.failed) return;
			if ( input.LA(1)==Token.DOWN ) {
				match(input, Token.DOWN, null); if (state.failed) return;
				// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:190:13: ( tokenSpec )*
				loop13:
				while (true) {
					int alt13=2;
					int LA13_0 = input.LA(1);
					if ( (LA13_0==ASSIGN||LA13_0==TOKEN_REF) ) {
						alt13=1;
					}

					switch (alt13) {
					case 1 :
						// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:190:13: tokenSpec
						{
						pushFollow(FOLLOW_tokenSpec_in_tokensSpec402);
						tokenSpec();
						state._fsp--;
						if (state.failed) return;
						}
						break;

					default :
						break loop13;
					}
				}

				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 "tokensSpec"



	// $ANTLR start "tokenSpec"
	// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:193:1: tokenSpec : (t= TOKEN_REF | ^( ASSIGN TOKEN_REF ( STRING_LITERAL | CHAR_LITERAL ) ) );
	public final void tokenSpec() throws RecognitionException {
		GrammarAST t=null;

		try {
			// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:194:2: (t= TOKEN_REF | ^( ASSIGN TOKEN_REF ( STRING_LITERAL | CHAR_LITERAL ) ) )
			int alt14=2;
			int LA14_0 = input.LA(1);
			if ( (LA14_0==TOKEN_REF) ) {
				alt14=1;
			}
			else if ( (LA14_0==ASSIGN) ) {
				alt14=2;
			}

			else {
				if (state.backtracking>0) {state.failed=true; return;}
				NoViableAltException nvae =
					new NoViableAltException("", 14, 0, input);
				throw nvae;
			}

			switch (alt14) {
				case 1 :
					// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:194:4: t= TOKEN_REF
					{
					t=(GrammarAST)match(input,TOKEN_REF,FOLLOW_TOKEN_REF_in_tokenSpec417); if (state.failed) return;
					}
					break;
				case 2 :
					// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:195:4: ^( ASSIGN TOKEN_REF ( STRING_LITERAL | CHAR_LITERAL ) )
					{
					match(input,ASSIGN,FOLLOW_ASSIGN_in_tokenSpec424); if (state.failed) return;
					match(input, Token.DOWN, null); if (state.failed) return;
					match(input,TOKEN_REF,FOLLOW_TOKEN_REF_in_tokenSpec429); if (state.failed) return;
					if ( input.LA(1)==CHAR_LITERAL||input.LA(1)==STRING_LITERAL ) {
						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;
					}
					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 "tokenSpec"



	// $ANTLR start "rules"
	// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:203:1: rules : ( rule | ^( PREC_RULE ( . )* ) )+ ;
	public final void rules() throws RecognitionException {
		try {
			// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:204:2: ( ( rule | ^( PREC_RULE ( . )* ) )+ )
			// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:204:4: ( rule | ^( PREC_RULE ( . )* ) )+
			{
			// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:204:4: ( rule | ^( PREC_RULE ( . )* ) )+
			int cnt16=0;
			loop16:
			while (true) {
				int alt16=3;
				int LA16_0 = input.LA(1);
				if ( (LA16_0==RULE) ) {
					alt16=1;
				}
				else if ( (LA16_0==PREC_RULE) ) {
					alt16=2;
				}

				switch (alt16) {
				case 1 :
					// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:204:5: rule
					{
					pushFollow(FOLLOW_rule_in_rules465);
					rule();
					state._fsp--;
					if (state.failed) return;
					}
					break;
				case 2 :
					// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:204:12: ^( PREC_RULE ( . )* )
					{
					match(input,PREC_RULE,FOLLOW_PREC_RULE_in_rules470); if (state.failed) return;
					if ( input.LA(1)==Token.DOWN ) {
						match(input, Token.DOWN, null); if (state.failed) return;
						// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:204:24: ( . )*
						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\\DefineGrammarItemsWalker.g:204:24: .
								{
								matchAny(input); if (state.failed) return;
								}
								break;

							default :
								break loop15;
							}
						}

						match(input, Token.UP, null); if (state.failed) return;
					}

					}
					break;

				default :
					if ( cnt16 >= 1 ) break loop16;
					if (state.backtracking>0) {state.failed=true; return;}
					EarlyExitException eee = new EarlyExitException(16, input);
					throw eee;
				}
				cnt16++;
			}

			}

		}
		catch (RecognitionException re) {
			reportError(re);
			recover(input,re);
		}
		finally {
			// do for sure before leaving
		}
	}
	// $ANTLR end "rules"


	public static class rule_return extends TreeRuleReturnScope {
	};


	// $ANTLR start "rule"
	// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:207:1: rule : ^( RULE id= ID ( modifier )? ^( ARG (args= ARG_ACTION )? ) ^( RET (ret= ARG_ACTION )? ) ( throwsSpec )? ( optionsSpec )? ( ruleScopeSpec[r] )? ( ruleAction[r] )* b= block ( exceptionGroup )? EOR ) ;
	public final DefineGrammarItemsWalker.rule_return rule() throws RecognitionException {
		DefineGrammarItemsWalker.rule_return retval = new DefineGrammarItemsWalker.rule_return();
		retval.start = input.LT(1);

		GrammarAST id=null;
		GrammarAST args=null;
		GrammarAST ret=null;
		GrammarAST RULE3=null;
		TreeRuleReturnScope b =null;
		TreeRuleReturnScope modifier4 =null;
		HashSet throwsSpec5 =null;


			String name=null;
			Map opts=null;
			Rule r = null;

		try {
			// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:214:2: ( ^( RULE id= ID ( modifier )? ^( ARG (args= ARG_ACTION )? ) ^( RET (ret= ARG_ACTION )? ) ( throwsSpec )? ( optionsSpec )? ( ruleScopeSpec[r] )? ( ruleAction[r] )* b= block ( exceptionGroup )? EOR ) )
			// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:214:5: ^( RULE id= ID ( modifier )? ^( ARG (args= ARG_ACTION )? ) ^( RET (ret= ARG_ACTION )? ) ( throwsSpec )? ( optionsSpec )? ( ruleScopeSpec[r] )? ( ruleAction[r] )* b= block ( exceptionGroup )? EOR )
			{
			RULE3=(GrammarAST)match(input,RULE,FOLLOW_RULE_in_rule495); if (state.failed) return retval;
			match(input, Token.DOWN, null); if (state.failed) return retval;
			id=(GrammarAST)match(input,ID,FOLLOW_ID_in_rule499); if (state.failed) return retval;
			if ( state.backtracking==0 ) {opts = RULE3.getBlockOptions();}
			// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:215:4: ( modifier )?
			int alt17=2;
			int LA17_0 = input.LA(1);
			if ( (LA17_0==FRAGMENT||(LA17_0 >= PRIVATE && LA17_0 <= PUBLIC)) ) {
				alt17=1;
			}
			switch (alt17) {
				case 1 :
					// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:215:5: modifier
					{
					pushFollow(FOLLOW_modifier_in_rule507);
					modifier4=modifier();
					state._fsp--;
					if (state.failed) return retval;
					}
					break;

			}

			match(input,ARG,FOLLOW_ARG_in_rule516); 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\\DefineGrammarItemsWalker.g:216:11: (args= ARG_ACTION )?
				int alt18=2;
				int LA18_0 = input.LA(1);
				if ( (LA18_0==ARG_ACTION) ) {
					alt18=1;
				}
				switch (alt18) {
					case 1 :
						// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:216:12: args= ARG_ACTION
						{
						args=(GrammarAST)match(input,ARG_ACTION,FOLLOW_ARG_ACTION_in_rule521); if (state.failed) return retval;
						}
						break;

				}

				match(input, Token.UP, null); if (state.failed) return retval;
			}

			match(input,RET,FOLLOW_RET_in_rule532); 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\\DefineGrammarItemsWalker.g:217:11: (ret= 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\\DefineGrammarItemsWalker.g:217:12: ret= ARG_ACTION
						{
						ret=(GrammarAST)match(input,ARG_ACTION,FOLLOW_ARG_ACTION_in_rule537); if (state.failed) return retval;
						}
						break;

				}

				match(input, Token.UP, null); if (state.failed) return retval;
			}

			// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:218:4: ( throwsSpec )?
			int alt20=2;
			int LA20_0 = input.LA(1);
			if ( (LA20_0==THROWS) ) {
				alt20=1;
			}
			switch (alt20) {
				case 1 :
					// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:218:5: throwsSpec
					{
					pushFollow(FOLLOW_throwsSpec_in_rule547);
					throwsSpec5=throwsSpec();
					state._fsp--;
					if (state.failed) return retval;
					}
					break;

			}

			// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:219:4: ( optionsSpec )?
			int alt21=2;
			int LA21_0 = input.LA(1);
			if ( (LA21_0==OPTIONS) ) {
				alt21=1;
			}
			switch (alt21) {
				case 1 :
					// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:219:5: optionsSpec
					{
					pushFollow(FOLLOW_optionsSpec_in_rule555);
					optionsSpec();
					state._fsp--;
					if (state.failed) return retval;
					}
					break;

			}

			if ( state.backtracking==0 ) {
							name = (id!=null?id.getText():null);
							currentRuleName = name;
							if ( Rule.getRuleType(name) == Grammar.LEXER && grammar.type==Grammar.COMBINED )
							{
								// a merged grammar spec, track lexer rules and send to another grammar
								grammar.defineLexerRuleFoundInParser(id.getToken(), ((GrammarAST)retval.start));
							}
							else
							{
								int numAlts = countAltsForRule(((GrammarAST)retval.start));
								grammar.defineRule(id.getToken(), (modifier4!=null?((DefineGrammarItemsWalker.modifier_return)modifier4).mod:null), opts, ((GrammarAST)retval.start), args, numAlts);
								r = grammar.getRule(name);
								if ( args!=null )
								{
									r.parameterScope = grammar.createParameterScope(name,args.getToken());
									r.parameterScope.addAttributes((args!=null?args.getText():null), ',');
								}
								if ( ret!=null )
								{
									r.returnScope = grammar.createReturnScope(name,ret.getToken());
									r.returnScope.addAttributes((ret!=null?ret.getText():null), ',');
								}
								if ( throwsSpec5 != null )
								{
									for (String exception : throwsSpec5)
										r.throwsSpec.add( exception );
								}
							}
						}
			// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:250:4: ( ruleScopeSpec[r] )?
			int alt22=2;
			int LA22_0 = input.LA(1);
			if ( (LA22_0==SCOPE) ) {
				alt22=1;
			}
			switch (alt22) {
				case 1 :
					// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:250:5: ruleScopeSpec[r]
					{
					pushFollow(FOLLOW_ruleScopeSpec_in_rule568);
					ruleScopeSpec(r);
					state._fsp--;
					if (state.failed) return retval;
					}
					break;

			}

			// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:251:4: ( ruleAction[r] )*
			loop23:
			while (true) {
				int alt23=2;
				int LA23_0 = input.LA(1);
				if ( (LA23_0==AMPERSAND) ) {
					alt23=1;
				}

				switch (alt23) {
				case 1 :
					// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:251:5: ruleAction[r]
					{
					pushFollow(FOLLOW_ruleAction_in_rule577);
					ruleAction(r);
					state._fsp--;
					if (state.failed) return retval;
					}
					break;

				default :
					break loop23;
				}
			}

			if ( state.backtracking==0 ) { this.blockLevel=0; }
			pushFollow(FOLLOW_block_in_rule592);
			b=block();
			state._fsp--;
			if (state.failed) return retval;
			// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:254:4: ( exceptionGroup )?
			int alt24=2;
			int LA24_0 = input.LA(1);
			if ( (LA24_0==CATCH||LA24_0==FINALLY) ) {
				alt24=1;
			}
			switch (alt24) {
				case 1 :
					// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:254:5: exceptionGroup
					{
					pushFollow(FOLLOW_exceptionGroup_in_rule598);
					exceptionGroup();
					state._fsp--;
					if (state.failed) return retval;
					}
					break;

			}

			match(input,EOR,FOLLOW_EOR_in_rule605); if (state.failed) return retval;
			if ( state.backtracking==0 ) {
							// copy rule options into the block AST, which is where
							// the analysis will look for k option etc...
							(b!=null?((GrammarAST)b.start):null).setBlockOptions(opts);
						}
			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 "rule"



	// $ANTLR start "ruleAction"
	// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:264:1: ruleAction[Rule r] : ^(amp= AMPERSAND id= ID a= ACTION ) ;
	public final void ruleAction(Rule r) throws RecognitionException {
		GrammarAST amp=null;
		GrammarAST id=null;
		GrammarAST a=null;

		try {
			// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:265:2: ( ^(amp= AMPERSAND id= ID a= ACTION ) )
			// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:265:4: ^(amp= AMPERSAND id= ID a= ACTION )
			{
			amp=(GrammarAST)match(input,AMPERSAND,FOLLOW_AMPERSAND_in_ruleAction629); if (state.failed) return;
			match(input, Token.DOWN, null); if (state.failed) return;
			id=(GrammarAST)match(input,ID,FOLLOW_ID_in_ruleAction633); if (state.failed) return;
			a=(GrammarAST)match(input,ACTION,FOLLOW_ACTION_in_ruleAction637); if (state.failed) return;
			match(input, Token.UP, null); if (state.failed) return;

			if ( state.backtracking==0 ) {if (r!=null) r.defineNamedAction(amp,id,a);}
			}

		}
		catch (RecognitionException re) {
			reportError(re);
			recover(input,re);
		}
		finally {
			// do for sure before leaving
		}
	}
	// $ANTLR end "ruleAction"


	public static class modifier_return extends TreeRuleReturnScope {
		public String mod;
	};


	// $ANTLR start "modifier"
	// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:268:1: modifier returns [String mod] : ( 'protected' | 'public' | 'private' | 'fragment' );
	public final DefineGrammarItemsWalker.modifier_return modifier() throws RecognitionException {
		DefineGrammarItemsWalker.modifier_return retval = new DefineGrammarItemsWalker.modifier_return();
		retval.start = input.LT(1);


			retval.mod = ((GrammarAST)retval.start).getToken().getText();

		try {
			// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:273:2: ( 'protected' | 'public' | 'private' | 'fragment' )
			// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.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\\DefineGrammarItemsWalker.g:279:1: throwsSpec returns [HashSet exceptions] : ^( 'throws' ( ID )+ ) ;
	public final HashSet throwsSpec() throws RecognitionException {
		HashSet exceptions = null;


		GrammarAST ID6=null;


			exceptions = new HashSet();

		try {
			// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:284:2: ( ^( 'throws' ( ID )+ ) )
			// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:284:4: ^( 'throws' ( ID )+ )
			{
			match(input,THROWS,FOLLOW_THROWS_in_throwsSpec697); if (state.failed) return exceptions;
			match(input, Token.DOWN, null); if (state.failed) return exceptions;
			// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:284:15: ( ID )+
			int cnt25=0;
			loop25:
			while (true) {
				int alt25=2;
				int LA25_0 = input.LA(1);
				if ( (LA25_0==ID) ) {
					alt25=1;
				}

				switch (alt25) {
				case 1 :
					// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:284:16: ID
					{
					ID6=(GrammarAST)match(input,ID,FOLLOW_ID_in_throwsSpec700); if (state.failed) return exceptions;
					if ( state.backtracking==0 ) {exceptions.add((ID6!=null?ID6.getText():null));}
					}
					break;

				default :
					if ( cnt25 >= 1 ) break loop25;
					if (state.backtracking>0) {state.failed=true; return exceptions;}
					EarlyExitException eee = new EarlyExitException(25, input);
					throw eee;
				}
				cnt25++;
			}

			match(input, Token.UP, null); if (state.failed) return exceptions;

			}

		}
		catch (RecognitionException re) {
			reportError(re);
			recover(input,re);
		}
		finally {
			// do for sure before leaving
		}
		return exceptions;
	}
	// $ANTLR end "throwsSpec"



	// $ANTLR start "ruleScopeSpec"
	// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:287:1: ruleScopeSpec[Rule r] : ^( 'scope' ( ( attrScopeAction )* attrs= ACTION )? (uses= ID )* ) ;
	public final void ruleScopeSpec(Rule r) throws RecognitionException {
		AttributeScopeActions_stack.push(new AttributeScopeActions_scope());

		GrammarAST attrs=null;
		GrammarAST uses=null;


			AttributeScopeActions_stack.peek().actions = new HashMap();

		try {
			// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:293:2: ( ^( 'scope' ( ( attrScopeAction )* attrs= ACTION )? (uses= ID )* ) )
			// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:293:4: ^( 'scope' ( ( attrScopeAction )* attrs= ACTION )? (uses= ID )* )
			{
			match(input,SCOPE,FOLLOW_SCOPE_in_ruleScopeSpec730); if (state.failed) return;
			if ( input.LA(1)==Token.DOWN ) {
				match(input, Token.DOWN, null); if (state.failed) return;
				// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:294:4: ( ( attrScopeAction )* attrs= ACTION )?
				int alt27=2;
				int LA27_0 = input.LA(1);
				if ( (LA27_0==ACTION||LA27_0==AMPERSAND) ) {
					alt27=1;
				}
				switch (alt27) {
					case 1 :
						// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:294:6: ( attrScopeAction )* attrs= ACTION
						{
						// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:294:6: ( attrScopeAction )*
						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\\DefineGrammarItemsWalker.g:294:6: attrScopeAction
								{
								pushFollow(FOLLOW_attrScopeAction_in_ruleScopeSpec737);
								attrScopeAction();
								state._fsp--;
								if (state.failed) return;
								}
								break;

							default :
								break loop26;
							}
						}

						attrs=(GrammarAST)match(input,ACTION,FOLLOW_ACTION_in_ruleScopeSpec742); if (state.failed) return;
						if ( state.backtracking==0 ) {
											r.ruleScope = grammar.createRuleScope(r.name,attrs.getToken());
											r.ruleScope.isDynamicRuleScope = true;
											r.ruleScope.addAttributes((attrs!=null?attrs.getText():null), ';');
											for (GrammarAST action : AttributeScopeActions_stack.peek().actions.keySet())
												r.ruleScope.defineNamedAction(action, AttributeScopeActions_stack.peek().actions.get(action));
										}
						}
						break;

				}

				// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:303:4: (uses= ID )*
				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\\DefineGrammarItemsWalker.g:303:6: uses= ID
						{
						uses=(GrammarAST)match(input,ID,FOLLOW_ID_in_ruleScopeSpec763); if (state.failed) return;
						if ( state.backtracking==0 ) {
											if ( grammar.getGlobalScope((uses!=null?uses.getText():null))==null ) {
											ErrorManager.grammarError(ErrorManager.MSG_UNKNOWN_DYNAMIC_SCOPE,
											grammar,
											uses.getToken(),
											(uses!=null?uses.getText():null));
											}
											else {
											if ( r.useScopes==null ) {r.useScopes=new ArrayList();}
											r.useScopes.add((uses!=null?uses.getText():null));
											}
										}
						}
						break;

					default :
						break loop28;
					}
				}

				match(input, Token.UP, null); if (state.failed) return;
			}

			}

		}
		catch (RecognitionException re) {
			reportError(re);
			recover(input,re);
		}
		finally {
			// do for sure before leaving
			AttributeScopeActions_stack.pop();

		}
	}
	// $ANTLR end "ruleScopeSpec"


	public static class block_return extends TreeRuleReturnScope {
	};


	// $ANTLR start "block"
	// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:320:1: block : ^( BLOCK ( optionsSpec )? ( blockAction )* ( alternative rewrite )+ EOB ) ;
	public final DefineGrammarItemsWalker.block_return block() throws RecognitionException {
		DefineGrammarItemsWalker.block_return retval = new DefineGrammarItemsWalker.block_return();
		retval.start = input.LT(1);


			// must run during backtracking
			this.blockLevel++;
			if ( blockLevel == 1 )
				this.outerAltNum=1;

		try {
			// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:328:2: ( ^( BLOCK ( optionsSpec )? ( blockAction )* ( alternative rewrite )+ EOB ) )
			// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:328:4: ^( BLOCK ( optionsSpec )? ( blockAction )* ( alternative rewrite )+ EOB )
			{
			match(input,BLOCK,FOLLOW_BLOCK_in_block797); if (state.failed) return retval;
			match(input, Token.DOWN, null); if (state.failed) return retval;
			// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:329:4: ( optionsSpec )?
			int alt29=2;
			int LA29_0 = input.LA(1);
			if ( (LA29_0==OPTIONS) ) {
				alt29=1;
			}
			switch (alt29) {
				case 1 :
					// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:329:5: optionsSpec
					{
					pushFollow(FOLLOW_optionsSpec_in_block803);
					optionsSpec();
					state._fsp--;
					if (state.failed) return retval;
					}
					break;

			}

			// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:330:4: ( blockAction )*
			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\\DefineGrammarItemsWalker.g:330:5: blockAction
					{
					pushFollow(FOLLOW_blockAction_in_block811);
					blockAction();
					state._fsp--;
					if (state.failed) return retval;
					}
					break;

				default :
					break loop30;
				}
			}

			// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:331:4: ( alternative rewrite )+
			int cnt31=0;
			loop31:
			while (true) {
				int alt31=2;
				int LA31_0 = input.LA(1);
				if ( (LA31_0==ALT) ) {
					alt31=1;
				}

				switch (alt31) {
				case 1 :
					// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:331:6: alternative rewrite
					{
					pushFollow(FOLLOW_alternative_in_block820);
					alternative();
					state._fsp--;
					if (state.failed) return retval;
					pushFollow(FOLLOW_rewrite_in_block822);
					rewrite();
					state._fsp--;
					if (state.failed) return retval;

										if ( this.blockLevel == 1 )
											this.outerAltNum++;
									
					}
					break;

				default :
					if ( cnt31 >= 1 ) break loop31;
					if (state.backtracking>0) {state.failed=true; return retval;}
					EarlyExitException eee = new EarlyExitException(31, input);
					throw eee;
				}
				cnt31++;
			}

			match(input,EOB,FOLLOW_EOB_in_block839); 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
			 blockLevel--; 
		}
		return retval;
	}
	// $ANTLR end "block"



	// $ANTLR start "blockAction"
	// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:343:1: blockAction : ^(amp= AMPERSAND id= ID a= ACTION ) ;
	public final void blockAction() throws RecognitionException {
		GrammarAST amp=null;
		GrammarAST id=null;
		GrammarAST a=null;

		try {
			// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:344:2: ( ^(amp= AMPERSAND id= ID a= ACTION ) )
			// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:344:4: ^(amp= AMPERSAND id= ID a= ACTION )
			{
			amp=(GrammarAST)match(input,AMPERSAND,FOLLOW_AMPERSAND_in_blockAction863); if (state.failed) return;
			match(input, Token.DOWN, null); if (state.failed) return;
			id=(GrammarAST)match(input,ID,FOLLOW_ID_in_blockAction867); if (state.failed) return;
			a=(GrammarAST)match(input,ACTION,FOLLOW_ACTION_in_blockAction871); 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 "blockAction"



	// $ANTLR start "alternative"
	// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:347:1: alternative : ^( ALT ( element )+ EOA ) ;
	public final void alternative() throws RecognitionException {
		try {
			// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:370:2: ( ^( ALT ( element )+ EOA ) )
			// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:370:4: ^( ALT ( element )+ EOA )
			{
			match(input,ALT,FOLLOW_ALT_in_alternative909); if (state.failed) return;
			match(input, Token.DOWN, null); if (state.failed) return;
			// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:370:11: ( element )+
			int cnt32=0;
			loop32:
			while (true) {
				int alt32=2;
				int LA32_0 = input.LA(1);
				if ( (LA32_0==ACTION||(LA32_0 >= ASSIGN && LA32_0 <= BLOCK)||(LA32_0 >= CHAR_LITERAL && LA32_0 <= CHAR_RANGE)||LA32_0==CLOSURE||LA32_0==DOT||LA32_0==EPSILON||LA32_0==FORCED_ACTION||LA32_0==GATED_SEMPRED||LA32_0==NOT||LA32_0==OPTIONAL||(LA32_0 >= PLUS_ASSIGN && LA32_0 <= POSITIVE_CLOSURE)||LA32_0==RANGE||LA32_0==ROOT||LA32_0==RULE_REF||LA32_0==SEMPRED||(LA32_0 >= STRING_LITERAL && LA32_0 <= SYN_SEMPRED)||LA32_0==TOKEN_REF||LA32_0==TREE_BEGIN||LA32_0==WILDCARD) ) {
					alt32=1;
				}

				switch (alt32) {
				case 1 :
					// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:370:12: element
					{
					pushFollow(FOLLOW_element_in_alternative912);
					element();
					state._fsp--;
					if (state.failed) return;
					}
					break;

				default :
					if ( cnt32 >= 1 ) break loop32;
					if (state.backtracking>0) {state.failed=true; return;}
					EarlyExitException eee = new EarlyExitException(32, input);
					throw eee;
				}
				cnt32++;
			}

			match(input,EOA,FOLLOW_EOA_in_alternative916); 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 "alternative"



	// $ANTLR start "exceptionGroup"
	// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:373:1: exceptionGroup : ( ( exceptionHandler )+ ( finallyClause )? | finallyClause );
	public final void exceptionGroup() throws RecognitionException {
		try {
			// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:374:2: ( ( exceptionHandler )+ ( finallyClause )? | finallyClause )
			int alt35=2;
			int LA35_0 = input.LA(1);
			if ( (LA35_0==CATCH) ) {
				alt35=1;
			}
			else if ( (LA35_0==FINALLY) ) {
				alt35=2;
			}

			else {
				if (state.backtracking>0) {state.failed=true; return;}
				NoViableAltException nvae =
					new NoViableAltException("", 35, 0, input);
				throw nvae;
			}

			switch (alt35) {
				case 1 :
					// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:374:4: ( exceptionHandler )+ ( finallyClause )?
					{
					// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:374:4: ( exceptionHandler )+
					int cnt33=0;
					loop33:
					while (true) {
						int alt33=2;
						int LA33_0 = input.LA(1);
						if ( (LA33_0==CATCH) ) {
							alt33=1;
						}

						switch (alt33) {
						case 1 :
							// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:374:6: exceptionHandler
							{
							pushFollow(FOLLOW_exceptionHandler_in_exceptionGroup931);
							exceptionHandler();
							state._fsp--;
							if (state.failed) return;
							}
							break;

						default :
							if ( cnt33 >= 1 ) break loop33;
							if (state.backtracking>0) {state.failed=true; return;}
							EarlyExitException eee = new EarlyExitException(33, input);
							throw eee;
						}
						cnt33++;
					}

					// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:374:26: ( finallyClause )?
					int alt34=2;
					int LA34_0 = input.LA(1);
					if ( (LA34_0==FINALLY) ) {
						alt34=1;
					}
					switch (alt34) {
						case 1 :
							// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:374:27: finallyClause
							{
							pushFollow(FOLLOW_finallyClause_in_exceptionGroup937);
							finallyClause();
							state._fsp--;
							if (state.failed) return;
							}
							break;

					}

					}
					break;
				case 2 :
					// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:375:4: finallyClause
					{
					pushFollow(FOLLOW_finallyClause_in_exceptionGroup944);
					finallyClause();
					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\\DefineGrammarItemsWalker.g:378:1: exceptionHandler : ^( 'catch' ARG_ACTION ACTION ) ;
	public final void exceptionHandler() throws RecognitionException {
		GrammarAST ACTION7=null;

		try {
			// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:379:2: ( ^( 'catch' ARG_ACTION ACTION ) )
			// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:379:6: ^( 'catch' ARG_ACTION ACTION )
			{
			match(input,CATCH,FOLLOW_CATCH_in_exceptionHandler958); if (state.failed) return;
			match(input, Token.DOWN, null); if (state.failed) return;
			match(input,ARG_ACTION,FOLLOW_ARG_ACTION_in_exceptionHandler960); if (state.failed) return;
			ACTION7=(GrammarAST)match(input,ACTION,FOLLOW_ACTION_in_exceptionHandler962); if (state.failed) return;
			match(input, Token.UP, null); if (state.failed) return;

			if ( state.backtracking==0 ) {trackInlineAction(ACTION7);}
			}

		}
		catch (RecognitionException re) {
			reportError(re);
			recover(input,re);
		}
		finally {
			// do for sure before leaving
		}
	}
	// $ANTLR end "exceptionHandler"



	// $ANTLR start "finallyClause"
	// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:382:1: finallyClause : ^( 'finally' ACTION ) ;
	public final void finallyClause() throws RecognitionException {
		GrammarAST ACTION8=null;

		try {
			// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:383:2: ( ^( 'finally' ACTION ) )
			// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:383:7: ^( 'finally' ACTION )
			{
			match(input,FINALLY,FOLLOW_FINALLY_in_finallyClause980); if (state.failed) return;
			match(input, Token.DOWN, null); if (state.failed) return;
			ACTION8=(GrammarAST)match(input,ACTION,FOLLOW_ACTION_in_finallyClause982); if (state.failed) return;
			match(input, Token.UP, null); if (state.failed) return;

			if ( state.backtracking==0 ) {trackInlineAction(ACTION8);}
			}

		}
		catch (RecognitionException re) {
			reportError(re);
			recover(input,re);
		}
		finally {
			// do for sure before leaving
		}
	}
	// $ANTLR end "finallyClause"


	public static class element_return extends TreeRuleReturnScope {
	};


	// $ANTLR start "element"
	// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:386:1: element : ( ^( ROOT element ) | ^( BANG element ) | atom[null] | ^( NOT element ) | ^( RANGE atom[null] atom[null] ) | ^( CHAR_RANGE atom[null] atom[null] ) | ^( ASSIGN id= ID el= element ) | ^( PLUS_ASSIGN id2= ID a2= element ) | ebnf | tree_ | ^( SYNPRED block ) |act= ACTION |act2= FORCED_ACTION | SEMPRED | SYN_SEMPRED | ^( BACKTRACK_SEMPRED ( . )* ) | GATED_SEMPRED | EPSILON );
	public final DefineGrammarItemsWalker.element_return element() throws RecognitionException {
		DefineGrammarItemsWalker.element_return retval = new DefineGrammarItemsWalker.element_return();
		retval.start = input.LT(1);

		GrammarAST id=null;
		GrammarAST id2=null;
		GrammarAST act=null;
		GrammarAST act2=null;
		GrammarAST SEMPRED9=null;
		GrammarAST GATED_SEMPRED10=null;
		TreeRuleReturnScope el =null;
		TreeRuleReturnScope a2 =null;

		try {
			// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:387:2: ( ^( ROOT element ) | ^( BANG element ) | atom[null] | ^( NOT element ) | ^( RANGE atom[null] atom[null] ) | ^( CHAR_RANGE atom[null] atom[null] ) | ^( ASSIGN id= ID el= element ) | ^( PLUS_ASSIGN id2= ID a2= element ) | ebnf | tree_ | ^( SYNPRED block ) |act= ACTION |act2= FORCED_ACTION | SEMPRED | SYN_SEMPRED | ^( BACKTRACK_SEMPRED ( . )* ) | GATED_SEMPRED | EPSILON )
			int alt37=18;
			switch ( input.LA(1) ) {
			case ROOT:
				{
				alt37=1;
				}
				break;
			case BANG:
				{
				alt37=2;
				}
				break;
			case CHAR_LITERAL:
			case DOT:
			case RULE_REF:
			case STRING_LITERAL:
			case TOKEN_REF:
			case WILDCARD:
				{
				alt37=3;
				}
				break;
			case NOT:
				{
				alt37=4;
				}
				break;
			case RANGE:
				{
				alt37=5;
				}
				break;
			case CHAR_RANGE:
				{
				alt37=6;
				}
				break;
			case ASSIGN:
				{
				alt37=7;
				}
				break;
			case PLUS_ASSIGN:
				{
				alt37=8;
				}
				break;
			case BLOCK:
			case CLOSURE:
			case OPTIONAL:
			case POSITIVE_CLOSURE:
				{
				alt37=9;
				}
				break;
			case TREE_BEGIN:
				{
				alt37=10;
				}
				break;
			case SYNPRED:
				{
				alt37=11;
				}
				break;
			case ACTION:
				{
				alt37=12;
				}
				break;
			case FORCED_ACTION:
				{
				alt37=13;
				}
				break;
			case SEMPRED:
				{
				alt37=14;
				}
				break;
			case SYN_SEMPRED:
				{
				alt37=15;
				}
				break;
			case BACKTRACK_SEMPRED:
				{
				alt37=16;
				}
				break;
			case GATED_SEMPRED:
				{
				alt37=17;
				}
				break;
			case EPSILON:
				{
				alt37=18;
				}
				break;
			default:
				if (state.backtracking>0) {state.failed=true; return retval;}
				NoViableAltException nvae =
					new NoViableAltException("", 37, 0, input);
				throw nvae;
			}
			switch (alt37) {
				case 1 :
					// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:387:6: ^( ROOT element )
					{
					match(input,ROOT,FOLLOW_ROOT_in_element999); if (state.failed) return retval;
					match(input, Token.DOWN, null); if (state.failed) return retval;
					pushFollow(FOLLOW_element_in_element1001);
					element();
					state._fsp--;
					if (state.failed) return retval;
					match(input, Token.UP, null); if (state.failed) return retval;

					}
					break;
				case 2 :
					// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:388:6: ^( BANG element )
					{
					match(input,BANG,FOLLOW_BANG_in_element1010); if (state.failed) return retval;
					match(input, Token.DOWN, null); if (state.failed) return retval;
					pushFollow(FOLLOW_element_in_element1012);
					element();
					state._fsp--;
					if (state.failed) return retval;
					match(input, Token.UP, null); if (state.failed) return retval;

					}
					break;
				case 3 :
					// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:389:6: atom[null]
					{
					pushFollow(FOLLOW_atom_in_element1020);
					atom(null);
					state._fsp--;
					if (state.failed) return retval;
					}
					break;
				case 4 :
					// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:390:6: ^( NOT element )
					{
					match(input,NOT,FOLLOW_NOT_in_element1029); if (state.failed) return retval;
					match(input, Token.DOWN, null); if (state.failed) return retval;
					pushFollow(FOLLOW_element_in_element1031);
					element();
					state._fsp--;
					if (state.failed) return retval;
					match(input, Token.UP, null); if (state.failed) return retval;

					}
					break;
				case 5 :
					// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:391:6: ^( RANGE atom[null] atom[null] )
					{
					match(input,RANGE,FOLLOW_RANGE_in_element1040); if (state.failed) return retval;
					match(input, Token.DOWN, null); if (state.failed) return retval;
					pushFollow(FOLLOW_atom_in_element1042);
					atom(null);
					state._fsp--;
					if (state.failed) return retval;
					pushFollow(FOLLOW_atom_in_element1045);
					atom(null);
					state._fsp--;
					if (state.failed) return retval;
					match(input, Token.UP, null); if (state.failed) return retval;

					}
					break;
				case 6 :
					// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:392:6: ^( CHAR_RANGE atom[null] atom[null] )
					{
					match(input,CHAR_RANGE,FOLLOW_CHAR_RANGE_in_element1055); if (state.failed) return retval;
					match(input, Token.DOWN, null); if (state.failed) return retval;
					pushFollow(FOLLOW_atom_in_element1057);
					atom(null);
					state._fsp--;
					if (state.failed) return retval;
					pushFollow(FOLLOW_atom_in_element1060);
					atom(null);
					state._fsp--;
					if (state.failed) return retval;
					match(input, Token.UP, null); if (state.failed) return retval;

					}
					break;
				case 7 :
					// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:393:4: ^( ASSIGN id= ID el= element )
					{
					match(input,ASSIGN,FOLLOW_ASSIGN_in_element1069); if (state.failed) return retval;
					match(input, Token.DOWN, null); if (state.failed) return retval;
					id=(GrammarAST)match(input,ID,FOLLOW_ID_in_element1073); if (state.failed) return retval;
					pushFollow(FOLLOW_element_in_element1077);
					el=element();
					state._fsp--;
					if (state.failed) return retval;
					match(input, Token.UP, null); if (state.failed) return retval;

					if ( state.backtracking==0 ) {
									GrammarAST e = (el!=null?((GrammarAST)el.start):null);
									if ( e.getType()==ANTLRParser.ROOT || e.getType()==ANTLRParser.BANG )
									{
										e = (GrammarAST)e.getChild(0);
									}
									if ( e.getType()==RULE_REF)
									{
										grammar.defineRuleRefLabel(currentRuleName,id.getToken(),e);
									}
									else if ( e.getType()==WILDCARD && grammar.type==Grammar.TREE_PARSER )
									{
										grammar.defineWildcardTreeLabel(currentRuleName,id.getToken(),e);
									}
									else
									{
										grammar.defineTokenRefLabel(currentRuleName,id.getToken(),e);
									}
								}
					}
					break;
				case 8 :
					// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:413:4: ^( PLUS_ASSIGN id2= ID a2= element )
					{
					match(input,PLUS_ASSIGN,FOLLOW_PLUS_ASSIGN_in_element1090); if (state.failed) return retval;
					match(input, Token.DOWN, null); if (state.failed) return retval;
					id2=(GrammarAST)match(input,ID,FOLLOW_ID_in_element1094); if (state.failed) return retval;
					pushFollow(FOLLOW_element_in_element1098);
					a2=element();
					state._fsp--;
					if (state.failed) return retval;
					if ( state.backtracking==0 ) {
									GrammarAST a = (a2!=null?((GrammarAST)a2.start):null);
									if ( a.getType()==ANTLRParser.ROOT || a.getType()==ANTLRParser.BANG )
									{
										a = (GrammarAST)a.getChild(0);
									}
									if ( a.getType()==RULE_REF )
									{
										grammar.defineRuleListLabel(currentRuleName,id2.getToken(),a);
									}
									else if ( a.getType() == WILDCARD && grammar.type == Grammar.TREE_PARSER )
									{
										grammar.defineWildcardTreeListLabel( currentRuleName, id2.getToken(), a );
									}
									else
									{
										grammar.defineTokenListLabel(currentRuleName,id2.getToken(),a);
									}
								}
					match(input, Token.UP, null); if (state.failed) return retval;

					}
					break;
				case 9 :
					// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:434:6: ebnf
					{
					pushFollow(FOLLOW_ebnf_in_element1115);
					ebnf();
					state._fsp--;
					if (state.failed) return retval;
					}
					break;
				case 10 :
					// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:435:6: tree_
					{
					pushFollow(FOLLOW_tree__in_element1122);
					tree_();
					state._fsp--;
					if (state.failed) return retval;
					}
					break;
				case 11 :
					// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:436:6: ^( SYNPRED block )
					{
					match(input,SYNPRED,FOLLOW_SYNPRED_in_element1131); if (state.failed) return retval;
					match(input, Token.DOWN, null); if (state.failed) return retval;
					pushFollow(FOLLOW_block_in_element1133);
					block();
					state._fsp--;
					if (state.failed) return retval;
					match(input, Token.UP, null); if (state.failed) return retval;

					}
					break;
				case 12 :
					// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:437:6: act= ACTION
					{
					act=(GrammarAST)match(input,ACTION,FOLLOW_ACTION_in_element1144); if (state.failed) return retval;
					if ( state.backtracking==0 ) {
								act.outerAltNum = this.outerAltNum;
								trackInlineAction(act);
							}
					}
					break;
				case 13 :
					// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:442:6: act2= FORCED_ACTION
					{
					act2=(GrammarAST)match(input,FORCED_ACTION,FOLLOW_FORCED_ACTION_in_element1157); if (state.failed) return retval;
					if ( state.backtracking==0 ) {
								act2.outerAltNum = this.outerAltNum;
								trackInlineAction(act2);
							}
					}
					break;
				case 14 :
					// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:447:6: SEMPRED
					{
					SEMPRED9=(GrammarAST)match(input,SEMPRED,FOLLOW_SEMPRED_in_element1168); if (state.failed) return retval;
					if ( state.backtracking==0 ) {
								SEMPRED9.outerAltNum = this.outerAltNum;
								trackInlineAction(SEMPRED9);
							}
					}
					break;
				case 15 :
					// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:452:6: SYN_SEMPRED
					{
					match(input,SYN_SEMPRED,FOLLOW_SYN_SEMPRED_in_element1179); if (state.failed) return retval;
					}
					break;
				case 16 :
					// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:453:6: ^( BACKTRACK_SEMPRED ( . )* )
					{
					match(input,BACKTRACK_SEMPRED,FOLLOW_BACKTRACK_SEMPRED_in_element1187); 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\\DefineGrammarItemsWalker.g:453:26: ( . )*
						loop36:
						while (true) {
							int alt36=2;
							int LA36_0 = input.LA(1);
							if ( ((LA36_0 >= ACTION && LA36_0 <= XDIGIT)) ) {
								alt36=1;
							}
							else if ( (LA36_0==UP) ) {
								alt36=2;
							}

							switch (alt36) {
							case 1 :
								// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:453:26: .
								{
								matchAny(input); if (state.failed) return retval;
								}
								break;

							default :
								break loop36;
							}
						}

						match(input, Token.UP, null); if (state.failed) return retval;
					}

					}
					break;
				case 17 :
					// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:454:6: GATED_SEMPRED
					{
					GATED_SEMPRED10=(GrammarAST)match(input,GATED_SEMPRED,FOLLOW_GATED_SEMPRED_in_element1198); if (state.failed) return retval;
					if ( state.backtracking==0 ) {
								GATED_SEMPRED10.outerAltNum = this.outerAltNum;
								trackInlineAction(GATED_SEMPRED10);
							}
					}
					break;
				case 18 :
					// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:459:6: EPSILON
					{
					match(input,EPSILON,FOLLOW_EPSILON_in_element1209); 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"



	// $ANTLR start "ebnf"
	// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:462:1: ebnf : ( ( dotLoop )=> dotLoop | block | ^( OPTIONAL block ) | ^( CLOSURE block ) | ^( POSITIVE_CLOSURE block ) );
	public final void ebnf() throws RecognitionException {
		try {
			// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:463:2: ( ( dotLoop )=> dotLoop | block | ^( OPTIONAL block ) | ^( CLOSURE block ) | ^( POSITIVE_CLOSURE block ) )
			int alt38=5;
			switch ( input.LA(1) ) {
			case CLOSURE:
				{
				int LA38_1 = input.LA(2);
				if ( (LA38_1==DOWN) ) {
					int LA38_5 = input.LA(3);
					if ( (LA38_5==BLOCK) ) {
						int LA38_7 = input.LA(4);
						if ( (LA38_7==DOWN) ) {
							int LA38_9 = input.LA(5);
							if ( (LA38_9==ALT) ) {
								int LA38_11 = input.LA(6);
								if ( (LA38_11==DOWN) ) {
									int LA38_15 = input.LA(7);
									if ( (LA38_15==WILDCARD) ) {
										int LA38_17 = input.LA(8);
										if ( (LA38_17==EOA) ) {
											int LA38_19 = input.LA(9);
											if ( (LA38_19==UP) ) {
												int LA38_21 = input.LA(10);
												if ( (LA38_21==EOB) ) {
													int LA38_23 = input.LA(11);
													if ( (LA38_23==UP) ) {
														int LA38_25 = input.LA(12);
														if ( (LA38_25==UP) ) {
															int LA38_27 = input.LA(13);
															if ( (synpred1_DefineGrammarItemsWalker()) ) {
																alt38=1;
															}
															else if ( (true) ) {
																alt38=4;
															}

														}

														else {
															if (state.backtracking>0) {state.failed=true; return;}
															int nvaeMark = input.mark();
															try {
																for (int nvaeConsume = 0; nvaeConsume < 12 - 1; nvaeConsume++) {
																	input.consume();
																}
																NoViableAltException nvae =
																	new NoViableAltException("", 38, 25, input);
																throw nvae;
															} finally {
																input.rewind(nvaeMark);
															}
														}

													}

													else {
														if (state.backtracking>0) {state.failed=true; return;}
														int nvaeMark = input.mark();
														try {
															for (int nvaeConsume = 0; nvaeConsume < 11 - 1; nvaeConsume++) {
																input.consume();
															}
															NoViableAltException nvae =
																new NoViableAltException("", 38, 23, input);
															throw nvae;
														} finally {
															input.rewind(nvaeMark);
														}
													}

												}
												else if ( (LA38_21==ALT||LA38_21==REWRITES) ) {
													alt38=4;
												}

												else {
													if (state.backtracking>0) {state.failed=true; return;}
													int nvaeMark = input.mark();
													try {
														for (int nvaeConsume = 0; nvaeConsume < 10 - 1; nvaeConsume++) {
															input.consume();
														}
														NoViableAltException nvae =
															new NoViableAltException("", 38, 21, input);
														throw nvae;
													} finally {
														input.rewind(nvaeMark);
													}
												}

											}

											else {
												if (state.backtracking>0) {state.failed=true; return;}
												int nvaeMark = input.mark();
												try {
													for (int nvaeConsume = 0; nvaeConsume < 9 - 1; nvaeConsume++) {
														input.consume();
													}
													NoViableAltException nvae =
														new NoViableAltException("", 38, 19, input);
													throw nvae;
												} finally {
													input.rewind(nvaeMark);
												}
											}

										}
										else if ( (LA38_17==ACTION||(LA38_17 >= ASSIGN && LA38_17 <= BLOCK)||(LA38_17 >= CHAR_LITERAL && LA38_17 <= CHAR_RANGE)||LA38_17==CLOSURE||LA38_17==DOT||LA38_17==EPSILON||LA38_17==FORCED_ACTION||LA38_17==GATED_SEMPRED||LA38_17==NOT||LA38_17==OPTIONAL||(LA38_17 >= PLUS_ASSIGN && LA38_17 <= POSITIVE_CLOSURE)||LA38_17==RANGE||LA38_17==ROOT||LA38_17==RULE_REF||LA38_17==SEMPRED||(LA38_17 >= STRING_LITERAL && LA38_17 <= SYN_SEMPRED)||LA38_17==TOKEN_REF||LA38_17==TREE_BEGIN||LA38_17==WILDCARD) ) {
											alt38=4;
										}

										else {
											if (state.backtracking>0) {state.failed=true; return;}
											int nvaeMark = input.mark();
											try {
												for (int nvaeConsume = 0; nvaeConsume < 8 - 1; nvaeConsume++) {
													input.consume();
												}
												NoViableAltException nvae =
													new NoViableAltException("", 38, 17, input);
												throw nvae;
											} finally {
												input.rewind(nvaeMark);
											}
										}

									}
									else if ( (LA38_15==ACTION||(LA38_15 >= ASSIGN && LA38_15 <= BLOCK)||(LA38_15 >= CHAR_LITERAL && LA38_15 <= CHAR_RANGE)||LA38_15==CLOSURE||LA38_15==DOT||LA38_15==EPSILON||LA38_15==FORCED_ACTION||LA38_15==GATED_SEMPRED||LA38_15==NOT||LA38_15==OPTIONAL||(LA38_15 >= PLUS_ASSIGN && LA38_15 <= POSITIVE_CLOSURE)||LA38_15==RANGE||LA38_15==ROOT||LA38_15==RULE_REF||LA38_15==SEMPRED||(LA38_15 >= STRING_LITERAL && LA38_15 <= SYN_SEMPRED)||LA38_15==TOKEN_REF||LA38_15==TREE_BEGIN) ) {
										alt38=4;
									}

									else {
										if (state.backtracking>0) {state.failed=true; return;}
										int nvaeMark = input.mark();
										try {
											for (int nvaeConsume = 0; nvaeConsume < 7 - 1; nvaeConsume++) {
												input.consume();
											}
											NoViableAltException nvae =
												new NoViableAltException("", 38, 15, input);
											throw nvae;
										} finally {
											input.rewind(nvaeMark);
										}
									}

								}

								else {
									if (state.backtracking>0) {state.failed=true; return;}
									int nvaeMark = input.mark();
									try {
										for (int nvaeConsume = 0; nvaeConsume < 6 - 1; nvaeConsume++) {
											input.consume();
										}
										NoViableAltException nvae =
											new NoViableAltException("", 38, 11, input);
										throw nvae;
									} finally {
										input.rewind(nvaeMark);
									}
								}

							}
							else if ( (LA38_9==AMPERSAND||LA38_9==OPTIONS) ) {
								alt38=4;
							}

							else {
								if (state.backtracking>0) {state.failed=true; return;}
								int nvaeMark = input.mark();
								try {
									for (int nvaeConsume = 0; nvaeConsume < 5 - 1; nvaeConsume++) {
										input.consume();
									}
									NoViableAltException nvae =
										new NoViableAltException("", 38, 9, input);
									throw nvae;
								} finally {
									input.rewind(nvaeMark);
								}
							}

						}

						else {
							if (state.backtracking>0) {state.failed=true; return;}
							int nvaeMark = input.mark();
							try {
								for (int nvaeConsume = 0; nvaeConsume < 4 - 1; nvaeConsume++) {
									input.consume();
								}
								NoViableAltException nvae =
									new NoViableAltException("", 38, 7, input);
								throw nvae;
							} finally {
								input.rewind(nvaeMark);
							}
						}

					}

					else {
						if (state.backtracking>0) {state.failed=true; return;}
						int nvaeMark = input.mark();
						try {
							for (int nvaeConsume = 0; nvaeConsume < 3 - 1; nvaeConsume++) {
								input.consume();
							}
							NoViableAltException nvae =
								new NoViableAltException("", 38, 5, input);
							throw nvae;
						} finally {
							input.rewind(nvaeMark);
						}
					}

				}

				else {
					if (state.backtracking>0) {state.failed=true; return;}
					int nvaeMark = input.mark();
					try {
						input.consume();
						NoViableAltException nvae =
							new NoViableAltException("", 38, 1, input);
						throw nvae;
					} finally {
						input.rewind(nvaeMark);
					}
				}

				}
				break;
			case POSITIVE_CLOSURE:
				{
				int LA38_2 = input.LA(2);
				if ( (LA38_2==DOWN) ) {
					int LA38_6 = input.LA(3);
					if ( (LA38_6==BLOCK) ) {
						int LA38_8 = input.LA(4);
						if ( (LA38_8==DOWN) ) {
							int LA38_10 = input.LA(5);
							if ( (LA38_10==ALT) ) {
								int LA38_13 = input.LA(6);
								if ( (LA38_13==DOWN) ) {
									int LA38_16 = input.LA(7);
									if ( (LA38_16==WILDCARD) ) {
										int LA38_18 = input.LA(8);
										if ( (LA38_18==EOA) ) {
											int LA38_20 = input.LA(9);
											if ( (LA38_20==UP) ) {
												int LA38_22 = input.LA(10);
												if ( (LA38_22==EOB) ) {
													int LA38_24 = input.LA(11);
													if ( (LA38_24==UP) ) {
														int LA38_26 = input.LA(12);
														if ( (LA38_26==UP) ) {
															int LA38_28 = input.LA(13);
															if ( (synpred1_DefineGrammarItemsWalker()) ) {
																alt38=1;
															}
															else if ( (true) ) {
																alt38=5;
															}

														}

														else {
															if (state.backtracking>0) {state.failed=true; return;}
															int nvaeMark = input.mark();
															try {
																for (int nvaeConsume = 0; nvaeConsume < 12 - 1; nvaeConsume++) {
																	input.consume();
																}
																NoViableAltException nvae =
																	new NoViableAltException("", 38, 26, input);
																throw nvae;
															} finally {
																input.rewind(nvaeMark);
															}
														}

													}

													else {
														if (state.backtracking>0) {state.failed=true; return;}
														int nvaeMark = input.mark();
														try {
															for (int nvaeConsume = 0; nvaeConsume < 11 - 1; nvaeConsume++) {
																input.consume();
															}
															NoViableAltException nvae =
																new NoViableAltException("", 38, 24, input);
															throw nvae;
														} finally {
															input.rewind(nvaeMark);
														}
													}

												}
												else if ( (LA38_22==ALT||LA38_22==REWRITES) ) {
													alt38=5;
												}

												else {
													if (state.backtracking>0) {state.failed=true; return;}
													int nvaeMark = input.mark();
													try {
														for (int nvaeConsume = 0; nvaeConsume < 10 - 1; nvaeConsume++) {
															input.consume();
														}
														NoViableAltException nvae =
															new NoViableAltException("", 38, 22, input);
														throw nvae;
													} finally {
														input.rewind(nvaeMark);
													}
												}

											}

											else {
												if (state.backtracking>0) {state.failed=true; return;}
												int nvaeMark = input.mark();
												try {
													for (int nvaeConsume = 0; nvaeConsume < 9 - 1; nvaeConsume++) {
														input.consume();
													}
													NoViableAltException nvae =
														new NoViableAltException("", 38, 20, input);
													throw nvae;
												} finally {
													input.rewind(nvaeMark);
												}
											}

										}
										else if ( (LA38_18==ACTION||(LA38_18 >= ASSIGN && LA38_18 <= BLOCK)||(LA38_18 >= CHAR_LITERAL && LA38_18 <= CHAR_RANGE)||LA38_18==CLOSURE||LA38_18==DOT||LA38_18==EPSILON||LA38_18==FORCED_ACTION||LA38_18==GATED_SEMPRED||LA38_18==NOT||LA38_18==OPTIONAL||(LA38_18 >= PLUS_ASSIGN && LA38_18 <= POSITIVE_CLOSURE)||LA38_18==RANGE||LA38_18==ROOT||LA38_18==RULE_REF||LA38_18==SEMPRED||(LA38_18 >= STRING_LITERAL && LA38_18 <= SYN_SEMPRED)||LA38_18==TOKEN_REF||LA38_18==TREE_BEGIN||LA38_18==WILDCARD) ) {
											alt38=5;
										}

										else {
											if (state.backtracking>0) {state.failed=true; return;}
											int nvaeMark = input.mark();
											try {
												for (int nvaeConsume = 0; nvaeConsume < 8 - 1; nvaeConsume++) {
													input.consume();
												}
												NoViableAltException nvae =
													new NoViableAltException("", 38, 18, input);
												throw nvae;
											} finally {
												input.rewind(nvaeMark);
											}
										}

									}
									else if ( (LA38_16==ACTION||(LA38_16 >= ASSIGN && LA38_16 <= BLOCK)||(LA38_16 >= CHAR_LITERAL && LA38_16 <= CHAR_RANGE)||LA38_16==CLOSURE||LA38_16==DOT||LA38_16==EPSILON||LA38_16==FORCED_ACTION||LA38_16==GATED_SEMPRED||LA38_16==NOT||LA38_16==OPTIONAL||(LA38_16 >= PLUS_ASSIGN && LA38_16 <= POSITIVE_CLOSURE)||LA38_16==RANGE||LA38_16==ROOT||LA38_16==RULE_REF||LA38_16==SEMPRED||(LA38_16 >= STRING_LITERAL && LA38_16 <= SYN_SEMPRED)||LA38_16==TOKEN_REF||LA38_16==TREE_BEGIN) ) {
										alt38=5;
									}

									else {
										if (state.backtracking>0) {state.failed=true; return;}
										int nvaeMark = input.mark();
										try {
											for (int nvaeConsume = 0; nvaeConsume < 7 - 1; nvaeConsume++) {
												input.consume();
											}
											NoViableAltException nvae =
												new NoViableAltException("", 38, 16, input);
											throw nvae;
										} finally {
											input.rewind(nvaeMark);
										}
									}

								}

								else {
									if (state.backtracking>0) {state.failed=true; return;}
									int nvaeMark = input.mark();
									try {
										for (int nvaeConsume = 0; nvaeConsume < 6 - 1; nvaeConsume++) {
											input.consume();
										}
										NoViableAltException nvae =
											new NoViableAltException("", 38, 13, input);
										throw nvae;
									} finally {
										input.rewind(nvaeMark);
									}
								}

							}
							else if ( (LA38_10==AMPERSAND||LA38_10==OPTIONS) ) {
								alt38=5;
							}

							else {
								if (state.backtracking>0) {state.failed=true; return;}
								int nvaeMark = input.mark();
								try {
									for (int nvaeConsume = 0; nvaeConsume < 5 - 1; nvaeConsume++) {
										input.consume();
									}
									NoViableAltException nvae =
										new NoViableAltException("", 38, 10, input);
									throw nvae;
								} finally {
									input.rewind(nvaeMark);
								}
							}

						}

						else {
							if (state.backtracking>0) {state.failed=true; return;}
							int nvaeMark = input.mark();
							try {
								for (int nvaeConsume = 0; nvaeConsume < 4 - 1; nvaeConsume++) {
									input.consume();
								}
								NoViableAltException nvae =
									new NoViableAltException("", 38, 8, input);
								throw nvae;
							} finally {
								input.rewind(nvaeMark);
							}
						}

					}

					else {
						if (state.backtracking>0) {state.failed=true; return;}
						int nvaeMark = input.mark();
						try {
							for (int nvaeConsume = 0; nvaeConsume < 3 - 1; nvaeConsume++) {
								input.consume();
							}
							NoViableAltException nvae =
								new NoViableAltException("", 38, 6, input);
							throw nvae;
						} finally {
							input.rewind(nvaeMark);
						}
					}

				}

				else {
					if (state.backtracking>0) {state.failed=true; return;}
					int nvaeMark = input.mark();
					try {
						input.consume();
						NoViableAltException nvae =
							new NoViableAltException("", 38, 2, input);
						throw nvae;
					} finally {
						input.rewind(nvaeMark);
					}
				}

				}
				break;
			case BLOCK:
				{
				alt38=2;
				}
				break;
			case OPTIONAL:
				{
				alt38=3;
				}
				break;
			default:
				if (state.backtracking>0) {state.failed=true; return;}
				NoViableAltException nvae =
					new NoViableAltException("", 38, 0, input);
				throw nvae;
			}
			switch (alt38) {
				case 1 :
					// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:463:4: ( dotLoop )=> dotLoop
					{
					pushFollow(FOLLOW_dotLoop_in_ebnf1227);
					dotLoop();
					state._fsp--;
					if (state.failed) return;
					}
					break;
				case 2 :
					// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:464:4: block
					{
					pushFollow(FOLLOW_block_in_ebnf1233);
					block();
					state._fsp--;
					if (state.failed) return;
					}
					break;
				case 3 :
					// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:465:4: ^( OPTIONAL block )
					{
					match(input,OPTIONAL,FOLLOW_OPTIONAL_in_ebnf1240); if (state.failed) return;
					match(input, Token.DOWN, null); if (state.failed) return;
					pushFollow(FOLLOW_block_in_ebnf1242);
					block();
					state._fsp--;
					if (state.failed) return;
					match(input, Token.UP, null); if (state.failed) return;

					}
					break;
				case 4 :
					// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:466:4: ^( CLOSURE block )
					{
					match(input,CLOSURE,FOLLOW_CLOSURE_in_ebnf1251); if (state.failed) return;
					match(input, Token.DOWN, null); if (state.failed) return;
					pushFollow(FOLLOW_block_in_ebnf1253);
					block();
					state._fsp--;
					if (state.failed) return;
					match(input, Token.UP, null); if (state.failed) return;

					}
					break;
				case 5 :
					// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:467:4: ^( POSITIVE_CLOSURE block )
					{
					match(input,POSITIVE_CLOSURE,FOLLOW_POSITIVE_CLOSURE_in_ebnf1262); if (state.failed) return;
					match(input, Token.DOWN, null); if (state.failed) return;
					pushFollow(FOLLOW_block_in_ebnf1264);
					block();
					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 "ebnf"


	public static class dotLoop_return extends TreeRuleReturnScope {
	};


	// $ANTLR start "dotLoop"
	// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:472:1: dotLoop : ( ^( CLOSURE dotBlock ) | ^( POSITIVE_CLOSURE dotBlock ) ) ;
	public final DefineGrammarItemsWalker.dotLoop_return dotLoop() throws RecognitionException {
		DefineGrammarItemsWalker.dotLoop_return retval = new DefineGrammarItemsWalker.dotLoop_return();
		retval.start = input.LT(1);

		try {
			// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:473:2: ( ( ^( CLOSURE dotBlock ) | ^( POSITIVE_CLOSURE dotBlock ) ) )
			// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:473:4: ( ^( CLOSURE dotBlock ) | ^( POSITIVE_CLOSURE dotBlock ) )
			{
			// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:473:4: ( ^( CLOSURE dotBlock ) | ^( POSITIVE_CLOSURE dotBlock ) )
			int alt39=2;
			int LA39_0 = input.LA(1);
			if ( (LA39_0==CLOSURE) ) {
				alt39=1;
			}
			else if ( (LA39_0==POSITIVE_CLOSURE) ) {
				alt39=2;
			}

			else {
				if (state.backtracking>0) {state.failed=true; return retval;}
				NoViableAltException nvae =
					new NoViableAltException("", 39, 0, input);
				throw nvae;
			}

			switch (alt39) {
				case 1 :
					// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:473:6: ^( CLOSURE dotBlock )
					{
					match(input,CLOSURE,FOLLOW_CLOSURE_in_dotLoop1283); if (state.failed) return retval;
					match(input, Token.DOWN, null); if (state.failed) return retval;
					pushFollow(FOLLOW_dotBlock_in_dotLoop1285);
					dotBlock();
					state._fsp--;
					if (state.failed) return retval;
					match(input, Token.UP, null); if (state.failed) return retval;

					}
					break;
				case 2 :
					// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:474:5: ^( POSITIVE_CLOSURE dotBlock )
					{
					match(input,POSITIVE_CLOSURE,FOLLOW_POSITIVE_CLOSURE_in_dotLoop1295); if (state.failed) return retval;
					match(input, Token.DOWN, null); if (state.failed) return retval;
					pushFollow(FOLLOW_dotBlock_in_dotLoop1297);
					dotBlock();
					state._fsp--;
					if (state.failed) return retval;
					match(input, Token.UP, null); if (state.failed) return retval;

					}
					break;

			}

			if ( state.backtracking==0 ) {
						GrammarAST block = (GrammarAST)((GrammarAST)retval.start).getChild(0);
						Map opts = new HashMap();
						opts.put("greedy", "false");
						if ( grammar.type!=Grammar.LEXER )
						{
							// parser grammars assume k=1 for .* loops
							// otherwise they (analysis?) look til EOF!
							opts.put("k", 1);
						}
						block.setOptions(grammar,opts);
					}
			}

		}
		catch (RecognitionException re) {
			reportError(re);
			recover(input,re);
		}
		finally {
			// do for sure before leaving
		}
		return retval;
	}
	// $ANTLR end "dotLoop"



	// $ANTLR start "dotBlock"
	// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:490:1: dotBlock : ^( BLOCK ^( ALT WILDCARD EOA ) EOB ) ;
	public final void dotBlock() throws RecognitionException {
		try {
			// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:491:2: ( ^( BLOCK ^( ALT WILDCARD EOA ) EOB ) )
			// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:491:4: ^( BLOCK ^( ALT WILDCARD EOA ) EOB )
			{
			match(input,BLOCK,FOLLOW_BLOCK_in_dotBlock1320); if (state.failed) return;
			match(input, Token.DOWN, null); if (state.failed) return;
			match(input,ALT,FOLLOW_ALT_in_dotBlock1324); if (state.failed) return;
			match(input, Token.DOWN, null); if (state.failed) return;
			match(input,WILDCARD,FOLLOW_WILDCARD_in_dotBlock1326); if (state.failed) return;
			match(input,EOA,FOLLOW_EOA_in_dotBlock1328); if (state.failed) return;
			match(input, Token.UP, null); if (state.failed) return;

			match(input,EOB,FOLLOW_EOB_in_dotBlock1332); 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 "dotBlock"



	// $ANTLR start "tree_"
	// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:494:1: tree_ : ^( TREE_BEGIN ( element )+ ) ;
	public final void tree_() throws RecognitionException {
		try {
			// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:495:2: ( ^( TREE_BEGIN ( element )+ ) )
			// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:495:4: ^( TREE_BEGIN ( element )+ )
			{
			match(input,TREE_BEGIN,FOLLOW_TREE_BEGIN_in_tree_1346); if (state.failed) return;
			match(input, Token.DOWN, null); if (state.failed) return;
			// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:495:17: ( element )+
			int cnt40=0;
			loop40:
			while (true) {
				int alt40=2;
				int LA40_0 = input.LA(1);
				if ( (LA40_0==ACTION||(LA40_0 >= ASSIGN && LA40_0 <= BLOCK)||(LA40_0 >= CHAR_LITERAL && LA40_0 <= CHAR_RANGE)||LA40_0==CLOSURE||LA40_0==DOT||LA40_0==EPSILON||LA40_0==FORCED_ACTION||LA40_0==GATED_SEMPRED||LA40_0==NOT||LA40_0==OPTIONAL||(LA40_0 >= PLUS_ASSIGN && LA40_0 <= POSITIVE_CLOSURE)||LA40_0==RANGE||LA40_0==ROOT||LA40_0==RULE_REF||LA40_0==SEMPRED||(LA40_0 >= STRING_LITERAL && LA40_0 <= SYN_SEMPRED)||LA40_0==TOKEN_REF||LA40_0==TREE_BEGIN||LA40_0==WILDCARD) ) {
					alt40=1;
				}

				switch (alt40) {
				case 1 :
					// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:495:17: element
					{
					pushFollow(FOLLOW_element_in_tree_1348);
					element();
					state._fsp--;
					if (state.failed) return;
					}
					break;

				default :
					if ( cnt40 >= 1 ) break loop40;
					if (state.backtracking>0) {state.failed=true; return;}
					EarlyExitException eee = new EarlyExitException(40, input);
					throw eee;
				}
				cnt40++;
			}

			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 "tree_"



	// $ANTLR start "atom"
	// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:498:1: atom[GrammarAST scope_] : ( ^(rr= RULE_REF (rarg= ARG_ACTION )? ) | ^(t= TOKEN_REF (targ= ARG_ACTION )? ) |c= CHAR_LITERAL |s= STRING_LITERAL | WILDCARD | ^( DOT ID atom[$ID] ) );
	public final void atom(GrammarAST scope_) throws RecognitionException {
		GrammarAST rr=null;
		GrammarAST rarg=null;
		GrammarAST t=null;
		GrammarAST targ=null;
		GrammarAST c=null;
		GrammarAST s=null;
		GrammarAST ID11=null;

		try {
			// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:499:2: ( ^(rr= RULE_REF (rarg= ARG_ACTION )? ) | ^(t= TOKEN_REF (targ= ARG_ACTION )? ) |c= CHAR_LITERAL |s= STRING_LITERAL | WILDCARD | ^( DOT ID atom[$ID] ) )
			int alt43=6;
			switch ( input.LA(1) ) {
			case RULE_REF:
				{
				alt43=1;
				}
				break;
			case TOKEN_REF:
				{
				alt43=2;
				}
				break;
			case CHAR_LITERAL:
				{
				alt43=3;
				}
				break;
			case STRING_LITERAL:
				{
				alt43=4;
				}
				break;
			case WILDCARD:
				{
				alt43=5;
				}
				break;
			case DOT:
				{
				alt43=6;
				}
				break;
			default:
				if (state.backtracking>0) {state.failed=true; return;}
				NoViableAltException nvae =
					new NoViableAltException("", 43, 0, input);
				throw nvae;
			}
			switch (alt43) {
				case 1 :
					// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:499:4: ^(rr= RULE_REF (rarg= ARG_ACTION )? )
					{
					rr=(GrammarAST)match(input,RULE_REF,FOLLOW_RULE_REF_in_atom1366); if (state.failed) return;
					if ( input.LA(1)==Token.DOWN ) {
						match(input, Token.DOWN, null); if (state.failed) return;
						// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:499:19: (rarg= ARG_ACTION )?
						int alt41=2;
						int LA41_0 = input.LA(1);
						if ( (LA41_0==ARG_ACTION) ) {
							alt41=1;
						}
						switch (alt41) {
							case 1 :
								// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:499:20: rarg= ARG_ACTION
								{
								rarg=(GrammarAST)match(input,ARG_ACTION,FOLLOW_ARG_ACTION_in_atom1371); if (state.failed) return;
								}
								break;

						}

						match(input, Token.UP, null); if (state.failed) return;
					}

					if ( state.backtracking==0 ) {
								grammar.altReferencesRule( currentRuleName, scope_, rr, this.outerAltNum );
								if ( rarg != null )
								{
									rarg.outerAltNum = this.outerAltNum;
									trackInlineAction(rarg);
								}
							}
					}
					break;
				case 2 :
					// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:508:4: ^(t= TOKEN_REF (targ= ARG_ACTION )? )
					{
					t=(GrammarAST)match(input,TOKEN_REF,FOLLOW_TOKEN_REF_in_atom1388); if (state.failed) return;
					if ( input.LA(1)==Token.DOWN ) {
						match(input, Token.DOWN, null); if (state.failed) return;
						// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:508:19: (targ= ARG_ACTION )?
						int alt42=2;
						int LA42_0 = input.LA(1);
						if ( (LA42_0==ARG_ACTION) ) {
							alt42=1;
						}
						switch (alt42) {
							case 1 :
								// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:508:20: targ= ARG_ACTION
								{
								targ=(GrammarAST)match(input,ARG_ACTION,FOLLOW_ARG_ACTION_in_atom1393); if (state.failed) return;
								}
								break;

						}

						match(input, Token.UP, null); if (state.failed) return;
					}

					if ( state.backtracking==0 ) {
								if ( targ != null )
								{
									targ.outerAltNum = this.outerAltNum;
									trackInlineAction(targ);
								}
								if ( grammar.type == Grammar.LEXER )
								{
									grammar.altReferencesRule( currentRuleName, scope_, t, this.outerAltNum );
								}
								else
								{
									grammar.altReferencesTokenID( currentRuleName, t, this.outerAltNum );
								}
							}
					}
					break;
				case 3 :
					// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:524:4: c= CHAR_LITERAL
					{
					c=(GrammarAST)match(input,CHAR_LITERAL,FOLLOW_CHAR_LITERAL_in_atom1409); if (state.failed) return;
					if ( state.backtracking==0 ) {
								if ( grammar.type != Grammar.LEXER )
								{
									Rule rule = grammar.getRule(currentRuleName);
									if ( rule != null )
										rule.trackTokenReferenceInAlt(c, outerAltNum);
								}
							}
					}
					break;
				case 4 :
					// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:533:4: s= STRING_LITERAL
					{
					s=(GrammarAST)match(input,STRING_LITERAL,FOLLOW_STRING_LITERAL_in_atom1420); if (state.failed) return;
					if ( state.backtracking==0 ) {
								if ( grammar.type != Grammar.LEXER )
								{
									Rule rule = grammar.getRule(currentRuleName);
									if ( rule!=null )
										rule.trackTokenReferenceInAlt(s, outerAltNum);
								}
							}
					}
					break;
				case 5 :
					// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:542:4: WILDCARD
					{
					match(input,WILDCARD,FOLLOW_WILDCARD_in_atom1430); if (state.failed) return;
					}
					break;
				case 6 :
					// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:543:4: ^( DOT ID atom[$ID] )
					{
					match(input,DOT,FOLLOW_DOT_in_atom1436); if (state.failed) return;
					match(input, Token.DOWN, null); if (state.failed) return;
					ID11=(GrammarAST)match(input,ID,FOLLOW_ID_in_atom1438); if (state.failed) return;
					pushFollow(FOLLOW_atom_in_atom1440);
					atom(ID11);
					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 "atom"



	// $ANTLR start "ast_suffix"
	// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:546:1: ast_suffix : ( ROOT | BANG );
	public final void ast_suffix() throws RecognitionException {
		try {
			// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:547:2: ( ROOT | BANG )
			// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.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"


	public static class rewrite_return extends TreeRuleReturnScope {
	};


	// $ANTLR start "rewrite"
	// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:551:1: rewrite : ( ^( REWRITES ( ^( REWRITE (pred= SEMPRED )? rewrite_alternative ) )* ) |);
	public final DefineGrammarItemsWalker.rewrite_return rewrite() throws RecognitionException {
		DefineGrammarItemsWalker.rewrite_return retval = new DefineGrammarItemsWalker.rewrite_return();
		retval.start = input.LT(1);

		GrammarAST pred=null;


			// track top level REWRITES node, store stuff there
			currentRewriteRule = ((GrammarAST)retval.start); // has to execute during backtracking
			if ( state.backtracking == 0 )
			{
				if ( grammar.buildAST() )
					currentRewriteRule.rewriteRefsDeep = new HashSet();
			}

		try {
			// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:562:2: ( ^( REWRITES ( ^( REWRITE (pred= SEMPRED )? rewrite_alternative ) )* ) |)
			int alt46=2;
			int LA46_0 = input.LA(1);
			if ( (LA46_0==REWRITES) ) {
				alt46=1;
			}
			else if ( (LA46_0==ALT||LA46_0==EOB) ) {
				alt46=2;
			}

			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\\DefineGrammarItemsWalker.g:562:4: ^( REWRITES ( ^( REWRITE (pred= SEMPRED )? rewrite_alternative ) )* )
					{
					match(input,REWRITES,FOLLOW_REWRITES_in_rewrite1477); 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\\DefineGrammarItemsWalker.g:563:4: ( ^( REWRITE (pred= SEMPRED )? rewrite_alternative ) )*
						loop45:
						while (true) {
							int alt45=2;
							int LA45_0 = input.LA(1);
							if ( (LA45_0==REWRITE) ) {
								alt45=1;
							}

							switch (alt45) {
							case 1 :
								// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:563:6: ^( REWRITE (pred= SEMPRED )? rewrite_alternative )
								{
								match(input,REWRITE,FOLLOW_REWRITE_in_rewrite1486); if (state.failed) return retval;
								match(input, Token.DOWN, null); if (state.failed) return retval;
								// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:563:17: (pred= SEMPRED )?
								int alt44=2;
								int LA44_0 = input.LA(1);
								if ( (LA44_0==SEMPRED) ) {
									alt44=1;
								}
								switch (alt44) {
									case 1 :
										// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:563:18: pred= SEMPRED
										{
										pred=(GrammarAST)match(input,SEMPRED,FOLLOW_SEMPRED_in_rewrite1491); if (state.failed) return retval;
										}
										break;

								}

								pushFollow(FOLLOW_rewrite_alternative_in_rewrite1495);
								rewrite_alternative();
								state._fsp--;
								if (state.failed) return retval;
								match(input, Token.UP, null); if (state.failed) return retval;

								if ( state.backtracking==0 ) {
													if ( pred != null )
													{
														pred.outerAltNum = this.outerAltNum;
														trackInlineAction(pred);
													}
												}
								}
								break;

							default :
								break loop45;
							}
						}

						match(input, Token.UP, null); if (state.failed) return retval;
					}

					}
					break;
				case 2 :
					// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:575:2: 
					{
					}
					break;

			}
		}
		catch (RecognitionException re) {
			reportError(re);
			recover(input,re);
		}
		finally {
			// do for sure before leaving
		}
		return retval;
	}
	// $ANTLR end "rewrite"


	public static class rewrite_block_return extends TreeRuleReturnScope {
	};


	// $ANTLR start "rewrite_block"
	// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:577:1: rewrite_block : ^( BLOCK rewrite_alternative EOB ) ;
	public final DefineGrammarItemsWalker.rewrite_block_return rewrite_block() throws RecognitionException {
		DefineGrammarItemsWalker.rewrite_block_return retval = new DefineGrammarItemsWalker.rewrite_block_return();
		retval.start = input.LT(1);


			GrammarAST enclosingBlock = currentRewriteBlock;
			if ( state.backtracking == 0 )
			{
				// don't do if guessing
				currentRewriteBlock=((GrammarAST)retval.start); // pts to BLOCK node
				currentRewriteBlock.rewriteRefsShallow = new HashSet();
				currentRewriteBlock.rewriteRefsDeep = new HashSet();
			}

		try {
			// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:589:2: ( ^( BLOCK rewrite_alternative EOB ) )
			// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:589:6: ^( BLOCK rewrite_alternative EOB )
			{
			match(input,BLOCK,FOLLOW_BLOCK_in_rewrite_block1539); if (state.failed) return retval;
			match(input, Token.DOWN, null); if (state.failed) return retval;
			pushFollow(FOLLOW_rewrite_alternative_in_rewrite_block1541);
			rewrite_alternative();
			state._fsp--;
			if (state.failed) return retval;
			match(input,EOB,FOLLOW_EOB_in_rewrite_block1543); if (state.failed) return retval;
			match(input, Token.UP, null); if (state.failed) return retval;

			if ( state.backtracking==0 ) {
						// copy the element refs in this block to the surrounding block
						if ( enclosingBlock != null )
						{
							for (GrammarAST item : currentRewriteBlock.rewriteRefsShallow)
								enclosingBlock.rewriteRefsDeep.add( item );
						}
						//currentRewriteBlock = enclosingBlock; // restore old BLOCK ptr
					}
			}

		}
		catch (RecognitionException re) {
			reportError(re);
			recover(input,re);
		}
		finally {
			// do for sure before leaving
			 currentRewriteBlock = enclosingBlock; 
		}
		return retval;
	}
	// $ANTLR end "rewrite_block"



	// $ANTLR start "rewrite_alternative"
	// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:603:1: rewrite_alternative : ({...}? => ^(a= ALT ( ( rewrite_element )+ | EPSILON ) EOA ) |{...}? => rewrite_template | ETC {...}?);
	public final void rewrite_alternative() throws RecognitionException {
		GrammarAST a=null;

		try {
			// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:604:2: ({...}? => ^(a= ALT ( ( rewrite_element )+ | EPSILON ) EOA ) |{...}? => rewrite_template | ETC {...}?)
			int alt49=3;
			int LA49_0 = input.LA(1);
			if ( (LA49_0==ALT) && (((grammar.buildAST())||(grammar.buildTemplate())))) {
				int LA49_1 = input.LA(2);
				if ( (LA49_1==DOWN) && (((grammar.buildAST())||(grammar.buildTemplate())))) {
					int LA49_4 = input.LA(3);
					if ( (LA49_4==EPSILON) && (((grammar.buildAST())||(grammar.buildTemplate())))) {
						int LA49_5 = input.LA(4);
						if ( (LA49_5==EOA) && (((grammar.buildAST())||(grammar.buildTemplate())))) {
							int LA49_7 = input.LA(5);
							if ( (LA49_7==UP) && (((grammar.buildAST())||(grammar.buildTemplate())))) {
								int LA49_8 = input.LA(6);
								if ( ((grammar.buildAST())) ) {
									alt49=1;
								}
								else if ( ((grammar.buildTemplate())) ) {
									alt49=2;
								}

								else {
									if (state.backtracking>0) {state.failed=true; return;}
									int nvaeMark = input.mark();
									try {
										for (int nvaeConsume = 0; nvaeConsume < 6 - 1; nvaeConsume++) {
											input.consume();
										}
										NoViableAltException nvae =
											new NoViableAltException("", 49, 8, input);
										throw nvae;
									} finally {
										input.rewind(nvaeMark);
									}
								}

							}

						}

					}
					else if ( (LA49_4==ACTION||LA49_4==CHAR_LITERAL||LA49_4==CLOSURE||LA49_4==LABEL||LA49_4==OPTIONAL||LA49_4==POSITIVE_CLOSURE||LA49_4==RULE_REF||LA49_4==STRING_LITERAL||LA49_4==TOKEN_REF||LA49_4==TREE_BEGIN) && ((grammar.buildAST()))) {
						alt49=1;
					}

				}

			}
			else if ( (LA49_0==ACTION||LA49_0==TEMPLATE) && ((grammar.buildTemplate()))) {
				alt49=2;
			}
			else if ( (LA49_0==ETC) ) {
				alt49=3;
			}

			else {
				if (state.backtracking>0) {state.failed=true; return;}
				NoViableAltException nvae =
					new NoViableAltException("", 49, 0, input);
				throw nvae;
			}

			switch (alt49) {
				case 1 :
					// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:604:4: {...}? => ^(a= ALT ( ( rewrite_element )+ | EPSILON ) EOA )
					{
					if ( !((grammar.buildAST())) ) {
						if (state.backtracking>0) {state.failed=true; return;}
						throw new FailedPredicateException(input, "rewrite_alternative", "grammar.buildAST()");
					}
					a=(GrammarAST)match(input,ALT,FOLLOW_ALT_in_rewrite_alternative1575); if (state.failed) return;
					match(input, Token.DOWN, null); if (state.failed) return;
					// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:604:38: ( ( rewrite_element )+ | EPSILON )
					int alt48=2;
					int LA48_0 = input.LA(1);
					if ( (LA48_0==ACTION||LA48_0==CHAR_LITERAL||LA48_0==CLOSURE||LA48_0==LABEL||LA48_0==OPTIONAL||LA48_0==POSITIVE_CLOSURE||LA48_0==RULE_REF||LA48_0==STRING_LITERAL||LA48_0==TOKEN_REF||LA48_0==TREE_BEGIN) ) {
						alt48=1;
					}
					else if ( (LA48_0==EPSILON) ) {
						alt48=2;
					}

					else {
						if (state.backtracking>0) {state.failed=true; return;}
						NoViableAltException nvae =
							new NoViableAltException("", 48, 0, input);
						throw nvae;
					}

					switch (alt48) {
						case 1 :
							// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:604:40: ( rewrite_element )+
							{
							// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:604:40: ( rewrite_element )+
							int cnt47=0;
							loop47:
							while (true) {
								int alt47=2;
								int LA47_0 = input.LA(1);
								if ( (LA47_0==ACTION||LA47_0==CHAR_LITERAL||LA47_0==CLOSURE||LA47_0==LABEL||LA47_0==OPTIONAL||LA47_0==POSITIVE_CLOSURE||LA47_0==RULE_REF||LA47_0==STRING_LITERAL||LA47_0==TOKEN_REF||LA47_0==TREE_BEGIN) ) {
									alt47=1;
								}

								switch (alt47) {
								case 1 :
									// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:604:42: rewrite_element
									{
									pushFollow(FOLLOW_rewrite_element_in_rewrite_alternative1581);
									rewrite_element();
									state._fsp--;
									if (state.failed) return;
									}
									break;

								default :
									if ( cnt47 >= 1 ) break loop47;
									if (state.backtracking>0) {state.failed=true; return;}
									EarlyExitException eee = new EarlyExitException(47, input);
									throw eee;
								}
								cnt47++;
							}

							}
							break;
						case 2 :
							// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:604:63: EPSILON
							{
							match(input,EPSILON,FOLLOW_EPSILON_in_rewrite_alternative1588); if (state.failed) return;
							}
							break;

					}

					match(input,EOA,FOLLOW_EOA_in_rewrite_alternative1592); if (state.failed) return;
					match(input, Token.UP, null); if (state.failed) return;

					}
					break;
				case 2 :
					// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:605:4: {...}? => rewrite_template
					{
					if ( !((grammar.buildTemplate())) ) {
						if (state.backtracking>0) {state.failed=true; return;}
						throw new FailedPredicateException(input, "rewrite_alternative", "grammar.buildTemplate()");
					}
					pushFollow(FOLLOW_rewrite_template_in_rewrite_alternative1603);
					rewrite_template();
					state._fsp--;
					if (state.failed) return;
					}
					break;
				case 3 :
					// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:606:4: ETC {...}?
					{
					match(input,ETC,FOLLOW_ETC_in_rewrite_alternative1608); if (state.failed) return;
					if ( !((this.blockLevel==1)) ) {
						if (state.backtracking>0) {state.failed=true; return;}
						throw new FailedPredicateException(input, "rewrite_alternative", "this.blockLevel==1");
					}
					}
					break;

			}
		}
		catch (RecognitionException re) {
			reportError(re);
			recover(input,re);
		}
		finally {
			// do for sure before leaving
		}
	}
	// $ANTLR end "rewrite_alternative"



	// $ANTLR start "rewrite_element"
	// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:609:1: rewrite_element : ( rewrite_atom | rewrite_ebnf | rewrite_tree );
	public final void rewrite_element() throws RecognitionException {
		try {
			// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:610:2: ( rewrite_atom | rewrite_ebnf | rewrite_tree )
			int alt50=3;
			switch ( input.LA(1) ) {
			case ACTION:
			case CHAR_LITERAL:
			case LABEL:
			case RULE_REF:
			case STRING_LITERAL:
			case TOKEN_REF:
				{
				alt50=1;
				}
				break;
			case CLOSURE:
			case OPTIONAL:
			case POSITIVE_CLOSURE:
				{
				alt50=2;
				}
				break;
			case TREE_BEGIN:
				{
				alt50=3;
				}
				break;
			default:
				if (state.backtracking>0) {state.failed=true; return;}
				NoViableAltException nvae =
					new NoViableAltException("", 50, 0, input);
				throw nvae;
			}
			switch (alt50) {
				case 1 :
					// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:610:4: rewrite_atom
					{
					pushFollow(FOLLOW_rewrite_atom_in_rewrite_element1622);
					rewrite_atom();
					state._fsp--;
					if (state.failed) return;
					}
					break;
				case 2 :
					// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:611:4: rewrite_ebnf
					{
					pushFollow(FOLLOW_rewrite_ebnf_in_rewrite_element1627);
					rewrite_ebnf();
					state._fsp--;
					if (state.failed) return;
					}
					break;
				case 3 :
					// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:612:4: rewrite_tree
					{
					pushFollow(FOLLOW_rewrite_tree_in_rewrite_element1632);
					rewrite_tree();
					state._fsp--;
					if (state.failed) return;
					}
					break;

			}
		}
		catch (RecognitionException re) {
			reportError(re);
			recover(input,re);
		}
		finally {
			// do for sure before leaving
		}
	}
	// $ANTLR end "rewrite_element"



	// $ANTLR start "rewrite_ebnf"
	// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:615:1: rewrite_ebnf : ( ^( OPTIONAL rewrite_block ) | ^( CLOSURE rewrite_block ) | ^( POSITIVE_CLOSURE rewrite_block ) );
	public final void rewrite_ebnf() throws RecognitionException {
		try {
			// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:616:2: ( ^( OPTIONAL rewrite_block ) | ^( CLOSURE rewrite_block ) | ^( POSITIVE_CLOSURE rewrite_block ) )
			int alt51=3;
			switch ( input.LA(1) ) {
			case OPTIONAL:
				{
				alt51=1;
				}
				break;
			case CLOSURE:
				{
				alt51=2;
				}
				break;
			case POSITIVE_CLOSURE:
				{
				alt51=3;
				}
				break;
			default:
				if (state.backtracking>0) {state.failed=true; return;}
				NoViableAltException nvae =
					new NoViableAltException("", 51, 0, input);
				throw nvae;
			}
			switch (alt51) {
				case 1 :
					// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:616:4: ^( OPTIONAL rewrite_block )
					{
					match(input,OPTIONAL,FOLLOW_OPTIONAL_in_rewrite_ebnf1645); if (state.failed) return;
					match(input, Token.DOWN, null); if (state.failed) return;
					pushFollow(FOLLOW_rewrite_block_in_rewrite_ebnf1647);
					rewrite_block();
					state._fsp--;
					if (state.failed) return;
					match(input, Token.UP, null); if (state.failed) return;

					}
					break;
				case 2 :
					// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:617:4: ^( CLOSURE rewrite_block )
					{
					match(input,CLOSURE,FOLLOW_CLOSURE_in_rewrite_ebnf1656); if (state.failed) return;
					match(input, Token.DOWN, null); if (state.failed) return;
					pushFollow(FOLLOW_rewrite_block_in_rewrite_ebnf1658);
					rewrite_block();
					state._fsp--;
					if (state.failed) return;
					match(input, Token.UP, null); if (state.failed) return;

					}
					break;
				case 3 :
					// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:618:4: ^( POSITIVE_CLOSURE rewrite_block )
					{
					match(input,POSITIVE_CLOSURE,FOLLOW_POSITIVE_CLOSURE_in_rewrite_ebnf1667); if (state.failed) return;
					match(input, Token.DOWN, null); if (state.failed) return;
					pushFollow(FOLLOW_rewrite_block_in_rewrite_ebnf1669);
					rewrite_block();
					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 "rewrite_ebnf"



	// $ANTLR start "rewrite_tree"
	// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:621:1: rewrite_tree : ^( TREE_BEGIN rewrite_atom ( rewrite_element )* ) ;
	public final void rewrite_tree() throws RecognitionException {
		try {
			// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:622:2: ( ^( TREE_BEGIN rewrite_atom ( rewrite_element )* ) )
			// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:622:6: ^( TREE_BEGIN rewrite_atom ( rewrite_element )* )
			{
			match(input,TREE_BEGIN,FOLLOW_TREE_BEGIN_in_rewrite_tree1686); if (state.failed) return;
			match(input, Token.DOWN, null); if (state.failed) return;
			pushFollow(FOLLOW_rewrite_atom_in_rewrite_tree1688);
			rewrite_atom();
			state._fsp--;
			if (state.failed) return;
			// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:622:33: ( rewrite_element )*
			loop52:
			while (true) {
				int alt52=2;
				int LA52_0 = input.LA(1);
				if ( (LA52_0==ACTION||LA52_0==CHAR_LITERAL||LA52_0==CLOSURE||LA52_0==LABEL||LA52_0==OPTIONAL||LA52_0==POSITIVE_CLOSURE||LA52_0==RULE_REF||LA52_0==STRING_LITERAL||LA52_0==TOKEN_REF||LA52_0==TREE_BEGIN) ) {
					alt52=1;
				}

				switch (alt52) {
				case 1 :
					// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:622:35: rewrite_element
					{
					pushFollow(FOLLOW_rewrite_element_in_rewrite_tree1692);
					rewrite_element();
					state._fsp--;
					if (state.failed) return;
					}
					break;

				default :
					break loop52;
				}
			}

			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 "rewrite_tree"


	public static class rewrite_atom_return extends TreeRuleReturnScope {
	};


	// $ANTLR start "rewrite_atom"
	// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:625:1: rewrite_atom : ( RULE_REF | ( ^( TOKEN_REF ( ARG_ACTION )? ) | CHAR_LITERAL | STRING_LITERAL ) | LABEL | ACTION );
	public final DefineGrammarItemsWalker.rewrite_atom_return rewrite_atom() throws RecognitionException {
		DefineGrammarItemsWalker.rewrite_atom_return retval = new DefineGrammarItemsWalker.rewrite_atom_return();
		retval.start = input.LT(1);

		GrammarAST ARG_ACTION12=null;
		GrammarAST ACTION13=null;


			if ( state.backtracking == 0 )
			{
				Rule r = grammar.getRule(currentRuleName);
				Set tokenRefsInAlt = r.getTokenRefsInAlt(outerAltNum);
				boolean imaginary =
					((GrammarAST)retval.start).getType()==TOKEN_REF &&
					!tokenRefsInAlt.contains(((GrammarAST)retval.start).getText());
				if ( !imaginary && grammar.buildAST() &&
					 (((GrammarAST)retval.start).getType()==RULE_REF ||
					  ((GrammarAST)retval.start).getType()==LABEL ||
					  ((GrammarAST)retval.start).getType()==TOKEN_REF ||
					  ((GrammarAST)retval.start).getType()==CHAR_LITERAL ||
					  ((GrammarAST)retval.start).getType()==STRING_LITERAL) )
				{
					// track per block and for entire rewrite rule
					if ( currentRewriteBlock!=null )
					{
						currentRewriteBlock.rewriteRefsShallow.add(((GrammarAST)retval.start));
						currentRewriteBlock.rewriteRefsDeep.add(((GrammarAST)retval.start));
					}

					//System.out.println("adding "+((GrammarAST)retval.start).getText()+" to "+currentRewriteRule.getText());
					currentRewriteRule.rewriteRefsDeep.add(((GrammarAST)retval.start));
				}
			}

		try {
			// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:654:2: ( RULE_REF | ( ^( TOKEN_REF ( ARG_ACTION )? ) | CHAR_LITERAL | STRING_LITERAL ) | LABEL | ACTION )
			int alt55=4;
			switch ( input.LA(1) ) {
			case RULE_REF:
				{
				alt55=1;
				}
				break;
			case CHAR_LITERAL:
			case STRING_LITERAL:
			case TOKEN_REF:
				{
				alt55=2;
				}
				break;
			case LABEL:
				{
				alt55=3;
				}
				break;
			case ACTION:
				{
				alt55=4;
				}
				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\\DefineGrammarItemsWalker.g:654:4: RULE_REF
					{
					match(input,RULE_REF,FOLLOW_RULE_REF_in_rewrite_atom1713); if (state.failed) return retval;
					}
					break;
				case 2 :
					// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:655:4: ( ^( TOKEN_REF ( ARG_ACTION )? ) | CHAR_LITERAL | STRING_LITERAL )
					{
					// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:655:4: ( ^( TOKEN_REF ( ARG_ACTION )? ) | CHAR_LITERAL | STRING_LITERAL )
					int alt54=3;
					switch ( input.LA(1) ) {
					case TOKEN_REF:
						{
						alt54=1;
						}
						break;
					case CHAR_LITERAL:
						{
						alt54=2;
						}
						break;
					case STRING_LITERAL:
						{
						alt54=3;
						}
						break;
					default:
						if (state.backtracking>0) {state.failed=true; return retval;}
						NoViableAltException nvae =
							new NoViableAltException("", 54, 0, input);
						throw nvae;
					}
					switch (alt54) {
						case 1 :
							// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:655:6: ^( TOKEN_REF ( ARG_ACTION )? )
							{
							match(input,TOKEN_REF,FOLLOW_TOKEN_REF_in_rewrite_atom1723); 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\\DefineGrammarItemsWalker.g:656:5: ( 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\\DefineGrammarItemsWalker.g:656:7: ARG_ACTION
										{
										ARG_ACTION12=(GrammarAST)match(input,ARG_ACTION,FOLLOW_ARG_ACTION_in_rewrite_atom1731); if (state.failed) return retval;
										if ( state.backtracking==0 ) {
																ARG_ACTION12.outerAltNum = this.outerAltNum;
																trackInlineAction(ARG_ACTION12);
															}
										}
										break;

								}

								match(input, Token.UP, null); if (state.failed) return retval;
							}

							}
							break;
						case 2 :
							// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:663:5: CHAR_LITERAL
							{
							match(input,CHAR_LITERAL,FOLLOW_CHAR_LITERAL_in_rewrite_atom1756); if (state.failed) return retval;
							}
							break;
						case 3 :
							// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:664:5: STRING_LITERAL
							{
							match(input,STRING_LITERAL,FOLLOW_STRING_LITERAL_in_rewrite_atom1762); if (state.failed) return retval;
							}
							break;

					}

					}
					break;
				case 3 :
					// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:666:4: LABEL
					{
					match(input,LABEL,FOLLOW_LABEL_in_rewrite_atom1771); if (state.failed) return retval;
					}
					break;
				case 4 :
					// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:667:4: ACTION
					{
					ACTION13=(GrammarAST)match(input,ACTION,FOLLOW_ACTION_in_rewrite_atom1776); if (state.failed) return retval;
					if ( state.backtracking==0 ) {
								ACTION13.outerAltNum = this.outerAltNum;
								trackInlineAction(ACTION13);
							}
					}
					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\\DefineGrammarItemsWalker.g:674:1: rewrite_template : ( ^( 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 void rewrite_template() throws RecognitionException {
		GrammarAST id=null;
		GrammarAST ind=null;
		GrammarAST arg=null;
		GrammarAST a=null;
		GrammarAST act=null;

		try {
			// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:675: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 alt59=3;
			switch ( input.LA(1) ) {
			case ALT:
				{
				alt59=1;
				}
				break;
			case TEMPLATE:
				{
				alt59=2;
				}
				break;
			case ACTION:
				{
				alt59=3;
				}
				break;
			default:
				if (state.backtracking>0) {state.failed=true; return;}
				NoViableAltException nvae =
					new NoViableAltException("", 59, 0, input);
				throw nvae;
			}
			switch (alt59) {
				case 1 :
					// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:675:4: ^( ALT EPSILON EOA )
					{
					match(input,ALT,FOLLOW_ALT_in_rewrite_template1793); if (state.failed) return;
					match(input, Token.DOWN, null); if (state.failed) return;
					match(input,EPSILON,FOLLOW_EPSILON_in_rewrite_template1795); if (state.failed) return;
					match(input,EOA,FOLLOW_EOA_in_rewrite_template1797); if (state.failed) return;
					match(input, Token.UP, null); if (state.failed) return;

					}
					break;
				case 2 :
					// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:676: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_template1806); if (state.failed) return;
					match(input, Token.DOWN, null); if (state.failed) return;
					// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:676:16: (id= ID |ind= ACTION )
					int alt56=2;
					int LA56_0 = input.LA(1);
					if ( (LA56_0==ID) ) {
						alt56=1;
					}
					else if ( (LA56_0==ACTION) ) {
						alt56=2;
					}

					else {
						if (state.backtracking>0) {state.failed=true; return;}
						NoViableAltException nvae =
							new NoViableAltException("", 56, 0, input);
						throw nvae;
					}

					switch (alt56) {
						case 1 :
							// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:676:17: id= ID
							{
							id=(GrammarAST)match(input,ID,FOLLOW_ID_in_rewrite_template1811); if (state.failed) return;
							}
							break;
						case 2 :
							// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:676:23: ind= ACTION
							{
							ind=(GrammarAST)match(input,ACTION,FOLLOW_ACTION_in_rewrite_template1815); if (state.failed) return;
							}
							break;

					}

					match(input,ARGLIST,FOLLOW_ARGLIST_in_rewrite_template1823); if (state.failed) return;
					if ( input.LA(1)==Token.DOWN ) {
						match(input, Token.DOWN, null); if (state.failed) return;
						// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:678:5: ( ^( ARG arg= ID a= ACTION ) )*
						loop57:
						while (true) {
							int alt57=2;
							int LA57_0 = input.LA(1);
							if ( (LA57_0==ARG) ) {
								alt57=1;
							}

							switch (alt57) {
							case 1 :
								// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:678:7: ^( ARG arg= ID a= ACTION )
								{
								match(input,ARG,FOLLOW_ARG_in_rewrite_template1833); if (state.failed) return;
								match(input, Token.DOWN, null); if (state.failed) return;
								arg=(GrammarAST)match(input,ID,FOLLOW_ID_in_rewrite_template1837); if (state.failed) return;
								a=(GrammarAST)match(input,ACTION,FOLLOW_ACTION_in_rewrite_template1841); if (state.failed) return;
								match(input, Token.UP, null); if (state.failed) return;

								if ( state.backtracking==0 ) {
														a.outerAltNum = this.outerAltNum;
														trackInlineAction(a);
													}
								}
								break;

							default :
								break loop57;
							}
						}

						match(input, Token.UP, null); if (state.failed) return;
					}

					if ( state.backtracking==0 ) {
									if ( ind!=null )
									{
										ind.outerAltNum = this.outerAltNum;
										trackInlineAction(ind);
									}
								}
					// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:692:4: ( DOUBLE_QUOTE_STRING_LITERAL | DOUBLE_ANGLE_STRING_LITERAL )?
					int alt58=2;
					int LA58_0 = input.LA(1);
					if ( ((LA58_0 >= DOUBLE_ANGLE_STRING_LITERAL && LA58_0 <= DOUBLE_QUOTE_STRING_LITERAL)) ) {
						alt58=1;
					}
					switch (alt58) {
						case 1 :
							// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:
							{
							if ( (input.LA(1) >= DOUBLE_ANGLE_STRING_LITERAL && input.LA(1) <= DOUBLE_QUOTE_STRING_LITERAL) ) {
								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;
							}
							}
							break;

					}

					match(input, Token.UP, null); if (state.failed) return;

					}
					break;
				case 3 :
					// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:696:4: act= ACTION
					{
					act=(GrammarAST)match(input,ACTION,FOLLOW_ACTION_in_rewrite_template1898); if (state.failed) return;
					if ( state.backtracking==0 ) {
								act.outerAltNum = this.outerAltNum;
								trackInlineAction(act);
							}
					}
					break;

			}
		}
		catch (RecognitionException re) {
			reportError(re);
			recover(input,re);
		}
		finally {
			// do for sure before leaving
		}
	}
	// $ANTLR end "rewrite_template"

	// $ANTLR start synpred1_DefineGrammarItemsWalker
	public final void synpred1_DefineGrammarItemsWalker_fragment() throws RecognitionException {
		// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:463:4: ( dotLoop )
		// org\\antlr\\grammar\\v3\\DefineGrammarItemsWalker.g:463:5: dotLoop
		{
		pushFollow(FOLLOW_dotLoop_in_synpred1_DefineGrammarItemsWalker1222);
		dotLoop();
		state._fsp--;
		if (state.failed) return;
		}

	}
	// $ANTLR end synpred1_DefineGrammarItemsWalker

	// Delegated rules

	public final boolean synpred1_DefineGrammarItemsWalker() {
		state.backtracking++;
		int start = input.mark();
		try {
			synpred1_DefineGrammarItemsWalker_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_76 = new BitSet(new long[]{0x0000000000000004L});
	public static final BitSet FOLLOW_grammarSpec_in_grammar_82 = new BitSet(new long[]{0x0000000000000008L});
	public static final BitSet FOLLOW_PARSER_GRAMMAR_in_grammar_91 = new BitSet(new long[]{0x0000000000000004L});
	public static final BitSet FOLLOW_grammarSpec_in_grammar_96 = new BitSet(new long[]{0x0000000000000008L});
	public static final BitSet FOLLOW_TREE_GRAMMAR_in_grammar_105 = new BitSet(new long[]{0x0000000000000004L});
	public static final BitSet FOLLOW_grammarSpec_in_grammar_110 = new BitSet(new long[]{0x0000000000000008L});
	public static final BitSet FOLLOW_COMBINED_GRAMMAR_in_grammar_119 = new BitSet(new long[]{0x0000000000000004L});
	public static final BitSet FOLLOW_grammarSpec_in_grammar_124 = new BitSet(new long[]{0x0000000000000008L});
	public static final BitSet FOLLOW_SCOPE_in_attrScope149 = new BitSet(new long[]{0x0000000000000004L});
	public static final BitSet FOLLOW_ID_in_attrScope153 = new BitSet(new long[]{0x0000000000000210L});
	public static final BitSet FOLLOW_attrScopeAction_in_attrScope155 = new BitSet(new long[]{0x0000000000000210L});
	public static final BitSet FOLLOW_ACTION_in_attrScope160 = new BitSet(new long[]{0x0000000000000008L});
	public static final BitSet FOLLOW_AMPERSAND_in_attrScopeAction178 = new BitSet(new long[]{0x0000000000000004L});
	public static final BitSet FOLLOW_ID_in_attrScopeAction180 = new BitSet(new long[]{0x0000000000000010L});
	public static final BitSet FOLLOW_ACTION_in_attrScopeAction182 = new BitSet(new long[]{0x0000000000000008L});
	public static final BitSet FOLLOW_ID_in_grammarSpec200 = new BitSet(new long[]{0x0400200008000200L,0x0000000020028002L});
	public static final BitSet FOLLOW_DOC_COMMENT_in_grammarSpec207 = new BitSet(new long[]{0x0400200000000200L,0x0000000020028002L});
	public static final BitSet FOLLOW_optionsSpec_in_grammarSpec215 = new BitSet(new long[]{0x0000200000000200L,0x0000000020028002L});
	public static final BitSet FOLLOW_delegateGrammars_in_grammarSpec223 = new BitSet(new long[]{0x0000000000000200L,0x0000000020028002L});
	public static final BitSet FOLLOW_tokensSpec_in_grammarSpec230 = new BitSet(new long[]{0x0000000000000200L,0x0000000000028002L});
	public static final BitSet FOLLOW_attrScope_in_grammarSpec237 = new BitSet(new long[]{0x0000000000000200L,0x0000000000028002L});
	public static final BitSet FOLLOW_actions_in_grammarSpec244 = new BitSet(new long[]{0x0000000000000000L,0x0000000000008002L});
	public static final BitSet FOLLOW_rules_in_grammarSpec250 = new BitSet(new long[]{0x0000000000000002L});
	public static final BitSet FOLLOW_action_in_actions263 = new BitSet(new long[]{0x0000000000000202L});
	public static final BitSet FOLLOW_AMPERSAND_in_action285 = new BitSet(new long[]{0x0000000000000004L});
	public static final BitSet FOLLOW_ID_in_action289 = new BitSet(new long[]{0x0000080000000010L});
	public static final BitSet FOLLOW_ID_in_action298 = new BitSet(new long[]{0x0000000000000010L});
	public static final BitSet FOLLOW_ACTION_in_action302 = new BitSet(new long[]{0x0000000000000008L});
	public static final BitSet FOLLOW_ACTION_in_action318 = new BitSet(new long[]{0x0000000000000008L});
	public static final BitSet FOLLOW_OPTIONS_in_optionsSpec352 = new BitSet(new long[]{0x0000000000000004L});
	public static final BitSet FOLLOW_IMPORT_in_delegateGrammars369 = new BitSet(new long[]{0x0000000000000004L});
	public static final BitSet FOLLOW_ASSIGN_in_delegateGrammars374 = new BitSet(new long[]{0x0000000000000004L});
	public static final BitSet FOLLOW_ID_in_delegateGrammars376 = new BitSet(new long[]{0x0000080000000000L});
	public static final BitSet FOLLOW_ID_in_delegateGrammars378 = new BitSet(new long[]{0x0000000000000008L});
	public static final BitSet FOLLOW_ID_in_delegateGrammars383 = new BitSet(new long[]{0x0000080000002008L});
	public static final BitSet FOLLOW_TOKENS_in_tokensSpec400 = new BitSet(new long[]{0x0000000000000004L});
	public static final BitSet FOLLOW_tokenSpec_in_tokensSpec402 = new BitSet(new long[]{0x0000000000002008L,0x0000000040000000L});
	public static final BitSet FOLLOW_TOKEN_REF_in_tokenSpec417 = new BitSet(new long[]{0x0000000000000002L});
	public static final BitSet FOLLOW_ASSIGN_in_tokenSpec424 = new BitSet(new long[]{0x0000000000000004L});
	public static final BitSet FOLLOW_TOKEN_REF_in_tokenSpec429 = new BitSet(new long[]{0x0000000000040000L,0x0000000001000000L});
	public static final BitSet FOLLOW_set_in_tokenSpec434 = new BitSet(new long[]{0x0000000000000008L});
	public static final BitSet FOLLOW_rule_in_rules465 = new BitSet(new long[]{0x0000000000000002L,0x0000000000008002L});
	public static final BitSet FOLLOW_PREC_RULE_in_rules470 = new BitSet(new long[]{0x0000000000000004L});
	public static final BitSet FOLLOW_RULE_in_rule495 = new BitSet(new long[]{0x0000000000000004L});
	public static final BitSet FOLLOW_ID_in_rule499 = new BitSet(new long[]{0x0000010000000400L,0x000000000000001CL});
	public static final BitSet FOLLOW_modifier_in_rule507 = new BitSet(new long[]{0x0000000000000400L});
	public static final BitSet FOLLOW_ARG_in_rule516 = new BitSet(new long[]{0x0000000000000004L});
	public static final BitSet FOLLOW_ARG_ACTION_in_rule521 = new BitSet(new long[]{0x0000000000000008L});
	public static final BitSet FOLLOW_RET_in_rule532 = new BitSet(new long[]{0x0000000000000004L});
	public static final BitSet FOLLOW_ARG_ACTION_in_rule537 = new BitSet(new long[]{0x0000000000000008L});
	public static final BitSet FOLLOW_throwsSpec_in_rule547 = new BitSet(new long[]{0x0400000000010200L,0x0000000000020000L});
	public static final BitSet FOLLOW_optionsSpec_in_rule555 = new BitSet(new long[]{0x0000000000010200L,0x0000000000020000L});
	public static final BitSet FOLLOW_ruleScopeSpec_in_rule568 = new BitSet(new long[]{0x0000000000010200L});
	public static final BitSet FOLLOW_ruleAction_in_rule577 = new BitSet(new long[]{0x0000000000010200L});
	public static final BitSet FOLLOW_block_in_rule592 = new BitSet(new long[]{0x0000004400020000L});
	public static final BitSet FOLLOW_exceptionGroup_in_rule598 = new BitSet(new long[]{0x0000000400000000L});
	public static final BitSet FOLLOW_EOR_in_rule605 = new BitSet(new long[]{0x0000000000000008L});
	public static final BitSet FOLLOW_AMPERSAND_in_ruleAction629 = new BitSet(new long[]{0x0000000000000004L});
	public static final BitSet FOLLOW_ID_in_ruleAction633 = new BitSet(new long[]{0x0000000000000010L});
	public static final BitSet FOLLOW_ACTION_in_ruleAction637 = new BitSet(new long[]{0x0000000000000008L});
	public static final BitSet FOLLOW_THROWS_in_throwsSpec697 = new BitSet(new long[]{0x0000000000000004L});
	public static final BitSet FOLLOW_ID_in_throwsSpec700 = new BitSet(new long[]{0x0000080000000008L});
	public static final BitSet FOLLOW_SCOPE_in_ruleScopeSpec730 = new BitSet(new long[]{0x0000000000000004L});
	public static final BitSet FOLLOW_attrScopeAction_in_ruleScopeSpec737 = new BitSet(new long[]{0x0000000000000210L});
	public static final BitSet FOLLOW_ACTION_in_ruleScopeSpec742 = new BitSet(new long[]{0x0000080000000008L});
	public static final BitSet FOLLOW_ID_in_ruleScopeSpec763 = new BitSet(new long[]{0x0000080000000008L});
	public static final BitSet FOLLOW_BLOCK_in_block797 = new BitSet(new long[]{0x0000000000000004L});
	public static final BitSet FOLLOW_optionsSpec_in_block803 = new BitSet(new long[]{0x0000000000000300L});
	public static final BitSet FOLLOW_blockAction_in_block811 = new BitSet(new long[]{0x0000000000000300L});
	public static final BitSet FOLLOW_alternative_in_block820 = new BitSet(new long[]{0x0000000200000100L,0x0000000000001000L});
	public static final BitSet FOLLOW_rewrite_in_block822 = new BitSet(new long[]{0x0000000200000100L});
	public static final BitSet FOLLOW_EOB_in_block839 = new BitSet(new long[]{0x0000000000000008L});
	public static final BitSet FOLLOW_AMPERSAND_in_blockAction863 = new BitSet(new long[]{0x0000000000000004L});
	public static final BitSet FOLLOW_ID_in_blockAction867 = new BitSet(new long[]{0x0000000000000010L});
	public static final BitSet FOLLOW_ACTION_in_blockAction871 = new BitSet(new long[]{0x0000000000000008L});
	public static final BitSet FOLLOW_ALT_in_alternative909 = new BitSet(new long[]{0x0000000000000004L});
	public static final BitSet FOLLOW_element_in_alternative912 = new BitSet(new long[]{0x82800289202DE010L,0x0000000547092041L});
	public static final BitSet FOLLOW_EOA_in_alternative916 = new BitSet(new long[]{0x0000000000000008L});
	public static final BitSet FOLLOW_exceptionHandler_in_exceptionGroup931 = new BitSet(new long[]{0x0000004000020002L});
	public static final BitSet FOLLOW_finallyClause_in_exceptionGroup937 = new BitSet(new long[]{0x0000000000000002L});
	public static final BitSet FOLLOW_finallyClause_in_exceptionGroup944 = new BitSet(new long[]{0x0000000000000002L});
	public static final BitSet FOLLOW_CATCH_in_exceptionHandler958 = new BitSet(new long[]{0x0000000000000004L});
	public static final BitSet FOLLOW_ARG_ACTION_in_exceptionHandler960 = new BitSet(new long[]{0x0000000000000010L});
	public static final BitSet FOLLOW_ACTION_in_exceptionHandler962 = new BitSet(new long[]{0x0000000000000008L});
	public static final BitSet FOLLOW_FINALLY_in_finallyClause980 = new BitSet(new long[]{0x0000000000000004L});
	public static final BitSet FOLLOW_ACTION_in_finallyClause982 = new BitSet(new long[]{0x0000000000000008L});
	public static final BitSet FOLLOW_ROOT_in_element999 = new BitSet(new long[]{0x0000000000000004L});
	public static final BitSet FOLLOW_element_in_element1001 = new BitSet(new long[]{0x0000000000000008L});
	public static final BitSet FOLLOW_BANG_in_element1010 = new BitSet(new long[]{0x0000000000000004L});
	public static final BitSet FOLLOW_element_in_element1012 = new BitSet(new long[]{0x0000000000000008L});
	public static final BitSet FOLLOW_atom_in_element1020 = new BitSet(new long[]{0x0000000000000002L});
	public static final BitSet FOLLOW_NOT_in_element1029 = new BitSet(new long[]{0x0000000000000004L});
	public static final BitSet FOLLOW_element_in_element1031 = new BitSet(new long[]{0x0000000000000008L});
	public static final BitSet FOLLOW_RANGE_in_element1040 = new BitSet(new long[]{0x0000000000000004L});
	public static final BitSet FOLLOW_atom_in_element1042 = new BitSet(new long[]{0x0000000020040000L,0x0000000441010000L});
	public static final BitSet FOLLOW_atom_in_element1045 = new BitSet(new long[]{0x0000000000000008L});
	public static final BitSet FOLLOW_CHAR_RANGE_in_element1055 = new BitSet(new long[]{0x0000000000000004L});
	public static final BitSet FOLLOW_atom_in_element1057 = new BitSet(new long[]{0x0000000020040000L,0x0000000441010000L});
	public static final BitSet FOLLOW_atom_in_element1060 = new BitSet(new long[]{0x0000000000000008L});
	public static final BitSet FOLLOW_ASSIGN_in_element1069 = new BitSet(new long[]{0x0000000000000004L});
	public static final BitSet FOLLOW_ID_in_element1073 = new BitSet(new long[]{0x82800288202DE010L,0x0000000547092041L});
	public static final BitSet FOLLOW_element_in_element1077 = new BitSet(new long[]{0x0000000000000008L});
	public static final BitSet FOLLOW_PLUS_ASSIGN_in_element1090 = new BitSet(new long[]{0x0000000000000004L});
	public static final BitSet FOLLOW_ID_in_element1094 = new BitSet(new long[]{0x82800288202DE010L,0x0000000547092041L});
	public static final BitSet FOLLOW_element_in_element1098 = new BitSet(new long[]{0x0000000000000008L});
	public static final BitSet FOLLOW_ebnf_in_element1115 = new BitSet(new long[]{0x0000000000000002L});
	public static final BitSet FOLLOW_tree__in_element1122 = new BitSet(new long[]{0x0000000000000002L});
	public static final BitSet FOLLOW_SYNPRED_in_element1131 = new BitSet(new long[]{0x0000000000000004L});
	public static final BitSet FOLLOW_block_in_element1133 = new BitSet(new long[]{0x0000000000000008L});
	public static final BitSet FOLLOW_ACTION_in_element1144 = new BitSet(new long[]{0x0000000000000002L});
	public static final BitSet FOLLOW_FORCED_ACTION_in_element1157 = new BitSet(new long[]{0x0000000000000002L});
	public static final BitSet FOLLOW_SEMPRED_in_element1168 = new BitSet(new long[]{0x0000000000000002L});
	public static final BitSet FOLLOW_SYN_SEMPRED_in_element1179 = new BitSet(new long[]{0x0000000000000002L});
	public static final BitSet FOLLOW_BACKTRACK_SEMPRED_in_element1187 = new BitSet(new long[]{0x0000000000000004L});
	public static final BitSet FOLLOW_GATED_SEMPRED_in_element1198 = new BitSet(new long[]{0x0000000000000002L});
	public static final BitSet FOLLOW_EPSILON_in_element1209 = new BitSet(new long[]{0x0000000000000002L});
	public static final BitSet FOLLOW_dotLoop_in_ebnf1227 = new BitSet(new long[]{0x0000000000000002L});
	public static final BitSet FOLLOW_block_in_ebnf1233 = new BitSet(new long[]{0x0000000000000002L});
	public static final BitSet FOLLOW_OPTIONAL_in_ebnf1240 = new BitSet(new long[]{0x0000000000000004L});
	public static final BitSet FOLLOW_block_in_ebnf1242 = new BitSet(new long[]{0x0000000000000008L});
	public static final BitSet FOLLOW_CLOSURE_in_ebnf1251 = new BitSet(new long[]{0x0000000000000004L});
	public static final BitSet FOLLOW_block_in_ebnf1253 = new BitSet(new long[]{0x0000000000000008L});
	public static final BitSet FOLLOW_POSITIVE_CLOSURE_in_ebnf1262 = new BitSet(new long[]{0x0000000000000004L});
	public static final BitSet FOLLOW_block_in_ebnf1264 = new BitSet(new long[]{0x0000000000000008L});
	public static final BitSet FOLLOW_CLOSURE_in_dotLoop1283 = new BitSet(new long[]{0x0000000000000004L});
	public static final BitSet FOLLOW_dotBlock_in_dotLoop1285 = new BitSet(new long[]{0x0000000000000008L});
	public static final BitSet FOLLOW_POSITIVE_CLOSURE_in_dotLoop1295 = new BitSet(new long[]{0x0000000000000004L});
	public static final BitSet FOLLOW_dotBlock_in_dotLoop1297 = new BitSet(new long[]{0x0000000000000008L});
	public static final BitSet FOLLOW_BLOCK_in_dotBlock1320 = new BitSet(new long[]{0x0000000000000004L});
	public static final BitSet FOLLOW_ALT_in_dotBlock1324 = new BitSet(new long[]{0x0000000000000004L});
	public static final BitSet FOLLOW_WILDCARD_in_dotBlock1326 = new BitSet(new long[]{0x0000000100000000L});
	public static final BitSet FOLLOW_EOA_in_dotBlock1328 = new BitSet(new long[]{0x0000000000000008L});
	public static final BitSet FOLLOW_EOB_in_dotBlock1332 = new BitSet(new long[]{0x0000000000000008L});
	public static final BitSet FOLLOW_TREE_BEGIN_in_tree_1346 = new BitSet(new long[]{0x0000000000000004L});
	public static final BitSet FOLLOW_element_in_tree_1348 = new BitSet(new long[]{0x82800288202DE018L,0x0000000547092041L});
	public static final BitSet FOLLOW_RULE_REF_in_atom1366 = new BitSet(new long[]{0x0000000000000004L});
	public static final BitSet FOLLOW_ARG_ACTION_in_atom1371 = new BitSet(new long[]{0x0000000000000008L});
	public static final BitSet FOLLOW_TOKEN_REF_in_atom1388 = new BitSet(new long[]{0x0000000000000004L});
	public static final BitSet FOLLOW_ARG_ACTION_in_atom1393 = new BitSet(new long[]{0x0000000000000008L});
	public static final BitSet FOLLOW_CHAR_LITERAL_in_atom1409 = new BitSet(new long[]{0x0000000000000002L});
	public static final BitSet FOLLOW_STRING_LITERAL_in_atom1420 = new BitSet(new long[]{0x0000000000000002L});
	public static final BitSet FOLLOW_WILDCARD_in_atom1430 = new BitSet(new long[]{0x0000000000000002L});
	public static final BitSet FOLLOW_DOT_in_atom1436 = new BitSet(new long[]{0x0000000000000004L});
	public static final BitSet FOLLOW_ID_in_atom1438 = new BitSet(new long[]{0x0000000020040000L,0x0000000441010000L});
	public static final BitSet FOLLOW_atom_in_atom1440 = new BitSet(new long[]{0x0000000000000008L});
	public static final BitSet FOLLOW_REWRITES_in_rewrite1477 = new BitSet(new long[]{0x0000000000000004L});
	public static final BitSet FOLLOW_REWRITE_in_rewrite1486 = new BitSet(new long[]{0x0000000000000004L});
	public static final BitSet FOLLOW_SEMPRED_in_rewrite1491 = new BitSet(new long[]{0x0000002000000110L,0x0000000008000000L});
	public static final BitSet FOLLOW_rewrite_alternative_in_rewrite1495 = new BitSet(new long[]{0x0000000000000008L});
	public static final BitSet FOLLOW_BLOCK_in_rewrite_block1539 = new BitSet(new long[]{0x0000000000000004L});
	public static final BitSet FOLLOW_rewrite_alternative_in_rewrite_block1541 = new BitSet(new long[]{0x0000000200000000L});
	public static final BitSet FOLLOW_EOB_in_rewrite_block1543 = new BitSet(new long[]{0x0000000000000008L});
	public static final BitSet FOLLOW_ALT_in_rewrite_alternative1575 = new BitSet(new long[]{0x0000000000000004L});
	public static final BitSet FOLLOW_rewrite_element_in_rewrite_alternative1581 = new BitSet(new long[]{0x0201000100240010L,0x0000000141010001L});
	public static final BitSet FOLLOW_EPSILON_in_rewrite_alternative1588 = new BitSet(new long[]{0x0000000100000000L});
	public static final BitSet FOLLOW_EOA_in_rewrite_alternative1592 = new BitSet(new long[]{0x0000000000000008L});
	public static final BitSet FOLLOW_rewrite_template_in_rewrite_alternative1603 = new BitSet(new long[]{0x0000000000000002L});
	public static final BitSet FOLLOW_ETC_in_rewrite_alternative1608 = new BitSet(new long[]{0x0000000000000002L});
	public static final BitSet FOLLOW_rewrite_atom_in_rewrite_element1622 = new BitSet(new long[]{0x0000000000000002L});
	public static final BitSet FOLLOW_rewrite_ebnf_in_rewrite_element1627 = new BitSet(new long[]{0x0000000000000002L});
	public static final BitSet FOLLOW_rewrite_tree_in_rewrite_element1632 = new BitSet(new long[]{0x0000000000000002L});
	public static final BitSet FOLLOW_OPTIONAL_in_rewrite_ebnf1645 = new BitSet(new long[]{0x0000000000000004L});
	public static final BitSet FOLLOW_rewrite_block_in_rewrite_ebnf1647 = new BitSet(new long[]{0x0000000000000008L});
	public static final BitSet FOLLOW_CLOSURE_in_rewrite_ebnf1656 = new BitSet(new long[]{0x0000000000000004L});
	public static final BitSet FOLLOW_rewrite_block_in_rewrite_ebnf1658 = new BitSet(new long[]{0x0000000000000008L});
	public static final BitSet FOLLOW_POSITIVE_CLOSURE_in_rewrite_ebnf1667 = new BitSet(new long[]{0x0000000000000004L});
	public static final BitSet FOLLOW_rewrite_block_in_rewrite_ebnf1669 = new BitSet(new long[]{0x0000000000000008L});
	public static final BitSet FOLLOW_TREE_BEGIN_in_rewrite_tree1686 = new BitSet(new long[]{0x0000000000000004L});
	public static final BitSet FOLLOW_rewrite_atom_in_rewrite_tree1688 = new BitSet(new long[]{0x0201000000240018L,0x0000000141010001L});
	public static final BitSet FOLLOW_rewrite_element_in_rewrite_tree1692 = new BitSet(new long[]{0x0201000000240018L,0x0000000141010001L});
	public static final BitSet FOLLOW_RULE_REF_in_rewrite_atom1713 = new BitSet(new long[]{0x0000000000000002L});
	public static final BitSet FOLLOW_TOKEN_REF_in_rewrite_atom1723 = new BitSet(new long[]{0x0000000000000004L});
	public static final BitSet FOLLOW_ARG_ACTION_in_rewrite_atom1731 = new BitSet(new long[]{0x0000000000000008L});
	public static final BitSet FOLLOW_CHAR_LITERAL_in_rewrite_atom1756 = new BitSet(new long[]{0x0000000000000002L});
	public static final BitSet FOLLOW_STRING_LITERAL_in_rewrite_atom1762 = new BitSet(new long[]{0x0000000000000002L});
	public static final BitSet FOLLOW_LABEL_in_rewrite_atom1771 = new BitSet(new long[]{0x0000000000000002L});
	public static final BitSet FOLLOW_ACTION_in_rewrite_atom1776 = new BitSet(new long[]{0x0000000000000002L});
	public static final BitSet FOLLOW_ALT_in_rewrite_template1793 = new BitSet(new long[]{0x0000000000000004L});
	public static final BitSet FOLLOW_EPSILON_in_rewrite_template1795 = new BitSet(new long[]{0x0000000100000000L});
	public static final BitSet FOLLOW_EOA_in_rewrite_template1797 = new BitSet(new long[]{0x0000000000000008L});
	public static final BitSet FOLLOW_TEMPLATE_in_rewrite_template1806 = new BitSet(new long[]{0x0000000000000004L});
	public static final BitSet FOLLOW_ID_in_rewrite_template1811 = new BitSet(new long[]{0x0000000000000800L});
	public static final BitSet FOLLOW_ACTION_in_rewrite_template1815 = new BitSet(new long[]{0x0000000000000800L});
	public static final BitSet FOLLOW_ARGLIST_in_rewrite_template1823 = new BitSet(new long[]{0x0000000000000004L});
	public static final BitSet FOLLOW_ARG_in_rewrite_template1833 = new BitSet(new long[]{0x0000000000000004L});
	public static final BitSet FOLLOW_ID_in_rewrite_template1837 = new BitSet(new long[]{0x0000000000000010L});
	public static final BitSet FOLLOW_ACTION_in_rewrite_template1841 = new BitSet(new long[]{0x0000000000000008L});
	public static final BitSet FOLLOW_ACTION_in_rewrite_template1898 = new BitSet(new long[]{0x0000000000000002L});
	public static final BitSet FOLLOW_dotLoop_in_synpred1_DefineGrammarItemsWalker1222 = new BitSet(new long[]{0x0000000000000002L});
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy