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

jetbrick.template.runtime.parser.grammer.JetTemplateParser Maven / Gradle / Ivy

There is a newer version: 2.1.10
Show newest version
// Generated from jetbrick/template/runtime/parser/grammer/JetTemplateParser.g4 by ANTLR 4.3
package jetbrick.template.runtime.parser.grammer;
import org.antlr.v4.runtime.atn.*;
import org.antlr.v4.runtime.dfa.DFA;
import org.antlr.v4.runtime.*;
import org.antlr.v4.runtime.misc.*;
import org.antlr.v4.runtime.tree.*;
import java.util.List;
import java.util.Iterator;
import java.util.ArrayList;

@SuppressWarnings({"all", "warnings", "unchecked", "unused", "cast"})
public class JetTemplateParser extends Parser {
	static { RuntimeMetaData.checkVersion("4.3", RuntimeMetaData.VERSION); }

	protected static final DFA[] _decisionToDFA;
	protected static final PredictionContextCache _sharedContextCache =
		new PredictionContextCache();
	public static final int
		STRING_DOUBLE=86, INSTANCEOF=77, NEW=78, COLON2=50, DIRECTIVE_END=24, 
		DIRECTIVE_OPEN_RETURN=18, NULL_AS_DEFAULT=53, LT=59, DIRECTIVE_OPEN_DEFINE=10, 
		VALUE_OPEN=7, MINUS=66, DIRECTIVE_OPEN_CONTINUE=16, COMMENT_BLOCK=2, DIRECTIVE_OPEN_CALL=21, 
		WHITESPACE=40, TEXT_CHAR_ESCAPED=5, DIRECTIVE_SET=31, DIRECTIVE_MACRO=38, 
		INTEGER=83, DIRECTIVE_BREAK=25, NULL=81, MUL=67, DIRECTIVE_OPEN_MACRO=22, 
		IDENTICALLY_EQUAL=54, LPAREN=41, DOT=51, TRUE=79, RPAREN=42, VALUE_OPEN_ESCAPED=8, 
		EQ=56, DIRECTIVE_OPEN_FOR=14, DIRECTIVE_CONTINUE=26, DIRECTIVE_INCLUDE=35, 
		IDENTICALLY_EQUAL_NOT=55, TEXT_CDATA=4, RBRACK=44, NOT=64, DIRECTIVE_OPEN_SET=11, 
		RBRACE=46, LBRACK=43, STRING_SINGLE=87, DIRECTIVE_OPEN_BREAK=15, DIRECTIVE_FOR=34, 
		NE=57, AND=62, DIRECTIVE_OPEN_INCLUDE=19, BIT_OR=71, TEXT_PLAIN=3, COMMENT_LINE=1, 
		DIRECTIVE_STOP=27, LBRACE=45, PLUS=65, DIRECTIVE_TAG=36, DIRECTIVE_CALL=37, 
		ASSIGN=52, DIRECTIVE_OPEN_OPTIONS=9, QUESTION=48, BIT_XOR=73, BIT_USHR=76, 
		BIT_NOT=72, TEXT_CHAR_SINGLE=6, IDENTIFIER=82, BIT_AND=70, FLOATING_POINT=85, 
		GE=60, INTEGER_HEX=84, COMMA=47, DIRECTIVE_OPEN_IF=12, OR=63, MOD=69, 
		DIRECTIVE_RETURN=28, TEXT_DIRECTIVE_LIKE=39, DIRECTIVE_IF=32, COLON=49, 
		DIRECTIVE_ELSE=23, GT=58, DIV=68, DIRECTIVE_DEFINE=30, BIT_SHR=75, LE=61, 
		DIRECTIVE_OPEN_STOP=17, FALSE=80, DIRECTIVE_OPEN_TAG=20, DIRECTIVE_OPTIONS=29, 
		BIT_SHL=74, DIRECTIVE_OPEN_ELSEIF=13, DIRECTIVE_ELSEIF=33;
	public static final String[] tokenNames = {
		"", "COMMENT_LINE", "COMMENT_BLOCK", "TEXT_PLAIN", "TEXT_CDATA", 
		"TEXT_CHAR_ESCAPED", "TEXT_CHAR_SINGLE", "'${'", "'$!{'", "DIRECTIVE_OPEN_OPTIONS", 
		"DIRECTIVE_OPEN_DEFINE", "DIRECTIVE_OPEN_SET", "DIRECTIVE_OPEN_IF", "DIRECTIVE_OPEN_ELSEIF", 
		"DIRECTIVE_OPEN_FOR", "DIRECTIVE_OPEN_BREAK", "DIRECTIVE_OPEN_CONTINUE", 
		"DIRECTIVE_OPEN_STOP", "DIRECTIVE_OPEN_RETURN", "DIRECTIVE_OPEN_INCLUDE", 
		"DIRECTIVE_OPEN_TAG", "DIRECTIVE_OPEN_CALL", "DIRECTIVE_OPEN_MACRO", "DIRECTIVE_ELSE", 
		"DIRECTIVE_END", "'#break'", "'#continue'", "'#stop'", "'#return'", "'#options'", 
		"'#define'", "'#set'", "'#if'", "'#elseif'", "'#for'", "'#include'", "'#tag'", 
		"'#call'", "'#macro'", "TEXT_DIRECTIVE_LIKE", "WHITESPACE", "'('", "')'", 
		"'['", "']'", "'{'", "'}'", "','", "'?'", "':'", "'::'", "'.'", "'='", 
		"'?!'", "'==='", "'!=='", "'=='", "'!='", "'>'", "'<'", "'>='", "'<='", 
		"'&&'", "'||'", "'!'", "'+'", "'-'", "'*'", "'/'", "'%'", "'&'", "'|'", 
		"'~'", "'^'", "'<<'", "'>>'", "'>>>'", "'instanceof'", "'new'", "'true'", 
		"'false'", "'null'", "IDENTIFIER", "INTEGER", "INTEGER_HEX", "FLOATING_POINT", 
		"STRING_DOUBLE", "STRING_SINGLE"
	};
	public static final int
		RULE_template = 0, RULE_block = 1, RULE_text = 2, RULE_value = 3, RULE_directive = 4, 
		RULE_directive_options = 5, RULE_directive_options_expression = 6, RULE_directive_define = 7, 
		RULE_directive_define_expression = 8, RULE_directive_set = 9, RULE_directive_set_expression = 10, 
		RULE_directive_if = 11, RULE_directive_elseif = 12, RULE_directive_else = 13, 
		RULE_directive_for = 14, RULE_directive_break = 15, RULE_directive_continue = 16, 
		RULE_directive_stop = 17, RULE_directive_return = 18, RULE_directive_include = 19, 
		RULE_directive_tag = 20, RULE_directive_call = 21, RULE_directive_macro = 22, 
		RULE_directive_macro_arguments = 23, RULE_directive_invalid = 24, RULE_expression = 25, 
		RULE_identifier = 26, RULE_constant = 27, RULE_expression_list = 28, RULE_hash_map_entry = 29, 
		RULE_type = 30;
	public static final String[] ruleNames = {
		"template", "block", "text", "value", "directive", "directive_options", 
		"directive_options_expression", "directive_define", "directive_define_expression", 
		"directive_set", "directive_set_expression", "directive_if", "directive_elseif", 
		"directive_else", "directive_for", "directive_break", "directive_continue", 
		"directive_stop", "directive_return", "directive_include", "directive_tag", 
		"directive_call", "directive_macro", "directive_macro_arguments", "directive_invalid", 
		"expression", "identifier", "constant", "expression_list", "hash_map_entry", 
		"type"
	};

	@Override
	public String getGrammarFileName() { return "JetTemplateParser.g4"; }

	@Override
	public String[] getTokenNames() { return tokenNames; }

	@Override
	public String[] getRuleNames() { return ruleNames; }

	@Override
	public String getSerializedATN() { return _serializedATN; }

	@Override
	public ATN getATN() { return _ATN; }

	public JetTemplateParser(TokenStream input) {
		super(input);
		_interp = new ParserATNSimulator(this,_ATN,_decisionToDFA,_sharedContextCache);
	}
	public static class TemplateContext extends ParserRuleContext {
		public TerminalNode EOF() { return getToken(JetTemplateParser.EOF, 0); }
		public BlockContext block() {
			return getRuleContext(BlockContext.class,0);
		}
		public TemplateContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_template; }
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof JetTemplateParserVisitor ) return ((JetTemplateParserVisitor)visitor).visitTemplate(this);
			else return visitor.visitChildren(this);
		}
	}

	public final TemplateContext template() throws RecognitionException {
		TemplateContext _localctx = new TemplateContext(_ctx, getState());
		enterRule(_localctx, 0, RULE_template);
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(62); block();
			setState(63); match(EOF);
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class BlockContext extends ParserRuleContext {
		public DirectiveContext directive(int i) {
			return getRuleContext(DirectiveContext.class,i);
		}
		public List value() {
			return getRuleContexts(ValueContext.class);
		}
		public List directive() {
			return getRuleContexts(DirectiveContext.class);
		}
		public ValueContext value(int i) {
			return getRuleContext(ValueContext.class,i);
		}
		public List text() {
			return getRuleContexts(TextContext.class);
		}
		public TextContext text(int i) {
			return getRuleContext(TextContext.class,i);
		}
		public BlockContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_block; }
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof JetTemplateParserVisitor ) return ((JetTemplateParserVisitor)visitor).visitBlock(this);
			else return visitor.visitChildren(this);
		}
	}

	public final BlockContext block() throws RecognitionException {
		BlockContext _localctx = new BlockContext(_ctx, getState());
		enterRule(_localctx, 2, RULE_block);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(70);
			_errHandler.sync(this);
			_la = _input.LA(1);
			while ((((_la) & ~0x3f) == 0 && ((1L << _la) & ((1L << TEXT_PLAIN) | (1L << TEXT_CDATA) | (1L << TEXT_CHAR_ESCAPED) | (1L << TEXT_CHAR_SINGLE) | (1L << VALUE_OPEN) | (1L << VALUE_OPEN_ESCAPED) | (1L << DIRECTIVE_OPEN_OPTIONS) | (1L << DIRECTIVE_OPEN_DEFINE) | (1L << DIRECTIVE_OPEN_SET) | (1L << DIRECTIVE_OPEN_IF) | (1L << DIRECTIVE_OPEN_FOR) | (1L << DIRECTIVE_OPEN_BREAK) | (1L << DIRECTIVE_OPEN_CONTINUE) | (1L << DIRECTIVE_OPEN_STOP) | (1L << DIRECTIVE_OPEN_RETURN) | (1L << DIRECTIVE_OPEN_INCLUDE) | (1L << DIRECTIVE_OPEN_TAG) | (1L << DIRECTIVE_OPEN_CALL) | (1L << DIRECTIVE_OPEN_MACRO) | (1L << DIRECTIVE_BREAK) | (1L << DIRECTIVE_CONTINUE) | (1L << DIRECTIVE_STOP) | (1L << DIRECTIVE_RETURN) | (1L << DIRECTIVE_OPTIONS) | (1L << DIRECTIVE_DEFINE) | (1L << DIRECTIVE_SET) | (1L << DIRECTIVE_IF) | (1L << DIRECTIVE_ELSEIF) | (1L << DIRECTIVE_FOR) | (1L << DIRECTIVE_INCLUDE) | (1L << DIRECTIVE_TAG) | (1L << DIRECTIVE_CALL) | (1L << DIRECTIVE_MACRO) | (1L << TEXT_DIRECTIVE_LIKE))) != 0)) {
				{
				setState(68);
				switch (_input.LA(1)) {
				case TEXT_PLAIN:
				case TEXT_CDATA:
				case TEXT_CHAR_ESCAPED:
				case TEXT_CHAR_SINGLE:
				case TEXT_DIRECTIVE_LIKE:
					{
					setState(65); text();
					}
					break;
				case VALUE_OPEN:
				case VALUE_OPEN_ESCAPED:
					{
					setState(66); value();
					}
					break;
				case DIRECTIVE_OPEN_OPTIONS:
				case DIRECTIVE_OPEN_DEFINE:
				case DIRECTIVE_OPEN_SET:
				case DIRECTIVE_OPEN_IF:
				case DIRECTIVE_OPEN_FOR:
				case DIRECTIVE_OPEN_BREAK:
				case DIRECTIVE_OPEN_CONTINUE:
				case DIRECTIVE_OPEN_STOP:
				case DIRECTIVE_OPEN_RETURN:
				case DIRECTIVE_OPEN_INCLUDE:
				case DIRECTIVE_OPEN_TAG:
				case DIRECTIVE_OPEN_CALL:
				case DIRECTIVE_OPEN_MACRO:
				case DIRECTIVE_BREAK:
				case DIRECTIVE_CONTINUE:
				case DIRECTIVE_STOP:
				case DIRECTIVE_RETURN:
				case DIRECTIVE_OPTIONS:
				case DIRECTIVE_DEFINE:
				case DIRECTIVE_SET:
				case DIRECTIVE_IF:
				case DIRECTIVE_ELSEIF:
				case DIRECTIVE_FOR:
				case DIRECTIVE_INCLUDE:
				case DIRECTIVE_TAG:
				case DIRECTIVE_CALL:
				case DIRECTIVE_MACRO:
					{
					setState(67); directive();
					}
					break;
				default:
					throw new NoViableAltException(this);
				}
				}
				setState(72);
				_errHandler.sync(this);
				_la = _input.LA(1);
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class TextContext extends ParserRuleContext {
		public TerminalNode TEXT_CHAR_SINGLE() { return getToken(JetTemplateParser.TEXT_CHAR_SINGLE, 0); }
		public TerminalNode TEXT_CHAR_ESCAPED() { return getToken(JetTemplateParser.TEXT_CHAR_ESCAPED, 0); }
		public TerminalNode TEXT_CDATA() { return getToken(JetTemplateParser.TEXT_CDATA, 0); }
		public TerminalNode TEXT_DIRECTIVE_LIKE() { return getToken(JetTemplateParser.TEXT_DIRECTIVE_LIKE, 0); }
		public TerminalNode TEXT_PLAIN() { return getToken(JetTemplateParser.TEXT_PLAIN, 0); }
		public TextContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_text; }
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof JetTemplateParserVisitor ) return ((JetTemplateParserVisitor)visitor).visitText(this);
			else return visitor.visitChildren(this);
		}
	}

	public final TextContext text() throws RecognitionException {
		TextContext _localctx = new TextContext(_ctx, getState());
		enterRule(_localctx, 4, RULE_text);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(73);
			_la = _input.LA(1);
			if ( !((((_la) & ~0x3f) == 0 && ((1L << _la) & ((1L << TEXT_PLAIN) | (1L << TEXT_CDATA) | (1L << TEXT_CHAR_ESCAPED) | (1L << TEXT_CHAR_SINGLE) | (1L << TEXT_DIRECTIVE_LIKE))) != 0)) ) {
			_errHandler.recoverInline(this);
			}
			consume();
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class ValueContext extends ParserRuleContext {
		public TerminalNode VALUE_OPEN() { return getToken(JetTemplateParser.VALUE_OPEN, 0); }
		public ExpressionContext expression() {
			return getRuleContext(ExpressionContext.class,0);
		}
		public TerminalNode VALUE_OPEN_ESCAPED() { return getToken(JetTemplateParser.VALUE_OPEN_ESCAPED, 0); }
		public ValueContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_value; }
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof JetTemplateParserVisitor ) return ((JetTemplateParserVisitor)visitor).visitValue(this);
			else return visitor.visitChildren(this);
		}
	}

	public final ValueContext value() throws RecognitionException {
		ValueContext _localctx = new ValueContext(_ctx, getState());
		enterRule(_localctx, 6, RULE_value);
		try {
			setState(83);
			switch (_input.LA(1)) {
			case VALUE_OPEN:
				enterOuterAlt(_localctx, 1);
				{
				setState(75); match(VALUE_OPEN);
				setState(76); expression(0);
				setState(77); match(RBRACE);
				}
				break;
			case VALUE_OPEN_ESCAPED:
				enterOuterAlt(_localctx, 2);
				{
				setState(79); match(VALUE_OPEN_ESCAPED);
				setState(80); expression(0);
				setState(81); match(RBRACE);
				}
				break;
			default:
				throw new NoViableAltException(this);
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class DirectiveContext extends ParserRuleContext {
		public Directive_ifContext directive_if() {
			return getRuleContext(Directive_ifContext.class,0);
		}
		public Directive_forContext directive_for() {
			return getRuleContext(Directive_forContext.class,0);
		}
		public Directive_includeContext directive_include() {
			return getRuleContext(Directive_includeContext.class,0);
		}
		public Directive_returnContext directive_return() {
			return getRuleContext(Directive_returnContext.class,0);
		}
		public Directive_stopContext directive_stop() {
			return getRuleContext(Directive_stopContext.class,0);
		}
		public Directive_invalidContext directive_invalid() {
			return getRuleContext(Directive_invalidContext.class,0);
		}
		public Directive_setContext directive_set() {
			return getRuleContext(Directive_setContext.class,0);
		}
		public Directive_breakContext directive_break() {
			return getRuleContext(Directive_breakContext.class,0);
		}
		public Directive_optionsContext directive_options() {
			return getRuleContext(Directive_optionsContext.class,0);
		}
		public Directive_callContext directive_call() {
			return getRuleContext(Directive_callContext.class,0);
		}
		public Directive_macroContext directive_macro() {
			return getRuleContext(Directive_macroContext.class,0);
		}
		public Directive_continueContext directive_continue() {
			return getRuleContext(Directive_continueContext.class,0);
		}
		public Directive_defineContext directive_define() {
			return getRuleContext(Directive_defineContext.class,0);
		}
		public Directive_tagContext directive_tag() {
			return getRuleContext(Directive_tagContext.class,0);
		}
		public DirectiveContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_directive; }
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof JetTemplateParserVisitor ) return ((JetTemplateParserVisitor)visitor).visitDirective(this);
			else return visitor.visitChildren(this);
		}
	}

	public final DirectiveContext directive() throws RecognitionException {
		DirectiveContext _localctx = new DirectiveContext(_ctx, getState());
		enterRule(_localctx, 8, RULE_directive);
		try {
			setState(99);
			switch (_input.LA(1)) {
			case DIRECTIVE_OPEN_OPTIONS:
				enterOuterAlt(_localctx, 1);
				{
				setState(85); directive_options();
				}
				break;
			case DIRECTIVE_OPEN_DEFINE:
				enterOuterAlt(_localctx, 2);
				{
				setState(86); directive_define();
				}
				break;
			case DIRECTIVE_OPEN_SET:
				enterOuterAlt(_localctx, 3);
				{
				setState(87); directive_set();
				}
				break;
			case DIRECTIVE_OPEN_IF:
				enterOuterAlt(_localctx, 4);
				{
				setState(88); directive_if();
				}
				break;
			case DIRECTIVE_OPEN_FOR:
				enterOuterAlt(_localctx, 5);
				{
				setState(89); directive_for();
				}
				break;
			case DIRECTIVE_OPEN_BREAK:
			case DIRECTIVE_BREAK:
				enterOuterAlt(_localctx, 6);
				{
				setState(90); directive_break();
				}
				break;
			case DIRECTIVE_OPEN_CONTINUE:
			case DIRECTIVE_CONTINUE:
				enterOuterAlt(_localctx, 7);
				{
				setState(91); directive_continue();
				}
				break;
			case DIRECTIVE_OPEN_STOP:
			case DIRECTIVE_STOP:
				enterOuterAlt(_localctx, 8);
				{
				setState(92); directive_stop();
				}
				break;
			case DIRECTIVE_OPEN_INCLUDE:
				enterOuterAlt(_localctx, 9);
				{
				setState(93); directive_include();
				}
				break;
			case DIRECTIVE_OPEN_RETURN:
			case DIRECTIVE_RETURN:
				enterOuterAlt(_localctx, 10);
				{
				setState(94); directive_return();
				}
				break;
			case DIRECTIVE_OPEN_TAG:
				enterOuterAlt(_localctx, 11);
				{
				setState(95); directive_tag();
				}
				break;
			case DIRECTIVE_OPEN_CALL:
				enterOuterAlt(_localctx, 12);
				{
				setState(96); directive_call();
				}
				break;
			case DIRECTIVE_OPEN_MACRO:
				enterOuterAlt(_localctx, 13);
				{
				setState(97); directive_macro();
				}
				break;
			case DIRECTIVE_OPTIONS:
			case DIRECTIVE_DEFINE:
			case DIRECTIVE_SET:
			case DIRECTIVE_IF:
			case DIRECTIVE_ELSEIF:
			case DIRECTIVE_FOR:
			case DIRECTIVE_INCLUDE:
			case DIRECTIVE_TAG:
			case DIRECTIVE_CALL:
			case DIRECTIVE_MACRO:
				enterOuterAlt(_localctx, 14);
				{
				setState(98); directive_invalid();
				}
				break;
			default:
				throw new NoViableAltException(this);
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class Directive_optionsContext extends ParserRuleContext {
		public TerminalNode DIRECTIVE_OPEN_OPTIONS() { return getToken(JetTemplateParser.DIRECTIVE_OPEN_OPTIONS, 0); }
		public Directive_options_expressionContext directive_options_expression(int i) {
			return getRuleContext(Directive_options_expressionContext.class,i);
		}
		public List directive_options_expression() {
			return getRuleContexts(Directive_options_expressionContext.class);
		}
		public Directive_optionsContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_directive_options; }
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof JetTemplateParserVisitor ) return ((JetTemplateParserVisitor)visitor).visitDirective_options(this);
			else return visitor.visitChildren(this);
		}
	}

	public final Directive_optionsContext directive_options() throws RecognitionException {
		Directive_optionsContext _localctx = new Directive_optionsContext(_ctx, getState());
		enterRule(_localctx, 10, RULE_directive_options);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(101); match(DIRECTIVE_OPEN_OPTIONS);
			setState(102); directive_options_expression();
			setState(107);
			_errHandler.sync(this);
			_la = _input.LA(1);
			while (_la==COMMA) {
				{
				{
				setState(103); match(COMMA);
				setState(104); directive_options_expression();
				}
				}
				setState(109);
				_errHandler.sync(this);
				_la = _input.LA(1);
			}
			setState(110); match(RPAREN);
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class Directive_options_expressionContext extends ParserRuleContext {
		public ConstantContext constant() {
			return getRuleContext(ConstantContext.class,0);
		}
		public TerminalNode IDENTIFIER() { return getToken(JetTemplateParser.IDENTIFIER, 0); }
		public Directive_options_expressionContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_directive_options_expression; }
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof JetTemplateParserVisitor ) return ((JetTemplateParserVisitor)visitor).visitDirective_options_expression(this);
			else return visitor.visitChildren(this);
		}
	}

	public final Directive_options_expressionContext directive_options_expression() throws RecognitionException {
		Directive_options_expressionContext _localctx = new Directive_options_expressionContext(_ctx, getState());
		enterRule(_localctx, 12, RULE_directive_options_expression);
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(112); match(IDENTIFIER);
			setState(113); match(ASSIGN);
			setState(114); constant();
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class Directive_defineContext extends ParserRuleContext {
		public List directive_define_expression() {
			return getRuleContexts(Directive_define_expressionContext.class);
		}
		public TerminalNode DIRECTIVE_OPEN_DEFINE() { return getToken(JetTemplateParser.DIRECTIVE_OPEN_DEFINE, 0); }
		public Directive_define_expressionContext directive_define_expression(int i) {
			return getRuleContext(Directive_define_expressionContext.class,i);
		}
		public Directive_defineContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_directive_define; }
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof JetTemplateParserVisitor ) return ((JetTemplateParserVisitor)visitor).visitDirective_define(this);
			else return visitor.visitChildren(this);
		}
	}

	public final Directive_defineContext directive_define() throws RecognitionException {
		Directive_defineContext _localctx = new Directive_defineContext(_ctx, getState());
		enterRule(_localctx, 14, RULE_directive_define);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(116); match(DIRECTIVE_OPEN_DEFINE);
			setState(117); directive_define_expression();
			setState(122);
			_errHandler.sync(this);
			_la = _input.LA(1);
			while (_la==COMMA) {
				{
				{
				setState(118); match(COMMA);
				setState(119); directive_define_expression();
				}
				}
				setState(124);
				_errHandler.sync(this);
				_la = _input.LA(1);
			}
			setState(125); match(RPAREN);
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class Directive_define_expressionContext extends ParserRuleContext {
		public TypeContext type() {
			return getRuleContext(TypeContext.class,0);
		}
		public TerminalNode IDENTIFIER() { return getToken(JetTemplateParser.IDENTIFIER, 0); }
		public Directive_define_expressionContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_directive_define_expression; }
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof JetTemplateParserVisitor ) return ((JetTemplateParserVisitor)visitor).visitDirective_define_expression(this);
			else return visitor.visitChildren(this);
		}
	}

	public final Directive_define_expressionContext directive_define_expression() throws RecognitionException {
		Directive_define_expressionContext _localctx = new Directive_define_expressionContext(_ctx, getState());
		enterRule(_localctx, 16, RULE_directive_define_expression);
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(127); type();
			setState(128); match(IDENTIFIER);
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class Directive_setContext extends ParserRuleContext {
		public Directive_set_expressionContext directive_set_expression(int i) {
			return getRuleContext(Directive_set_expressionContext.class,i);
		}
		public List directive_set_expression() {
			return getRuleContexts(Directive_set_expressionContext.class);
		}
		public TerminalNode DIRECTIVE_OPEN_SET() { return getToken(JetTemplateParser.DIRECTIVE_OPEN_SET, 0); }
		public Directive_setContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_directive_set; }
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof JetTemplateParserVisitor ) return ((JetTemplateParserVisitor)visitor).visitDirective_set(this);
			else return visitor.visitChildren(this);
		}
	}

	public final Directive_setContext directive_set() throws RecognitionException {
		Directive_setContext _localctx = new Directive_setContext(_ctx, getState());
		enterRule(_localctx, 18, RULE_directive_set);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(130); match(DIRECTIVE_OPEN_SET);
			setState(131); directive_set_expression();
			setState(136);
			_errHandler.sync(this);
			_la = _input.LA(1);
			while (_la==COMMA) {
				{
				{
				setState(132); match(COMMA);
				setState(133); directive_set_expression();
				}
				}
				setState(138);
				_errHandler.sync(this);
				_la = _input.LA(1);
			}
			setState(139); match(RPAREN);
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class Directive_set_expressionContext extends ParserRuleContext {
		public TypeContext type() {
			return getRuleContext(TypeContext.class,0);
		}
		public TerminalNode IDENTIFIER() { return getToken(JetTemplateParser.IDENTIFIER, 0); }
		public ExpressionContext expression() {
			return getRuleContext(ExpressionContext.class,0);
		}
		public Directive_set_expressionContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_directive_set_expression; }
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof JetTemplateParserVisitor ) return ((JetTemplateParserVisitor)visitor).visitDirective_set_expression(this);
			else return visitor.visitChildren(this);
		}
	}

	public final Directive_set_expressionContext directive_set_expression() throws RecognitionException {
		Directive_set_expressionContext _localctx = new Directive_set_expressionContext(_ctx, getState());
		enterRule(_localctx, 20, RULE_directive_set_expression);
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(142);
			switch ( getInterpreter().adaptivePredict(_input,7,_ctx) ) {
			case 1:
				{
				setState(141); type();
				}
				break;
			}
			setState(144); match(IDENTIFIER);
			setState(145); match(ASSIGN);
			setState(146); expression(0);
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class Directive_ifContext extends ParserRuleContext {
		public TerminalNode DIRECTIVE_OPEN_IF() { return getToken(JetTemplateParser.DIRECTIVE_OPEN_IF, 0); }
		public Directive_elseifContext directive_elseif() {
			return getRuleContext(Directive_elseifContext.class,0);
		}
		public Directive_elseContext directive_else() {
			return getRuleContext(Directive_elseContext.class,0);
		}
		public ExpressionContext expression() {
			return getRuleContext(ExpressionContext.class,0);
		}
		public BlockContext block() {
			return getRuleContext(BlockContext.class,0);
		}
		public TerminalNode DIRECTIVE_END() { return getToken(JetTemplateParser.DIRECTIVE_END, 0); }
		public Directive_ifContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_directive_if; }
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof JetTemplateParserVisitor ) return ((JetTemplateParserVisitor)visitor).visitDirective_if(this);
			else return visitor.visitChildren(this);
		}
	}

	public final Directive_ifContext directive_if() throws RecognitionException {
		Directive_ifContext _localctx = new Directive_ifContext(_ctx, getState());
		enterRule(_localctx, 22, RULE_directive_if);
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(148); match(DIRECTIVE_OPEN_IF);
			setState(149); expression(0);
			setState(150); match(RPAREN);
			setState(151); block();
			setState(154);
			switch (_input.LA(1)) {
			case DIRECTIVE_OPEN_ELSEIF:
				{
				setState(152); directive_elseif();
				}
				break;
			case DIRECTIVE_ELSE:
				{
				setState(153); directive_else();
				}
				break;
			case DIRECTIVE_END:
				break;
			default:
				throw new NoViableAltException(this);
			}
			setState(156); match(DIRECTIVE_END);
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class Directive_elseifContext extends ParserRuleContext {
		public TerminalNode DIRECTIVE_OPEN_ELSEIF() { return getToken(JetTemplateParser.DIRECTIVE_OPEN_ELSEIF, 0); }
		public Directive_elseifContext directive_elseif() {
			return getRuleContext(Directive_elseifContext.class,0);
		}
		public Directive_elseContext directive_else() {
			return getRuleContext(Directive_elseContext.class,0);
		}
		public ExpressionContext expression() {
			return getRuleContext(ExpressionContext.class,0);
		}
		public BlockContext block() {
			return getRuleContext(BlockContext.class,0);
		}
		public Directive_elseifContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_directive_elseif; }
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof JetTemplateParserVisitor ) return ((JetTemplateParserVisitor)visitor).visitDirective_elseif(this);
			else return visitor.visitChildren(this);
		}
	}

	public final Directive_elseifContext directive_elseif() throws RecognitionException {
		Directive_elseifContext _localctx = new Directive_elseifContext(_ctx, getState());
		enterRule(_localctx, 24, RULE_directive_elseif);
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(158); match(DIRECTIVE_OPEN_ELSEIF);
			setState(159); expression(0);
			setState(160); match(RPAREN);
			setState(161); block();
			setState(164);
			switch (_input.LA(1)) {
			case DIRECTIVE_OPEN_ELSEIF:
				{
				setState(162); directive_elseif();
				}
				break;
			case DIRECTIVE_ELSE:
				{
				setState(163); directive_else();
				}
				break;
			case DIRECTIVE_END:
				break;
			default:
				throw new NoViableAltException(this);
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class Directive_elseContext extends ParserRuleContext {
		public BlockContext block() {
			return getRuleContext(BlockContext.class,0);
		}
		public TerminalNode DIRECTIVE_ELSE() { return getToken(JetTemplateParser.DIRECTIVE_ELSE, 0); }
		public Directive_elseContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_directive_else; }
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof JetTemplateParserVisitor ) return ((JetTemplateParserVisitor)visitor).visitDirective_else(this);
			else return visitor.visitChildren(this);
		}
	}

	public final Directive_elseContext directive_else() throws RecognitionException {
		Directive_elseContext _localctx = new Directive_elseContext(_ctx, getState());
		enterRule(_localctx, 26, RULE_directive_else);
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(166); match(DIRECTIVE_ELSE);
			setState(167); block();
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class Directive_forContext extends ParserRuleContext {
		public Directive_elseContext directive_else() {
			return getRuleContext(Directive_elseContext.class,0);
		}
		public TerminalNode DIRECTIVE_OPEN_FOR() { return getToken(JetTemplateParser.DIRECTIVE_OPEN_FOR, 0); }
		public TypeContext type() {
			return getRuleContext(TypeContext.class,0);
		}
		public TerminalNode IDENTIFIER() { return getToken(JetTemplateParser.IDENTIFIER, 0); }
		public ExpressionContext expression() {
			return getRuleContext(ExpressionContext.class,0);
		}
		public BlockContext block() {
			return getRuleContext(BlockContext.class,0);
		}
		public TerminalNode DIRECTIVE_END() { return getToken(JetTemplateParser.DIRECTIVE_END, 0); }
		public Directive_forContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_directive_for; }
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof JetTemplateParserVisitor ) return ((JetTemplateParserVisitor)visitor).visitDirective_for(this);
			else return visitor.visitChildren(this);
		}
	}

	public final Directive_forContext directive_for() throws RecognitionException {
		Directive_forContext _localctx = new Directive_forContext(_ctx, getState());
		enterRule(_localctx, 28, RULE_directive_for);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(169); match(DIRECTIVE_OPEN_FOR);
			setState(171);
			switch ( getInterpreter().adaptivePredict(_input,10,_ctx) ) {
			case 1:
				{
				setState(170); type();
				}
				break;
			}
			setState(173); match(IDENTIFIER);
			setState(174); match(COLON);
			setState(175); expression(0);
			setState(176); match(RPAREN);
			setState(177); block();
			setState(179);
			_la = _input.LA(1);
			if (_la==DIRECTIVE_ELSE) {
				{
				setState(178); directive_else();
				}
			}

			setState(181); match(DIRECTIVE_END);
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class Directive_breakContext extends ParserRuleContext {
		public TerminalNode DIRECTIVE_BREAK() { return getToken(JetTemplateParser.DIRECTIVE_BREAK, 0); }
		public ExpressionContext expression() {
			return getRuleContext(ExpressionContext.class,0);
		}
		public TerminalNode DIRECTIVE_OPEN_BREAK() { return getToken(JetTemplateParser.DIRECTIVE_OPEN_BREAK, 0); }
		public Directive_breakContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_directive_break; }
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof JetTemplateParserVisitor ) return ((JetTemplateParserVisitor)visitor).visitDirective_break(this);
			else return visitor.visitChildren(this);
		}
	}

	public final Directive_breakContext directive_break() throws RecognitionException {
		Directive_breakContext _localctx = new Directive_breakContext(_ctx, getState());
		enterRule(_localctx, 30, RULE_directive_break);
		int _la;
		try {
			setState(189);
			switch (_input.LA(1)) {
			case DIRECTIVE_OPEN_BREAK:
				enterOuterAlt(_localctx, 1);
				{
				setState(183); match(DIRECTIVE_OPEN_BREAK);
				setState(185);
				_la = _input.LA(1);
				if (((((_la - 41)) & ~0x3f) == 0 && ((1L << (_la - 41)) & ((1L << (LPAREN - 41)) | (1L << (LBRACK - 41)) | (1L << (LBRACE - 41)) | (1L << (NOT - 41)) | (1L << (PLUS - 41)) | (1L << (MINUS - 41)) | (1L << (BIT_NOT - 41)) | (1L << (NEW - 41)) | (1L << (TRUE - 41)) | (1L << (FALSE - 41)) | (1L << (NULL - 41)) | (1L << (IDENTIFIER - 41)) | (1L << (INTEGER - 41)) | (1L << (INTEGER_HEX - 41)) | (1L << (FLOATING_POINT - 41)) | (1L << (STRING_DOUBLE - 41)) | (1L << (STRING_SINGLE - 41)))) != 0)) {
					{
					setState(184); expression(0);
					}
				}

				setState(187); match(RPAREN);
				}
				break;
			case DIRECTIVE_BREAK:
				enterOuterAlt(_localctx, 2);
				{
				setState(188); match(DIRECTIVE_BREAK);
				}
				break;
			default:
				throw new NoViableAltException(this);
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class Directive_continueContext extends ParserRuleContext {
		public TerminalNode DIRECTIVE_OPEN_CONTINUE() { return getToken(JetTemplateParser.DIRECTIVE_OPEN_CONTINUE, 0); }
		public ExpressionContext expression() {
			return getRuleContext(ExpressionContext.class,0);
		}
		public TerminalNode DIRECTIVE_CONTINUE() { return getToken(JetTemplateParser.DIRECTIVE_CONTINUE, 0); }
		public Directive_continueContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_directive_continue; }
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof JetTemplateParserVisitor ) return ((JetTemplateParserVisitor)visitor).visitDirective_continue(this);
			else return visitor.visitChildren(this);
		}
	}

	public final Directive_continueContext directive_continue() throws RecognitionException {
		Directive_continueContext _localctx = new Directive_continueContext(_ctx, getState());
		enterRule(_localctx, 32, RULE_directive_continue);
		int _la;
		try {
			setState(197);
			switch (_input.LA(1)) {
			case DIRECTIVE_OPEN_CONTINUE:
				enterOuterAlt(_localctx, 1);
				{
				setState(191); match(DIRECTIVE_OPEN_CONTINUE);
				setState(193);
				_la = _input.LA(1);
				if (((((_la - 41)) & ~0x3f) == 0 && ((1L << (_la - 41)) & ((1L << (LPAREN - 41)) | (1L << (LBRACK - 41)) | (1L << (LBRACE - 41)) | (1L << (NOT - 41)) | (1L << (PLUS - 41)) | (1L << (MINUS - 41)) | (1L << (BIT_NOT - 41)) | (1L << (NEW - 41)) | (1L << (TRUE - 41)) | (1L << (FALSE - 41)) | (1L << (NULL - 41)) | (1L << (IDENTIFIER - 41)) | (1L << (INTEGER - 41)) | (1L << (INTEGER_HEX - 41)) | (1L << (FLOATING_POINT - 41)) | (1L << (STRING_DOUBLE - 41)) | (1L << (STRING_SINGLE - 41)))) != 0)) {
					{
					setState(192); expression(0);
					}
				}

				setState(195); match(RPAREN);
				}
				break;
			case DIRECTIVE_CONTINUE:
				enterOuterAlt(_localctx, 2);
				{
				setState(196); match(DIRECTIVE_CONTINUE);
				}
				break;
			default:
				throw new NoViableAltException(this);
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class Directive_stopContext extends ParserRuleContext {
		public TerminalNode DIRECTIVE_OPEN_STOP() { return getToken(JetTemplateParser.DIRECTIVE_OPEN_STOP, 0); }
		public ExpressionContext expression() {
			return getRuleContext(ExpressionContext.class,0);
		}
		public TerminalNode DIRECTIVE_STOP() { return getToken(JetTemplateParser.DIRECTIVE_STOP, 0); }
		public Directive_stopContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_directive_stop; }
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof JetTemplateParserVisitor ) return ((JetTemplateParserVisitor)visitor).visitDirective_stop(this);
			else return visitor.visitChildren(this);
		}
	}

	public final Directive_stopContext directive_stop() throws RecognitionException {
		Directive_stopContext _localctx = new Directive_stopContext(_ctx, getState());
		enterRule(_localctx, 34, RULE_directive_stop);
		int _la;
		try {
			setState(205);
			switch (_input.LA(1)) {
			case DIRECTIVE_OPEN_STOP:
				enterOuterAlt(_localctx, 1);
				{
				setState(199); match(DIRECTIVE_OPEN_STOP);
				setState(201);
				_la = _input.LA(1);
				if (((((_la - 41)) & ~0x3f) == 0 && ((1L << (_la - 41)) & ((1L << (LPAREN - 41)) | (1L << (LBRACK - 41)) | (1L << (LBRACE - 41)) | (1L << (NOT - 41)) | (1L << (PLUS - 41)) | (1L << (MINUS - 41)) | (1L << (BIT_NOT - 41)) | (1L << (NEW - 41)) | (1L << (TRUE - 41)) | (1L << (FALSE - 41)) | (1L << (NULL - 41)) | (1L << (IDENTIFIER - 41)) | (1L << (INTEGER - 41)) | (1L << (INTEGER_HEX - 41)) | (1L << (FLOATING_POINT - 41)) | (1L << (STRING_DOUBLE - 41)) | (1L << (STRING_SINGLE - 41)))) != 0)) {
					{
					setState(200); expression(0);
					}
				}

				setState(203); match(RPAREN);
				}
				break;
			case DIRECTIVE_STOP:
				enterOuterAlt(_localctx, 2);
				{
				setState(204); match(DIRECTIVE_STOP);
				}
				break;
			default:
				throw new NoViableAltException(this);
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class Directive_returnContext extends ParserRuleContext {
		public TerminalNode DIRECTIVE_OPEN_RETURN() { return getToken(JetTemplateParser.DIRECTIVE_OPEN_RETURN, 0); }
		public TerminalNode DIRECTIVE_RETURN() { return getToken(JetTemplateParser.DIRECTIVE_RETURN, 0); }
		public ExpressionContext expression() {
			return getRuleContext(ExpressionContext.class,0);
		}
		public Directive_returnContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_directive_return; }
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof JetTemplateParserVisitor ) return ((JetTemplateParserVisitor)visitor).visitDirective_return(this);
			else return visitor.visitChildren(this);
		}
	}

	public final Directive_returnContext directive_return() throws RecognitionException {
		Directive_returnContext _localctx = new Directive_returnContext(_ctx, getState());
		enterRule(_localctx, 36, RULE_directive_return);
		try {
			setState(212);
			switch (_input.LA(1)) {
			case DIRECTIVE_OPEN_RETURN:
				enterOuterAlt(_localctx, 1);
				{
				setState(207); match(DIRECTIVE_OPEN_RETURN);
				setState(208); expression(0);
				setState(209); match(RPAREN);
				}
				break;
			case DIRECTIVE_RETURN:
				enterOuterAlt(_localctx, 2);
				{
				setState(211); match(DIRECTIVE_RETURN);
				}
				break;
			default:
				throw new NoViableAltException(this);
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class Directive_includeContext extends ParserRuleContext {
		public TerminalNode DIRECTIVE_OPEN_INCLUDE() { return getToken(JetTemplateParser.DIRECTIVE_OPEN_INCLUDE, 0); }
		public ExpressionContext expression(int i) {
			return getRuleContext(ExpressionContext.class,i);
		}
		public List expression() {
			return getRuleContexts(ExpressionContext.class);
		}
		public Directive_includeContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_directive_include; }
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof JetTemplateParserVisitor ) return ((JetTemplateParserVisitor)visitor).visitDirective_include(this);
			else return visitor.visitChildren(this);
		}
	}

	public final Directive_includeContext directive_include() throws RecognitionException {
		Directive_includeContext _localctx = new Directive_includeContext(_ctx, getState());
		enterRule(_localctx, 38, RULE_directive_include);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(214); match(DIRECTIVE_OPEN_INCLUDE);
			setState(215); expression(0);
			setState(220);
			_errHandler.sync(this);
			_la = _input.LA(1);
			while (_la==COMMA) {
				{
				{
				setState(216); match(COMMA);
				setState(217); expression(0);
				}
				}
				setState(222);
				_errHandler.sync(this);
				_la = _input.LA(1);
			}
			setState(223); match(RPAREN);
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class Directive_tagContext extends ParserRuleContext {
		public Expression_listContext expression_list() {
			return getRuleContext(Expression_listContext.class,0);
		}
		public TerminalNode DIRECTIVE_OPEN_TAG() { return getToken(JetTemplateParser.DIRECTIVE_OPEN_TAG, 0); }
		public BlockContext block() {
			return getRuleContext(BlockContext.class,0);
		}
		public TerminalNode DIRECTIVE_END() { return getToken(JetTemplateParser.DIRECTIVE_END, 0); }
		public Directive_tagContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_directive_tag; }
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof JetTemplateParserVisitor ) return ((JetTemplateParserVisitor)visitor).visitDirective_tag(this);
			else return visitor.visitChildren(this);
		}
	}

	public final Directive_tagContext directive_tag() throws RecognitionException {
		Directive_tagContext _localctx = new Directive_tagContext(_ctx, getState());
		enterRule(_localctx, 40, RULE_directive_tag);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(225); match(DIRECTIVE_OPEN_TAG);
			setState(227);
			_la = _input.LA(1);
			if (((((_la - 41)) & ~0x3f) == 0 && ((1L << (_la - 41)) & ((1L << (LPAREN - 41)) | (1L << (LBRACK - 41)) | (1L << (LBRACE - 41)) | (1L << (NOT - 41)) | (1L << (PLUS - 41)) | (1L << (MINUS - 41)) | (1L << (BIT_NOT - 41)) | (1L << (NEW - 41)) | (1L << (TRUE - 41)) | (1L << (FALSE - 41)) | (1L << (NULL - 41)) | (1L << (IDENTIFIER - 41)) | (1L << (INTEGER - 41)) | (1L << (INTEGER_HEX - 41)) | (1L << (FLOATING_POINT - 41)) | (1L << (STRING_DOUBLE - 41)) | (1L << (STRING_SINGLE - 41)))) != 0)) {
				{
				setState(226); expression_list();
				}
			}

			setState(229); match(RPAREN);
			setState(230); block();
			setState(231); match(DIRECTIVE_END);
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class Directive_callContext extends ParserRuleContext {
		public Expression_listContext expression_list() {
			return getRuleContext(Expression_listContext.class,0);
		}
		public TerminalNode DIRECTIVE_OPEN_CALL() { return getToken(JetTemplateParser.DIRECTIVE_OPEN_CALL, 0); }
		public Directive_callContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_directive_call; }
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof JetTemplateParserVisitor ) return ((JetTemplateParserVisitor)visitor).visitDirective_call(this);
			else return visitor.visitChildren(this);
		}
	}

	public final Directive_callContext directive_call() throws RecognitionException {
		Directive_callContext _localctx = new Directive_callContext(_ctx, getState());
		enterRule(_localctx, 42, RULE_directive_call);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(233); match(DIRECTIVE_OPEN_CALL);
			setState(235);
			_la = _input.LA(1);
			if (((((_la - 41)) & ~0x3f) == 0 && ((1L << (_la - 41)) & ((1L << (LPAREN - 41)) | (1L << (LBRACK - 41)) | (1L << (LBRACE - 41)) | (1L << (NOT - 41)) | (1L << (PLUS - 41)) | (1L << (MINUS - 41)) | (1L << (BIT_NOT - 41)) | (1L << (NEW - 41)) | (1L << (TRUE - 41)) | (1L << (FALSE - 41)) | (1L << (NULL - 41)) | (1L << (IDENTIFIER - 41)) | (1L << (INTEGER - 41)) | (1L << (INTEGER_HEX - 41)) | (1L << (FLOATING_POINT - 41)) | (1L << (STRING_DOUBLE - 41)) | (1L << (STRING_SINGLE - 41)))) != 0)) {
				{
				setState(234); expression_list();
				}
			}

			setState(237); match(RPAREN);
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class Directive_macroContext extends ParserRuleContext {
		public Directive_macro_argumentsContext directive_macro_arguments() {
			return getRuleContext(Directive_macro_argumentsContext.class,0);
		}
		public TerminalNode DIRECTIVE_OPEN_MACRO() { return getToken(JetTemplateParser.DIRECTIVE_OPEN_MACRO, 0); }
		public BlockContext block() {
			return getRuleContext(BlockContext.class,0);
		}
		public TerminalNode DIRECTIVE_END() { return getToken(JetTemplateParser.DIRECTIVE_END, 0); }
		public Directive_macroContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_directive_macro; }
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof JetTemplateParserVisitor ) return ((JetTemplateParserVisitor)visitor).visitDirective_macro(this);
			else return visitor.visitChildren(this);
		}
	}

	public final Directive_macroContext directive_macro() throws RecognitionException {
		Directive_macroContext _localctx = new Directive_macroContext(_ctx, getState());
		enterRule(_localctx, 44, RULE_directive_macro);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(239); match(DIRECTIVE_OPEN_MACRO);
			setState(241);
			_la = _input.LA(1);
			if (_la==IDENTIFIER) {
				{
				setState(240); directive_macro_arguments();
				}
			}

			setState(243); match(RPAREN);
			setState(244); block();
			setState(245); match(DIRECTIVE_END);
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class Directive_macro_argumentsContext extends ParserRuleContext {
		public TypeContext type(int i) {
			return getRuleContext(TypeContext.class,i);
		}
		public TerminalNode IDENTIFIER(int i) {
			return getToken(JetTemplateParser.IDENTIFIER, i);
		}
		public List type() {
			return getRuleContexts(TypeContext.class);
		}
		public List IDENTIFIER() { return getTokens(JetTemplateParser.IDENTIFIER); }
		public Directive_macro_argumentsContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_directive_macro_arguments; }
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof JetTemplateParserVisitor ) return ((JetTemplateParserVisitor)visitor).visitDirective_macro_arguments(this);
			else return visitor.visitChildren(this);
		}
	}

	public final Directive_macro_argumentsContext directive_macro_arguments() throws RecognitionException {
		Directive_macro_argumentsContext _localctx = new Directive_macro_argumentsContext(_ctx, getState());
		enterRule(_localctx, 46, RULE_directive_macro_arguments);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(248);
			switch ( getInterpreter().adaptivePredict(_input,23,_ctx) ) {
			case 1:
				{
				setState(247); type();
				}
				break;
			}
			setState(250); match(IDENTIFIER);
			setState(258);
			_errHandler.sync(this);
			_la = _input.LA(1);
			while (_la==COMMA) {
				{
				{
				setState(251); match(COMMA);
				setState(253);
				switch ( getInterpreter().adaptivePredict(_input,24,_ctx) ) {
				case 1:
					{
					setState(252); type();
					}
					break;
				}
				setState(255); match(IDENTIFIER);
				}
				}
				setState(260);
				_errHandler.sync(this);
				_la = _input.LA(1);
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class Directive_invalidContext extends ParserRuleContext {
		public TerminalNode DIRECTIVE_ELSEIF() { return getToken(JetTemplateParser.DIRECTIVE_ELSEIF, 0); }
		public TerminalNode DIRECTIVE_MACRO() { return getToken(JetTemplateParser.DIRECTIVE_MACRO, 0); }
		public TerminalNode DIRECTIVE_SET() { return getToken(JetTemplateParser.DIRECTIVE_SET, 0); }
		public TerminalNode DIRECTIVE_IF() { return getToken(JetTemplateParser.DIRECTIVE_IF, 0); }
		public TerminalNode DIRECTIVE_TAG() { return getToken(JetTemplateParser.DIRECTIVE_TAG, 0); }
		public TerminalNode DIRECTIVE_CALL() { return getToken(JetTemplateParser.DIRECTIVE_CALL, 0); }
		public TerminalNode DIRECTIVE_FOR() { return getToken(JetTemplateParser.DIRECTIVE_FOR, 0); }
		public TerminalNode DIRECTIVE_DEFINE() { return getToken(JetTemplateParser.DIRECTIVE_DEFINE, 0); }
		public TerminalNode DIRECTIVE_INCLUDE() { return getToken(JetTemplateParser.DIRECTIVE_INCLUDE, 0); }
		public TerminalNode DIRECTIVE_OPTIONS() { return getToken(JetTemplateParser.DIRECTIVE_OPTIONS, 0); }
		public Directive_invalidContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_directive_invalid; }
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof JetTemplateParserVisitor ) return ((JetTemplateParserVisitor)visitor).visitDirective_invalid(this);
			else return visitor.visitChildren(this);
		}
	}

	public final Directive_invalidContext directive_invalid() throws RecognitionException {
		Directive_invalidContext _localctx = new Directive_invalidContext(_ctx, getState());
		enterRule(_localctx, 48, RULE_directive_invalid);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(261);
			_la = _input.LA(1);
			if ( !((((_la) & ~0x3f) == 0 && ((1L << _la) & ((1L << DIRECTIVE_OPTIONS) | (1L << DIRECTIVE_DEFINE) | (1L << DIRECTIVE_SET) | (1L << DIRECTIVE_IF) | (1L << DIRECTIVE_ELSEIF) | (1L << DIRECTIVE_FOR) | (1L << DIRECTIVE_INCLUDE) | (1L << DIRECTIVE_TAG) | (1L << DIRECTIVE_CALL) | (1L << DIRECTIVE_MACRO))) != 0)) ) {
			_errHandler.recoverInline(this);
			}
			consume();
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class ExpressionContext extends ParserRuleContext {
		public ExpressionContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_expression; }
	 
		public ExpressionContext() { }
		public void copyFrom(ExpressionContext ctx) {
			super.copyFrom(ctx);
		}
	}
	public static class Expression_instanceofContext extends ExpressionContext {
		public TypeContext type() {
			return getRuleContext(TypeContext.class,0);
		}
		public ExpressionContext expression() {
			return getRuleContext(ExpressionContext.class,0);
		}
		public Expression_instanceofContext(ExpressionContext ctx) { copyFrom(ctx); }
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof JetTemplateParserVisitor ) return ((JetTemplateParserVisitor)visitor).visitExpression_instanceof(this);
			else return visitor.visitChildren(this);
		}
	}
	public static class Expression_primaryContext extends ExpressionContext {
		public ExpressionContext expression() {
			return getRuleContext(ExpressionContext.class,0);
		}
		public Expression_primaryContext(ExpressionContext ctx) { copyFrom(ctx); }
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof JetTemplateParserVisitor ) return ((JetTemplateParserVisitor)visitor).visitExpression_primary(this);
			else return visitor.visitChildren(this);
		}
	}
	public static class Expression_identifierContext extends ExpressionContext {
		public IdentifierContext identifier() {
			return getRuleContext(IdentifierContext.class,0);
		}
		public Expression_identifierContext(ExpressionContext ctx) { copyFrom(ctx); }
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof JetTemplateParserVisitor ) return ((JetTemplateParserVisitor)visitor).visitExpression_identifier(this);
			else return visitor.visitChildren(this);
		}
	}
	public static class Expression_ternary_operatorContext extends ExpressionContext {
		public ExpressionContext expression(int i) {
			return getRuleContext(ExpressionContext.class,i);
		}
		public List expression() {
			return getRuleContexts(ExpressionContext.class);
		}
		public Expression_ternary_operatorContext(ExpressionContext ctx) { copyFrom(ctx); }
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof JetTemplateParserVisitor ) return ((JetTemplateParserVisitor)visitor).visitExpression_ternary_operator(this);
			else return visitor.visitChildren(this);
		}
	}
	public static class Expression_functionContext extends ExpressionContext {
		public Expression_listContext expression_list() {
			return getRuleContext(Expression_listContext.class,0);
		}
		public TerminalNode IDENTIFIER() { return getToken(JetTemplateParser.IDENTIFIER, 0); }
		public Expression_functionContext(ExpressionContext ctx) { copyFrom(ctx); }
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof JetTemplateParserVisitor ) return ((JetTemplateParserVisitor)visitor).visitExpression_function(this);
			else return visitor.visitChildren(this);
		}
	}
	public static class Expression_field_staticContext extends ExpressionContext {
		public TypeContext type() {
			return getRuleContext(TypeContext.class,0);
		}
		public TerminalNode IDENTIFIER() { return getToken(JetTemplateParser.IDENTIFIER, 0); }
		public Expression_field_staticContext(ExpressionContext ctx) { copyFrom(ctx); }
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof JetTemplateParserVisitor ) return ((JetTemplateParserVisitor)visitor).visitExpression_field_static(this);
			else return visitor.visitChildren(this);
		}
	}
	public static class Expression_methodContext extends ExpressionContext {
		public Expression_listContext expression_list() {
			return getRuleContext(Expression_listContext.class,0);
		}
		public ExpressionContext expression() {
			return getRuleContext(ExpressionContext.class,0);
		}
		public TerminalNode IDENTIFIER() { return getToken(JetTemplateParser.IDENTIFIER, 0); }
		public Expression_methodContext(ExpressionContext ctx) { copyFrom(ctx); }
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof JetTemplateParserVisitor ) return ((JetTemplateParserVisitor)visitor).visitExpression_method(this);
			else return visitor.visitChildren(this);
		}
	}
	public static class Expression_nullsafe_operatorContext extends ExpressionContext {
		public ExpressionContext expression(int i) {
			return getRuleContext(ExpressionContext.class,i);
		}
		public List expression() {
			return getRuleContexts(ExpressionContext.class);
		}
		public Expression_nullsafe_operatorContext(ExpressionContext ctx) { copyFrom(ctx); }
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof JetTemplateParserVisitor ) return ((JetTemplateParserVisitor)visitor).visitExpression_nullsafe_operator(this);
			else return visitor.visitChildren(this);
		}
	}
	public static class Expression_array_listContext extends ExpressionContext {
		public Expression_listContext expression_list() {
			return getRuleContext(Expression_listContext.class,0);
		}
		public Expression_array_listContext(ExpressionContext ctx) { copyFrom(ctx); }
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof JetTemplateParserVisitor ) return ((JetTemplateParserVisitor)visitor).visitExpression_array_list(this);
			else return visitor.visitChildren(this);
		}
	}
	public static class Expression_hash_mapContext extends ExpressionContext {
		public Hash_map_entryContext hash_map_entry(int i) {
			return getRuleContext(Hash_map_entryContext.class,i);
		}
		public List hash_map_entry() {
			return getRuleContexts(Hash_map_entryContext.class);
		}
		public Expression_hash_mapContext(ExpressionContext ctx) { copyFrom(ctx); }
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof JetTemplateParserVisitor ) return ((JetTemplateParserVisitor)visitor).visitExpression_hash_map(this);
			else return visitor.visitChildren(this);
		}
	}
	public static class Expression_unary_operatorContext extends ExpressionContext {
		public ExpressionContext expression() {
			return getRuleContext(ExpressionContext.class,0);
		}
		public Expression_unary_operatorContext(ExpressionContext ctx) { copyFrom(ctx); }
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof JetTemplateParserVisitor ) return ((JetTemplateParserVisitor)visitor).visitExpression_unary_operator(this);
			else return visitor.visitChildren(this);
		}
	}
	public static class Expression_new_arrayContext extends ExpressionContext {
		public ExpressionContext expression(int i) {
			return getRuleContext(ExpressionContext.class,i);
		}
		public TypeContext type() {
			return getRuleContext(TypeContext.class,0);
		}
		public List expression() {
			return getRuleContexts(ExpressionContext.class);
		}
		public Expression_new_arrayContext(ExpressionContext ctx) { copyFrom(ctx); }
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof JetTemplateParserVisitor ) return ((JetTemplateParserVisitor)visitor).visitExpression_new_array(this);
			else return visitor.visitChildren(this);
		}
	}
	public static class Expression_fieldContext extends ExpressionContext {
		public ExpressionContext expression() {
			return getRuleContext(ExpressionContext.class,0);
		}
		public TerminalNode IDENTIFIER() { return getToken(JetTemplateParser.IDENTIFIER, 0); }
		public Expression_fieldContext(ExpressionContext ctx) { copyFrom(ctx); }
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof JetTemplateParserVisitor ) return ((JetTemplateParserVisitor)visitor).visitExpression_field(this);
			else return visitor.visitChildren(this);
		}
	}
	public static class Expression_index_getContext extends ExpressionContext {
		public ExpressionContext expression(int i) {
			return getRuleContext(ExpressionContext.class,i);
		}
		public List expression() {
			return getRuleContexts(ExpressionContext.class);
		}
		public Expression_index_getContext(ExpressionContext ctx) { copyFrom(ctx); }
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof JetTemplateParserVisitor ) return ((JetTemplateParserVisitor)visitor).visitExpression_index_get(this);
			else return visitor.visitChildren(this);
		}
	}
	public static class Expression_method_staticContext extends ExpressionContext {
		public Expression_listContext expression_list() {
			return getRuleContext(Expression_listContext.class,0);
		}
		public TypeContext type() {
			return getRuleContext(TypeContext.class,0);
		}
		public TerminalNode IDENTIFIER() { return getToken(JetTemplateParser.IDENTIFIER, 0); }
		public Expression_method_staticContext(ExpressionContext ctx) { copyFrom(ctx); }
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof JetTemplateParserVisitor ) return ((JetTemplateParserVisitor)visitor).visitExpression_method_static(this);
			else return visitor.visitChildren(this);
		}
	}
	public static class Expression_constantContext extends ExpressionContext {
		public ConstantContext constant() {
			return getRuleContext(ConstantContext.class,0);
		}
		public Expression_constantContext(ExpressionContext ctx) { copyFrom(ctx); }
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof JetTemplateParserVisitor ) return ((JetTemplateParserVisitor)visitor).visitExpression_constant(this);
			else return visitor.visitChildren(this);
		}
	}
	public static class Expression_new_objectContext extends ExpressionContext {
		public Expression_listContext expression_list() {
			return getRuleContext(Expression_listContext.class,0);
		}
		public TypeContext type() {
			return getRuleContext(TypeContext.class,0);
		}
		public Expression_new_objectContext(ExpressionContext ctx) { copyFrom(ctx); }
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof JetTemplateParserVisitor ) return ((JetTemplateParserVisitor)visitor).visitExpression_new_object(this);
			else return visitor.visitChildren(this);
		}
	}
	public static class Expression_binary_operatorContext extends ExpressionContext {
		public ExpressionContext expression(int i) {
			return getRuleContext(ExpressionContext.class,i);
		}
		public List expression() {
			return getRuleContexts(ExpressionContext.class);
		}
		public Expression_binary_operatorContext(ExpressionContext ctx) { copyFrom(ctx); }
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof JetTemplateParserVisitor ) return ((JetTemplateParserVisitor)visitor).visitExpression_binary_operator(this);
			else return visitor.visitChildren(this);
		}
	}

	public final ExpressionContext expression() throws RecognitionException {
		return expression(0);
	}

	private ExpressionContext expression(int _p) throws RecognitionException {
		ParserRuleContext _parentctx = _ctx;
		int _parentState = getState();
		ExpressionContext _localctx = new ExpressionContext(_ctx, _parentState);
		ExpressionContext _prevctx = _localctx;
		int _startState = 50;
		enterRecursionRule(_localctx, 50, RULE_expression, _p);
		int _la;
		try {
			int _alt;
			enterOuterAlt(_localctx, 1);
			{
			setState(330);
			switch ( getInterpreter().adaptivePredict(_input,33,_ctx) ) {
			case 1:
				{
				_localctx = new Expression_unary_operatorContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;

				setState(264);
				_la = _input.LA(1);
				if ( !(_la==PLUS || _la==MINUS) ) {
				_errHandler.recoverInline(this);
				}
				consume();
				setState(265); expression(18);
				}
				break;

			case 2:
				{
				_localctx = new Expression_unary_operatorContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(266); match(BIT_NOT);
				setState(267); expression(17);
				}
				break;

			case 3:
				{
				_localctx = new Expression_unary_operatorContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(268); match(NOT);
				setState(269); expression(16);
				}
				break;

			case 4:
				{
				_localctx = new Expression_primaryContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(270); match(LPAREN);
				setState(271); expression(0);
				setState(272); match(RPAREN);
				}
				break;

			case 5:
				{
				_localctx = new Expression_constantContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(274); constant();
				}
				break;

			case 6:
				{
				_localctx = new Expression_identifierContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(275); identifier();
				}
				break;

			case 7:
				{
				_localctx = new Expression_array_listContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(276); match(LBRACK);
				setState(278);
				_la = _input.LA(1);
				if (((((_la - 41)) & ~0x3f) == 0 && ((1L << (_la - 41)) & ((1L << (LPAREN - 41)) | (1L << (LBRACK - 41)) | (1L << (LBRACE - 41)) | (1L << (NOT - 41)) | (1L << (PLUS - 41)) | (1L << (MINUS - 41)) | (1L << (BIT_NOT - 41)) | (1L << (NEW - 41)) | (1L << (TRUE - 41)) | (1L << (FALSE - 41)) | (1L << (NULL - 41)) | (1L << (IDENTIFIER - 41)) | (1L << (INTEGER - 41)) | (1L << (INTEGER_HEX - 41)) | (1L << (FLOATING_POINT - 41)) | (1L << (STRING_DOUBLE - 41)) | (1L << (STRING_SINGLE - 41)))) != 0)) {
					{
					setState(277); expression_list();
					}
				}

				setState(280); match(RBRACK);
				}
				break;

			case 8:
				{
				_localctx = new Expression_hash_mapContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(281); match(LBRACE);
				setState(290);
				_la = _input.LA(1);
				if (((((_la - 82)) & ~0x3f) == 0 && ((1L << (_la - 82)) & ((1L << (IDENTIFIER - 82)) | (1L << (STRING_DOUBLE - 82)) | (1L << (STRING_SINGLE - 82)))) != 0)) {
					{
					setState(282); hash_map_entry();
					setState(287);
					_errHandler.sync(this);
					_la = _input.LA(1);
					while (_la==COMMA) {
						{
						{
						setState(283); match(COMMA);
						setState(284); hash_map_entry();
						}
						}
						setState(289);
						_errHandler.sync(this);
						_la = _input.LA(1);
					}
					}
				}

				setState(292); match(RBRACE);
				}
				break;

			case 9:
				{
				_localctx = new Expression_field_staticContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(293); type();
				setState(294); match(COLON2);
				setState(295); match(IDENTIFIER);
				}
				break;

			case 10:
				{
				_localctx = new Expression_method_staticContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(297); type();
				setState(298); match(COLON2);
				setState(299); match(IDENTIFIER);
				setState(300); match(LPAREN);
				setState(302);
				_la = _input.LA(1);
				if (((((_la - 41)) & ~0x3f) == 0 && ((1L << (_la - 41)) & ((1L << (LPAREN - 41)) | (1L << (LBRACK - 41)) | (1L << (LBRACE - 41)) | (1L << (NOT - 41)) | (1L << (PLUS - 41)) | (1L << (MINUS - 41)) | (1L << (BIT_NOT - 41)) | (1L << (NEW - 41)) | (1L << (TRUE - 41)) | (1L << (FALSE - 41)) | (1L << (NULL - 41)) | (1L << (IDENTIFIER - 41)) | (1L << (INTEGER - 41)) | (1L << (INTEGER_HEX - 41)) | (1L << (FLOATING_POINT - 41)) | (1L << (STRING_DOUBLE - 41)) | (1L << (STRING_SINGLE - 41)))) != 0)) {
					{
					setState(301); expression_list();
					}
				}

				setState(304); match(RPAREN);
				}
				break;

			case 11:
				{
				_localctx = new Expression_functionContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(306); match(IDENTIFIER);
				setState(307); match(LPAREN);
				setState(309);
				_la = _input.LA(1);
				if (((((_la - 41)) & ~0x3f) == 0 && ((1L << (_la - 41)) & ((1L << (LPAREN - 41)) | (1L << (LBRACK - 41)) | (1L << (LBRACE - 41)) | (1L << (NOT - 41)) | (1L << (PLUS - 41)) | (1L << (MINUS - 41)) | (1L << (BIT_NOT - 41)) | (1L << (NEW - 41)) | (1L << (TRUE - 41)) | (1L << (FALSE - 41)) | (1L << (NULL - 41)) | (1L << (IDENTIFIER - 41)) | (1L << (INTEGER - 41)) | (1L << (INTEGER_HEX - 41)) | (1L << (FLOATING_POINT - 41)) | (1L << (STRING_DOUBLE - 41)) | (1L << (STRING_SINGLE - 41)))) != 0)) {
					{
					setState(308); expression_list();
					}
				}

				setState(311); match(RPAREN);
				}
				break;

			case 12:
				{
				_localctx = new Expression_new_objectContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(312); match(NEW);
				setState(313); type();
				setState(314); match(LPAREN);
				setState(316);
				_la = _input.LA(1);
				if (((((_la - 41)) & ~0x3f) == 0 && ((1L << (_la - 41)) & ((1L << (LPAREN - 41)) | (1L << (LBRACK - 41)) | (1L << (LBRACE - 41)) | (1L << (NOT - 41)) | (1L << (PLUS - 41)) | (1L << (MINUS - 41)) | (1L << (BIT_NOT - 41)) | (1L << (NEW - 41)) | (1L << (TRUE - 41)) | (1L << (FALSE - 41)) | (1L << (NULL - 41)) | (1L << (IDENTIFIER - 41)) | (1L << (INTEGER - 41)) | (1L << (INTEGER_HEX - 41)) | (1L << (FLOATING_POINT - 41)) | (1L << (STRING_DOUBLE - 41)) | (1L << (STRING_SINGLE - 41)))) != 0)) {
					{
					setState(315); expression_list();
					}
				}

				setState(318); match(RPAREN);
				}
				break;

			case 13:
				{
				_localctx = new Expression_new_arrayContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(320); match(NEW);
				setState(321); type();
				setState(326); 
				_errHandler.sync(this);
				_alt = 1;
				do {
					switch (_alt) {
					case 1:
						{
						{
						setState(322); match(LBRACK);
						setState(323); expression(0);
						setState(324); match(RBRACK);
						}
						}
						break;
					default:
						throw new NoViableAltException(this);
					}
					setState(328); 
					_errHandler.sync(this);
					_alt = getInterpreter().adaptivePredict(_input,32,_ctx);
				} while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER );
				}
				break;
			}
			_ctx.stop = _input.LT(-1);
			setState(393);
			_errHandler.sync(this);
			_alt = getInterpreter().adaptivePredict(_input,37,_ctx);
			while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) {
				if ( _alt==1 ) {
					if ( _parseListeners!=null ) triggerExitRuleEvent();
					_prevctx = _localctx;
					{
					setState(391);
					switch ( getInterpreter().adaptivePredict(_input,36,_ctx) ) {
					case 1:
						{
						_localctx = new Expression_nullsafe_operatorContext(new ExpressionContext(_parentctx, _parentState));
						pushNewRecursionContext(_localctx, _startState, RULE_expression);
						setState(332);
						if (!(precpred(_ctx, 13))) throw new FailedPredicateException(this, "precpred(_ctx, 13)");
						setState(333); match(NULL_AS_DEFAULT);
						setState(334); expression(14);
						}
						break;

					case 2:
						{
						_localctx = new Expression_binary_operatorContext(new ExpressionContext(_parentctx, _parentState));
						pushNewRecursionContext(_localctx, _startState, RULE_expression);
						setState(335);
						if (!(precpred(_ctx, 12))) throw new FailedPredicateException(this, "precpred(_ctx, 12)");
						setState(336);
						_la = _input.LA(1);
						if ( !(((((_la - 67)) & ~0x3f) == 0 && ((1L << (_la - 67)) & ((1L << (MUL - 67)) | (1L << (DIV - 67)) | (1L << (MOD - 67)))) != 0)) ) {
						_errHandler.recoverInline(this);
						}
						consume();
						setState(337); expression(13);
						}
						break;

					case 3:
						{
						_localctx = new Expression_binary_operatorContext(new ExpressionContext(_parentctx, _parentState));
						pushNewRecursionContext(_localctx, _startState, RULE_expression);
						setState(338);
						if (!(precpred(_ctx, 11))) throw new FailedPredicateException(this, "precpred(_ctx, 11)");
						setState(339);
						_la = _input.LA(1);
						if ( !(_la==PLUS || _la==MINUS) ) {
						_errHandler.recoverInline(this);
						}
						consume();
						setState(340); expression(12);
						}
						break;

					case 4:
						{
						_localctx = new Expression_binary_operatorContext(new ExpressionContext(_parentctx, _parentState));
						pushNewRecursionContext(_localctx, _startState, RULE_expression);
						setState(341);
						if (!(precpred(_ctx, 10))) throw new FailedPredicateException(this, "precpred(_ctx, 10)");
						setState(342);
						_la = _input.LA(1);
						if ( !(((((_la - 74)) & ~0x3f) == 0 && ((1L << (_la - 74)) & ((1L << (BIT_SHL - 74)) | (1L << (BIT_SHR - 74)) | (1L << (BIT_USHR - 74)))) != 0)) ) {
						_errHandler.recoverInline(this);
						}
						consume();
						setState(343); expression(11);
						}
						break;

					case 5:
						{
						_localctx = new Expression_binary_operatorContext(new ExpressionContext(_parentctx, _parentState));
						pushNewRecursionContext(_localctx, _startState, RULE_expression);
						setState(344);
						if (!(precpred(_ctx, 9))) throw new FailedPredicateException(this, "precpred(_ctx, 9)");
						setState(345);
						_la = _input.LA(1);
						if ( !((((_la) & ~0x3f) == 0 && ((1L << _la) & ((1L << GT) | (1L << LT) | (1L << GE) | (1L << LE))) != 0)) ) {
						_errHandler.recoverInline(this);
						}
						consume();
						setState(346); expression(10);
						}
						break;

					case 6:
						{
						_localctx = new Expression_binary_operatorContext(new ExpressionContext(_parentctx, _parentState));
						pushNewRecursionContext(_localctx, _startState, RULE_expression);
						setState(347);
						if (!(precpred(_ctx, 7))) throw new FailedPredicateException(this, "precpred(_ctx, 7)");
						setState(348);
						_la = _input.LA(1);
						if ( !((((_la) & ~0x3f) == 0 && ((1L << _la) & ((1L << IDENTICALLY_EQUAL) | (1L << IDENTICALLY_EQUAL_NOT) | (1L << EQ) | (1L << NE))) != 0)) ) {
						_errHandler.recoverInline(this);
						}
						consume();
						setState(349); expression(8);
						}
						break;

					case 7:
						{
						_localctx = new Expression_binary_operatorContext(new ExpressionContext(_parentctx, _parentState));
						pushNewRecursionContext(_localctx, _startState, RULE_expression);
						setState(350);
						if (!(precpred(_ctx, 6))) throw new FailedPredicateException(this, "precpred(_ctx, 6)");
						setState(351); match(BIT_AND);
						setState(352); expression(7);
						}
						break;

					case 8:
						{
						_localctx = new Expression_binary_operatorContext(new ExpressionContext(_parentctx, _parentState));
						pushNewRecursionContext(_localctx, _startState, RULE_expression);
						setState(353);
						if (!(precpred(_ctx, 5))) throw new FailedPredicateException(this, "precpred(_ctx, 5)");
						setState(354); match(BIT_XOR);
						setState(355); expression(5);
						}
						break;

					case 9:
						{
						_localctx = new Expression_binary_operatorContext(new ExpressionContext(_parentctx, _parentState));
						pushNewRecursionContext(_localctx, _startState, RULE_expression);
						setState(356);
						if (!(precpred(_ctx, 4))) throw new FailedPredicateException(this, "precpred(_ctx, 4)");
						setState(357); match(BIT_OR);
						setState(358); expression(5);
						}
						break;

					case 10:
						{
						_localctx = new Expression_binary_operatorContext(new ExpressionContext(_parentctx, _parentState));
						pushNewRecursionContext(_localctx, _startState, RULE_expression);
						setState(359);
						if (!(precpred(_ctx, 3))) throw new FailedPredicateException(this, "precpred(_ctx, 3)");
						setState(360); match(AND);
						setState(361); expression(4);
						}
						break;

					case 11:
						{
						_localctx = new Expression_binary_operatorContext(new ExpressionContext(_parentctx, _parentState));
						pushNewRecursionContext(_localctx, _startState, RULE_expression);
						setState(362);
						if (!(precpred(_ctx, 2))) throw new FailedPredicateException(this, "precpred(_ctx, 2)");
						setState(363); match(OR);
						setState(364); expression(3);
						}
						break;

					case 12:
						{
						_localctx = new Expression_ternary_operatorContext(new ExpressionContext(_parentctx, _parentState));
						pushNewRecursionContext(_localctx, _startState, RULE_expression);
						setState(365);
						if (!(precpred(_ctx, 1))) throw new FailedPredicateException(this, "precpred(_ctx, 1)");
						setState(366); match(QUESTION);
						setState(368);
						_la = _input.LA(1);
						if (((((_la - 41)) & ~0x3f) == 0 && ((1L << (_la - 41)) & ((1L << (LPAREN - 41)) | (1L << (LBRACK - 41)) | (1L << (LBRACE - 41)) | (1L << (NOT - 41)) | (1L << (PLUS - 41)) | (1L << (MINUS - 41)) | (1L << (BIT_NOT - 41)) | (1L << (NEW - 41)) | (1L << (TRUE - 41)) | (1L << (FALSE - 41)) | (1L << (NULL - 41)) | (1L << (IDENTIFIER - 41)) | (1L << (INTEGER - 41)) | (1L << (INTEGER_HEX - 41)) | (1L << (FLOATING_POINT - 41)) | (1L << (STRING_DOUBLE - 41)) | (1L << (STRING_SINGLE - 41)))) != 0)) {
							{
							setState(367); expression(0);
							}
						}

						setState(370); match(COLON);
						setState(371); expression(1);
						}
						break;

					case 13:
						{
						_localctx = new Expression_fieldContext(new ExpressionContext(_parentctx, _parentState));
						pushNewRecursionContext(_localctx, _startState, RULE_expression);
						setState(372);
						if (!(precpred(_ctx, 24))) throw new FailedPredicateException(this, "precpred(_ctx, 24)");
						setState(373); match(DOT);
						setState(374); match(IDENTIFIER);
						}
						break;

					case 14:
						{
						_localctx = new Expression_methodContext(new ExpressionContext(_parentctx, _parentState));
						pushNewRecursionContext(_localctx, _startState, RULE_expression);
						setState(375);
						if (!(precpred(_ctx, 23))) throw new FailedPredicateException(this, "precpred(_ctx, 23)");
						setState(376); match(DOT);
						setState(377); match(IDENTIFIER);
						setState(378); match(LPAREN);
						setState(380);
						_la = _input.LA(1);
						if (((((_la - 41)) & ~0x3f) == 0 && ((1L << (_la - 41)) & ((1L << (LPAREN - 41)) | (1L << (LBRACK - 41)) | (1L << (LBRACE - 41)) | (1L << (NOT - 41)) | (1L << (PLUS - 41)) | (1L << (MINUS - 41)) | (1L << (BIT_NOT - 41)) | (1L << (NEW - 41)) | (1L << (TRUE - 41)) | (1L << (FALSE - 41)) | (1L << (NULL - 41)) | (1L << (IDENTIFIER - 41)) | (1L << (INTEGER - 41)) | (1L << (INTEGER_HEX - 41)) | (1L << (FLOATING_POINT - 41)) | (1L << (STRING_DOUBLE - 41)) | (1L << (STRING_SINGLE - 41)))) != 0)) {
							{
							setState(379); expression_list();
							}
						}

						setState(382); match(RPAREN);
						}
						break;

					case 15:
						{
						_localctx = new Expression_index_getContext(new ExpressionContext(_parentctx, _parentState));
						pushNewRecursionContext(_localctx, _startState, RULE_expression);
						setState(383);
						if (!(precpred(_ctx, 20))) throw new FailedPredicateException(this, "precpred(_ctx, 20)");
						setState(384); match(LBRACK);
						setState(385); expression(0);
						setState(386); match(RBRACK);
						}
						break;

					case 16:
						{
						_localctx = new Expression_instanceofContext(new ExpressionContext(_parentctx, _parentState));
						pushNewRecursionContext(_localctx, _startState, RULE_expression);
						setState(388);
						if (!(precpred(_ctx, 8))) throw new FailedPredicateException(this, "precpred(_ctx, 8)");
						setState(389); match(INSTANCEOF);
						setState(390); type();
						}
						break;
					}
					} 
				}
				setState(395);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,37,_ctx);
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			unrollRecursionContexts(_parentctx);
		}
		return _localctx;
	}

	public static class IdentifierContext extends ParserRuleContext {
		public TerminalNode IDENTIFIER() { return getToken(JetTemplateParser.IDENTIFIER, 0); }
		public IdentifierContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_identifier; }
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof JetTemplateParserVisitor ) return ((JetTemplateParserVisitor)visitor).visitIdentifier(this);
			else return visitor.visitChildren(this);
		}
	}

	public final IdentifierContext identifier() throws RecognitionException {
		IdentifierContext _localctx = new IdentifierContext(_ctx, getState());
		enterRule(_localctx, 52, RULE_identifier);
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(396); match(IDENTIFIER);
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class ConstantContext extends ParserRuleContext {
		public TerminalNode FLOATING_POINT() { return getToken(JetTemplateParser.FLOATING_POINT, 0); }
		public TerminalNode INTEGER() { return getToken(JetTemplateParser.INTEGER, 0); }
		public TerminalNode NULL() { return getToken(JetTemplateParser.NULL, 0); }
		public TerminalNode FALSE() { return getToken(JetTemplateParser.FALSE, 0); }
		public TerminalNode TRUE() { return getToken(JetTemplateParser.TRUE, 0); }
		public TerminalNode STRING_DOUBLE() { return getToken(JetTemplateParser.STRING_DOUBLE, 0); }
		public TerminalNode STRING_SINGLE() { return getToken(JetTemplateParser.STRING_SINGLE, 0); }
		public TerminalNode INTEGER_HEX() { return getToken(JetTemplateParser.INTEGER_HEX, 0); }
		public ConstantContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_constant; }
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof JetTemplateParserVisitor ) return ((JetTemplateParserVisitor)visitor).visitConstant(this);
			else return visitor.visitChildren(this);
		}
	}

	public final ConstantContext constant() throws RecognitionException {
		ConstantContext _localctx = new ConstantContext(_ctx, getState());
		enterRule(_localctx, 54, RULE_constant);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(398);
			_la = _input.LA(1);
			if ( !(((((_la - 79)) & ~0x3f) == 0 && ((1L << (_la - 79)) & ((1L << (TRUE - 79)) | (1L << (FALSE - 79)) | (1L << (NULL - 79)) | (1L << (INTEGER - 79)) | (1L << (INTEGER_HEX - 79)) | (1L << (FLOATING_POINT - 79)) | (1L << (STRING_DOUBLE - 79)) | (1L << (STRING_SINGLE - 79)))) != 0)) ) {
			_errHandler.recoverInline(this);
			}
			consume();
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class Expression_listContext extends ParserRuleContext {
		public ExpressionContext expression(int i) {
			return getRuleContext(ExpressionContext.class,i);
		}
		public List expression() {
			return getRuleContexts(ExpressionContext.class);
		}
		public Expression_listContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_expression_list; }
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof JetTemplateParserVisitor ) return ((JetTemplateParserVisitor)visitor).visitExpression_list(this);
			else return visitor.visitChildren(this);
		}
	}

	public final Expression_listContext expression_list() throws RecognitionException {
		Expression_listContext _localctx = new Expression_listContext(_ctx, getState());
		enterRule(_localctx, 56, RULE_expression_list);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(400); expression(0);
			setState(405);
			_errHandler.sync(this);
			_la = _input.LA(1);
			while (_la==COMMA) {
				{
				{
				setState(401); match(COMMA);
				setState(402); expression(0);
				}
				}
				setState(407);
				_errHandler.sync(this);
				_la = _input.LA(1);
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class Hash_map_entryContext extends ParserRuleContext {
		public TerminalNode STRING_DOUBLE() { return getToken(JetTemplateParser.STRING_DOUBLE, 0); }
		public TerminalNode STRING_SINGLE() { return getToken(JetTemplateParser.STRING_SINGLE, 0); }
		public ExpressionContext expression() {
			return getRuleContext(ExpressionContext.class,0);
		}
		public TerminalNode IDENTIFIER() { return getToken(JetTemplateParser.IDENTIFIER, 0); }
		public Hash_map_entryContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_hash_map_entry; }
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof JetTemplateParserVisitor ) return ((JetTemplateParserVisitor)visitor).visitHash_map_entry(this);
			else return visitor.visitChildren(this);
		}
	}

	public final Hash_map_entryContext hash_map_entry() throws RecognitionException {
		Hash_map_entryContext _localctx = new Hash_map_entryContext(_ctx, getState());
		enterRule(_localctx, 58, RULE_hash_map_entry);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(408);
			_la = _input.LA(1);
			if ( !(((((_la - 82)) & ~0x3f) == 0 && ((1L << (_la - 82)) & ((1L << (IDENTIFIER - 82)) | (1L << (STRING_DOUBLE - 82)) | (1L << (STRING_SINGLE - 82)))) != 0)) ) {
			_errHandler.recoverInline(this);
			}
			consume();
			setState(409); match(COLON);
			setState(410); expression(0);
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class TypeContext extends ParserRuleContext {
		public TerminalNode IDENTIFIER(int i) {
			return getToken(JetTemplateParser.IDENTIFIER, i);
		}
		public List IDENTIFIER() { return getTokens(JetTemplateParser.IDENTIFIER); }
		public TypeContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_type; }
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof JetTemplateParserVisitor ) return ((JetTemplateParserVisitor)visitor).visitType(this);
			else return visitor.visitChildren(this);
		}
	}

	public final TypeContext type() throws RecognitionException {
		TypeContext _localctx = new TypeContext(_ctx, getState());
		enterRule(_localctx, 60, RULE_type);
		try {
			int _alt;
			enterOuterAlt(_localctx, 1);
			{
			setState(412); match(IDENTIFIER);
			setState(417);
			_errHandler.sync(this);
			_alt = getInterpreter().adaptivePredict(_input,39,_ctx);
			while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) {
				if ( _alt==1 ) {
					{
					{
					setState(413); match(DOT);
					setState(414); match(IDENTIFIER);
					}
					} 
				}
				setState(419);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,39,_ctx);
			}
			setState(424);
			_errHandler.sync(this);
			_alt = getInterpreter().adaptivePredict(_input,40,_ctx);
			while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) {
				if ( _alt==1 ) {
					{
					{
					setState(420); match(LBRACK);
					setState(421); match(RBRACK);
					}
					} 
				}
				setState(426);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,40,_ctx);
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public boolean sempred(RuleContext _localctx, int ruleIndex, int predIndex) {
		switch (ruleIndex) {
		case 25: return expression_sempred((ExpressionContext)_localctx, predIndex);
		}
		return true;
	}
	private boolean expression_sempred(ExpressionContext _localctx, int predIndex) {
		switch (predIndex) {
		case 0: return precpred(_ctx, 13);

		case 1: return precpred(_ctx, 12);

		case 2: return precpred(_ctx, 11);

		case 3: return precpred(_ctx, 10);

		case 4: return precpred(_ctx, 9);

		case 5: return precpred(_ctx, 7);

		case 6: return precpred(_ctx, 6);

		case 7: return precpred(_ctx, 5);

		case 8: return precpred(_ctx, 4);

		case 9: return precpred(_ctx, 3);

		case 10: return precpred(_ctx, 2);

		case 11: return precpred(_ctx, 1);

		case 12: return precpred(_ctx, 24);

		case 13: return precpred(_ctx, 23);

		case 14: return precpred(_ctx, 20);

		case 15: return precpred(_ctx, 8);
		}
		return true;
	}

	public static final String _serializedATN =
		"\3\u0430\ud6d1\u8206\uad2d\u4417\uaef1\u8d80\uaadd\3Y\u01ae\4\2\t\2\4"+
		"\3\t\3\4\4\t\4\4\5\t\5\4\6\t\6\4\7\t\7\4\b\t\b\4\t\t\t\4\n\t\n\4\13\t"+
		"\13\4\f\t\f\4\r\t\r\4\16\t\16\4\17\t\17\4\20\t\20\4\21\t\21\4\22\t\22"+
		"\4\23\t\23\4\24\t\24\4\25\t\25\4\26\t\26\4\27\t\27\4\30\t\30\4\31\t\31"+
		"\4\32\t\32\4\33\t\33\4\34\t\34\4\35\t\35\4\36\t\36\4\37\t\37\4 \t \3\2"+
		"\3\2\3\2\3\3\3\3\3\3\7\3G\n\3\f\3\16\3J\13\3\3\4\3\4\3\5\3\5\3\5\3\5\3"+
		"\5\3\5\3\5\3\5\5\5V\n\5\3\6\3\6\3\6\3\6\3\6\3\6\3\6\3\6\3\6\3\6\3\6\3"+
		"\6\3\6\3\6\5\6f\n\6\3\7\3\7\3\7\3\7\7\7l\n\7\f\7\16\7o\13\7\3\7\3\7\3"+
		"\b\3\b\3\b\3\b\3\t\3\t\3\t\3\t\7\t{\n\t\f\t\16\t~\13\t\3\t\3\t\3\n\3\n"+
		"\3\n\3\13\3\13\3\13\3\13\7\13\u0089\n\13\f\13\16\13\u008c\13\13\3\13\3"+
		"\13\3\f\5\f\u0091\n\f\3\f\3\f\3\f\3\f\3\r\3\r\3\r\3\r\3\r\3\r\5\r\u009d"+
		"\n\r\3\r\3\r\3\16\3\16\3\16\3\16\3\16\3\16\5\16\u00a7\n\16\3\17\3\17\3"+
		"\17\3\20\3\20\5\20\u00ae\n\20\3\20\3\20\3\20\3\20\3\20\3\20\5\20\u00b6"+
		"\n\20\3\20\3\20\3\21\3\21\5\21\u00bc\n\21\3\21\3\21\5\21\u00c0\n\21\3"+
		"\22\3\22\5\22\u00c4\n\22\3\22\3\22\5\22\u00c8\n\22\3\23\3\23\5\23\u00cc"+
		"\n\23\3\23\3\23\5\23\u00d0\n\23\3\24\3\24\3\24\3\24\3\24\5\24\u00d7\n"+
		"\24\3\25\3\25\3\25\3\25\7\25\u00dd\n\25\f\25\16\25\u00e0\13\25\3\25\3"+
		"\25\3\26\3\26\5\26\u00e6\n\26\3\26\3\26\3\26\3\26\3\27\3\27\5\27\u00ee"+
		"\n\27\3\27\3\27\3\30\3\30\5\30\u00f4\n\30\3\30\3\30\3\30\3\30\3\31\5\31"+
		"\u00fb\n\31\3\31\3\31\3\31\5\31\u0100\n\31\3\31\7\31\u0103\n\31\f\31\16"+
		"\31\u0106\13\31\3\32\3\32\3\33\3\33\3\33\3\33\3\33\3\33\3\33\3\33\3\33"+
		"\3\33\3\33\3\33\3\33\3\33\3\33\5\33\u0119\n\33\3\33\3\33\3\33\3\33\3\33"+
		"\7\33\u0120\n\33\f\33\16\33\u0123\13\33\5\33\u0125\n\33\3\33\3\33\3\33"+
		"\3\33\3\33\3\33\3\33\3\33\3\33\3\33\5\33\u0131\n\33\3\33\3\33\3\33\3\33"+
		"\3\33\5\33\u0138\n\33\3\33\3\33\3\33\3\33\3\33\5\33\u013f\n\33\3\33\3"+
		"\33\3\33\3\33\3\33\3\33\3\33\3\33\6\33\u0149\n\33\r\33\16\33\u014a\5\33"+
		"\u014d\n\33\3\33\3\33\3\33\3\33\3\33\3\33\3\33\3\33\3\33\3\33\3\33\3\33"+
		"\3\33\3\33\3\33\3\33\3\33\3\33\3\33\3\33\3\33\3\33\3\33\3\33\3\33\3\33"+
		"\3\33\3\33\3\33\3\33\3\33\3\33\3\33\3\33\3\33\3\33\5\33\u0173\n\33\3\33"+
		"\3\33\3\33\3\33\3\33\3\33\3\33\3\33\3\33\3\33\5\33\u017f\n\33\3\33\3\33"+
		"\3\33\3\33\3\33\3\33\3\33\3\33\3\33\7\33\u018a\n\33\f\33\16\33\u018d\13"+
		"\33\3\34\3\34\3\35\3\35\3\36\3\36\3\36\7\36\u0196\n\36\f\36\16\36\u0199"+
		"\13\36\3\37\3\37\3\37\3\37\3 \3 \3 \7 \u01a2\n \f \16 \u01a5\13 \3 \3"+
		" \7 \u01a9\n \f \16 \u01ac\13 \3 \2\3\64!\2\4\6\b\n\f\16\20\22\24\26\30"+
		"\32\34\36 \"$&(*,.\60\62\64\668:<>\2\13\4\2\5\b))\3\2\37(\3\2CD\3\2EG"+
		"\3\2LN\3\2\u019e"+
		"\3\2\2\2@A\5\4\3\2AB\7\2\2\3B\3\3\2\2\2CG\5\6\4\2DG\5\b\5\2EG\5\n\6\2"+
		"FC\3\2\2\2FD\3\2\2\2FE\3\2\2\2GJ\3\2\2\2HF\3\2\2\2HI\3\2\2\2I\5\3\2\2"+
		"\2JH\3\2\2\2KL\t\2\2\2L\7\3\2\2\2MN\7\t\2\2NO\5\64\33\2OP\7\60\2\2PV\3"+
		"\2\2\2QR\7\n\2\2RS\5\64\33\2ST\7\60\2\2TV\3\2\2\2UM\3\2\2\2UQ\3\2\2\2"+
		"V\t\3\2\2\2Wf\5\f\7\2Xf\5\20\t\2Yf\5\24\13\2Zf\5\30\r\2[f\5\36\20\2\\"+
		"f\5 \21\2]f\5\"\22\2^f\5$\23\2_f\5(\25\2`f\5&\24\2af\5*\26\2bf\5,\27\2"+
		"cf\5.\30\2df\5\62\32\2eW\3\2\2\2eX\3\2\2\2eY\3\2\2\2eZ\3\2\2\2e[\3\2\2"+
		"\2e\\\3\2\2\2e]\3\2\2\2e^\3\2\2\2e_\3\2\2\2e`\3\2\2\2ea\3\2\2\2eb\3\2"+
		"\2\2ec\3\2\2\2ed\3\2\2\2f\13\3\2\2\2gh\7\13\2\2hm\5\16\b\2ij\7\61\2\2"+
		"jl\5\16\b\2ki\3\2\2\2lo\3\2\2\2mk\3\2\2\2mn\3\2\2\2np\3\2\2\2om\3\2\2"+
		"\2pq\7,\2\2q\r\3\2\2\2rs\7T\2\2st\7\66\2\2tu\58\35\2u\17\3\2\2\2vw\7\f"+
		"\2\2w|\5\22\n\2xy\7\61\2\2y{\5\22\n\2zx\3\2\2\2{~\3\2\2\2|z\3\2\2\2|}"+
		"\3\2\2\2}\177\3\2\2\2~|\3\2\2\2\177\u0080\7,\2\2\u0080\21\3\2\2\2\u0081"+
		"\u0082\5> \2\u0082\u0083\7T\2\2\u0083\23\3\2\2\2\u0084\u0085\7\r\2\2\u0085"+
		"\u008a\5\26\f\2\u0086\u0087\7\61\2\2\u0087\u0089\5\26\f\2\u0088\u0086"+
		"\3\2\2\2\u0089\u008c\3\2\2\2\u008a\u0088\3\2\2\2\u008a\u008b\3\2\2\2\u008b"+
		"\u008d\3\2\2\2\u008c\u008a\3\2\2\2\u008d\u008e\7,\2\2\u008e\25\3\2\2\2"+
		"\u008f\u0091\5> \2\u0090\u008f\3\2\2\2\u0090\u0091\3\2\2\2\u0091\u0092"+
		"\3\2\2\2\u0092\u0093\7T\2\2\u0093\u0094\7\66\2\2\u0094\u0095\5\64\33\2"+
		"\u0095\27\3\2\2\2\u0096\u0097\7\16\2\2\u0097\u0098\5\64\33\2\u0098\u0099"+
		"\7,\2\2\u0099\u009c\5\4\3\2\u009a\u009d\5\32\16\2\u009b\u009d\5\34\17"+
		"\2\u009c\u009a\3\2\2\2\u009c\u009b\3\2\2\2\u009c\u009d\3\2\2\2\u009d\u009e"+
		"\3\2\2\2\u009e\u009f\7\32\2\2\u009f\31\3\2\2\2\u00a0\u00a1\7\17\2\2\u00a1"+
		"\u00a2\5\64\33\2\u00a2\u00a3\7,\2\2\u00a3\u00a6\5\4\3\2\u00a4\u00a7\5"+
		"\32\16\2\u00a5\u00a7\5\34\17\2\u00a6\u00a4\3\2\2\2\u00a6\u00a5\3\2\2\2"+
		"\u00a6\u00a7\3\2\2\2\u00a7\33\3\2\2\2\u00a8\u00a9\7\31\2\2\u00a9\u00aa"+
		"\5\4\3\2\u00aa\35\3\2\2\2\u00ab\u00ad\7\20\2\2\u00ac\u00ae\5> \2\u00ad"+
		"\u00ac\3\2\2\2\u00ad\u00ae\3\2\2\2\u00ae\u00af\3\2\2\2\u00af\u00b0\7T"+
		"\2\2\u00b0\u00b1\7\63\2\2\u00b1\u00b2\5\64\33\2\u00b2\u00b3\7,\2\2\u00b3"+
		"\u00b5\5\4\3\2\u00b4\u00b6\5\34\17\2\u00b5\u00b4\3\2\2\2\u00b5\u00b6\3"+
		"\2\2\2\u00b6\u00b7\3\2\2\2\u00b7\u00b8\7\32\2\2\u00b8\37\3\2\2\2\u00b9"+
		"\u00bb\7\21\2\2\u00ba\u00bc\5\64\33\2\u00bb\u00ba\3\2\2\2\u00bb\u00bc"+
		"\3\2\2\2\u00bc\u00bd\3\2\2\2\u00bd\u00c0\7,\2\2\u00be\u00c0\7\33\2\2\u00bf"+
		"\u00b9\3\2\2\2\u00bf\u00be\3\2\2\2\u00c0!\3\2\2\2\u00c1\u00c3\7\22\2\2"+
		"\u00c2\u00c4\5\64\33\2\u00c3\u00c2\3\2\2\2\u00c3\u00c4\3\2\2\2\u00c4\u00c5"+
		"\3\2\2\2\u00c5\u00c8\7,\2\2\u00c6\u00c8\7\34\2\2\u00c7\u00c1\3\2\2\2\u00c7"+
		"\u00c6\3\2\2\2\u00c8#\3\2\2\2\u00c9\u00cb\7\23\2\2\u00ca\u00cc\5\64\33"+
		"\2\u00cb\u00ca\3\2\2\2\u00cb\u00cc\3\2\2\2\u00cc\u00cd\3\2\2\2\u00cd\u00d0"+
		"\7,\2\2\u00ce\u00d0\7\35\2\2\u00cf\u00c9\3\2\2\2\u00cf\u00ce\3\2\2\2\u00d0"+
		"%\3\2\2\2\u00d1\u00d2\7\24\2\2\u00d2\u00d3\5\64\33\2\u00d3\u00d4\7,\2"+
		"\2\u00d4\u00d7\3\2\2\2\u00d5\u00d7\7\36\2\2\u00d6\u00d1\3\2\2\2\u00d6"+
		"\u00d5\3\2\2\2\u00d7\'\3\2\2\2\u00d8\u00d9\7\25\2\2\u00d9\u00de\5\64\33"+
		"\2\u00da\u00db\7\61\2\2\u00db\u00dd\5\64\33\2\u00dc\u00da\3\2\2\2\u00dd"+
		"\u00e0\3\2\2\2\u00de\u00dc\3\2\2\2\u00de\u00df\3\2\2\2\u00df\u00e1\3\2"+
		"\2\2\u00e0\u00de\3\2\2\2\u00e1\u00e2\7,\2\2\u00e2)\3\2\2\2\u00e3\u00e5"+
		"\7\26\2\2\u00e4\u00e6\5:\36\2\u00e5\u00e4\3\2\2\2\u00e5\u00e6\3\2\2\2"+
		"\u00e6\u00e7\3\2\2\2\u00e7\u00e8\7,\2\2\u00e8\u00e9\5\4\3\2\u00e9\u00ea"+
		"\7\32\2\2\u00ea+\3\2\2\2\u00eb\u00ed\7\27\2\2\u00ec\u00ee\5:\36\2\u00ed"+
		"\u00ec\3\2\2\2\u00ed\u00ee\3\2\2\2\u00ee\u00ef\3\2\2\2\u00ef\u00f0\7,"+
		"\2\2\u00f0-\3\2\2\2\u00f1\u00f3\7\30\2\2\u00f2\u00f4\5\60\31\2\u00f3\u00f2"+
		"\3\2\2\2\u00f3\u00f4\3\2\2\2\u00f4\u00f5\3\2\2\2\u00f5\u00f6\7,\2\2\u00f6"+
		"\u00f7\5\4\3\2\u00f7\u00f8\7\32\2\2\u00f8/\3\2\2\2\u00f9\u00fb\5> \2\u00fa"+
		"\u00f9\3\2\2\2\u00fa\u00fb\3\2\2\2\u00fb\u00fc\3\2\2\2\u00fc\u0104\7T"+
		"\2\2\u00fd\u00ff\7\61\2\2\u00fe\u0100\5> \2\u00ff\u00fe\3\2\2\2\u00ff"+
		"\u0100\3\2\2\2\u0100\u0101\3\2\2\2\u0101\u0103\7T\2\2\u0102\u00fd\3\2"+
		"\2\2\u0103\u0106\3\2\2\2\u0104\u0102\3\2\2\2\u0104\u0105\3\2\2\2\u0105"+
		"\61\3\2\2\2\u0106\u0104\3\2\2\2\u0107\u0108\t\3\2\2\u0108\63\3\2\2\2\u0109"+
		"\u010a\b\33\1\2\u010a\u010b\t\4\2\2\u010b\u014d\5\64\33\24\u010c\u010d"+
		"\7J\2\2\u010d\u014d\5\64\33\23\u010e\u010f\7B\2\2\u010f\u014d\5\64\33"+
		"\22\u0110\u0111\7+\2\2\u0111\u0112\5\64\33\2\u0112\u0113\7,\2\2\u0113"+
		"\u014d\3\2\2\2\u0114\u014d\58\35\2\u0115\u014d\5\66\34\2\u0116\u0118\7"+
		"-\2\2\u0117\u0119\5:\36\2\u0118\u0117\3\2\2\2\u0118\u0119\3\2\2\2\u0119"+
		"\u011a\3\2\2\2\u011a\u014d\7.\2\2\u011b\u0124\7/\2\2\u011c\u0121\5<\37"+
		"\2\u011d\u011e\7\61\2\2\u011e\u0120\5<\37\2\u011f\u011d\3\2\2\2\u0120"+
		"\u0123\3\2\2\2\u0121\u011f\3\2\2\2\u0121\u0122\3\2\2\2\u0122\u0125\3\2"+
		"\2\2\u0123\u0121\3\2\2\2\u0124\u011c\3\2\2\2\u0124\u0125\3\2\2\2\u0125"+
		"\u0126\3\2\2\2\u0126\u014d\7\60\2\2\u0127\u0128\5> \2\u0128\u0129\7\64"+
		"\2\2\u0129\u012a\7T\2\2\u012a\u014d\3\2\2\2\u012b\u012c\5> \2\u012c\u012d"+
		"\7\64\2\2\u012d\u012e\7T\2\2\u012e\u0130\7+\2\2\u012f\u0131\5:\36\2\u0130"+
		"\u012f\3\2\2\2\u0130\u0131\3\2\2\2\u0131\u0132\3\2\2\2\u0132\u0133\7,"+
		"\2\2\u0133\u014d\3\2\2\2\u0134\u0135\7T\2\2\u0135\u0137\7+\2\2\u0136\u0138"+
		"\5:\36\2\u0137\u0136\3\2\2\2\u0137\u0138\3\2\2\2\u0138\u0139\3\2\2\2\u0139"+
		"\u014d\7,\2\2\u013a\u013b\7P\2\2\u013b\u013c\5> \2\u013c\u013e\7+\2\2"+
		"\u013d\u013f\5:\36\2\u013e\u013d\3\2\2\2\u013e\u013f\3\2\2\2\u013f\u0140"+
		"\3\2\2\2\u0140\u0141\7,\2\2\u0141\u014d\3\2\2\2\u0142\u0143\7P\2\2\u0143"+
		"\u0148\5> \2\u0144\u0145\7-\2\2\u0145\u0146\5\64\33\2\u0146\u0147\7.\2"+
		"\2\u0147\u0149\3\2\2\2\u0148\u0144\3\2\2\2\u0149\u014a\3\2\2\2\u014a\u0148"+
		"\3\2\2\2\u014a\u014b\3\2\2\2\u014b\u014d\3\2\2\2\u014c\u0109\3\2\2\2\u014c"+
		"\u010c\3\2\2\2\u014c\u010e\3\2\2\2\u014c\u0110\3\2\2\2\u014c\u0114\3\2"+
		"\2\2\u014c\u0115\3\2\2\2\u014c\u0116\3\2\2\2\u014c\u011b\3\2\2\2\u014c"+
		"\u0127\3\2\2\2\u014c\u012b\3\2\2\2\u014c\u0134\3\2\2\2\u014c\u013a\3\2"+
		"\2\2\u014c\u0142\3\2\2\2\u014d\u018b\3\2\2\2\u014e\u014f\f\17\2\2\u014f"+
		"\u0150\7\67\2\2\u0150\u018a\5\64\33\20\u0151\u0152\f\16\2\2\u0152\u0153"+
		"\t\5\2\2\u0153\u018a\5\64\33\17\u0154\u0155\f\r\2\2\u0155\u0156\t\4\2"+
		"\2\u0156\u018a\5\64\33\16\u0157\u0158\f\f\2\2\u0158\u0159\t\6\2\2\u0159"+
		"\u018a\5\64\33\r\u015a\u015b\f\13\2\2\u015b\u015c\t\7\2\2\u015c\u018a"+
		"\5\64\33\f\u015d\u015e\f\t\2\2\u015e\u015f\t\b\2\2\u015f\u018a\5\64\33"+
		"\n\u0160\u0161\f\b\2\2\u0161\u0162\7H\2\2\u0162\u018a\5\64\33\t\u0163"+
		"\u0164\f\7\2\2\u0164\u0165\7K\2\2\u0165\u018a\5\64\33\7\u0166\u0167\f"+
		"\6\2\2\u0167\u0168\7I\2\2\u0168\u018a\5\64\33\7\u0169\u016a\f\5\2\2\u016a"+
		"\u016b\7@\2\2\u016b\u018a\5\64\33\6\u016c\u016d\f\4\2\2\u016d\u016e\7"+
		"A\2\2\u016e\u018a\5\64\33\5\u016f\u0170\f\3\2\2\u0170\u0172\7\62\2\2\u0171"+
		"\u0173\5\64\33\2\u0172\u0171\3\2\2\2\u0172\u0173\3\2\2\2\u0173\u0174\3"+
		"\2\2\2\u0174\u0175\7\63\2\2\u0175\u018a\5\64\33\3\u0176\u0177\f\32\2\2"+
		"\u0177\u0178\7\65\2\2\u0178\u018a\7T\2\2\u0179\u017a\f\31\2\2\u017a\u017b"+
		"\7\65\2\2\u017b\u017c\7T\2\2\u017c\u017e\7+\2\2\u017d\u017f\5:\36\2\u017e"+
		"\u017d\3\2\2\2\u017e\u017f\3\2\2\2\u017f\u0180\3\2\2\2\u0180\u018a\7,"+
		"\2\2\u0181\u0182\f\26\2\2\u0182\u0183\7-\2\2\u0183\u0184\5\64\33\2\u0184"+
		"\u0185\7.\2\2\u0185\u018a\3\2\2\2\u0186\u0187\f\n\2\2\u0187\u0188\7O\2"+
		"\2\u0188\u018a\5> \2\u0189\u014e\3\2\2\2\u0189\u0151\3\2\2\2\u0189\u0154"+
		"\3\2\2\2\u0189\u0157\3\2\2\2\u0189\u015a\3\2\2\2\u0189\u015d\3\2\2\2\u0189"+
		"\u0160\3\2\2\2\u0189\u0163\3\2\2\2\u0189\u0166\3\2\2\2\u0189\u0169\3\2"+
		"\2\2\u0189\u016c\3\2\2\2\u0189\u016f\3\2\2\2\u0189\u0176\3\2\2\2\u0189"+
		"\u0179\3\2\2\2\u0189\u0181\3\2\2\2\u0189\u0186\3\2\2\2\u018a\u018d\3\2"+
		"\2\2\u018b\u0189\3\2\2\2\u018b\u018c\3\2\2\2\u018c\65\3\2\2\2\u018d\u018b"+
		"\3\2\2\2\u018e\u018f\7T\2\2\u018f\67\3\2\2\2\u0190\u0191\t\t\2\2\u0191"+
		"9\3\2\2\2\u0192\u0197\5\64\33\2\u0193\u0194\7\61\2\2\u0194\u0196\5\64"+
		"\33\2\u0195\u0193\3\2\2\2\u0196\u0199\3\2\2\2\u0197\u0195\3\2\2\2\u0197"+
		"\u0198\3\2\2\2\u0198;\3\2\2\2\u0199\u0197\3\2\2\2\u019a\u019b\t\n\2\2"+
		"\u019b\u019c\7\63\2\2\u019c\u019d\5\64\33\2\u019d=\3\2\2\2\u019e\u01a3"+
		"\7T\2\2\u019f\u01a0\7\65\2\2\u01a0\u01a2\7T\2\2\u01a1\u019f\3\2\2\2\u01a2"+
		"\u01a5\3\2\2\2\u01a3\u01a1\3\2\2\2\u01a3\u01a4\3\2\2\2\u01a4\u01aa\3\2"+
		"\2\2\u01a5\u01a3\3\2\2\2\u01a6\u01a7\7-\2\2\u01a7\u01a9\7.\2\2\u01a8\u01a6"+
		"\3\2\2\2\u01a9\u01ac\3\2\2\2\u01aa\u01a8\3\2\2\2\u01aa\u01ab\3\2\2\2\u01ab"+
		"?\3\2\2\2\u01ac\u01aa\3\2\2\2+FHUem|\u008a\u0090\u009c\u00a6\u00ad\u00b5"+
		"\u00bb\u00bf\u00c3\u00c7\u00cb\u00cf\u00d6\u00de\u00e5\u00ed\u00f3\u00fa"+
		"\u00ff\u0104\u0118\u0121\u0124\u0130\u0137\u013e\u014a\u014c\u0172\u017e"+
		"\u0189\u018b\u0197\u01a3\u01aa";
	public static final ATN _ATN =
		new ATNDeserializer().deserialize(_serializedATN.toCharArray());
	static {
		_decisionToDFA = new DFA[_ATN.getNumberOfDecisions()];
		for (int i = 0; i < _ATN.getNumberOfDecisions(); i++) {
			_decisionToDFA[i] = new DFA(_ATN.getDecisionState(i), i);
		}
	}
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy