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

llmeier.rubysrc2cpg_3.2.0.440+7-e7df7a79.source-code.RubyParser Maven / Gradle / Ivy

// Generated from /home/mp/Projects/shiftleft/joern/joern-cli/frontends/rubysrc2cpg/src/main/antlr4/io/joern/rubysrc2cpg/parser/RubyParser.g4 by ANTLR 4.7.2

    package io.joern.rubysrc2cpg.parser;

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 RubyParser extends Parser {
	static { RuntimeMetaData.checkVersion("4.7.2", RuntimeMetaData.VERSION); }

	protected static final DFA[] _decisionToDFA;
	protected static final PredictionContextCache _sharedContextCache =
		new PredictionContextCache();
	public static final int
		STRING_INTERPOLATION_END=1, REGULAR_EXPRESSION_INTERPOLATION_END=2, REGULAR_EXPRESSION_START=3, 
		QUOTED_NON_EXPANDED_STRING_LITERAL_END=4, QUOTED_NON_EXPANDED_STRING_ARRAY_LITERAL_END=5, 
		QUOTED_NON_EXPANDED_SYMBOL_ARRAY_LITERAL_END=6, QUOTED_EXPANDED_REGULAR_EXPRESSION_END=7, 
		QUOTED_EXPANDED_STRING_LITERAL_END=8, QUOTED_EXPANDED_EXTERNAL_COMMAND_LITERAL_END=9, 
		QUOTED_EXPANDED_STRING_ARRAY_LITERAL_END=10, QUOTED_EXPANDED_SYMBOL_ARRAY_LITERAL_END=11, 
		DELIMITED_STRING_INTERPOLATION_END=12, DELIMITED_ARRAY_ITEM_INTERPOLATION_END=13, 
		NON_EXPANDED_LITERAL_CHARACTER_SEQUENCE=14, EXPANDED_LITERAL_CHARACTER_SEQUENCE=15, 
		LINE__=16, ENCODING__=17, FILE__=18, BEGIN_=19, END_=20, ALIAS=21, AND=22, 
		BEGIN=23, BREAK=24, CASE=25, CLASS=26, DEF=27, IS_DEFINED=28, DO=29, ELSE=30, 
		ELSIF=31, END=32, ENSURE=33, FOR=34, FALSE=35, IF=36, IN=37, MODULE=38, 
		NEXT=39, NIL=40, NOT=41, OR=42, REDO=43, RESCUE=44, RETRY=45, RETURN=46, 
		SELF=47, SUPER=48, THEN=49, TRUE=50, UNDEF=51, UNLESS=52, UNTIL=53, WHEN=54, 
		WHILE=55, YIELD=56, LBRACK=57, RBRACK=58, LPAREN=59, RPAREN=60, LCURLY=61, 
		RCURLY=62, COLON=63, COLON2=64, COMMA=65, SEMI=66, DOT=67, DOT2=68, DOT3=69, 
		QMARK=70, EQGT=71, MINUSGT=72, EMARK=73, EMARKEQ=74, EMARKTILDE=75, AMP=76, 
		AMP2=77, AMPDOT=78, BAR=79, BAR2=80, EQ=81, EQ2=82, EQ3=83, CARET=84, 
		LTEQGT=85, EQTILDE=86, GT=87, GTEQ=88, LT=89, LTEQ=90, LT2=91, GT2=92, 
		PLUS=93, MINUS=94, STAR=95, STAR2=96, SLASH=97, PERCENT=98, TILDE=99, 
		PLUSAT=100, MINUSAT=101, ASSIGNMENT_OPERATOR=102, SINGLE_QUOTED_STRING_LITERAL=103, 
		DOUBLE_QUOTED_STRING_START=104, QUOTED_NON_EXPANDED_STRING_LITERAL_START=105, 
		QUOTED_EXPANDED_STRING_LITERAL_START=106, QUOTED_EXPANDED_REGULAR_EXPRESSION_START=107, 
		QUOTED_EXPANDED_EXTERNAL_COMMAND_LITERAL_START=108, QUOTED_NON_EXPANDED_STRING_ARRAY_LITERAL_START=109, 
		QUOTED_EXPANDED_STRING_ARRAY_LITERAL_START=110, HERE_DOC_IDENTIFIER=111, 
		HERE_DOC=112, QUOTED_NON_EXPANDED_SYMBOL_ARRAY_LITERAL_START=113, QUOTED_EXPANDED_SYMBOL_ARRAY_LITERAL_START=114, 
		END_OF_PROGRAM_MARKER=115, DECIMAL_INTEGER_LITERAL=116, BINARY_INTEGER_LITERAL=117, 
		OCTAL_INTEGER_LITERAL=118, HEXADECIMAL_INTEGER_LITERAL=119, FLOAT_LITERAL_WITHOUT_EXPONENT=120, 
		FLOAT_LITERAL_WITH_EXPONENT=121, NL=122, WS=123, SYMBOL_LITERAL=124, LOCAL_VARIABLE_IDENTIFIER=125, 
		GLOBAL_VARIABLE_IDENTIFIER=126, INSTANCE_VARIABLE_IDENTIFIER=127, CLASS_VARIABLE_IDENTIFIER=128, 
		CONSTANT_IDENTIFIER=129, ASSIGNMENT_LIKE_METHOD_IDENTIFIER=130, SINGLE_LINE_COMMENT=131, 
		MULTI_LINE_COMMENT=132, UNRECOGNIZED=133, DOUBLE_QUOTED_STRING_END=134, 
		DOUBLE_QUOTED_STRING_CHARACTER_SEQUENCE=135, INTERPOLATED_CHARACTER_SEQUENCE=136, 
		STRING_INTERPOLATION_BEGIN=137, DELIMITED_STRING_INTERPOLATION_BEGIN=138, 
		EXPANDED_VARIABLE_CHARACTER_SEQUENCE=139, EXPANDED_LITERAL_CHARACTER=140, 
		NON_EXPANDED_LITERAL_CHARACTER=141, DELIMITED_ARRAY_ITEM_INTERPOLATION_BEGIN=142, 
		EXPANDED_ARRAY_ITEM_SEPARATOR=143, EXPANDED_ARRAY_ITEM_CHARACTER=144, 
		NON_EXPANDED_ARRAY_ITEM_SEPARATOR=145, NON_EXPANDED_ARRAY_ITEM_CHARACTER=146, 
		REGULAR_EXPRESSION_END=147, REGULAR_EXPRESSION_BODY=148, REGULAR_EXPRESSION_INTERPOLATION_BEGIN=149, 
		DATA_SECTION_CONTENT=150;
	public static final int
		RULE_program = 0, RULE_compoundStatement = 1, RULE_statements = 2, RULE_statement = 3, 
		RULE_definedMethodNameOrSymbol = 4, RULE_singleAssignmentStatement = 5, 
		RULE_multipleAssignmentStatement = 6, RULE_leftHandSide = 7, RULE_multipleLeftHandSide = 8, 
		RULE_multipleLeftHandSideExceptPacking = 9, RULE_packingLeftHandSide = 10, 
		RULE_groupedLeftHandSide = 11, RULE_multipleLeftHandSideItem = 12, RULE_multipleRightHandSide = 13, 
		RULE_splattingRightHandSide = 14, RULE_methodIdentifier = 15, RULE_methodName = 16, 
		RULE_methodOnlyIdentifier = 17, RULE_methodInvocationWithoutParentheses = 18, 
		RULE_command = 19, RULE_commandArgument = 20, RULE_chainedCommandWithDoBlock = 21, 
		RULE_chainedMethodInvocation = 22, RULE_commandWithDoBlock = 23, RULE_indexingArgumentList = 24, 
		RULE_splattingArgument = 25, RULE_operatorExpressionList = 26, RULE_operatorExpressionList2 = 27, 
		RULE_argumentWithParentheses = 28, RULE_argumentList = 29, RULE_commandArgumentList = 30, 
		RULE_primaryValueList = 31, RULE_blockArgument = 32, RULE_expressionOrCommand = 33, 
		RULE_operatorExpression = 34, RULE_primary = 35, RULE_primaryValue = 36, 
		RULE_methodCallsWithParentheses = 37, RULE_commandOrPrimaryValueClass = 38, 
		RULE_commandOrPrimaryValue = 39, RULE_block = 40, RULE_doBlock = 41, RULE_blockParameter = 42, 
		RULE_thenClause = 43, RULE_elseClause = 44, RULE_elsifClause = 45, RULE_whenClause = 46, 
		RULE_whenArgument = 47, RULE_doClause = 48, RULE_forVariable = 49, RULE_bodyStatement = 50, 
		RULE_rescueClause = 51, RULE_exceptionClassList = 52, RULE_exceptionVariableAssignment = 53, 
		RULE_ensureClause = 54, RULE_definedMethodName = 55, RULE_methodParameterPart = 56, 
		RULE_parameterList = 57, RULE_mandatoryOrOptionalParameterList = 58, RULE_mandatoryOrOptionalParameter = 59, 
		RULE_mandatoryParameter = 60, RULE_optionalParameter = 61, RULE_optionalParameterName = 62, 
		RULE_arrayParameter = 63, RULE_hashParameter = 64, RULE_procParameter = 65, 
		RULE_procParameterName = 66, RULE_classPath = 67, RULE_singletonObject = 68, 
		RULE_variableReference = 69, RULE_associationList = 70, RULE_association = 71, 
		RULE_associationKey = 72, RULE_associationHashArgument = 73, RULE_regexpLiteralContent = 74, 
		RULE_singleQuotedString = 75, RULE_singleOrDoubleQuotedString = 76, RULE_doubleQuotedString = 77, 
		RULE_quotedExpandedExternalCommandString = 78, RULE_doubleQuotedStringContent = 79, 
		RULE_quotedNonExpandedLiteralString = 80, RULE_quotedExpandedLiteralString = 81, 
		RULE_quotedExpandedLiteralStringContent = 82, RULE_quotedNonExpandedArrayElementContent = 83, 
		RULE_quotedExpandedArrayElementContent = 84, RULE_quotedExpandedArrayElement = 85, 
		RULE_quotedNonExpandedArrayElementList = 86, RULE_quotedExpandedArrayElementList = 87, 
		RULE_symbol = 88, RULE_hereDoc = 89, RULE_isDefinedKeyword = 90, RULE_assignmentOperator = 91, 
		RULE_statementModifier = 92, RULE_variable = 93, RULE_pseudoVariable = 94, 
		RULE_unsignedNumericLiteral = 95, RULE_unaryOperator = 96, RULE_multiplicativeOperator = 97, 
		RULE_additiveOperator = 98, RULE_bitwiseShiftOperator = 99, RULE_bitwiseOrOperator = 100, 
		RULE_relationalOperator = 101, RULE_equalityOperator = 102, RULE_rangeOperator = 103, 
		RULE_keyword = 104;
	private static String[] makeRuleNames() {
		return new String[] {
			"program", "compoundStatement", "statements", "statement", "definedMethodNameOrSymbol", 
			"singleAssignmentStatement", "multipleAssignmentStatement", "leftHandSide", 
			"multipleLeftHandSide", "multipleLeftHandSideExceptPacking", "packingLeftHandSide", 
			"groupedLeftHandSide", "multipleLeftHandSideItem", "multipleRightHandSide", 
			"splattingRightHandSide", "methodIdentifier", "methodName", "methodOnlyIdentifier", 
			"methodInvocationWithoutParentheses", "command", "commandArgument", "chainedCommandWithDoBlock", 
			"chainedMethodInvocation", "commandWithDoBlock", "indexingArgumentList", 
			"splattingArgument", "operatorExpressionList", "operatorExpressionList2", 
			"argumentWithParentheses", "argumentList", "commandArgumentList", "primaryValueList", 
			"blockArgument", "expressionOrCommand", "operatorExpression", "primary", 
			"primaryValue", "methodCallsWithParentheses", "commandOrPrimaryValueClass", 
			"commandOrPrimaryValue", "block", "doBlock", "blockParameter", "thenClause", 
			"elseClause", "elsifClause", "whenClause", "whenArgument", "doClause", 
			"forVariable", "bodyStatement", "rescueClause", "exceptionClassList", 
			"exceptionVariableAssignment", "ensureClause", "definedMethodName", "methodParameterPart", 
			"parameterList", "mandatoryOrOptionalParameterList", "mandatoryOrOptionalParameter", 
			"mandatoryParameter", "optionalParameter", "optionalParameterName", "arrayParameter", 
			"hashParameter", "procParameter", "procParameterName", "classPath", "singletonObject", 
			"variableReference", "associationList", "association", "associationKey", 
			"associationHashArgument", "regexpLiteralContent", "singleQuotedString", 
			"singleOrDoubleQuotedString", "doubleQuotedString", "quotedExpandedExternalCommandString", 
			"doubleQuotedStringContent", "quotedNonExpandedLiteralString", "quotedExpandedLiteralString", 
			"quotedExpandedLiteralStringContent", "quotedNonExpandedArrayElementContent", 
			"quotedExpandedArrayElementContent", "quotedExpandedArrayElement", "quotedNonExpandedArrayElementList", 
			"quotedExpandedArrayElementList", "symbol", "hereDoc", "isDefinedKeyword", 
			"assignmentOperator", "statementModifier", "variable", "pseudoVariable", 
			"unsignedNumericLiteral", "unaryOperator", "multiplicativeOperator", 
			"additiveOperator", "bitwiseShiftOperator", "bitwiseOrOperator", "relationalOperator", 
			"equalityOperator", "rangeOperator", "keyword"
		};
	}
	public static final String[] ruleNames = makeRuleNames();

	private static String[] makeLiteralNames() {
		return new String[] {
			null, null, null, null, null, null, null, null, null, null, null, null, 
			null, null, null, null, "'__LINE__'", "'__ENCODING__'", "'__FILE__'", 
			"'BEGIN'", "'END'", "'alias'", "'and'", "'begin'", "'break'", "'case'", 
			"'class'", "'def'", "'defined?'", "'do'", "'else'", "'elsif'", "'end'", 
			"'ensure'", "'for'", "'false'", "'if'", "'in'", "'module'", "'next'", 
			"'nil'", "'not'", "'or'", "'redo'", "'rescue'", "'retry'", "'return'", 
			"'self'", "'super'", "'then'", "'true'", "'undef'", "'unless'", "'until'", 
			"'when'", "'while'", "'yield'", "'['", "']'", "'('", "')'", "'{'", "'}'", 
			"':'", "'::'", "','", "';'", "'.'", "'..'", "'...'", "'?'", "'=>'", "'->'", 
			"'!'", "'!='", "'!~'", "'&'", "'&&'", "'&.'", "'|'", "'||'", "'='", "'=='", 
			"'==='", "'^'", "'<=>'", "'=~'", "'>'", "'>='", "'<'", "'<='", "'<<'", 
			"'>>'", "'+'", "'-'", "'*'", "'**'", "'/'", "'%'", "'~'", "'+@'", "'-@'"
		};
	}
	private static final String[] _LITERAL_NAMES = makeLiteralNames();
	private static String[] makeSymbolicNames() {
		return new String[] {
			null, "STRING_INTERPOLATION_END", "REGULAR_EXPRESSION_INTERPOLATION_END", 
			"REGULAR_EXPRESSION_START", "QUOTED_NON_EXPANDED_STRING_LITERAL_END", 
			"QUOTED_NON_EXPANDED_STRING_ARRAY_LITERAL_END", "QUOTED_NON_EXPANDED_SYMBOL_ARRAY_LITERAL_END", 
			"QUOTED_EXPANDED_REGULAR_EXPRESSION_END", "QUOTED_EXPANDED_STRING_LITERAL_END", 
			"QUOTED_EXPANDED_EXTERNAL_COMMAND_LITERAL_END", "QUOTED_EXPANDED_STRING_ARRAY_LITERAL_END", 
			"QUOTED_EXPANDED_SYMBOL_ARRAY_LITERAL_END", "DELIMITED_STRING_INTERPOLATION_END", 
			"DELIMITED_ARRAY_ITEM_INTERPOLATION_END", "NON_EXPANDED_LITERAL_CHARACTER_SEQUENCE", 
			"EXPANDED_LITERAL_CHARACTER_SEQUENCE", "LINE__", "ENCODING__", "FILE__", 
			"BEGIN_", "END_", "ALIAS", "AND", "BEGIN", "BREAK", "CASE", "CLASS", 
			"DEF", "IS_DEFINED", "DO", "ELSE", "ELSIF", "END", "ENSURE", "FOR", "FALSE", 
			"IF", "IN", "MODULE", "NEXT", "NIL", "NOT", "OR", "REDO", "RESCUE", "RETRY", 
			"RETURN", "SELF", "SUPER", "THEN", "TRUE", "UNDEF", "UNLESS", "UNTIL", 
			"WHEN", "WHILE", "YIELD", "LBRACK", "RBRACK", "LPAREN", "RPAREN", "LCURLY", 
			"RCURLY", "COLON", "COLON2", "COMMA", "SEMI", "DOT", "DOT2", "DOT3", 
			"QMARK", "EQGT", "MINUSGT", "EMARK", "EMARKEQ", "EMARKTILDE", "AMP", 
			"AMP2", "AMPDOT", "BAR", "BAR2", "EQ", "EQ2", "EQ3", "CARET", "LTEQGT", 
			"EQTILDE", "GT", "GTEQ", "LT", "LTEQ", "LT2", "GT2", "PLUS", "MINUS", 
			"STAR", "STAR2", "SLASH", "PERCENT", "TILDE", "PLUSAT", "MINUSAT", "ASSIGNMENT_OPERATOR", 
			"SINGLE_QUOTED_STRING_LITERAL", "DOUBLE_QUOTED_STRING_START", "QUOTED_NON_EXPANDED_STRING_LITERAL_START", 
			"QUOTED_EXPANDED_STRING_LITERAL_START", "QUOTED_EXPANDED_REGULAR_EXPRESSION_START", 
			"QUOTED_EXPANDED_EXTERNAL_COMMAND_LITERAL_START", "QUOTED_NON_EXPANDED_STRING_ARRAY_LITERAL_START", 
			"QUOTED_EXPANDED_STRING_ARRAY_LITERAL_START", "HERE_DOC_IDENTIFIER", 
			"HERE_DOC", "QUOTED_NON_EXPANDED_SYMBOL_ARRAY_LITERAL_START", "QUOTED_EXPANDED_SYMBOL_ARRAY_LITERAL_START", 
			"END_OF_PROGRAM_MARKER", "DECIMAL_INTEGER_LITERAL", "BINARY_INTEGER_LITERAL", 
			"OCTAL_INTEGER_LITERAL", "HEXADECIMAL_INTEGER_LITERAL", "FLOAT_LITERAL_WITHOUT_EXPONENT", 
			"FLOAT_LITERAL_WITH_EXPONENT", "NL", "WS", "SYMBOL_LITERAL", "LOCAL_VARIABLE_IDENTIFIER", 
			"GLOBAL_VARIABLE_IDENTIFIER", "INSTANCE_VARIABLE_IDENTIFIER", "CLASS_VARIABLE_IDENTIFIER", 
			"CONSTANT_IDENTIFIER", "ASSIGNMENT_LIKE_METHOD_IDENTIFIER", "SINGLE_LINE_COMMENT", 
			"MULTI_LINE_COMMENT", "UNRECOGNIZED", "DOUBLE_QUOTED_STRING_END", "DOUBLE_QUOTED_STRING_CHARACTER_SEQUENCE", 
			"INTERPOLATED_CHARACTER_SEQUENCE", "STRING_INTERPOLATION_BEGIN", "DELIMITED_STRING_INTERPOLATION_BEGIN", 
			"EXPANDED_VARIABLE_CHARACTER_SEQUENCE", "EXPANDED_LITERAL_CHARACTER", 
			"NON_EXPANDED_LITERAL_CHARACTER", "DELIMITED_ARRAY_ITEM_INTERPOLATION_BEGIN", 
			"EXPANDED_ARRAY_ITEM_SEPARATOR", "EXPANDED_ARRAY_ITEM_CHARACTER", "NON_EXPANDED_ARRAY_ITEM_SEPARATOR", 
			"NON_EXPANDED_ARRAY_ITEM_CHARACTER", "REGULAR_EXPRESSION_END", "REGULAR_EXPRESSION_BODY", 
			"REGULAR_EXPRESSION_INTERPOLATION_BEGIN", "DATA_SECTION_CONTENT"
		};
	}
	private static final String[] _SYMBOLIC_NAMES = makeSymbolicNames();
	public static final Vocabulary VOCABULARY = new VocabularyImpl(_LITERAL_NAMES, _SYMBOLIC_NAMES);

	/**
	 * @deprecated Use {@link #VOCABULARY} instead.
	 */
	@Deprecated
	public static final String[] tokenNames;
	static {
		tokenNames = new String[_SYMBOLIC_NAMES.length];
		for (int i = 0; i < tokenNames.length; i++) {
			tokenNames[i] = VOCABULARY.getLiteralName(i);
			if (tokenNames[i] == null) {
				tokenNames[i] = VOCABULARY.getSymbolicName(i);
			}

			if (tokenNames[i] == null) {
				tokenNames[i] = "";
			}
		}
	}

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

	@Override

	public Vocabulary getVocabulary() {
		return VOCABULARY;
	}

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

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

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

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

	public RubyParser(TokenStream input) {
		super(input);
		_interp = new ParserATNSimulator(this,_ATN,_decisionToDFA,_sharedContextCache);
	}

	public static class ProgramContext extends ParserRuleContext {
		public CompoundStatementContext compoundStatement() {
			return getRuleContext(CompoundStatementContext.class,0);
		}
		public TerminalNode EOF() { return getToken(RubyParser.EOF, 0); }
		public ProgramContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_program; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterProgram(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitProgram(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitProgram(this);
			else return visitor.visitChildren(this);
		}
	}

	public final ProgramContext program() throws RecognitionException {
		ProgramContext _localctx = new ProgramContext(_ctx, getState());
		enterRule(_localctx, 0, RULE_program);
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(210);
			compoundStatement();
			setState(211);
			match(EOF);
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class CompoundStatementContext extends ParserRuleContext {
		public StatementsContext statements() {
			return getRuleContext(StatementsContext.class,0);
		}
		public List SEMI() { return getTokens(RubyParser.SEMI); }
		public TerminalNode SEMI(int i) {
			return getToken(RubyParser.SEMI, i);
		}
		public List NL() { return getTokens(RubyParser.NL); }
		public TerminalNode NL(int i) {
			return getToken(RubyParser.NL, i);
		}
		public CompoundStatementContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_compoundStatement; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterCompoundStatement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitCompoundStatement(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitCompoundStatement(this);
			else return visitor.visitChildren(this);
		}
	}

	public final CompoundStatementContext compoundStatement() throws RecognitionException {
		CompoundStatementContext _localctx = new CompoundStatementContext(_ctx, getState());
		enterRule(_localctx, 2, RULE_compoundStatement);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(214);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,0,_ctx) ) {
			case 1:
				{
				setState(213);
				statements();
				}
				break;
			}
			setState(219);
			_errHandler.sync(this);
			_la = _input.LA(1);
			while (_la==SEMI || _la==NL) {
				{
				{
				setState(216);
				_la = _input.LA(1);
				if ( !(_la==SEMI || _la==NL) ) {
				_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				}
				}
				setState(221);
				_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 StatementsContext extends ParserRuleContext {
		public List statement() {
			return getRuleContexts(StatementContext.class);
		}
		public StatementContext statement(int i) {
			return getRuleContext(StatementContext.class,i);
		}
		public List SEMI() { return getTokens(RubyParser.SEMI); }
		public TerminalNode SEMI(int i) {
			return getToken(RubyParser.SEMI, i);
		}
		public List NL() { return getTokens(RubyParser.NL); }
		public TerminalNode NL(int i) {
			return getToken(RubyParser.NL, i);
		}
		public StatementsContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_statements; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterStatements(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitStatements(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitStatements(this);
			else return visitor.visitChildren(this);
		}
	}

	public final StatementsContext statements() throws RecognitionException {
		StatementsContext _localctx = new StatementsContext(_ctx, getState());
		enterRule(_localctx, 4, RULE_statements);
		int _la;
		try {
			int _alt;
			enterOuterAlt(_localctx, 1);
			{
			setState(225);
			_errHandler.sync(this);
			_la = _input.LA(1);
			while (_la==SEMI || _la==NL) {
				{
				{
				setState(222);
				_la = _input.LA(1);
				if ( !(_la==SEMI || _la==NL) ) {
				_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				}
				}
				setState(227);
				_errHandler.sync(this);
				_la = _input.LA(1);
			}
			setState(228);
			statement(0);
			setState(237);
			_errHandler.sync(this);
			_alt = getInterpreter().adaptivePredict(_input,4,_ctx);
			while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) {
				if ( _alt==1 ) {
					{
					{
					setState(230); 
					_errHandler.sync(this);
					_la = _input.LA(1);
					do {
						{
						{
						setState(229);
						_la = _input.LA(1);
						if ( !(_la==SEMI || _la==NL) ) {
						_errHandler.recoverInline(this);
						}
						else {
							if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
							_errHandler.reportMatch(this);
							consume();
						}
						}
						}
						setState(232); 
						_errHandler.sync(this);
						_la = _input.LA(1);
					} while ( _la==SEMI || _la==NL );
					setState(234);
					statement(0);
					}
					} 
				}
				setState(239);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,4,_ctx);
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class StatementContext extends ParserRuleContext {
		public StatementContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_statement; }
	 
		public StatementContext() { }
		public void copyFrom(StatementContext ctx) {
			super.copyFrom(ctx);
		}
	}
	public static class SingleAssignmentStatementStatementContext extends StatementContext {
		public SingleAssignmentStatementContext singleAssignmentStatement() {
			return getRuleContext(SingleAssignmentStatementContext.class,0);
		}
		public SingleAssignmentStatementStatementContext(StatementContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterSingleAssignmentStatementStatement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitSingleAssignmentStatementStatement(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitSingleAssignmentStatementStatement(this);
			else return visitor.visitChildren(this);
		}
	}
	public static class ModifierStatementContext extends StatementContext {
		public StatementContext statement() {
			return getRuleContext(StatementContext.class,0);
		}
		public StatementModifierContext statementModifier() {
			return getRuleContext(StatementModifierContext.class,0);
		}
		public ExpressionOrCommandContext expressionOrCommand() {
			return getRuleContext(ExpressionOrCommandContext.class,0);
		}
		public List NL() { return getTokens(RubyParser.NL); }
		public TerminalNode NL(int i) {
			return getToken(RubyParser.NL, i);
		}
		public ModifierStatementContext(StatementContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterModifierStatement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitModifierStatement(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitModifierStatement(this);
			else return visitor.visitChildren(this);
		}
	}
	public static class AliasStatementContext extends StatementContext {
		public DefinedMethodNameOrSymbolContext oldName;
		public DefinedMethodNameOrSymbolContext newName;
		public TerminalNode ALIAS() { return getToken(RubyParser.ALIAS, 0); }
		public List definedMethodNameOrSymbol() {
			return getRuleContexts(DefinedMethodNameOrSymbolContext.class);
		}
		public DefinedMethodNameOrSymbolContext definedMethodNameOrSymbol(int i) {
			return getRuleContext(DefinedMethodNameOrSymbolContext.class,i);
		}
		public List NL() { return getTokens(RubyParser.NL); }
		public TerminalNode NL(int i) {
			return getToken(RubyParser.NL, i);
		}
		public AliasStatementContext(StatementContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterAliasStatement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitAliasStatement(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitAliasStatement(this);
			else return visitor.visitChildren(this);
		}
	}
	public static class UndefStatementContext extends StatementContext {
		public TerminalNode UNDEF() { return getToken(RubyParser.UNDEF, 0); }
		public List definedMethodNameOrSymbol() {
			return getRuleContexts(DefinedMethodNameOrSymbolContext.class);
		}
		public DefinedMethodNameOrSymbolContext definedMethodNameOrSymbol(int i) {
			return getRuleContext(DefinedMethodNameOrSymbolContext.class,i);
		}
		public List NL() { return getTokens(RubyParser.NL); }
		public TerminalNode NL(int i) {
			return getToken(RubyParser.NL, i);
		}
		public List COMMA() { return getTokens(RubyParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(RubyParser.COMMA, i);
		}
		public UndefStatementContext(StatementContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterUndefStatement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitUndefStatement(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitUndefStatement(this);
			else return visitor.visitChildren(this);
		}
	}
	public static class ExpressionOrCommandStatementContext extends StatementContext {
		public ExpressionOrCommandContext expressionOrCommand() {
			return getRuleContext(ExpressionOrCommandContext.class,0);
		}
		public ExpressionOrCommandStatementContext(StatementContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterExpressionOrCommandStatement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitExpressionOrCommandStatement(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitExpressionOrCommandStatement(this);
			else return visitor.visitChildren(this);
		}
	}
	public static class MultipleAssignmentStatementStatementContext extends StatementContext {
		public MultipleAssignmentStatementContext multipleAssignmentStatement() {
			return getRuleContext(MultipleAssignmentStatementContext.class,0);
		}
		public MultipleAssignmentStatementStatementContext(StatementContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterMultipleAssignmentStatementStatement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitMultipleAssignmentStatementStatement(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitMultipleAssignmentStatementStatement(this);
			else return visitor.visitChildren(this);
		}
	}

	public final StatementContext statement() throws RecognitionException {
		return statement(0);
	}

	private StatementContext statement(int _p) throws RecognitionException {
		ParserRuleContext _parentctx = _ctx;
		int _parentState = getState();
		StatementContext _localctx = new StatementContext(_ctx, _parentState);
		StatementContext _prevctx = _localctx;
		int _startState = 6;
		enterRecursionRule(_localctx, 6, RULE_statement, _p);
		int _la;
		try {
			int _alt;
			enterOuterAlt(_localctx, 1);
			{
			setState(275);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,9,_ctx) ) {
			case 1:
				{
				_localctx = new ExpressionOrCommandStatementContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;

				setState(241);
				expressionOrCommand(0);
				}
				break;
			case 2:
				{
				_localctx = new AliasStatementContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(242);
				match(ALIAS);
				setState(246);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==NL) {
					{
					{
					setState(243);
					match(NL);
					}
					}
					setState(248);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(249);
				((AliasStatementContext)_localctx).oldName = definedMethodNameOrSymbol();
				setState(250);
				((AliasStatementContext)_localctx).newName = definedMethodNameOrSymbol();
				}
				break;
			case 3:
				{
				_localctx = new UndefStatementContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(252);
				match(UNDEF);
				setState(256);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==NL) {
					{
					{
					setState(253);
					match(NL);
					}
					}
					setState(258);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(259);
				definedMethodNameOrSymbol();
				setState(270);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,8,_ctx);
				while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) {
					if ( _alt==1 ) {
						{
						{
						setState(260);
						match(COMMA);
						setState(264);
						_errHandler.sync(this);
						_la = _input.LA(1);
						while (_la==NL) {
							{
							{
							setState(261);
							match(NL);
							}
							}
							setState(266);
							_errHandler.sync(this);
							_la = _input.LA(1);
						}
						setState(267);
						definedMethodNameOrSymbol();
						}
						} 
					}
					setState(272);
					_errHandler.sync(this);
					_alt = getInterpreter().adaptivePredict(_input,8,_ctx);
				}
				}
				break;
			case 4:
				{
				_localctx = new SingleAssignmentStatementStatementContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(273);
				singleAssignmentStatement();
				}
				break;
			case 5:
				{
				_localctx = new MultipleAssignmentStatementStatementContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(274);
				multipleAssignmentStatement();
				}
				break;
			}
			_ctx.stop = _input.LT(-1);
			setState(289);
			_errHandler.sync(this);
			_alt = getInterpreter().adaptivePredict(_input,11,_ctx);
			while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) {
				if ( _alt==1 ) {
					if ( _parseListeners!=null ) triggerExitRuleEvent();
					_prevctx = _localctx;
					{
					{
					_localctx = new ModifierStatementContext(new StatementContext(_parentctx, _parentState));
					pushNewRecursionContext(_localctx, _startState, RULE_statement);
					setState(277);
					if (!(precpred(_ctx, 3))) throw new FailedPredicateException(this, "precpred(_ctx, 3)");
					setState(278);
					statementModifier();
					setState(282);
					_errHandler.sync(this);
					_la = _input.LA(1);
					while (_la==NL) {
						{
						{
						setState(279);
						match(NL);
						}
						}
						setState(284);
						_errHandler.sync(this);
						_la = _input.LA(1);
					}
					setState(285);
					expressionOrCommand(0);
					}
					} 
				}
				setState(291);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,11,_ctx);
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			unrollRecursionContexts(_parentctx);
		}
		return _localctx;
	}

	public static class DefinedMethodNameOrSymbolContext extends ParserRuleContext {
		public DefinedMethodNameContext definedMethodName() {
			return getRuleContext(DefinedMethodNameContext.class,0);
		}
		public SymbolContext symbol() {
			return getRuleContext(SymbolContext.class,0);
		}
		public DefinedMethodNameOrSymbolContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_definedMethodNameOrSymbol; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterDefinedMethodNameOrSymbol(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitDefinedMethodNameOrSymbol(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitDefinedMethodNameOrSymbol(this);
			else return visitor.visitChildren(this);
		}
	}

	public final DefinedMethodNameOrSymbolContext definedMethodNameOrSymbol() throws RecognitionException {
		DefinedMethodNameOrSymbolContext _localctx = new DefinedMethodNameOrSymbolContext(_ctx, getState());
		enterRule(_localctx, 8, RULE_definedMethodNameOrSymbol);
		try {
			setState(294);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case LINE__:
			case ENCODING__:
			case FILE__:
			case BEGIN_:
			case END_:
			case ALIAS:
			case AND:
			case BEGIN:
			case BREAK:
			case CASE:
			case CLASS:
			case DEF:
			case IS_DEFINED:
			case DO:
			case ELSE:
			case ELSIF:
			case END:
			case ENSURE:
			case FOR:
			case FALSE:
			case IF:
			case IN:
			case MODULE:
			case NEXT:
			case NIL:
			case NOT:
			case OR:
			case REDO:
			case RESCUE:
			case RETRY:
			case RETURN:
			case SELF:
			case SUPER:
			case THEN:
			case TRUE:
			case UNDEF:
			case UNLESS:
			case UNTIL:
			case WHEN:
			case WHILE:
			case YIELD:
			case LBRACK:
			case EQ2:
			case EQ3:
			case LTEQGT:
			case LT2:
			case LOCAL_VARIABLE_IDENTIFIER:
			case CONSTANT_IDENTIFIER:
			case ASSIGNMENT_LIKE_METHOD_IDENTIFIER:
				enterOuterAlt(_localctx, 1);
				{
				setState(292);
				definedMethodName();
				}
				break;
			case COLON:
			case SYMBOL_LITERAL:
				enterOuterAlt(_localctx, 2);
				{
				setState(293);
				symbol();
				}
				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 SingleAssignmentStatementContext extends ParserRuleContext {
		public VariableContext variable() {
			return getRuleContext(VariableContext.class,0);
		}
		public AssignmentOperatorContext assignmentOperator() {
			return getRuleContext(AssignmentOperatorContext.class,0);
		}
		public MethodInvocationWithoutParenthesesContext methodInvocationWithoutParentheses() {
			return getRuleContext(MethodInvocationWithoutParenthesesContext.class,0);
		}
		public List NL() { return getTokens(RubyParser.NL); }
		public TerminalNode NL(int i) {
			return getToken(RubyParser.NL, i);
		}
		public TerminalNode COLON2() { return getToken(RubyParser.COLON2, 0); }
		public TerminalNode CONSTANT_IDENTIFIER() { return getToken(RubyParser.CONSTANT_IDENTIFIER, 0); }
		public PrimaryContext primary() {
			return getRuleContext(PrimaryContext.class,0);
		}
		public TerminalNode LBRACK() { return getToken(RubyParser.LBRACK, 0); }
		public TerminalNode RBRACK() { return getToken(RubyParser.RBRACK, 0); }
		public IndexingArgumentListContext indexingArgumentList() {
			return getRuleContext(IndexingArgumentListContext.class,0);
		}
		public MethodNameContext methodName() {
			return getRuleContext(MethodNameContext.class,0);
		}
		public TerminalNode DOT() { return getToken(RubyParser.DOT, 0); }
		public SingleAssignmentStatementContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_singleAssignmentStatement; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterSingleAssignmentStatement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitSingleAssignmentStatement(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitSingleAssignmentStatement(this);
			else return visitor.visitChildren(this);
		}
	}

	public final SingleAssignmentStatementContext singleAssignmentStatement() throws RecognitionException {
		SingleAssignmentStatementContext _localctx = new SingleAssignmentStatementContext(_ctx, getState());
		enterRule(_localctx, 10, RULE_singleAssignmentStatement);
		int _la;
		try {
			setState(344);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,18,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(296);
				variable();
				setState(297);
				assignmentOperator();
				setState(301);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==NL) {
					{
					{
					setState(298);
					match(NL);
					}
					}
					setState(303);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(304);
				methodInvocationWithoutParentheses();
				}
				break;
			case 2:
				enterOuterAlt(_localctx, 2);
				{
				setState(306);
				match(COLON2);
				setState(307);
				match(CONSTANT_IDENTIFIER);
				setState(308);
				assignmentOperator();
				setState(312);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==NL) {
					{
					{
					setState(309);
					match(NL);
					}
					}
					setState(314);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(315);
				methodInvocationWithoutParentheses();
				}
				break;
			case 3:
				enterOuterAlt(_localctx, 3);
				{
				setState(317);
				primary();
				setState(318);
				match(LBRACK);
				setState(320);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (((((_la - 3)) & ~0x3f) == 0 && ((1L << (_la - 3)) & ((1L << (REGULAR_EXPRESSION_START - 3)) | (1L << (LINE__ - 3)) | (1L << (ENCODING__ - 3)) | (1L << (FILE__ - 3)) | (1L << (BEGIN_ - 3)) | (1L << (END_ - 3)) | (1L << (ALIAS - 3)) | (1L << (AND - 3)) | (1L << (BEGIN - 3)) | (1L << (BREAK - 3)) | (1L << (CASE - 3)) | (1L << (CLASS - 3)) | (1L << (DEF - 3)) | (1L << (IS_DEFINED - 3)) | (1L << (DO - 3)) | (1L << (ELSE - 3)) | (1L << (ELSIF - 3)) | (1L << (END - 3)) | (1L << (ENSURE - 3)) | (1L << (FOR - 3)) | (1L << (FALSE - 3)) | (1L << (IF - 3)) | (1L << (IN - 3)) | (1L << (MODULE - 3)) | (1L << (NEXT - 3)) | (1L << (NIL - 3)) | (1L << (NOT - 3)) | (1L << (OR - 3)) | (1L << (REDO - 3)) | (1L << (RESCUE - 3)) | (1L << (RETRY - 3)) | (1L << (RETURN - 3)) | (1L << (SELF - 3)) | (1L << (SUPER - 3)) | (1L << (THEN - 3)) | (1L << (TRUE - 3)) | (1L << (UNDEF - 3)) | (1L << (UNLESS - 3)) | (1L << (UNTIL - 3)) | (1L << (WHEN - 3)) | (1L << (WHILE - 3)) | (1L << (YIELD - 3)) | (1L << (LBRACK - 3)) | (1L << (LPAREN - 3)) | (1L << (LCURLY - 3)) | (1L << (COLON - 3)) | (1L << (COLON2 - 3)))) != 0) || ((((_la - 72)) & ~0x3f) == 0 && ((1L << (_la - 72)) & ((1L << (MINUSGT - 72)) | (1L << (EMARK - 72)) | (1L << (PLUS - 72)) | (1L << (MINUS - 72)) | (1L << (STAR - 72)) | (1L << (STAR2 - 72)) | (1L << (TILDE - 72)) | (1L << (SINGLE_QUOTED_STRING_LITERAL - 72)) | (1L << (DOUBLE_QUOTED_STRING_START - 72)) | (1L << (QUOTED_NON_EXPANDED_STRING_LITERAL_START - 72)) | (1L << (QUOTED_EXPANDED_STRING_LITERAL_START - 72)) | (1L << (QUOTED_EXPANDED_REGULAR_EXPRESSION_START - 72)) | (1L << (QUOTED_EXPANDED_EXTERNAL_COMMAND_LITERAL_START - 72)) | (1L << (QUOTED_NON_EXPANDED_STRING_ARRAY_LITERAL_START - 72)) | (1L << (QUOTED_EXPANDED_STRING_ARRAY_LITERAL_START - 72)) | (1L << (HERE_DOC - 72)) | (1L << (QUOTED_NON_EXPANDED_SYMBOL_ARRAY_LITERAL_START - 72)) | (1L << (QUOTED_EXPANDED_SYMBOL_ARRAY_LITERAL_START - 72)) | (1L << (DECIMAL_INTEGER_LITERAL - 72)) | (1L << (BINARY_INTEGER_LITERAL - 72)) | (1L << (OCTAL_INTEGER_LITERAL - 72)) | (1L << (HEXADECIMAL_INTEGER_LITERAL - 72)) | (1L << (FLOAT_LITERAL_WITHOUT_EXPONENT - 72)) | (1L << (FLOAT_LITERAL_WITH_EXPONENT - 72)) | (1L << (SYMBOL_LITERAL - 72)) | (1L << (LOCAL_VARIABLE_IDENTIFIER - 72)) | (1L << (GLOBAL_VARIABLE_IDENTIFIER - 72)) | (1L << (INSTANCE_VARIABLE_IDENTIFIER - 72)) | (1L << (CLASS_VARIABLE_IDENTIFIER - 72)) | (1L << (CONSTANT_IDENTIFIER - 72)))) != 0)) {
					{
					setState(319);
					indexingArgumentList();
					}
				}

				setState(322);
				match(RBRACK);
				setState(323);
				assignmentOperator();
				setState(327);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==NL) {
					{
					{
					setState(324);
					match(NL);
					}
					}
					setState(329);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(330);
				methodInvocationWithoutParentheses();
				}
				break;
			case 4:
				enterOuterAlt(_localctx, 4);
				{
				setState(332);
				primary();
				setState(333);
				_la = _input.LA(1);
				if ( !(_la==COLON2 || _la==DOT) ) {
				_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				setState(334);
				methodName();
				setState(335);
				assignmentOperator();
				setState(339);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==NL) {
					{
					{
					setState(336);
					match(NL);
					}
					}
					setState(341);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(342);
				methodInvocationWithoutParentheses();
				}
				break;
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class MultipleAssignmentStatementContext extends ParserRuleContext {
		public LeftHandSideContext leftHandSide() {
			return getRuleContext(LeftHandSideContext.class,0);
		}
		public TerminalNode EQ() { return getToken(RubyParser.EQ, 0); }
		public MultipleRightHandSideContext multipleRightHandSide() {
			return getRuleContext(MultipleRightHandSideContext.class,0);
		}
		public List NL() { return getTokens(RubyParser.NL); }
		public TerminalNode NL(int i) {
			return getToken(RubyParser.NL, i);
		}
		public PackingLeftHandSideContext packingLeftHandSide() {
			return getRuleContext(PackingLeftHandSideContext.class,0);
		}
		public MethodInvocationWithoutParenthesesContext methodInvocationWithoutParentheses() {
			return getRuleContext(MethodInvocationWithoutParenthesesContext.class,0);
		}
		public OperatorExpressionContext operatorExpression() {
			return getRuleContext(OperatorExpressionContext.class,0);
		}
		public MultipleLeftHandSideContext multipleLeftHandSide() {
			return getRuleContext(MultipleLeftHandSideContext.class,0);
		}
		public MultipleLeftHandSideExceptPackingContext multipleLeftHandSideExceptPacking() {
			return getRuleContext(MultipleLeftHandSideExceptPackingContext.class,0);
		}
		public MultipleAssignmentStatementContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_multipleAssignmentStatement; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterMultipleAssignmentStatement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitMultipleAssignmentStatement(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitMultipleAssignmentStatement(this);
			else return visitor.visitChildren(this);
		}
	}

	public final MultipleAssignmentStatementContext multipleAssignmentStatement() throws RecognitionException {
		MultipleAssignmentStatementContext _localctx = new MultipleAssignmentStatementContext(_ctx, getState());
		enterRule(_localctx, 12, RULE_multipleAssignmentStatement);
		int _la;
		try {
			setState(390);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,25,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(346);
				leftHandSide();
				setState(347);
				match(EQ);
				setState(351);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==NL) {
					{
					{
					setState(348);
					match(NL);
					}
					}
					setState(353);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(354);
				multipleRightHandSide();
				}
				break;
			case 2:
				enterOuterAlt(_localctx, 2);
				{
				setState(356);
				packingLeftHandSide();
				setState(357);
				match(EQ);
				setState(361);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==NL) {
					{
					{
					setState(358);
					match(NL);
					}
					}
					setState(363);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(366);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,21,_ctx) ) {
				case 1:
					{
					setState(364);
					methodInvocationWithoutParentheses();
					}
					break;
				case 2:
					{
					setState(365);
					operatorExpression(0);
					}
					break;
				}
				}
				break;
			case 3:
				enterOuterAlt(_localctx, 3);
				{
				setState(368);
				multipleLeftHandSide();
				setState(369);
				match(EQ);
				setState(373);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==NL) {
					{
					{
					setState(370);
					match(NL);
					}
					}
					setState(375);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(376);
				multipleRightHandSide();
				}
				break;
			case 4:
				enterOuterAlt(_localctx, 4);
				{
				setState(378);
				multipleLeftHandSideExceptPacking();
				setState(379);
				match(EQ);
				setState(383);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==NL) {
					{
					{
					setState(380);
					match(NL);
					}
					}
					setState(385);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(388);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,24,_ctx) ) {
				case 1:
					{
					setState(386);
					methodInvocationWithoutParentheses();
					}
					break;
				case 2:
					{
					setState(387);
					operatorExpression(0);
					}
					break;
				}
				}
				break;
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class LeftHandSideContext extends ParserRuleContext {
		public LeftHandSideContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_leftHandSide; }
	 
		public LeftHandSideContext() { }
		public void copyFrom(LeftHandSideContext ctx) {
			super.copyFrom(ctx);
		}
	}
	public static class QualifiedLeftHandSideContext extends LeftHandSideContext {
		public TerminalNode COLON2() { return getToken(RubyParser.COLON2, 0); }
		public TerminalNode CONSTANT_IDENTIFIER() { return getToken(RubyParser.CONSTANT_IDENTIFIER, 0); }
		public QualifiedLeftHandSideContext(LeftHandSideContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterQualifiedLeftHandSide(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitQualifiedLeftHandSide(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitQualifiedLeftHandSide(this);
			else return visitor.visitChildren(this);
		}
	}
	public static class VariableLeftHandSideContext extends LeftHandSideContext {
		public VariableContext variable() {
			return getRuleContext(VariableContext.class,0);
		}
		public TerminalNode EQ() { return getToken(RubyParser.EQ, 0); }
		public PrimaryContext primary() {
			return getRuleContext(PrimaryContext.class,0);
		}
		public VariableLeftHandSideContext(LeftHandSideContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterVariableLeftHandSide(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitVariableLeftHandSide(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitVariableLeftHandSide(this);
			else return visitor.visitChildren(this);
		}
	}
	public static class IndexingLeftHandSideContext extends LeftHandSideContext {
		public PrimaryContext primary() {
			return getRuleContext(PrimaryContext.class,0);
		}
		public TerminalNode LBRACK() { return getToken(RubyParser.LBRACK, 0); }
		public TerminalNode RBRACK() { return getToken(RubyParser.RBRACK, 0); }
		public IndexingArgumentListContext indexingArgumentList() {
			return getRuleContext(IndexingArgumentListContext.class,0);
		}
		public IndexingLeftHandSideContext(LeftHandSideContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterIndexingLeftHandSide(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitIndexingLeftHandSide(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitIndexingLeftHandSide(this);
			else return visitor.visitChildren(this);
		}
	}
	public static class MemberAccessLeftHandSideContext extends LeftHandSideContext {
		public PrimaryContext primary() {
			return getRuleContext(PrimaryContext.class,0);
		}
		public TerminalNode DOT() { return getToken(RubyParser.DOT, 0); }
		public TerminalNode COLON2() { return getToken(RubyParser.COLON2, 0); }
		public TerminalNode LOCAL_VARIABLE_IDENTIFIER() { return getToken(RubyParser.LOCAL_VARIABLE_IDENTIFIER, 0); }
		public TerminalNode CONSTANT_IDENTIFIER() { return getToken(RubyParser.CONSTANT_IDENTIFIER, 0); }
		public MemberAccessLeftHandSideContext(LeftHandSideContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterMemberAccessLeftHandSide(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitMemberAccessLeftHandSide(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitMemberAccessLeftHandSide(this);
			else return visitor.visitChildren(this);
		}
	}

	public final LeftHandSideContext leftHandSide() throws RecognitionException {
		LeftHandSideContext _localctx = new LeftHandSideContext(_ctx, getState());
		enterRule(_localctx, 14, RULE_leftHandSide);
		int _la;
		try {
			setState(410);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,28,_ctx) ) {
			case 1:
				_localctx = new VariableLeftHandSideContext(_localctx);
				enterOuterAlt(_localctx, 1);
				{
				setState(392);
				variable();
				setState(395);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,26,_ctx) ) {
				case 1:
					{
					setState(393);
					match(EQ);
					setState(394);
					primary();
					}
					break;
				}
				}
				break;
			case 2:
				_localctx = new IndexingLeftHandSideContext(_localctx);
				enterOuterAlt(_localctx, 2);
				{
				setState(397);
				primary();
				setState(398);
				match(LBRACK);
				setState(400);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (((((_la - 3)) & ~0x3f) == 0 && ((1L << (_la - 3)) & ((1L << (REGULAR_EXPRESSION_START - 3)) | (1L << (LINE__ - 3)) | (1L << (ENCODING__ - 3)) | (1L << (FILE__ - 3)) | (1L << (BEGIN_ - 3)) | (1L << (END_ - 3)) | (1L << (ALIAS - 3)) | (1L << (AND - 3)) | (1L << (BEGIN - 3)) | (1L << (BREAK - 3)) | (1L << (CASE - 3)) | (1L << (CLASS - 3)) | (1L << (DEF - 3)) | (1L << (IS_DEFINED - 3)) | (1L << (DO - 3)) | (1L << (ELSE - 3)) | (1L << (ELSIF - 3)) | (1L << (END - 3)) | (1L << (ENSURE - 3)) | (1L << (FOR - 3)) | (1L << (FALSE - 3)) | (1L << (IF - 3)) | (1L << (IN - 3)) | (1L << (MODULE - 3)) | (1L << (NEXT - 3)) | (1L << (NIL - 3)) | (1L << (NOT - 3)) | (1L << (OR - 3)) | (1L << (REDO - 3)) | (1L << (RESCUE - 3)) | (1L << (RETRY - 3)) | (1L << (RETURN - 3)) | (1L << (SELF - 3)) | (1L << (SUPER - 3)) | (1L << (THEN - 3)) | (1L << (TRUE - 3)) | (1L << (UNDEF - 3)) | (1L << (UNLESS - 3)) | (1L << (UNTIL - 3)) | (1L << (WHEN - 3)) | (1L << (WHILE - 3)) | (1L << (YIELD - 3)) | (1L << (LBRACK - 3)) | (1L << (LPAREN - 3)) | (1L << (LCURLY - 3)) | (1L << (COLON - 3)) | (1L << (COLON2 - 3)))) != 0) || ((((_la - 72)) & ~0x3f) == 0 && ((1L << (_la - 72)) & ((1L << (MINUSGT - 72)) | (1L << (EMARK - 72)) | (1L << (PLUS - 72)) | (1L << (MINUS - 72)) | (1L << (STAR - 72)) | (1L << (STAR2 - 72)) | (1L << (TILDE - 72)) | (1L << (SINGLE_QUOTED_STRING_LITERAL - 72)) | (1L << (DOUBLE_QUOTED_STRING_START - 72)) | (1L << (QUOTED_NON_EXPANDED_STRING_LITERAL_START - 72)) | (1L << (QUOTED_EXPANDED_STRING_LITERAL_START - 72)) | (1L << (QUOTED_EXPANDED_REGULAR_EXPRESSION_START - 72)) | (1L << (QUOTED_EXPANDED_EXTERNAL_COMMAND_LITERAL_START - 72)) | (1L << (QUOTED_NON_EXPANDED_STRING_ARRAY_LITERAL_START - 72)) | (1L << (QUOTED_EXPANDED_STRING_ARRAY_LITERAL_START - 72)) | (1L << (HERE_DOC - 72)) | (1L << (QUOTED_NON_EXPANDED_SYMBOL_ARRAY_LITERAL_START - 72)) | (1L << (QUOTED_EXPANDED_SYMBOL_ARRAY_LITERAL_START - 72)) | (1L << (DECIMAL_INTEGER_LITERAL - 72)) | (1L << (BINARY_INTEGER_LITERAL - 72)) | (1L << (OCTAL_INTEGER_LITERAL - 72)) | (1L << (HEXADECIMAL_INTEGER_LITERAL - 72)) | (1L << (FLOAT_LITERAL_WITHOUT_EXPONENT - 72)) | (1L << (FLOAT_LITERAL_WITH_EXPONENT - 72)) | (1L << (SYMBOL_LITERAL - 72)) | (1L << (LOCAL_VARIABLE_IDENTIFIER - 72)) | (1L << (GLOBAL_VARIABLE_IDENTIFIER - 72)) | (1L << (INSTANCE_VARIABLE_IDENTIFIER - 72)) | (1L << (CLASS_VARIABLE_IDENTIFIER - 72)) | (1L << (CONSTANT_IDENTIFIER - 72)))) != 0)) {
					{
					setState(399);
					indexingArgumentList();
					}
				}

				setState(402);
				match(RBRACK);
				}
				break;
			case 3:
				_localctx = new MemberAccessLeftHandSideContext(_localctx);
				enterOuterAlt(_localctx, 3);
				{
				setState(404);
				primary();
				setState(405);
				_la = _input.LA(1);
				if ( !(_la==COLON2 || _la==DOT) ) {
				_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				setState(406);
				_la = _input.LA(1);
				if ( !(_la==LOCAL_VARIABLE_IDENTIFIER || _la==CONSTANT_IDENTIFIER) ) {
				_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				}
				break;
			case 4:
				_localctx = new QualifiedLeftHandSideContext(_localctx);
				enterOuterAlt(_localctx, 4);
				{
				setState(408);
				match(COLON2);
				setState(409);
				match(CONSTANT_IDENTIFIER);
				}
				break;
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class MultipleLeftHandSideContext extends ParserRuleContext {
		public List multipleLeftHandSideItem() {
			return getRuleContexts(MultipleLeftHandSideItemContext.class);
		}
		public MultipleLeftHandSideItemContext multipleLeftHandSideItem(int i) {
			return getRuleContext(MultipleLeftHandSideItemContext.class,i);
		}
		public List COMMA() { return getTokens(RubyParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(RubyParser.COMMA, i);
		}
		public PackingLeftHandSideContext packingLeftHandSide() {
			return getRuleContext(PackingLeftHandSideContext.class,0);
		}
		public ProcParameterContext procParameter() {
			return getRuleContext(ProcParameterContext.class,0);
		}
		public List NL() { return getTokens(RubyParser.NL); }
		public TerminalNode NL(int i) {
			return getToken(RubyParser.NL, i);
		}
		public GroupedLeftHandSideContext groupedLeftHandSide() {
			return getRuleContext(GroupedLeftHandSideContext.class,0);
		}
		public MultipleLeftHandSideContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_multipleLeftHandSide; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterMultipleLeftHandSide(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitMultipleLeftHandSide(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitMultipleLeftHandSide(this);
			else return visitor.visitChildren(this);
		}
	}

	public final MultipleLeftHandSideContext multipleLeftHandSide() throws RecognitionException {
		MultipleLeftHandSideContext _localctx = new MultipleLeftHandSideContext(_ctx, getState());
		enterRule(_localctx, 16, RULE_multipleLeftHandSide);
		int _la;
		try {
			int _alt;
			setState(449);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,37,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(415); 
				_errHandler.sync(this);
				_alt = 1;
				do {
					switch (_alt) {
					case 1:
						{
						{
						setState(412);
						multipleLeftHandSideItem();
						setState(413);
						match(COMMA);
						}
						}
						break;
					default:
						throw new NoViableAltException(this);
					}
					setState(417); 
					_errHandler.sync(this);
					_alt = getInterpreter().adaptivePredict(_input,29,_ctx);
				} while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER );
				setState(420);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (((((_la - 3)) & ~0x3f) == 0 && ((1L << (_la - 3)) & ((1L << (REGULAR_EXPRESSION_START - 3)) | (1L << (LINE__ - 3)) | (1L << (ENCODING__ - 3)) | (1L << (FILE__ - 3)) | (1L << (BEGIN - 3)) | (1L << (BREAK - 3)) | (1L << (CASE - 3)) | (1L << (CLASS - 3)) | (1L << (DEF - 3)) | (1L << (IS_DEFINED - 3)) | (1L << (FOR - 3)) | (1L << (FALSE - 3)) | (1L << (IF - 3)) | (1L << (MODULE - 3)) | (1L << (NEXT - 3)) | (1L << (NIL - 3)) | (1L << (REDO - 3)) | (1L << (RETRY - 3)) | (1L << (RETURN - 3)) | (1L << (SELF - 3)) | (1L << (SUPER - 3)) | (1L << (TRUE - 3)) | (1L << (UNLESS - 3)) | (1L << (UNTIL - 3)) | (1L << (WHILE - 3)) | (1L << (YIELD - 3)) | (1L << (LBRACK - 3)) | (1L << (LPAREN - 3)) | (1L << (LCURLY - 3)) | (1L << (COLON - 3)) | (1L << (COLON2 - 3)))) != 0) || ((((_la - 72)) & ~0x3f) == 0 && ((1L << (_la - 72)) & ((1L << (MINUSGT - 72)) | (1L << (EMARK - 72)) | (1L << (PLUS - 72)) | (1L << (MINUS - 72)) | (1L << (TILDE - 72)) | (1L << (SINGLE_QUOTED_STRING_LITERAL - 72)) | (1L << (DOUBLE_QUOTED_STRING_START - 72)) | (1L << (QUOTED_NON_EXPANDED_STRING_LITERAL_START - 72)) | (1L << (QUOTED_EXPANDED_STRING_LITERAL_START - 72)) | (1L << (QUOTED_EXPANDED_REGULAR_EXPRESSION_START - 72)) | (1L << (QUOTED_EXPANDED_EXTERNAL_COMMAND_LITERAL_START - 72)) | (1L << (QUOTED_NON_EXPANDED_STRING_ARRAY_LITERAL_START - 72)) | (1L << (QUOTED_EXPANDED_STRING_ARRAY_LITERAL_START - 72)) | (1L << (HERE_DOC - 72)) | (1L << (QUOTED_NON_EXPANDED_SYMBOL_ARRAY_LITERAL_START - 72)) | (1L << (QUOTED_EXPANDED_SYMBOL_ARRAY_LITERAL_START - 72)) | (1L << (DECIMAL_INTEGER_LITERAL - 72)) | (1L << (BINARY_INTEGER_LITERAL - 72)) | (1L << (OCTAL_INTEGER_LITERAL - 72)) | (1L << (HEXADECIMAL_INTEGER_LITERAL - 72)) | (1L << (FLOAT_LITERAL_WITHOUT_EXPONENT - 72)) | (1L << (FLOAT_LITERAL_WITH_EXPONENT - 72)) | (1L << (SYMBOL_LITERAL - 72)) | (1L << (LOCAL_VARIABLE_IDENTIFIER - 72)) | (1L << (GLOBAL_VARIABLE_IDENTIFIER - 72)) | (1L << (INSTANCE_VARIABLE_IDENTIFIER - 72)) | (1L << (CLASS_VARIABLE_IDENTIFIER - 72)) | (1L << (CONSTANT_IDENTIFIER - 72)))) != 0)) {
					{
					setState(419);
					multipleLeftHandSideItem();
					}
				}

				}
				break;
			case 2:
				enterOuterAlt(_localctx, 2);
				{
				setState(425); 
				_errHandler.sync(this);
				_la = _input.LA(1);
				do {
					{
					{
					setState(422);
					multipleLeftHandSideItem();
					setState(423);
					match(COMMA);
					}
					}
					setState(427); 
					_errHandler.sync(this);
					_la = _input.LA(1);
				} while ( ((((_la - 3)) & ~0x3f) == 0 && ((1L << (_la - 3)) & ((1L << (REGULAR_EXPRESSION_START - 3)) | (1L << (LINE__ - 3)) | (1L << (ENCODING__ - 3)) | (1L << (FILE__ - 3)) | (1L << (BEGIN - 3)) | (1L << (BREAK - 3)) | (1L << (CASE - 3)) | (1L << (CLASS - 3)) | (1L << (DEF - 3)) | (1L << (IS_DEFINED - 3)) | (1L << (FOR - 3)) | (1L << (FALSE - 3)) | (1L << (IF - 3)) | (1L << (MODULE - 3)) | (1L << (NEXT - 3)) | (1L << (NIL - 3)) | (1L << (REDO - 3)) | (1L << (RETRY - 3)) | (1L << (RETURN - 3)) | (1L << (SELF - 3)) | (1L << (SUPER - 3)) | (1L << (TRUE - 3)) | (1L << (UNLESS - 3)) | (1L << (UNTIL - 3)) | (1L << (WHILE - 3)) | (1L << (YIELD - 3)) | (1L << (LBRACK - 3)) | (1L << (LPAREN - 3)) | (1L << (LCURLY - 3)) | (1L << (COLON - 3)) | (1L << (COLON2 - 3)))) != 0) || ((((_la - 72)) & ~0x3f) == 0 && ((1L << (_la - 72)) & ((1L << (MINUSGT - 72)) | (1L << (EMARK - 72)) | (1L << (PLUS - 72)) | (1L << (MINUS - 72)) | (1L << (TILDE - 72)) | (1L << (SINGLE_QUOTED_STRING_LITERAL - 72)) | (1L << (DOUBLE_QUOTED_STRING_START - 72)) | (1L << (QUOTED_NON_EXPANDED_STRING_LITERAL_START - 72)) | (1L << (QUOTED_EXPANDED_STRING_LITERAL_START - 72)) | (1L << (QUOTED_EXPANDED_REGULAR_EXPRESSION_START - 72)) | (1L << (QUOTED_EXPANDED_EXTERNAL_COMMAND_LITERAL_START - 72)) | (1L << (QUOTED_NON_EXPANDED_STRING_ARRAY_LITERAL_START - 72)) | (1L << (QUOTED_EXPANDED_STRING_ARRAY_LITERAL_START - 72)) | (1L << (HERE_DOC - 72)) | (1L << (QUOTED_NON_EXPANDED_SYMBOL_ARRAY_LITERAL_START - 72)) | (1L << (QUOTED_EXPANDED_SYMBOL_ARRAY_LITERAL_START - 72)) | (1L << (DECIMAL_INTEGER_LITERAL - 72)) | (1L << (BINARY_INTEGER_LITERAL - 72)) | (1L << (OCTAL_INTEGER_LITERAL - 72)) | (1L << (HEXADECIMAL_INTEGER_LITERAL - 72)) | (1L << (FLOAT_LITERAL_WITHOUT_EXPONENT - 72)) | (1L << (FLOAT_LITERAL_WITH_EXPONENT - 72)) | (1L << (SYMBOL_LITERAL - 72)) | (1L << (LOCAL_VARIABLE_IDENTIFIER - 72)) | (1L << (GLOBAL_VARIABLE_IDENTIFIER - 72)) | (1L << (INSTANCE_VARIABLE_IDENTIFIER - 72)) | (1L << (CLASS_VARIABLE_IDENTIFIER - 72)) | (1L << (CONSTANT_IDENTIFIER - 72)))) != 0) );
				setState(430);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==STAR) {
					{
					setState(429);
					packingLeftHandSide();
					}
				}

				setState(442);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,35,_ctx) ) {
				case 1:
					{
					setState(433);
					_errHandler.sync(this);
					_la = _input.LA(1);
					if (_la==COMMA) {
						{
						setState(432);
						match(COMMA);
						}
					}

					setState(438);
					_errHandler.sync(this);
					_la = _input.LA(1);
					while (_la==NL) {
						{
						{
						setState(435);
						match(NL);
						}
						}
						setState(440);
						_errHandler.sync(this);
						_la = _input.LA(1);
					}
					setState(441);
					procParameter();
					}
					break;
				}
				setState(445);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==COMMA) {
					{
					setState(444);
					match(COMMA);
					}
				}

				}
				break;
			case 3:
				enterOuterAlt(_localctx, 3);
				{
				setState(447);
				packingLeftHandSide();
				}
				break;
			case 4:
				enterOuterAlt(_localctx, 4);
				{
				setState(448);
				groupedLeftHandSide();
				}
				break;
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class MultipleLeftHandSideExceptPackingContext extends ParserRuleContext {
		public List multipleLeftHandSideItem() {
			return getRuleContexts(MultipleLeftHandSideItemContext.class);
		}
		public MultipleLeftHandSideItemContext multipleLeftHandSideItem(int i) {
			return getRuleContext(MultipleLeftHandSideItemContext.class,i);
		}
		public List COMMA() { return getTokens(RubyParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(RubyParser.COMMA, i);
		}
		public PackingLeftHandSideContext packingLeftHandSide() {
			return getRuleContext(PackingLeftHandSideContext.class,0);
		}
		public GroupedLeftHandSideContext groupedLeftHandSide() {
			return getRuleContext(GroupedLeftHandSideContext.class,0);
		}
		public MultipleLeftHandSideExceptPackingContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_multipleLeftHandSideExceptPacking; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterMultipleLeftHandSideExceptPacking(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitMultipleLeftHandSideExceptPacking(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitMultipleLeftHandSideExceptPacking(this);
			else return visitor.visitChildren(this);
		}
	}

	public final MultipleLeftHandSideExceptPackingContext multipleLeftHandSideExceptPacking() throws RecognitionException {
		MultipleLeftHandSideExceptPackingContext _localctx = new MultipleLeftHandSideExceptPackingContext(_ctx, getState());
		enterRule(_localctx, 18, RULE_multipleLeftHandSideExceptPacking);
		int _la;
		try {
			int _alt;
			setState(472);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,42,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(454); 
				_errHandler.sync(this);
				_alt = 1;
				do {
					switch (_alt) {
					case 1:
						{
						{
						setState(451);
						multipleLeftHandSideItem();
						setState(452);
						match(COMMA);
						}
						}
						break;
					default:
						throw new NoViableAltException(this);
					}
					setState(456); 
					_errHandler.sync(this);
					_alt = getInterpreter().adaptivePredict(_input,38,_ctx);
				} while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER );
				setState(459);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (((((_la - 3)) & ~0x3f) == 0 && ((1L << (_la - 3)) & ((1L << (REGULAR_EXPRESSION_START - 3)) | (1L << (LINE__ - 3)) | (1L << (ENCODING__ - 3)) | (1L << (FILE__ - 3)) | (1L << (BEGIN - 3)) | (1L << (BREAK - 3)) | (1L << (CASE - 3)) | (1L << (CLASS - 3)) | (1L << (DEF - 3)) | (1L << (IS_DEFINED - 3)) | (1L << (FOR - 3)) | (1L << (FALSE - 3)) | (1L << (IF - 3)) | (1L << (MODULE - 3)) | (1L << (NEXT - 3)) | (1L << (NIL - 3)) | (1L << (REDO - 3)) | (1L << (RETRY - 3)) | (1L << (RETURN - 3)) | (1L << (SELF - 3)) | (1L << (SUPER - 3)) | (1L << (TRUE - 3)) | (1L << (UNLESS - 3)) | (1L << (UNTIL - 3)) | (1L << (WHILE - 3)) | (1L << (YIELD - 3)) | (1L << (LBRACK - 3)) | (1L << (LPAREN - 3)) | (1L << (LCURLY - 3)) | (1L << (COLON - 3)) | (1L << (COLON2 - 3)))) != 0) || ((((_la - 72)) & ~0x3f) == 0 && ((1L << (_la - 72)) & ((1L << (MINUSGT - 72)) | (1L << (EMARK - 72)) | (1L << (PLUS - 72)) | (1L << (MINUS - 72)) | (1L << (TILDE - 72)) | (1L << (SINGLE_QUOTED_STRING_LITERAL - 72)) | (1L << (DOUBLE_QUOTED_STRING_START - 72)) | (1L << (QUOTED_NON_EXPANDED_STRING_LITERAL_START - 72)) | (1L << (QUOTED_EXPANDED_STRING_LITERAL_START - 72)) | (1L << (QUOTED_EXPANDED_REGULAR_EXPRESSION_START - 72)) | (1L << (QUOTED_EXPANDED_EXTERNAL_COMMAND_LITERAL_START - 72)) | (1L << (QUOTED_NON_EXPANDED_STRING_ARRAY_LITERAL_START - 72)) | (1L << (QUOTED_EXPANDED_STRING_ARRAY_LITERAL_START - 72)) | (1L << (HERE_DOC - 72)) | (1L << (QUOTED_NON_EXPANDED_SYMBOL_ARRAY_LITERAL_START - 72)) | (1L << (QUOTED_EXPANDED_SYMBOL_ARRAY_LITERAL_START - 72)) | (1L << (DECIMAL_INTEGER_LITERAL - 72)) | (1L << (BINARY_INTEGER_LITERAL - 72)) | (1L << (OCTAL_INTEGER_LITERAL - 72)) | (1L << (HEXADECIMAL_INTEGER_LITERAL - 72)) | (1L << (FLOAT_LITERAL_WITHOUT_EXPONENT - 72)) | (1L << (FLOAT_LITERAL_WITH_EXPONENT - 72)) | (1L << (SYMBOL_LITERAL - 72)) | (1L << (LOCAL_VARIABLE_IDENTIFIER - 72)) | (1L << (GLOBAL_VARIABLE_IDENTIFIER - 72)) | (1L << (INSTANCE_VARIABLE_IDENTIFIER - 72)) | (1L << (CLASS_VARIABLE_IDENTIFIER - 72)) | (1L << (CONSTANT_IDENTIFIER - 72)))) != 0)) {
					{
					setState(458);
					multipleLeftHandSideItem();
					}
				}

				}
				break;
			case 2:
				enterOuterAlt(_localctx, 2);
				{
				setState(464); 
				_errHandler.sync(this);
				_la = _input.LA(1);
				do {
					{
					{
					setState(461);
					multipleLeftHandSideItem();
					setState(462);
					match(COMMA);
					}
					}
					setState(466); 
					_errHandler.sync(this);
					_la = _input.LA(1);
				} while ( ((((_la - 3)) & ~0x3f) == 0 && ((1L << (_la - 3)) & ((1L << (REGULAR_EXPRESSION_START - 3)) | (1L << (LINE__ - 3)) | (1L << (ENCODING__ - 3)) | (1L << (FILE__ - 3)) | (1L << (BEGIN - 3)) | (1L << (BREAK - 3)) | (1L << (CASE - 3)) | (1L << (CLASS - 3)) | (1L << (DEF - 3)) | (1L << (IS_DEFINED - 3)) | (1L << (FOR - 3)) | (1L << (FALSE - 3)) | (1L << (IF - 3)) | (1L << (MODULE - 3)) | (1L << (NEXT - 3)) | (1L << (NIL - 3)) | (1L << (REDO - 3)) | (1L << (RETRY - 3)) | (1L << (RETURN - 3)) | (1L << (SELF - 3)) | (1L << (SUPER - 3)) | (1L << (TRUE - 3)) | (1L << (UNLESS - 3)) | (1L << (UNTIL - 3)) | (1L << (WHILE - 3)) | (1L << (YIELD - 3)) | (1L << (LBRACK - 3)) | (1L << (LPAREN - 3)) | (1L << (LCURLY - 3)) | (1L << (COLON - 3)) | (1L << (COLON2 - 3)))) != 0) || ((((_la - 72)) & ~0x3f) == 0 && ((1L << (_la - 72)) & ((1L << (MINUSGT - 72)) | (1L << (EMARK - 72)) | (1L << (PLUS - 72)) | (1L << (MINUS - 72)) | (1L << (TILDE - 72)) | (1L << (SINGLE_QUOTED_STRING_LITERAL - 72)) | (1L << (DOUBLE_QUOTED_STRING_START - 72)) | (1L << (QUOTED_NON_EXPANDED_STRING_LITERAL_START - 72)) | (1L << (QUOTED_EXPANDED_STRING_LITERAL_START - 72)) | (1L << (QUOTED_EXPANDED_REGULAR_EXPRESSION_START - 72)) | (1L << (QUOTED_EXPANDED_EXTERNAL_COMMAND_LITERAL_START - 72)) | (1L << (QUOTED_NON_EXPANDED_STRING_ARRAY_LITERAL_START - 72)) | (1L << (QUOTED_EXPANDED_STRING_ARRAY_LITERAL_START - 72)) | (1L << (HERE_DOC - 72)) | (1L << (QUOTED_NON_EXPANDED_SYMBOL_ARRAY_LITERAL_START - 72)) | (1L << (QUOTED_EXPANDED_SYMBOL_ARRAY_LITERAL_START - 72)) | (1L << (DECIMAL_INTEGER_LITERAL - 72)) | (1L << (BINARY_INTEGER_LITERAL - 72)) | (1L << (OCTAL_INTEGER_LITERAL - 72)) | (1L << (HEXADECIMAL_INTEGER_LITERAL - 72)) | (1L << (FLOAT_LITERAL_WITHOUT_EXPONENT - 72)) | (1L << (FLOAT_LITERAL_WITH_EXPONENT - 72)) | (1L << (SYMBOL_LITERAL - 72)) | (1L << (LOCAL_VARIABLE_IDENTIFIER - 72)) | (1L << (GLOBAL_VARIABLE_IDENTIFIER - 72)) | (1L << (INSTANCE_VARIABLE_IDENTIFIER - 72)) | (1L << (CLASS_VARIABLE_IDENTIFIER - 72)) | (1L << (CONSTANT_IDENTIFIER - 72)))) != 0) );
				setState(469);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==STAR) {
					{
					setState(468);
					packingLeftHandSide();
					}
				}

				}
				break;
			case 3:
				enterOuterAlt(_localctx, 3);
				{
				setState(471);
				groupedLeftHandSide();
				}
				break;
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class PackingLeftHandSideContext extends ParserRuleContext {
		public TerminalNode STAR() { return getToken(RubyParser.STAR, 0); }
		public LeftHandSideContext leftHandSide() {
			return getRuleContext(LeftHandSideContext.class,0);
		}
		public List COMMA() { return getTokens(RubyParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(RubyParser.COMMA, i);
		}
		public List multipleLeftHandSideItem() {
			return getRuleContexts(MultipleLeftHandSideItemContext.class);
		}
		public MultipleLeftHandSideItemContext multipleLeftHandSideItem(int i) {
			return getRuleContext(MultipleLeftHandSideItemContext.class,i);
		}
		public PackingLeftHandSideContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_packingLeftHandSide; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterPackingLeftHandSide(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitPackingLeftHandSide(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitPackingLeftHandSide(this);
			else return visitor.visitChildren(this);
		}
	}

	public final PackingLeftHandSideContext packingLeftHandSide() throws RecognitionException {
		PackingLeftHandSideContext _localctx = new PackingLeftHandSideContext(_ctx, getState());
		enterRule(_localctx, 20, RULE_packingLeftHandSide);
		int _la;
		try {
			int _alt;
			setState(487);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,45,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(474);
				match(STAR);
				setState(476);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (((((_la - 3)) & ~0x3f) == 0 && ((1L << (_la - 3)) & ((1L << (REGULAR_EXPRESSION_START - 3)) | (1L << (LINE__ - 3)) | (1L << (ENCODING__ - 3)) | (1L << (FILE__ - 3)) | (1L << (BEGIN - 3)) | (1L << (BREAK - 3)) | (1L << (CASE - 3)) | (1L << (CLASS - 3)) | (1L << (DEF - 3)) | (1L << (IS_DEFINED - 3)) | (1L << (FOR - 3)) | (1L << (FALSE - 3)) | (1L << (IF - 3)) | (1L << (MODULE - 3)) | (1L << (NEXT - 3)) | (1L << (NIL - 3)) | (1L << (REDO - 3)) | (1L << (RETRY - 3)) | (1L << (RETURN - 3)) | (1L << (SELF - 3)) | (1L << (SUPER - 3)) | (1L << (TRUE - 3)) | (1L << (UNLESS - 3)) | (1L << (UNTIL - 3)) | (1L << (WHILE - 3)) | (1L << (YIELD - 3)) | (1L << (LBRACK - 3)) | (1L << (LPAREN - 3)) | (1L << (LCURLY - 3)) | (1L << (COLON - 3)) | (1L << (COLON2 - 3)))) != 0) || ((((_la - 72)) & ~0x3f) == 0 && ((1L << (_la - 72)) & ((1L << (MINUSGT - 72)) | (1L << (EMARK - 72)) | (1L << (PLUS - 72)) | (1L << (MINUS - 72)) | (1L << (TILDE - 72)) | (1L << (SINGLE_QUOTED_STRING_LITERAL - 72)) | (1L << (DOUBLE_QUOTED_STRING_START - 72)) | (1L << (QUOTED_NON_EXPANDED_STRING_LITERAL_START - 72)) | (1L << (QUOTED_EXPANDED_STRING_LITERAL_START - 72)) | (1L << (QUOTED_EXPANDED_REGULAR_EXPRESSION_START - 72)) | (1L << (QUOTED_EXPANDED_EXTERNAL_COMMAND_LITERAL_START - 72)) | (1L << (QUOTED_NON_EXPANDED_STRING_ARRAY_LITERAL_START - 72)) | (1L << (QUOTED_EXPANDED_STRING_ARRAY_LITERAL_START - 72)) | (1L << (HERE_DOC - 72)) | (1L << (QUOTED_NON_EXPANDED_SYMBOL_ARRAY_LITERAL_START - 72)) | (1L << (QUOTED_EXPANDED_SYMBOL_ARRAY_LITERAL_START - 72)) | (1L << (DECIMAL_INTEGER_LITERAL - 72)) | (1L << (BINARY_INTEGER_LITERAL - 72)) | (1L << (OCTAL_INTEGER_LITERAL - 72)) | (1L << (HEXADECIMAL_INTEGER_LITERAL - 72)) | (1L << (FLOAT_LITERAL_WITHOUT_EXPONENT - 72)) | (1L << (FLOAT_LITERAL_WITH_EXPONENT - 72)) | (1L << (SYMBOL_LITERAL - 72)) | (1L << (LOCAL_VARIABLE_IDENTIFIER - 72)) | (1L << (GLOBAL_VARIABLE_IDENTIFIER - 72)) | (1L << (INSTANCE_VARIABLE_IDENTIFIER - 72)) | (1L << (CLASS_VARIABLE_IDENTIFIER - 72)) | (1L << (CONSTANT_IDENTIFIER - 72)))) != 0)) {
					{
					setState(475);
					leftHandSide();
					}
				}

				}
				break;
			case 2:
				enterOuterAlt(_localctx, 2);
				{
				setState(478);
				match(STAR);
				setState(479);
				leftHandSide();
				setState(484);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,44,_ctx);
				while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) {
					if ( _alt==1 ) {
						{
						{
						setState(480);
						match(COMMA);
						setState(481);
						multipleLeftHandSideItem();
						}
						} 
					}
					setState(486);
					_errHandler.sync(this);
					_alt = getInterpreter().adaptivePredict(_input,44,_ctx);
				}
				}
				break;
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class GroupedLeftHandSideContext extends ParserRuleContext {
		public TerminalNode LPAREN() { return getToken(RubyParser.LPAREN, 0); }
		public MultipleLeftHandSideContext multipleLeftHandSide() {
			return getRuleContext(MultipleLeftHandSideContext.class,0);
		}
		public TerminalNode RPAREN() { return getToken(RubyParser.RPAREN, 0); }
		public GroupedLeftHandSideContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_groupedLeftHandSide; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterGroupedLeftHandSide(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitGroupedLeftHandSide(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitGroupedLeftHandSide(this);
			else return visitor.visitChildren(this);
		}
	}

	public final GroupedLeftHandSideContext groupedLeftHandSide() throws RecognitionException {
		GroupedLeftHandSideContext _localctx = new GroupedLeftHandSideContext(_ctx, getState());
		enterRule(_localctx, 22, RULE_groupedLeftHandSide);
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(489);
			match(LPAREN);
			setState(490);
			multipleLeftHandSide();
			setState(491);
			match(RPAREN);
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class MultipleLeftHandSideItemContext extends ParserRuleContext {
		public LeftHandSideContext leftHandSide() {
			return getRuleContext(LeftHandSideContext.class,0);
		}
		public GroupedLeftHandSideContext groupedLeftHandSide() {
			return getRuleContext(GroupedLeftHandSideContext.class,0);
		}
		public MultipleLeftHandSideItemContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_multipleLeftHandSideItem; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterMultipleLeftHandSideItem(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitMultipleLeftHandSideItem(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitMultipleLeftHandSideItem(this);
			else return visitor.visitChildren(this);
		}
	}

	public final MultipleLeftHandSideItemContext multipleLeftHandSideItem() throws RecognitionException {
		MultipleLeftHandSideItemContext _localctx = new MultipleLeftHandSideItemContext(_ctx, getState());
		enterRule(_localctx, 24, RULE_multipleLeftHandSideItem);
		try {
			setState(495);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,46,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(493);
				leftHandSide();
				}
				break;
			case 2:
				enterOuterAlt(_localctx, 2);
				{
				setState(494);
				groupedLeftHandSide();
				}
				break;
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class MultipleRightHandSideContext extends ParserRuleContext {
		public OperatorExpressionListContext operatorExpressionList() {
			return getRuleContext(OperatorExpressionListContext.class,0);
		}
		public TerminalNode COMMA() { return getToken(RubyParser.COMMA, 0); }
		public SplattingRightHandSideContext splattingRightHandSide() {
			return getRuleContext(SplattingRightHandSideContext.class,0);
		}
		public MultipleRightHandSideContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_multipleRightHandSide; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterMultipleRightHandSide(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitMultipleRightHandSide(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitMultipleRightHandSide(this);
			else return visitor.visitChildren(this);
		}
	}

	public final MultipleRightHandSideContext multipleRightHandSide() throws RecognitionException {
		MultipleRightHandSideContext _localctx = new MultipleRightHandSideContext(_ctx, getState());
		enterRule(_localctx, 26, RULE_multipleRightHandSide);
		try {
			setState(503);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case REGULAR_EXPRESSION_START:
			case LINE__:
			case ENCODING__:
			case FILE__:
			case BEGIN:
			case BREAK:
			case CASE:
			case CLASS:
			case DEF:
			case IS_DEFINED:
			case FOR:
			case FALSE:
			case IF:
			case MODULE:
			case NEXT:
			case NIL:
			case REDO:
			case RETRY:
			case RETURN:
			case SELF:
			case SUPER:
			case TRUE:
			case UNLESS:
			case UNTIL:
			case WHILE:
			case YIELD:
			case LBRACK:
			case LPAREN:
			case LCURLY:
			case COLON:
			case COLON2:
			case MINUSGT:
			case EMARK:
			case PLUS:
			case MINUS:
			case TILDE:
			case SINGLE_QUOTED_STRING_LITERAL:
			case DOUBLE_QUOTED_STRING_START:
			case QUOTED_NON_EXPANDED_STRING_LITERAL_START:
			case QUOTED_EXPANDED_STRING_LITERAL_START:
			case QUOTED_EXPANDED_REGULAR_EXPRESSION_START:
			case QUOTED_EXPANDED_EXTERNAL_COMMAND_LITERAL_START:
			case QUOTED_NON_EXPANDED_STRING_ARRAY_LITERAL_START:
			case QUOTED_EXPANDED_STRING_ARRAY_LITERAL_START:
			case HERE_DOC:
			case QUOTED_NON_EXPANDED_SYMBOL_ARRAY_LITERAL_START:
			case QUOTED_EXPANDED_SYMBOL_ARRAY_LITERAL_START:
			case DECIMAL_INTEGER_LITERAL:
			case BINARY_INTEGER_LITERAL:
			case OCTAL_INTEGER_LITERAL:
			case HEXADECIMAL_INTEGER_LITERAL:
			case FLOAT_LITERAL_WITHOUT_EXPONENT:
			case FLOAT_LITERAL_WITH_EXPONENT:
			case SYMBOL_LITERAL:
			case LOCAL_VARIABLE_IDENTIFIER:
			case GLOBAL_VARIABLE_IDENTIFIER:
			case INSTANCE_VARIABLE_IDENTIFIER:
			case CLASS_VARIABLE_IDENTIFIER:
			case CONSTANT_IDENTIFIER:
				enterOuterAlt(_localctx, 1);
				{
				setState(497);
				operatorExpressionList();
				setState(500);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,47,_ctx) ) {
				case 1:
					{
					setState(498);
					match(COMMA);
					setState(499);
					splattingRightHandSide();
					}
					break;
				}
				}
				break;
			case STAR:
			case STAR2:
				enterOuterAlt(_localctx, 2);
				{
				setState(502);
				splattingRightHandSide();
				}
				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 SplattingRightHandSideContext extends ParserRuleContext {
		public SplattingArgumentContext splattingArgument() {
			return getRuleContext(SplattingArgumentContext.class,0);
		}
		public SplattingRightHandSideContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_splattingRightHandSide; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterSplattingRightHandSide(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitSplattingRightHandSide(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitSplattingRightHandSide(this);
			else return visitor.visitChildren(this);
		}
	}

	public final SplattingRightHandSideContext splattingRightHandSide() throws RecognitionException {
		SplattingRightHandSideContext _localctx = new SplattingRightHandSideContext(_ctx, getState());
		enterRule(_localctx, 28, RULE_splattingRightHandSide);
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(505);
			splattingArgument();
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class MethodIdentifierContext extends ParserRuleContext {
		public TerminalNode LOCAL_VARIABLE_IDENTIFIER() { return getToken(RubyParser.LOCAL_VARIABLE_IDENTIFIER, 0); }
		public TerminalNode CONSTANT_IDENTIFIER() { return getToken(RubyParser.CONSTANT_IDENTIFIER, 0); }
		public MethodOnlyIdentifierContext methodOnlyIdentifier() {
			return getRuleContext(MethodOnlyIdentifierContext.class,0);
		}
		public MethodIdentifierContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_methodIdentifier; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterMethodIdentifier(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitMethodIdentifier(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitMethodIdentifier(this);
			else return visitor.visitChildren(this);
		}
	}

	public final MethodIdentifierContext methodIdentifier() throws RecognitionException {
		MethodIdentifierContext _localctx = new MethodIdentifierContext(_ctx, getState());
		enterRule(_localctx, 30, RULE_methodIdentifier);
		try {
			setState(510);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,49,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(507);
				match(LOCAL_VARIABLE_IDENTIFIER);
				}
				break;
			case 2:
				enterOuterAlt(_localctx, 2);
				{
				setState(508);
				match(CONSTANT_IDENTIFIER);
				}
				break;
			case 3:
				enterOuterAlt(_localctx, 3);
				{
				setState(509);
				methodOnlyIdentifier();
				}
				break;
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class MethodNameContext extends ParserRuleContext {
		public MethodIdentifierContext methodIdentifier() {
			return getRuleContext(MethodIdentifierContext.class,0);
		}
		public KeywordContext keyword() {
			return getRuleContext(KeywordContext.class,0);
		}
		public PseudoVariableContext pseudoVariable() {
			return getRuleContext(PseudoVariableContext.class,0);
		}
		public MethodNameContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_methodName; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterMethodName(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitMethodName(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitMethodName(this);
			else return visitor.visitChildren(this);
		}
	}

	public final MethodNameContext methodName() throws RecognitionException {
		MethodNameContext _localctx = new MethodNameContext(_ctx, getState());
		enterRule(_localctx, 32, RULE_methodName);
		try {
			setState(515);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,50,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(512);
				methodIdentifier();
				}
				break;
			case 2:
				enterOuterAlt(_localctx, 2);
				{
				setState(513);
				keyword();
				}
				break;
			case 3:
				enterOuterAlt(_localctx, 3);
				{
				setState(514);
				pseudoVariable();
				}
				break;
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class MethodOnlyIdentifierContext extends ParserRuleContext {
		public TerminalNode EMARK() { return getToken(RubyParser.EMARK, 0); }
		public TerminalNode QMARK() { return getToken(RubyParser.QMARK, 0); }
		public TerminalNode EQ() { return getToken(RubyParser.EQ, 0); }
		public TerminalNode CONSTANT_IDENTIFIER() { return getToken(RubyParser.CONSTANT_IDENTIFIER, 0); }
		public TerminalNode LOCAL_VARIABLE_IDENTIFIER() { return getToken(RubyParser.LOCAL_VARIABLE_IDENTIFIER, 0); }
		public PseudoVariableContext pseudoVariable() {
			return getRuleContext(PseudoVariableContext.class,0);
		}
		public MethodOnlyIdentifierContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_methodOnlyIdentifier; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterMethodOnlyIdentifier(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitMethodOnlyIdentifier(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitMethodOnlyIdentifier(this);
			else return visitor.visitChildren(this);
		}
	}

	public final MethodOnlyIdentifierContext methodOnlyIdentifier() throws RecognitionException {
		MethodOnlyIdentifierContext _localctx = new MethodOnlyIdentifierContext(_ctx, getState());
		enterRule(_localctx, 34, RULE_methodOnlyIdentifier);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(520);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case CONSTANT_IDENTIFIER:
				{
				setState(517);
				match(CONSTANT_IDENTIFIER);
				}
				break;
			case LOCAL_VARIABLE_IDENTIFIER:
				{
				setState(518);
				match(LOCAL_VARIABLE_IDENTIFIER);
				}
				break;
			case LINE__:
			case ENCODING__:
			case FILE__:
			case FALSE:
			case NIL:
			case SELF:
			case TRUE:
				{
				setState(519);
				pseudoVariable();
				}
				break;
			default:
				throw new NoViableAltException(this);
			}
			setState(522);
			_la = _input.LA(1);
			if ( !(((((_la - 70)) & ~0x3f) == 0 && ((1L << (_la - 70)) & ((1L << (QMARK - 70)) | (1L << (EMARK - 70)) | (1L << (EQ - 70)))) != 0)) ) {
			_errHandler.recoverInline(this);
			}
			else {
				if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
				_errHandler.reportMatch(this);
				consume();
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class MethodInvocationWithoutParenthesesContext extends ParserRuleContext {
		public MethodInvocationWithoutParenthesesContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_methodInvocationWithoutParentheses; }
	 
		public MethodInvocationWithoutParenthesesContext() { }
		public void copyFrom(MethodInvocationWithoutParenthesesContext ctx) {
			super.copyFrom(ctx);
		}
	}
	public static class NextMethodInvocationWithoutParenthesesContext extends MethodInvocationWithoutParenthesesContext {
		public TerminalNode NEXT() { return getToken(RubyParser.NEXT, 0); }
		public PrimaryValueListContext primaryValueList() {
			return getRuleContext(PrimaryValueListContext.class,0);
		}
		public NextMethodInvocationWithoutParenthesesContext(MethodInvocationWithoutParenthesesContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterNextMethodInvocationWithoutParentheses(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitNextMethodInvocationWithoutParentheses(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitNextMethodInvocationWithoutParentheses(this);
			else return visitor.visitChildren(this);
		}
	}
	public static class ChainedMethodInvocationWithoutParenthesesContext extends MethodInvocationWithoutParenthesesContext {
		public ChainedCommandWithDoBlockContext chainedCommandWithDoBlock() {
			return getRuleContext(ChainedCommandWithDoBlockContext.class,0);
		}
		public MethodNameContext methodName() {
			return getRuleContext(MethodNameContext.class,0);
		}
		public CommandArgumentListContext commandArgumentList() {
			return getRuleContext(CommandArgumentListContext.class,0);
		}
		public TerminalNode DOT() { return getToken(RubyParser.DOT, 0); }
		public TerminalNode COLON2() { return getToken(RubyParser.COLON2, 0); }
		public ChainedMethodInvocationWithoutParenthesesContext(MethodInvocationWithoutParenthesesContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterChainedMethodInvocationWithoutParentheses(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitChainedMethodInvocationWithoutParentheses(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitChainedMethodInvocationWithoutParentheses(this);
			else return visitor.visitChildren(this);
		}
	}
	public static class ReturnMethodInvocationWithoutParenthesesContext extends MethodInvocationWithoutParenthesesContext {
		public TerminalNode RETURN() { return getToken(RubyParser.RETURN, 0); }
		public PrimaryValueListContext primaryValueList() {
			return getRuleContext(PrimaryValueListContext.class,0);
		}
		public ReturnMethodInvocationWithoutParenthesesContext(MethodInvocationWithoutParenthesesContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterReturnMethodInvocationWithoutParentheses(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitReturnMethodInvocationWithoutParentheses(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitReturnMethodInvocationWithoutParentheses(this);
			else return visitor.visitChildren(this);
		}
	}
	public static class YieldMethodInvocationWithoutParenthesesContext extends MethodInvocationWithoutParenthesesContext {
		public TerminalNode YIELD() { return getToken(RubyParser.YIELD, 0); }
		public PrimaryValueListContext primaryValueList() {
			return getRuleContext(PrimaryValueListContext.class,0);
		}
		public YieldMethodInvocationWithoutParenthesesContext(MethodInvocationWithoutParenthesesContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterYieldMethodInvocationWithoutParentheses(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitYieldMethodInvocationWithoutParentheses(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitYieldMethodInvocationWithoutParentheses(this);
			else return visitor.visitChildren(this);
		}
	}
	public static class BreakMethodInvocationWithoutParenthesesContext extends MethodInvocationWithoutParenthesesContext {
		public TerminalNode BREAK() { return getToken(RubyParser.BREAK, 0); }
		public PrimaryValueListContext primaryValueList() {
			return getRuleContext(PrimaryValueListContext.class,0);
		}
		public BreakMethodInvocationWithoutParenthesesContext(MethodInvocationWithoutParenthesesContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterBreakMethodInvocationWithoutParentheses(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitBreakMethodInvocationWithoutParentheses(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitBreakMethodInvocationWithoutParentheses(this);
			else return visitor.visitChildren(this);
		}
	}
	public static class CommandMethodInvocationWithoutParenthesesContext extends MethodInvocationWithoutParenthesesContext {
		public CommandContext command() {
			return getRuleContext(CommandContext.class,0);
		}
		public CommandMethodInvocationWithoutParenthesesContext(MethodInvocationWithoutParenthesesContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterCommandMethodInvocationWithoutParentheses(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitCommandMethodInvocationWithoutParentheses(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitCommandMethodInvocationWithoutParentheses(this);
			else return visitor.visitChildren(this);
		}
	}

	public final MethodInvocationWithoutParenthesesContext methodInvocationWithoutParentheses() throws RecognitionException {
		MethodInvocationWithoutParenthesesContext _localctx = new MethodInvocationWithoutParenthesesContext(_ctx, getState());
		enterRule(_localctx, 36, RULE_methodInvocationWithoutParentheses);
		int _la;
		try {
			setState(540);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,53,_ctx) ) {
			case 1:
				_localctx = new CommandMethodInvocationWithoutParenthesesContext(_localctx);
				enterOuterAlt(_localctx, 1);
				{
				setState(524);
				command();
				}
				break;
			case 2:
				_localctx = new ChainedMethodInvocationWithoutParenthesesContext(_localctx);
				enterOuterAlt(_localctx, 2);
				{
				setState(525);
				chainedCommandWithDoBlock();
				setState(530);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,52,_ctx) ) {
				case 1:
					{
					setState(526);
					_la = _input.LA(1);
					if ( !(_la==COLON2 || _la==DOT) ) {
					_errHandler.recoverInline(this);
					}
					else {
						if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
						_errHandler.reportMatch(this);
						consume();
					}
					setState(527);
					methodName();
					setState(528);
					commandArgumentList();
					}
					break;
				}
				}
				break;
			case 3:
				_localctx = new ReturnMethodInvocationWithoutParenthesesContext(_localctx);
				enterOuterAlt(_localctx, 3);
				{
				setState(532);
				match(RETURN);
				setState(533);
				primaryValueList();
				}
				break;
			case 4:
				_localctx = new BreakMethodInvocationWithoutParenthesesContext(_localctx);
				enterOuterAlt(_localctx, 4);
				{
				setState(534);
				match(BREAK);
				setState(535);
				primaryValueList();
				}
				break;
			case 5:
				_localctx = new NextMethodInvocationWithoutParenthesesContext(_localctx);
				enterOuterAlt(_localctx, 5);
				{
				setState(536);
				match(NEXT);
				setState(537);
				primaryValueList();
				}
				break;
			case 6:
				_localctx = new YieldMethodInvocationWithoutParenthesesContext(_localctx);
				enterOuterAlt(_localctx, 6);
				{
				setState(538);
				match(YIELD);
				setState(539);
				primaryValueList();
				}
				break;
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class CommandContext extends ParserRuleContext {
		public CommandContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_command; }
	 
		public CommandContext() { }
		public void copyFrom(CommandContext ctx) {
			super.copyFrom(ctx);
		}
	}
	public static class MemberAccessCommandContext extends CommandContext {
		public PrimaryContext primary() {
			return getRuleContext(PrimaryContext.class,0);
		}
		public MethodNameContext methodName() {
			return getRuleContext(MethodNameContext.class,0);
		}
		public CommandArgumentContext commandArgument() {
			return getRuleContext(CommandArgumentContext.class,0);
		}
		public TerminalNode AMPDOT() { return getToken(RubyParser.AMPDOT, 0); }
		public TerminalNode DOT() { return getToken(RubyParser.DOT, 0); }
		public TerminalNode COLON2() { return getToken(RubyParser.COLON2, 0); }
		public TerminalNode NL() { return getToken(RubyParser.NL, 0); }
		public MemberAccessCommandContext(CommandContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterMemberAccessCommand(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitMemberAccessCommand(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitMemberAccessCommand(this);
			else return visitor.visitChildren(this);
		}
	}
	public static class SimpleCommandContext extends CommandContext {
		public MethodIdentifierContext methodIdentifier() {
			return getRuleContext(MethodIdentifierContext.class,0);
		}
		public CommandArgumentContext commandArgument() {
			return getRuleContext(CommandArgumentContext.class,0);
		}
		public SimpleCommandContext(CommandContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterSimpleCommand(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitSimpleCommand(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitSimpleCommand(this);
			else return visitor.visitChildren(this);
		}
	}

	public final CommandContext command() throws RecognitionException {
		CommandContext _localctx = new CommandContext(_ctx, getState());
		enterRule(_localctx, 38, RULE_command);
		int _la;
		try {
			setState(553);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,55,_ctx) ) {
			case 1:
				_localctx = new MemberAccessCommandContext(_localctx);
				enterOuterAlt(_localctx, 1);
				{
				setState(542);
				primary();
				setState(544);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==NL) {
					{
					setState(543);
					match(NL);
					}
				}

				setState(546);
				_la = _input.LA(1);
				if ( !(((((_la - 64)) & ~0x3f) == 0 && ((1L << (_la - 64)) & ((1L << (COLON2 - 64)) | (1L << (DOT - 64)) | (1L << (AMPDOT - 64)))) != 0)) ) {
				_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				setState(547);
				methodName();
				setState(548);
				commandArgument();
				}
				break;
			case 2:
				_localctx = new SimpleCommandContext(_localctx);
				enterOuterAlt(_localctx, 2);
				{
				setState(550);
				methodIdentifier();
				setState(551);
				commandArgument();
				}
				break;
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class CommandArgumentContext extends ParserRuleContext {
		public CommandArgumentContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_commandArgument; }
	 
		public CommandArgumentContext() { }
		public void copyFrom(CommandArgumentContext ctx) {
			super.copyFrom(ctx);
		}
	}
	public static class CommandCommandArgumentListContext extends CommandArgumentContext {
		public CommandContext command() {
			return getRuleContext(CommandContext.class,0);
		}
		public CommandCommandArgumentListContext(CommandArgumentContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterCommandCommandArgumentList(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitCommandCommandArgumentList(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitCommandCommandArgumentList(this);
			else return visitor.visitChildren(this);
		}
	}
	public static class CommandArgumentCommandArgumentListContext extends CommandArgumentContext {
		public CommandArgumentListContext commandArgumentList() {
			return getRuleContext(CommandArgumentListContext.class,0);
		}
		public CommandArgumentCommandArgumentListContext(CommandArgumentContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterCommandArgumentCommandArgumentList(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitCommandArgumentCommandArgumentList(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitCommandArgumentCommandArgumentList(this);
			else return visitor.visitChildren(this);
		}
	}

	public final CommandArgumentContext commandArgument() throws RecognitionException {
		CommandArgumentContext _localctx = new CommandArgumentContext(_ctx, getState());
		enterRule(_localctx, 40, RULE_commandArgument);
		try {
			setState(557);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,56,_ctx) ) {
			case 1:
				_localctx = new CommandArgumentCommandArgumentListContext(_localctx);
				enterOuterAlt(_localctx, 1);
				{
				setState(555);
				commandArgumentList();
				}
				break;
			case 2:
				_localctx = new CommandCommandArgumentListContext(_localctx);
				enterOuterAlt(_localctx, 2);
				{
				setState(556);
				command();
				}
				break;
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class ChainedCommandWithDoBlockContext extends ParserRuleContext {
		public CommandWithDoBlockContext commandWithDoBlock() {
			return getRuleContext(CommandWithDoBlockContext.class,0);
		}
		public List chainedMethodInvocation() {
			return getRuleContexts(ChainedMethodInvocationContext.class);
		}
		public ChainedMethodInvocationContext chainedMethodInvocation(int i) {
			return getRuleContext(ChainedMethodInvocationContext.class,i);
		}
		public ChainedCommandWithDoBlockContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_chainedCommandWithDoBlock; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterChainedCommandWithDoBlock(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitChainedCommandWithDoBlock(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitChainedCommandWithDoBlock(this);
			else return visitor.visitChildren(this);
		}
	}

	public final ChainedCommandWithDoBlockContext chainedCommandWithDoBlock() throws RecognitionException {
		ChainedCommandWithDoBlockContext _localctx = new ChainedCommandWithDoBlockContext(_ctx, getState());
		enterRule(_localctx, 42, RULE_chainedCommandWithDoBlock);
		try {
			int _alt;
			enterOuterAlt(_localctx, 1);
			{
			setState(559);
			commandWithDoBlock();
			setState(563);
			_errHandler.sync(this);
			_alt = getInterpreter().adaptivePredict(_input,57,_ctx);
			while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) {
				if ( _alt==1 ) {
					{
					{
					setState(560);
					chainedMethodInvocation();
					}
					} 
				}
				setState(565);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,57,_ctx);
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class ChainedMethodInvocationContext extends ParserRuleContext {
		public MethodNameContext methodName() {
			return getRuleContext(MethodNameContext.class,0);
		}
		public TerminalNode DOT() { return getToken(RubyParser.DOT, 0); }
		public TerminalNode COLON2() { return getToken(RubyParser.COLON2, 0); }
		public ArgumentWithParenthesesContext argumentWithParentheses() {
			return getRuleContext(ArgumentWithParenthesesContext.class,0);
		}
		public ChainedMethodInvocationContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_chainedMethodInvocation; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterChainedMethodInvocation(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitChainedMethodInvocation(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitChainedMethodInvocation(this);
			else return visitor.visitChildren(this);
		}
	}

	public final ChainedMethodInvocationContext chainedMethodInvocation() throws RecognitionException {
		ChainedMethodInvocationContext _localctx = new ChainedMethodInvocationContext(_ctx, getState());
		enterRule(_localctx, 44, RULE_chainedMethodInvocation);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(566);
			_la = _input.LA(1);
			if ( !(_la==COLON2 || _la==DOT) ) {
			_errHandler.recoverInline(this);
			}
			else {
				if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
				_errHandler.reportMatch(this);
				consume();
			}
			setState(567);
			methodName();
			setState(569);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,58,_ctx) ) {
			case 1:
				{
				setState(568);
				argumentWithParentheses();
				}
				break;
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class CommandWithDoBlockContext extends ParserRuleContext {
		public TerminalNode SUPER() { return getToken(RubyParser.SUPER, 0); }
		public ArgumentListContext argumentList() {
			return getRuleContext(ArgumentListContext.class,0);
		}
		public DoBlockContext doBlock() {
			return getRuleContext(DoBlockContext.class,0);
		}
		public MethodIdentifierContext methodIdentifier() {
			return getRuleContext(MethodIdentifierContext.class,0);
		}
		public PrimaryContext primary() {
			return getRuleContext(PrimaryContext.class,0);
		}
		public MethodNameContext methodName() {
			return getRuleContext(MethodNameContext.class,0);
		}
		public TerminalNode DOT() { return getToken(RubyParser.DOT, 0); }
		public TerminalNode COLON2() { return getToken(RubyParser.COLON2, 0); }
		public CommandWithDoBlockContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_commandWithDoBlock; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterCommandWithDoBlock(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitCommandWithDoBlock(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitCommandWithDoBlock(this);
			else return visitor.visitChildren(this);
		}
	}

	public final CommandWithDoBlockContext commandWithDoBlock() throws RecognitionException {
		CommandWithDoBlockContext _localctx = new CommandWithDoBlockContext(_ctx, getState());
		enterRule(_localctx, 46, RULE_commandWithDoBlock);
		int _la;
		try {
			setState(585);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,59,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(571);
				match(SUPER);
				setState(572);
				argumentList();
				setState(573);
				doBlock();
				}
				break;
			case 2:
				enterOuterAlt(_localctx, 2);
				{
				setState(575);
				methodIdentifier();
				setState(576);
				argumentList();
				setState(577);
				doBlock();
				}
				break;
			case 3:
				enterOuterAlt(_localctx, 3);
				{
				setState(579);
				primary();
				setState(580);
				_la = _input.LA(1);
				if ( !(_la==COLON2 || _la==DOT) ) {
				_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				setState(581);
				methodName();
				setState(582);
				argumentList();
				setState(583);
				doBlock();
				}
				break;
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class IndexingArgumentListContext extends ParserRuleContext {
		public IndexingArgumentListContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_indexingArgumentList; }
	 
		public IndexingArgumentListContext() { }
		public void copyFrom(IndexingArgumentListContext ctx) {
			super.copyFrom(ctx);
		}
	}
	public static class CommandIndexingArgumentListContext extends IndexingArgumentListContext {
		public CommandContext command() {
			return getRuleContext(CommandContext.class,0);
		}
		public CommandIndexingArgumentListContext(IndexingArgumentListContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterCommandIndexingArgumentList(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitCommandIndexingArgumentList(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitCommandIndexingArgumentList(this);
			else return visitor.visitChildren(this);
		}
	}
	public static class OperatorExpressionListWithSplattingArgumentIndexingArgumentListContext extends IndexingArgumentListContext {
		public OperatorExpressionListContext operatorExpressionList() {
			return getRuleContext(OperatorExpressionListContext.class,0);
		}
		public TerminalNode COMMA() { return getToken(RubyParser.COMMA, 0); }
		public SplattingArgumentContext splattingArgument() {
			return getRuleContext(SplattingArgumentContext.class,0);
		}
		public OperatorExpressionListWithSplattingArgumentIndexingArgumentListContext(IndexingArgumentListContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterOperatorExpressionListWithSplattingArgumentIndexingArgumentList(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitOperatorExpressionListWithSplattingArgumentIndexingArgumentList(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitOperatorExpressionListWithSplattingArgumentIndexingArgumentList(this);
			else return visitor.visitChildren(this);
		}
	}
	public static class SplattingArgumentIndexingArgumentListContext extends IndexingArgumentListContext {
		public SplattingArgumentContext splattingArgument() {
			return getRuleContext(SplattingArgumentContext.class,0);
		}
		public SplattingArgumentIndexingArgumentListContext(IndexingArgumentListContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterSplattingArgumentIndexingArgumentList(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitSplattingArgumentIndexingArgumentList(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitSplattingArgumentIndexingArgumentList(this);
			else return visitor.visitChildren(this);
		}
	}
	public static class OperatorExpressionListIndexingArgumentListContext extends IndexingArgumentListContext {
		public OperatorExpressionListContext operatorExpressionList() {
			return getRuleContext(OperatorExpressionListContext.class,0);
		}
		public TerminalNode COMMA() { return getToken(RubyParser.COMMA, 0); }
		public OperatorExpressionListIndexingArgumentListContext(IndexingArgumentListContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterOperatorExpressionListIndexingArgumentList(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitOperatorExpressionListIndexingArgumentList(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitOperatorExpressionListIndexingArgumentList(this);
			else return visitor.visitChildren(this);
		}
	}
	public static class AssociationListIndexingArgumentListContext extends IndexingArgumentListContext {
		public AssociationListContext associationList() {
			return getRuleContext(AssociationListContext.class,0);
		}
		public TerminalNode COMMA() { return getToken(RubyParser.COMMA, 0); }
		public AssociationListIndexingArgumentListContext(IndexingArgumentListContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterAssociationListIndexingArgumentList(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitAssociationListIndexingArgumentList(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitAssociationListIndexingArgumentList(this);
			else return visitor.visitChildren(this);
		}
	}

	public final IndexingArgumentListContext indexingArgumentList() throws RecognitionException {
		IndexingArgumentListContext _localctx = new IndexingArgumentListContext(_ctx, getState());
		enterRule(_localctx, 48, RULE_indexingArgumentList);
		int _la;
		try {
			setState(601);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,62,_ctx) ) {
			case 1:
				_localctx = new CommandIndexingArgumentListContext(_localctx);
				enterOuterAlt(_localctx, 1);
				{
				setState(587);
				command();
				}
				break;
			case 2:
				_localctx = new OperatorExpressionListIndexingArgumentListContext(_localctx);
				enterOuterAlt(_localctx, 2);
				{
				setState(588);
				operatorExpressionList();
				setState(590);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==COMMA) {
					{
					setState(589);
					match(COMMA);
					}
				}

				}
				break;
			case 3:
				_localctx = new OperatorExpressionListWithSplattingArgumentIndexingArgumentListContext(_localctx);
				enterOuterAlt(_localctx, 3);
				{
				setState(592);
				operatorExpressionList();
				setState(593);
				match(COMMA);
				setState(594);
				splattingArgument();
				}
				break;
			case 4:
				_localctx = new AssociationListIndexingArgumentListContext(_localctx);
				enterOuterAlt(_localctx, 4);
				{
				setState(596);
				associationList();
				setState(598);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==COMMA) {
					{
					setState(597);
					match(COMMA);
					}
				}

				}
				break;
			case 5:
				_localctx = new SplattingArgumentIndexingArgumentListContext(_localctx);
				enterOuterAlt(_localctx, 5);
				{
				setState(600);
				splattingArgument();
				}
				break;
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class SplattingArgumentContext extends ParserRuleContext {
		public TerminalNode STAR() { return getToken(RubyParser.STAR, 0); }
		public OperatorExpressionContext operatorExpression() {
			return getRuleContext(OperatorExpressionContext.class,0);
		}
		public TerminalNode STAR2() { return getToken(RubyParser.STAR2, 0); }
		public SplattingArgumentContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_splattingArgument; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterSplattingArgument(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitSplattingArgument(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitSplattingArgument(this);
			else return visitor.visitChildren(this);
		}
	}

	public final SplattingArgumentContext splattingArgument() throws RecognitionException {
		SplattingArgumentContext _localctx = new SplattingArgumentContext(_ctx, getState());
		enterRule(_localctx, 50, RULE_splattingArgument);
		try {
			setState(607);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case STAR:
				enterOuterAlt(_localctx, 1);
				{
				setState(603);
				match(STAR);
				setState(604);
				operatorExpression(0);
				}
				break;
			case STAR2:
				enterOuterAlt(_localctx, 2);
				{
				setState(605);
				match(STAR2);
				setState(606);
				operatorExpression(0);
				}
				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 OperatorExpressionListContext extends ParserRuleContext {
		public List operatorExpression() {
			return getRuleContexts(OperatorExpressionContext.class);
		}
		public OperatorExpressionContext operatorExpression(int i) {
			return getRuleContext(OperatorExpressionContext.class,i);
		}
		public List COMMA() { return getTokens(RubyParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(RubyParser.COMMA, i);
		}
		public List NL() { return getTokens(RubyParser.NL); }
		public TerminalNode NL(int i) {
			return getToken(RubyParser.NL, i);
		}
		public OperatorExpressionListContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_operatorExpressionList; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterOperatorExpressionList(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitOperatorExpressionList(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitOperatorExpressionList(this);
			else return visitor.visitChildren(this);
		}
	}

	public final OperatorExpressionListContext operatorExpressionList() throws RecognitionException {
		OperatorExpressionListContext _localctx = new OperatorExpressionListContext(_ctx, getState());
		enterRule(_localctx, 52, RULE_operatorExpressionList);
		int _la;
		try {
			int _alt;
			enterOuterAlt(_localctx, 1);
			{
			setState(609);
			operatorExpression(0);
			setState(620);
			_errHandler.sync(this);
			_alt = getInterpreter().adaptivePredict(_input,65,_ctx);
			while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) {
				if ( _alt==1 ) {
					{
					{
					setState(610);
					match(COMMA);
					setState(614);
					_errHandler.sync(this);
					_la = _input.LA(1);
					while (_la==NL) {
						{
						{
						setState(611);
						match(NL);
						}
						}
						setState(616);
						_errHandler.sync(this);
						_la = _input.LA(1);
					}
					setState(617);
					operatorExpression(0);
					}
					} 
				}
				setState(622);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,65,_ctx);
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class OperatorExpressionList2Context extends ParserRuleContext {
		public List operatorExpression() {
			return getRuleContexts(OperatorExpressionContext.class);
		}
		public OperatorExpressionContext operatorExpression(int i) {
			return getRuleContext(OperatorExpressionContext.class,i);
		}
		public List COMMA() { return getTokens(RubyParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(RubyParser.COMMA, i);
		}
		public List NL() { return getTokens(RubyParser.NL); }
		public TerminalNode NL(int i) {
			return getToken(RubyParser.NL, i);
		}
		public OperatorExpressionList2Context(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_operatorExpressionList2; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterOperatorExpressionList2(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitOperatorExpressionList2(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitOperatorExpressionList2(this);
			else return visitor.visitChildren(this);
		}
	}

	public final OperatorExpressionList2Context operatorExpressionList2() throws RecognitionException {
		OperatorExpressionList2Context _localctx = new OperatorExpressionList2Context(_ctx, getState());
		enterRule(_localctx, 54, RULE_operatorExpressionList2);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(623);
			operatorExpression(0);
			setState(632); 
			_errHandler.sync(this);
			_la = _input.LA(1);
			do {
				{
				{
				setState(624);
				match(COMMA);
				setState(628);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==NL) {
					{
					{
					setState(625);
					match(NL);
					}
					}
					setState(630);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(631);
				operatorExpression(0);
				}
				}
				setState(634); 
				_errHandler.sync(this);
				_la = _input.LA(1);
			} while ( _la==COMMA );
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class ArgumentWithParenthesesContext extends ParserRuleContext {
		public ArgumentWithParenthesesContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_argumentWithParentheses; }
	 
		public ArgumentWithParenthesesContext() { }
		public void copyFrom(ArgumentWithParenthesesContext ctx) {
			super.copyFrom(ctx);
		}
	}
	public static class EmptyArgumentWithParenthesesContext extends ArgumentWithParenthesesContext {
		public TerminalNode LPAREN() { return getToken(RubyParser.LPAREN, 0); }
		public TerminalNode RPAREN() { return getToken(RubyParser.RPAREN, 0); }
		public List NL() { return getTokens(RubyParser.NL); }
		public TerminalNode NL(int i) {
			return getToken(RubyParser.NL, i);
		}
		public TerminalNode COMMA() { return getToken(RubyParser.COMMA, 0); }
		public EmptyArgumentWithParenthesesContext(ArgumentWithParenthesesContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterEmptyArgumentWithParentheses(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitEmptyArgumentWithParentheses(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitEmptyArgumentWithParentheses(this);
			else return visitor.visitChildren(this);
		}
	}
	public static class OperatorExpressionsAndChainedCommandWithBlockArgumentWithParenthesesContext extends ArgumentWithParenthesesContext {
		public TerminalNode LPAREN() { return getToken(RubyParser.LPAREN, 0); }
		public OperatorExpressionListContext operatorExpressionList() {
			return getRuleContext(OperatorExpressionListContext.class,0);
		}
		public List COMMA() { return getTokens(RubyParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(RubyParser.COMMA, i);
		}
		public ChainedCommandWithDoBlockContext chainedCommandWithDoBlock() {
			return getRuleContext(ChainedCommandWithDoBlockContext.class,0);
		}
		public TerminalNode RPAREN() { return getToken(RubyParser.RPAREN, 0); }
		public List NL() { return getTokens(RubyParser.NL); }
		public TerminalNode NL(int i) {
			return getToken(RubyParser.NL, i);
		}
		public OperatorExpressionsAndChainedCommandWithBlockArgumentWithParenthesesContext(ArgumentWithParenthesesContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterOperatorExpressionsAndChainedCommandWithBlockArgumentWithParentheses(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitOperatorExpressionsAndChainedCommandWithBlockArgumentWithParentheses(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitOperatorExpressionsAndChainedCommandWithBlockArgumentWithParentheses(this);
			else return visitor.visitChildren(this);
		}
	}
	public static class ChainedCommandWithDoBlockArgumentWithParenthesesContext extends ArgumentWithParenthesesContext {
		public TerminalNode LPAREN() { return getToken(RubyParser.LPAREN, 0); }
		public ChainedCommandWithDoBlockContext chainedCommandWithDoBlock() {
			return getRuleContext(ChainedCommandWithDoBlockContext.class,0);
		}
		public TerminalNode RPAREN() { return getToken(RubyParser.RPAREN, 0); }
		public List NL() { return getTokens(RubyParser.NL); }
		public TerminalNode NL(int i) {
			return getToken(RubyParser.NL, i);
		}
		public TerminalNode COMMA() { return getToken(RubyParser.COMMA, 0); }
		public ChainedCommandWithDoBlockArgumentWithParenthesesContext(ArgumentWithParenthesesContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterChainedCommandWithDoBlockArgumentWithParentheses(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitChainedCommandWithDoBlockArgumentWithParentheses(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitChainedCommandWithDoBlockArgumentWithParentheses(this);
			else return visitor.visitChildren(this);
		}
	}
	public static class ArgumentListArgumentWithParenthesesContext extends ArgumentWithParenthesesContext {
		public TerminalNode LPAREN() { return getToken(RubyParser.LPAREN, 0); }
		public ArgumentListContext argumentList() {
			return getRuleContext(ArgumentListContext.class,0);
		}
		public TerminalNode RPAREN() { return getToken(RubyParser.RPAREN, 0); }
		public List NL() { return getTokens(RubyParser.NL); }
		public TerminalNode NL(int i) {
			return getToken(RubyParser.NL, i);
		}
		public TerminalNode COMMA() { return getToken(RubyParser.COMMA, 0); }
		public ArgumentListArgumentWithParenthesesContext(ArgumentWithParenthesesContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterArgumentListArgumentWithParentheses(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitArgumentListArgumentWithParentheses(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitArgumentListArgumentWithParentheses(this);
			else return visitor.visitChildren(this);
		}
	}

	public final ArgumentWithParenthesesContext argumentWithParentheses() throws RecognitionException {
		ArgumentWithParenthesesContext _localctx = new ArgumentWithParenthesesContext(_ctx, getState());
		enterRule(_localctx, 56, RULE_argumentWithParentheses);
		int _la;
		try {
			int _alt;
			setState(718);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,81,_ctx) ) {
			case 1:
				_localctx = new EmptyArgumentWithParenthesesContext(_localctx);
				enterOuterAlt(_localctx, 1);
				{
				setState(636);
				match(LPAREN);
				setState(640);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,68,_ctx);
				while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) {
					if ( _alt==1 ) {
						{
						{
						setState(637);
						match(NL);
						}
						} 
					}
					setState(642);
					_errHandler.sync(this);
					_alt = getInterpreter().adaptivePredict(_input,68,_ctx);
				}
				setState(644);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==COMMA) {
					{
					setState(643);
					match(COMMA);
					}
				}

				setState(649);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==NL) {
					{
					{
					setState(646);
					match(NL);
					}
					}
					setState(651);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(652);
				match(RPAREN);
				}
				break;
			case 2:
				_localctx = new ArgumentListArgumentWithParenthesesContext(_localctx);
				enterOuterAlt(_localctx, 2);
				{
				setState(653);
				match(LPAREN);
				setState(657);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==NL) {
					{
					{
					setState(654);
					match(NL);
					}
					}
					setState(659);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(660);
				argumentList();
				setState(662);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==COMMA) {
					{
					setState(661);
					match(COMMA);
					}
				}

				setState(667);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==NL) {
					{
					{
					setState(664);
					match(NL);
					}
					}
					setState(669);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(670);
				match(RPAREN);
				}
				break;
			case 3:
				_localctx = new OperatorExpressionsAndChainedCommandWithBlockArgumentWithParenthesesContext(_localctx);
				enterOuterAlt(_localctx, 3);
				{
				setState(672);
				match(LPAREN);
				setState(676);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==NL) {
					{
					{
					setState(673);
					match(NL);
					}
					}
					setState(678);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(679);
				operatorExpressionList();
				setState(680);
				match(COMMA);
				setState(684);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==NL) {
					{
					{
					setState(681);
					match(NL);
					}
					}
					setState(686);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(687);
				chainedCommandWithDoBlock();
				setState(689);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==COMMA) {
					{
					setState(688);
					match(COMMA);
					}
				}

				setState(694);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==NL) {
					{
					{
					setState(691);
					match(NL);
					}
					}
					setState(696);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(697);
				match(RPAREN);
				}
				break;
			case 4:
				_localctx = new ChainedCommandWithDoBlockArgumentWithParenthesesContext(_localctx);
				enterOuterAlt(_localctx, 4);
				{
				setState(699);
				match(LPAREN);
				setState(703);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==NL) {
					{
					{
					setState(700);
					match(NL);
					}
					}
					setState(705);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(706);
				chainedCommandWithDoBlock();
				setState(708);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==COMMA) {
					{
					setState(707);
					match(COMMA);
					}
				}

				setState(713);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==NL) {
					{
					{
					setState(710);
					match(NL);
					}
					}
					setState(715);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(716);
				match(RPAREN);
				}
				break;
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class ArgumentListContext extends ParserRuleContext {
		public ArgumentListContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_argumentList; }
	 
		public ArgumentListContext() { }
		public void copyFrom(ArgumentListContext ctx) {
			super.copyFrom(ctx);
		}
	}
	public static class BlockArgumentArgumentListContext extends ArgumentListContext {
		public BlockArgumentContext blockArgument() {
			return getRuleContext(BlockArgumentContext.class,0);
		}
		public BlockArgumentArgumentListContext(ArgumentListContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterBlockArgumentArgumentList(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitBlockArgumentArgumentList(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitBlockArgumentArgumentList(this);
			else return visitor.visitChildren(this);
		}
	}
	public static class SplattingArgumentArgumentListContext extends ArgumentListContext {
		public SplattingArgumentContext splattingArgument() {
			return getRuleContext(SplattingArgumentContext.class,0);
		}
		public List COMMA() { return getTokens(RubyParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(RubyParser.COMMA, i);
		}
		public BlockArgumentContext blockArgument() {
			return getRuleContext(BlockArgumentContext.class,0);
		}
		public OperatorExpressionListContext operatorExpressionList() {
			return getRuleContext(OperatorExpressionListContext.class,0);
		}
		public List NL() { return getTokens(RubyParser.NL); }
		public TerminalNode NL(int i) {
			return getToken(RubyParser.NL, i);
		}
		public SplattingArgumentArgumentListContext(ArgumentListContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterSplattingArgumentArgumentList(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitSplattingArgumentArgumentList(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitSplattingArgumentArgumentList(this);
			else return visitor.visitChildren(this);
		}
	}
	public static class OperatorsArgumentListContext extends ArgumentListContext {
		public OperatorExpressionListContext operatorExpressionList() {
			return getRuleContext(OperatorExpressionListContext.class,0);
		}
		public List COMMA() { return getTokens(RubyParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(RubyParser.COMMA, i);
		}
		public AssociationListContext associationList() {
			return getRuleContext(AssociationListContext.class,0);
		}
		public SplattingArgumentContext splattingArgument() {
			return getRuleContext(SplattingArgumentContext.class,0);
		}
		public BlockArgumentContext blockArgument() {
			return getRuleContext(BlockArgumentContext.class,0);
		}
		public List NL() { return getTokens(RubyParser.NL); }
		public TerminalNode NL(int i) {
			return getToken(RubyParser.NL, i);
		}
		public OperatorsArgumentListContext(ArgumentListContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterOperatorsArgumentList(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitOperatorsArgumentList(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitOperatorsArgumentList(this);
			else return visitor.visitChildren(this);
		}
	}
	public static class SingleCommandArgumentListContext extends ArgumentListContext {
		public CommandContext command() {
			return getRuleContext(CommandContext.class,0);
		}
		public SingleCommandArgumentListContext(ArgumentListContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterSingleCommandArgumentList(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitSingleCommandArgumentList(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitSingleCommandArgumentList(this);
			else return visitor.visitChildren(this);
		}
	}
	public static class AssociationsArgumentListContext extends ArgumentListContext {
		public AssociationListContext associationList() {
			return getRuleContext(AssociationListContext.class,0);
		}
		public List COMMA() { return getTokens(RubyParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(RubyParser.COMMA, i);
		}
		public SplattingArgumentContext splattingArgument() {
			return getRuleContext(SplattingArgumentContext.class,0);
		}
		public BlockArgumentContext blockArgument() {
			return getRuleContext(BlockArgumentContext.class,0);
		}
		public List NL() { return getTokens(RubyParser.NL); }
		public TerminalNode NL(int i) {
			return getToken(RubyParser.NL, i);
		}
		public AssociationsArgumentListContext(ArgumentListContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterAssociationsArgumentList(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitAssociationsArgumentList(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitAssociationsArgumentList(this);
			else return visitor.visitChildren(this);
		}
	}

	public final ArgumentListContext argumentList() throws RecognitionException {
		ArgumentListContext _localctx = new ArgumentListContext(_ctx, getState());
		enterRule(_localctx, 58, RULE_argumentList);
		int _la;
		try {
			setState(795);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,96,_ctx) ) {
			case 1:
				_localctx = new BlockArgumentArgumentListContext(_localctx);
				enterOuterAlt(_localctx, 1);
				{
				setState(720);
				blockArgument();
				}
				break;
			case 2:
				_localctx = new SplattingArgumentArgumentListContext(_localctx);
				enterOuterAlt(_localctx, 2);
				{
				setState(721);
				splattingArgument();
				setState(730);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,83,_ctx) ) {
				case 1:
					{
					setState(722);
					match(COMMA);
					setState(726);
					_errHandler.sync(this);
					_la = _input.LA(1);
					while (_la==NL) {
						{
						{
						setState(723);
						match(NL);
						}
						}
						setState(728);
						_errHandler.sync(this);
						_la = _input.LA(1);
					}
					setState(729);
					blockArgument();
					}
					break;
				}
				setState(740);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,85,_ctx) ) {
				case 1:
					{
					setState(732);
					match(COMMA);
					setState(736);
					_errHandler.sync(this);
					_la = _input.LA(1);
					while (_la==NL) {
						{
						{
						setState(733);
						match(NL);
						}
						}
						setState(738);
						_errHandler.sync(this);
						_la = _input.LA(1);
					}
					setState(739);
					operatorExpressionList();
					}
					break;
				}
				}
				break;
			case 3:
				_localctx = new OperatorsArgumentListContext(_localctx);
				enterOuterAlt(_localctx, 3);
				{
				setState(742);
				operatorExpressionList();
				setState(751);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,87,_ctx) ) {
				case 1:
					{
					setState(743);
					match(COMMA);
					setState(747);
					_errHandler.sync(this);
					_la = _input.LA(1);
					while (_la==NL) {
						{
						{
						setState(744);
						match(NL);
						}
						}
						setState(749);
						_errHandler.sync(this);
						_la = _input.LA(1);
					}
					setState(750);
					associationList();
					}
					break;
				}
				setState(761);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,89,_ctx) ) {
				case 1:
					{
					setState(753);
					match(COMMA);
					setState(757);
					_errHandler.sync(this);
					_la = _input.LA(1);
					while (_la==NL) {
						{
						{
						setState(754);
						match(NL);
						}
						}
						setState(759);
						_errHandler.sync(this);
						_la = _input.LA(1);
					}
					setState(760);
					splattingArgument();
					}
					break;
				}
				setState(771);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,91,_ctx) ) {
				case 1:
					{
					setState(763);
					match(COMMA);
					setState(767);
					_errHandler.sync(this);
					_la = _input.LA(1);
					while (_la==NL) {
						{
						{
						setState(764);
						match(NL);
						}
						}
						setState(769);
						_errHandler.sync(this);
						_la = _input.LA(1);
					}
					setState(770);
					blockArgument();
					}
					break;
				}
				}
				break;
			case 4:
				_localctx = new AssociationsArgumentListContext(_localctx);
				enterOuterAlt(_localctx, 4);
				{
				setState(773);
				associationList();
				setState(782);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,93,_ctx) ) {
				case 1:
					{
					setState(774);
					match(COMMA);
					setState(778);
					_errHandler.sync(this);
					_la = _input.LA(1);
					while (_la==NL) {
						{
						{
						setState(775);
						match(NL);
						}
						}
						setState(780);
						_errHandler.sync(this);
						_la = _input.LA(1);
					}
					setState(781);
					splattingArgument();
					}
					break;
				}
				setState(792);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,95,_ctx) ) {
				case 1:
					{
					setState(784);
					match(COMMA);
					setState(788);
					_errHandler.sync(this);
					_la = _input.LA(1);
					while (_la==NL) {
						{
						{
						setState(785);
						match(NL);
						}
						}
						setState(790);
						_errHandler.sync(this);
						_la = _input.LA(1);
					}
					setState(791);
					blockArgument();
					}
					break;
				}
				}
				break;
			case 5:
				_localctx = new SingleCommandArgumentListContext(_localctx);
				enterOuterAlt(_localctx, 5);
				{
				setState(794);
				command();
				}
				break;
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class CommandArgumentListContext extends ParserRuleContext {
		public AssociationListContext associationList() {
			return getRuleContext(AssociationListContext.class,0);
		}
		public PrimaryValueListContext primaryValueList() {
			return getRuleContext(PrimaryValueListContext.class,0);
		}
		public TerminalNode COMMA() { return getToken(RubyParser.COMMA, 0); }
		public List NL() { return getTokens(RubyParser.NL); }
		public TerminalNode NL(int i) {
			return getToken(RubyParser.NL, i);
		}
		public CommandArgumentListContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_commandArgumentList; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterCommandArgumentList(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitCommandArgumentList(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitCommandArgumentList(this);
			else return visitor.visitChildren(this);
		}
	}

	public final CommandArgumentListContext commandArgumentList() throws RecognitionException {
		CommandArgumentListContext _localctx = new CommandArgumentListContext(_ctx, getState());
		enterRule(_localctx, 60, RULE_commandArgumentList);
		int _la;
		try {
			setState(809);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,99,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(797);
				associationList();
				}
				break;
			case 2:
				enterOuterAlt(_localctx, 2);
				{
				setState(798);
				primaryValueList();
				setState(807);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,98,_ctx) ) {
				case 1:
					{
					setState(799);
					match(COMMA);
					setState(803);
					_errHandler.sync(this);
					_la = _input.LA(1);
					while (_la==NL) {
						{
						{
						setState(800);
						match(NL);
						}
						}
						setState(805);
						_errHandler.sync(this);
						_la = _input.LA(1);
					}
					setState(806);
					associationList();
					}
					break;
				}
				}
				break;
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class PrimaryValueListContext extends ParserRuleContext {
		public List primaryValue() {
			return getRuleContexts(PrimaryValueContext.class);
		}
		public PrimaryValueContext primaryValue(int i) {
			return getRuleContext(PrimaryValueContext.class,i);
		}
		public List COMMA() { return getTokens(RubyParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(RubyParser.COMMA, i);
		}
		public List NL() { return getTokens(RubyParser.NL); }
		public TerminalNode NL(int i) {
			return getToken(RubyParser.NL, i);
		}
		public PrimaryValueListContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_primaryValueList; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterPrimaryValueList(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitPrimaryValueList(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitPrimaryValueList(this);
			else return visitor.visitChildren(this);
		}
	}

	public final PrimaryValueListContext primaryValueList() throws RecognitionException {
		PrimaryValueListContext _localctx = new PrimaryValueListContext(_ctx, getState());
		enterRule(_localctx, 62, RULE_primaryValueList);
		int _la;
		try {
			int _alt;
			enterOuterAlt(_localctx, 1);
			{
			setState(811);
			primaryValue(0);
			setState(822);
			_errHandler.sync(this);
			_alt = getInterpreter().adaptivePredict(_input,101,_ctx);
			while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) {
				if ( _alt==1 ) {
					{
					{
					setState(812);
					match(COMMA);
					setState(816);
					_errHandler.sync(this);
					_la = _input.LA(1);
					while (_la==NL) {
						{
						{
						setState(813);
						match(NL);
						}
						}
						setState(818);
						_errHandler.sync(this);
						_la = _input.LA(1);
					}
					setState(819);
					primaryValue(0);
					}
					} 
				}
				setState(824);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,101,_ctx);
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class BlockArgumentContext extends ParserRuleContext {
		public TerminalNode AMP() { return getToken(RubyParser.AMP, 0); }
		public OperatorExpressionContext operatorExpression() {
			return getRuleContext(OperatorExpressionContext.class,0);
		}
		public BlockArgumentContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_blockArgument; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterBlockArgument(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitBlockArgument(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitBlockArgument(this);
			else return visitor.visitChildren(this);
		}
	}

	public final BlockArgumentContext blockArgument() throws RecognitionException {
		BlockArgumentContext _localctx = new BlockArgumentContext(_ctx, getState());
		enterRule(_localctx, 64, RULE_blockArgument);
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(825);
			match(AMP);
			setState(826);
			operatorExpression(0);
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class ExpressionOrCommandContext extends ParserRuleContext {
		public ExpressionOrCommandContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_expressionOrCommand; }
	 
		public ExpressionOrCommandContext() { }
		public void copyFrom(ExpressionOrCommandContext ctx) {
			super.copyFrom(ctx);
		}
	}
	public static class OperatorExpressionOrCommandContext extends ExpressionOrCommandContext {
		public OperatorExpressionContext operatorExpression() {
			return getRuleContext(OperatorExpressionContext.class,0);
		}
		public OperatorExpressionOrCommandContext(ExpressionOrCommandContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterOperatorExpressionOrCommand(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitOperatorExpressionOrCommand(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitOperatorExpressionOrCommand(this);
			else return visitor.visitChildren(this);
		}
	}
	public static class NotExpressionOrCommandContext extends ExpressionOrCommandContext {
		public TerminalNode NOT() { return getToken(RubyParser.NOT, 0); }
		public ExpressionOrCommandContext expressionOrCommand() {
			return getRuleContext(ExpressionOrCommandContext.class,0);
		}
		public List NL() { return getTokens(RubyParser.NL); }
		public TerminalNode NL(int i) {
			return getToken(RubyParser.NL, i);
		}
		public NotExpressionOrCommandContext(ExpressionOrCommandContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterNotExpressionOrCommand(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitNotExpressionOrCommand(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitNotExpressionOrCommand(this);
			else return visitor.visitChildren(this);
		}
	}
	public static class KeywordAndOrExpressionOrCommandContext extends ExpressionOrCommandContext {
		public ExpressionOrCommandContext lhs;
		public Token binOp;
		public ExpressionOrCommandContext rhs;
		public List expressionOrCommand() {
			return getRuleContexts(ExpressionOrCommandContext.class);
		}
		public ExpressionOrCommandContext expressionOrCommand(int i) {
			return getRuleContext(ExpressionOrCommandContext.class,i);
		}
		public TerminalNode AND() { return getToken(RubyParser.AND, 0); }
		public TerminalNode OR() { return getToken(RubyParser.OR, 0); }
		public List NL() { return getTokens(RubyParser.NL); }
		public TerminalNode NL(int i) {
			return getToken(RubyParser.NL, i);
		}
		public KeywordAndOrExpressionOrCommandContext(ExpressionOrCommandContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterKeywordAndOrExpressionOrCommand(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitKeywordAndOrExpressionOrCommand(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitKeywordAndOrExpressionOrCommand(this);
			else return visitor.visitChildren(this);
		}
	}
	public static class CommandExpressionOrCommandContext extends ExpressionOrCommandContext {
		public MethodInvocationWithoutParenthesesContext methodInvocationWithoutParentheses() {
			return getRuleContext(MethodInvocationWithoutParenthesesContext.class,0);
		}
		public TerminalNode EMARK() { return getToken(RubyParser.EMARK, 0); }
		public CommandExpressionOrCommandContext(ExpressionOrCommandContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterCommandExpressionOrCommand(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitCommandExpressionOrCommand(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitCommandExpressionOrCommand(this);
			else return visitor.visitChildren(this);
		}
	}

	public final ExpressionOrCommandContext expressionOrCommand() throws RecognitionException {
		return expressionOrCommand(0);
	}

	private ExpressionOrCommandContext expressionOrCommand(int _p) throws RecognitionException {
		ParserRuleContext _parentctx = _ctx;
		int _parentState = getState();
		ExpressionOrCommandContext _localctx = new ExpressionOrCommandContext(_ctx, _parentState);
		ExpressionOrCommandContext _prevctx = _localctx;
		int _startState = 66;
		enterRecursionRule(_localctx, 66, RULE_expressionOrCommand, _p);
		int _la;
		try {
			int _alt;
			enterOuterAlt(_localctx, 1);
			{
			setState(842);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,104,_ctx) ) {
			case 1:
				{
				_localctx = new OperatorExpressionOrCommandContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;

				setState(829);
				operatorExpression(0);
				}
				break;
			case 2:
				{
				_localctx = new CommandExpressionOrCommandContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(831);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,102,_ctx) ) {
				case 1:
					{
					setState(830);
					match(EMARK);
					}
					break;
				}
				setState(833);
				methodInvocationWithoutParentheses();
				}
				break;
			case 3:
				{
				_localctx = new NotExpressionOrCommandContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(834);
				match(NOT);
				setState(838);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==NL) {
					{
					{
					setState(835);
					match(NL);
					}
					}
					setState(840);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(841);
				expressionOrCommand(2);
				}
				break;
			}
			_ctx.stop = _input.LT(-1);
			setState(855);
			_errHandler.sync(this);
			_alt = getInterpreter().adaptivePredict(_input,106,_ctx);
			while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) {
				if ( _alt==1 ) {
					if ( _parseListeners!=null ) triggerExitRuleEvent();
					_prevctx = _localctx;
					{
					{
					_localctx = new KeywordAndOrExpressionOrCommandContext(new ExpressionOrCommandContext(_parentctx, _parentState));
					((KeywordAndOrExpressionOrCommandContext)_localctx).lhs = _prevctx;
					pushNewRecursionContext(_localctx, _startState, RULE_expressionOrCommand);
					setState(844);
					if (!(precpred(_ctx, 1))) throw new FailedPredicateException(this, "precpred(_ctx, 1)");
					setState(845);
					((KeywordAndOrExpressionOrCommandContext)_localctx).binOp = _input.LT(1);
					_la = _input.LA(1);
					if ( !(_la==AND || _la==OR) ) {
						((KeywordAndOrExpressionOrCommandContext)_localctx).binOp = (Token)_errHandler.recoverInline(this);
					}
					else {
						if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
						_errHandler.reportMatch(this);
						consume();
					}
					setState(849);
					_errHandler.sync(this);
					_la = _input.LA(1);
					while (_la==NL) {
						{
						{
						setState(846);
						match(NL);
						}
						}
						setState(851);
						_errHandler.sync(this);
						_la = _input.LA(1);
					}
					setState(852);
					((KeywordAndOrExpressionOrCommandContext)_localctx).rhs = expressionOrCommand(2);
					}
					} 
				}
				setState(857);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,106,_ctx);
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			unrollRecursionContexts(_parentctx);
		}
		return _localctx;
	}

	public static class OperatorExpressionContext extends ParserRuleContext {
		public OperatorExpressionContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_operatorExpression; }
	 
		public OperatorExpressionContext() { }
		public void copyFrom(OperatorExpressionContext ctx) {
			super.copyFrom(ctx);
		}
	}
	public static class TernaryOperatorExpressionContext extends OperatorExpressionContext {
		public List operatorExpression() {
			return getRuleContexts(OperatorExpressionContext.class);
		}
		public OperatorExpressionContext operatorExpression(int i) {
			return getRuleContext(OperatorExpressionContext.class,i);
		}
		public TerminalNode QMARK() { return getToken(RubyParser.QMARK, 0); }
		public TerminalNode COLON() { return getToken(RubyParser.COLON, 0); }
		public List NL() { return getTokens(RubyParser.NL); }
		public TerminalNode NL(int i) {
			return getToken(RubyParser.NL, i);
		}
		public TernaryOperatorExpressionContext(OperatorExpressionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterTernaryOperatorExpression(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitTernaryOperatorExpression(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitTernaryOperatorExpression(this);
			else return visitor.visitChildren(this);
		}
	}
	public static class PrimaryOperatorExpressionContext extends OperatorExpressionContext {
		public PrimaryContext primary() {
			return getRuleContext(PrimaryContext.class,0);
		}
		public PrimaryOperatorExpressionContext(OperatorExpressionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterPrimaryOperatorExpression(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitPrimaryOperatorExpression(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitPrimaryOperatorExpression(this);
			else return visitor.visitChildren(this);
		}
	}

	public final OperatorExpressionContext operatorExpression() throws RecognitionException {
		return operatorExpression(0);
	}

	private OperatorExpressionContext operatorExpression(int _p) throws RecognitionException {
		ParserRuleContext _parentctx = _ctx;
		int _parentState = getState();
		OperatorExpressionContext _localctx = new OperatorExpressionContext(_ctx, _parentState);
		OperatorExpressionContext _prevctx = _localctx;
		int _startState = 68;
		enterRecursionRule(_localctx, 68, RULE_operatorExpression, _p);
		int _la;
		try {
			int _alt;
			enterOuterAlt(_localctx, 1);
			{
			{
			_localctx = new PrimaryOperatorExpressionContext(_localctx);
			_ctx = _localctx;
			_prevctx = _localctx;

			setState(859);
			primary();
			}
			_ctx.stop = _input.LT(-1);
			setState(887);
			_errHandler.sync(this);
			_alt = getInterpreter().adaptivePredict(_input,110,_ctx);
			while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) {
				if ( _alt==1 ) {
					if ( _parseListeners!=null ) triggerExitRuleEvent();
					_prevctx = _localctx;
					{
					{
					_localctx = new TernaryOperatorExpressionContext(new OperatorExpressionContext(_parentctx, _parentState));
					pushNewRecursionContext(_localctx, _startState, RULE_operatorExpression);
					setState(861);
					if (!(precpred(_ctx, 1))) throw new FailedPredicateException(this, "precpred(_ctx, 1)");
					setState(862);
					match(QMARK);
					setState(866);
					_errHandler.sync(this);
					_la = _input.LA(1);
					while (_la==NL) {
						{
						{
						setState(863);
						match(NL);
						}
						}
						setState(868);
						_errHandler.sync(this);
						_la = _input.LA(1);
					}
					setState(869);
					operatorExpression(0);
					setState(873);
					_errHandler.sync(this);
					_la = _input.LA(1);
					while (_la==NL) {
						{
						{
						setState(870);
						match(NL);
						}
						}
						setState(875);
						_errHandler.sync(this);
						_la = _input.LA(1);
					}
					setState(876);
					match(COLON);
					setState(880);
					_errHandler.sync(this);
					_la = _input.LA(1);
					while (_la==NL) {
						{
						{
						setState(877);
						match(NL);
						}
						}
						setState(882);
						_errHandler.sync(this);
						_la = _input.LA(1);
					}
					setState(883);
					operatorExpression(2);
					}
					} 
				}
				setState(889);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,110,_ctx);
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			unrollRecursionContexts(_parentctx);
		}
		return _localctx;
	}

	public static class PrimaryContext extends ParserRuleContext {
		public PrimaryContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_primary; }
	 
		public PrimaryContext() { }
		public void copyFrom(PrimaryContext ctx) {
			super.copyFrom(ctx);
		}
	}
	public static class PrimaryValuePrimaryContext extends PrimaryContext {
		public PrimaryValueContext primaryValue() {
			return getRuleContext(PrimaryValueContext.class,0);
		}
		public PrimaryValuePrimaryContext(PrimaryContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterPrimaryValuePrimary(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitPrimaryValuePrimary(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitPrimaryValuePrimary(this);
			else return visitor.visitChildren(this);
		}
	}
	public static class ReturnWithoutArgumentsContext extends PrimaryContext {
		public TerminalNode RETURN() { return getToken(RubyParser.RETURN, 0); }
		public ReturnWithoutArgumentsContext(PrimaryContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterReturnWithoutArguments(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitReturnWithoutArguments(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitReturnWithoutArguments(this);
			else return visitor.visitChildren(this);
		}
	}
	public static class BreakWithoutArgumentsContext extends PrimaryContext {
		public TerminalNode BREAK() { return getToken(RubyParser.BREAK, 0); }
		public BreakWithoutArgumentsContext(PrimaryContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterBreakWithoutArguments(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitBreakWithoutArguments(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitBreakWithoutArguments(this);
			else return visitor.visitChildren(this);
		}
	}
	public static class RedoWithoutArgumentsContext extends PrimaryContext {
		public TerminalNode REDO() { return getToken(RubyParser.REDO, 0); }
		public RedoWithoutArgumentsContext(PrimaryContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterRedoWithoutArguments(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitRedoWithoutArguments(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitRedoWithoutArguments(this);
			else return visitor.visitChildren(this);
		}
	}
	public static class NextWithoutArgumentsContext extends PrimaryContext {
		public TerminalNode NEXT() { return getToken(RubyParser.NEXT, 0); }
		public NextWithoutArgumentsContext(PrimaryContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterNextWithoutArguments(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitNextWithoutArguments(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitNextWithoutArguments(this);
			else return visitor.visitChildren(this);
		}
	}
	public static class RetryWithoutArgumentsContext extends PrimaryContext {
		public TerminalNode RETRY() { return getToken(RubyParser.RETRY, 0); }
		public RetryWithoutArgumentsContext(PrimaryContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterRetryWithoutArguments(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitRetryWithoutArguments(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitRetryWithoutArguments(this);
			else return visitor.visitChildren(this);
		}
	}

	public final PrimaryContext primary() throws RecognitionException {
		PrimaryContext _localctx = new PrimaryContext(_ctx, getState());
		enterRule(_localctx, 70, RULE_primary);
		try {
			setState(896);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case RETURN:
				_localctx = new ReturnWithoutArgumentsContext(_localctx);
				enterOuterAlt(_localctx, 1);
				{
				setState(890);
				match(RETURN);
				}
				break;
			case BREAK:
				_localctx = new BreakWithoutArgumentsContext(_localctx);
				enterOuterAlt(_localctx, 2);
				{
				setState(891);
				match(BREAK);
				}
				break;
			case NEXT:
				_localctx = new NextWithoutArgumentsContext(_localctx);
				enterOuterAlt(_localctx, 3);
				{
				setState(892);
				match(NEXT);
				}
				break;
			case REDO:
				_localctx = new RedoWithoutArgumentsContext(_localctx);
				enterOuterAlt(_localctx, 4);
				{
				setState(893);
				match(REDO);
				}
				break;
			case RETRY:
				_localctx = new RetryWithoutArgumentsContext(_localctx);
				enterOuterAlt(_localctx, 5);
				{
				setState(894);
				match(RETRY);
				}
				break;
			case REGULAR_EXPRESSION_START:
			case LINE__:
			case ENCODING__:
			case FILE__:
			case BEGIN:
			case CASE:
			case CLASS:
			case DEF:
			case IS_DEFINED:
			case FOR:
			case FALSE:
			case IF:
			case MODULE:
			case NIL:
			case SELF:
			case SUPER:
			case TRUE:
			case UNLESS:
			case UNTIL:
			case WHILE:
			case YIELD:
			case LBRACK:
			case LPAREN:
			case LCURLY:
			case COLON:
			case COLON2:
			case MINUSGT:
			case EMARK:
			case PLUS:
			case MINUS:
			case TILDE:
			case SINGLE_QUOTED_STRING_LITERAL:
			case DOUBLE_QUOTED_STRING_START:
			case QUOTED_NON_EXPANDED_STRING_LITERAL_START:
			case QUOTED_EXPANDED_STRING_LITERAL_START:
			case QUOTED_EXPANDED_REGULAR_EXPRESSION_START:
			case QUOTED_EXPANDED_EXTERNAL_COMMAND_LITERAL_START:
			case QUOTED_NON_EXPANDED_STRING_ARRAY_LITERAL_START:
			case QUOTED_EXPANDED_STRING_ARRAY_LITERAL_START:
			case HERE_DOC:
			case QUOTED_NON_EXPANDED_SYMBOL_ARRAY_LITERAL_START:
			case QUOTED_EXPANDED_SYMBOL_ARRAY_LITERAL_START:
			case DECIMAL_INTEGER_LITERAL:
			case BINARY_INTEGER_LITERAL:
			case OCTAL_INTEGER_LITERAL:
			case HEXADECIMAL_INTEGER_LITERAL:
			case FLOAT_LITERAL_WITHOUT_EXPONENT:
			case FLOAT_LITERAL_WITH_EXPONENT:
			case SYMBOL_LITERAL:
			case LOCAL_VARIABLE_IDENTIFIER:
			case GLOBAL_VARIABLE_IDENTIFIER:
			case INSTANCE_VARIABLE_IDENTIFIER:
			case CLASS_VARIABLE_IDENTIFIER:
			case CONSTANT_IDENTIFIER:
				_localctx = new PrimaryValuePrimaryContext(_localctx);
				enterOuterAlt(_localctx, 6);
				{
				setState(895);
				primaryValue(0);
				}
				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 PrimaryValueContext extends ParserRuleContext {
		public PrimaryValueContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_primaryValue; }
	 
		public PrimaryValueContext() { }
		public void copyFrom(PrimaryValueContext ctx) {
			super.copyFrom(ctx);
		}
	}
	public static class MethodDefinitionContext extends PrimaryValueContext {
		public TerminalNode DEF() { return getToken(RubyParser.DEF, 0); }
		public DefinedMethodNameContext definedMethodName() {
			return getRuleContext(DefinedMethodNameContext.class,0);
		}
		public MethodParameterPartContext methodParameterPart() {
			return getRuleContext(MethodParameterPartContext.class,0);
		}
		public BodyStatementContext bodyStatement() {
			return getRuleContext(BodyStatementContext.class,0);
		}
		public TerminalNode END() { return getToken(RubyParser.END, 0); }
		public MethodDefinitionContext(PrimaryValueContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterMethodDefinition(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitMethodDefinition(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitMethodDefinition(this);
			else return visitor.visitChildren(this);
		}
	}
	public static class BeginEndExpressionContext extends PrimaryValueContext {
		public TerminalNode BEGIN() { return getToken(RubyParser.BEGIN, 0); }
		public BodyStatementContext bodyStatement() {
			return getRuleContext(BodyStatementContext.class,0);
		}
		public TerminalNode END() { return getToken(RubyParser.END, 0); }
		public BeginEndExpressionContext(PrimaryValueContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterBeginEndExpression(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitBeginEndExpression(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitBeginEndExpression(this);
			else return visitor.visitChildren(this);
		}
	}
	public static class IndexingAccessExpressionContext extends PrimaryValueContext {
		public PrimaryValueContext primaryValue() {
			return getRuleContext(PrimaryValueContext.class,0);
		}
		public TerminalNode LBRACK() { return getToken(RubyParser.LBRACK, 0); }
		public TerminalNode RBRACK() { return getToken(RubyParser.RBRACK, 0); }
		public IndexingArgumentListContext indexingArgumentList() {
			return getRuleContext(IndexingArgumentListContext.class,0);
		}
		public IndexingAccessExpressionContext(PrimaryValueContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterIndexingAccessExpression(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitIndexingAccessExpression(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitIndexingAccessExpression(this);
			else return visitor.visitChildren(this);
		}
	}
	public static class ConstantAssignmentExpressionContext extends PrimaryValueContext {
		public TerminalNode COLON2() { return getToken(RubyParser.COLON2, 0); }
		public TerminalNode CONSTANT_IDENTIFIER() { return getToken(RubyParser.CONSTANT_IDENTIFIER, 0); }
		public AssignmentOperatorContext assignmentOperator() {
			return getRuleContext(AssignmentOperatorContext.class,0);
		}
		public OperatorExpressionContext operatorExpression() {
			return getRuleContext(OperatorExpressionContext.class,0);
		}
		public List NL() { return getTokens(RubyParser.NL); }
		public TerminalNode NL(int i) {
			return getToken(RubyParser.NL, i);
		}
		public ConstantAssignmentExpressionContext(PrimaryValueContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterConstantAssignmentExpression(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitConstantAssignmentExpression(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitConstantAssignmentExpression(this);
			else return visitor.visitChildren(this);
		}
	}
	public static class UntilExpressionContext extends PrimaryValueContext {
		public TerminalNode UNTIL() { return getToken(RubyParser.UNTIL, 0); }
		public ExpressionOrCommandContext expressionOrCommand() {
			return getRuleContext(ExpressionOrCommandContext.class,0);
		}
		public DoClauseContext doClause() {
			return getRuleContext(DoClauseContext.class,0);
		}
		public TerminalNode END() { return getToken(RubyParser.END, 0); }
		public List NL() { return getTokens(RubyParser.NL); }
		public TerminalNode NL(int i) {
			return getToken(RubyParser.NL, i);
		}
		public UntilExpressionContext(PrimaryValueContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterUntilExpression(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitUntilExpression(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitUntilExpression(this);
			else return visitor.visitChildren(this);
		}
	}
	public static class ModuleDefinitionContext extends PrimaryValueContext {
		public TerminalNode MODULE() { return getToken(RubyParser.MODULE, 0); }
		public ClassPathContext classPath() {
			return getRuleContext(ClassPathContext.class,0);
		}
		public BodyStatementContext bodyStatement() {
			return getRuleContext(BodyStatementContext.class,0);
		}
		public TerminalNode END() { return getToken(RubyParser.END, 0); }
		public ModuleDefinitionContext(PrimaryValueContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterModuleDefinition(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitModuleDefinition(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitModuleDefinition(this);
			else return visitor.visitChildren(this);
		}
	}
	public static class SingletonMethodDefinitionContext extends PrimaryValueContext {
		public Token op;
		public TerminalNode DEF() { return getToken(RubyParser.DEF, 0); }
		public SingletonObjectContext singletonObject() {
			return getRuleContext(SingletonObjectContext.class,0);
		}
		public DefinedMethodNameContext definedMethodName() {
			return getRuleContext(DefinedMethodNameContext.class,0);
		}
		public MethodParameterPartContext methodParameterPart() {
			return getRuleContext(MethodParameterPartContext.class,0);
		}
		public BodyStatementContext bodyStatement() {
			return getRuleContext(BodyStatementContext.class,0);
		}
		public TerminalNode END() { return getToken(RubyParser.END, 0); }
		public TerminalNode DOT() { return getToken(RubyParser.DOT, 0); }
		public TerminalNode COLON2() { return getToken(RubyParser.COLON2, 0); }
		public SingletonMethodDefinitionContext(PrimaryValueContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterSingletonMethodDefinition(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitSingletonMethodDefinition(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitSingletonMethodDefinition(this);
			else return visitor.visitChildren(this);
		}
	}
	public static class BitwiseAndExpressionContext extends PrimaryValueContext {
		public Token bitwiseAndOperator;
		public List primaryValue() {
			return getRuleContexts(PrimaryValueContext.class);
		}
		public PrimaryValueContext primaryValue(int i) {
			return getRuleContext(PrimaryValueContext.class,i);
		}
		public TerminalNode AMP() { return getToken(RubyParser.AMP, 0); }
		public List NL() { return getTokens(RubyParser.NL); }
		public TerminalNode NL(int i) {
			return getToken(RubyParser.NL, i);
		}
		public BitwiseAndExpressionContext(PrimaryValueContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterBitwiseAndExpression(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitBitwiseAndExpression(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitBitwiseAndExpression(this);
			else return visitor.visitChildren(this);
		}
	}
	public static class LogicalAndExpressionContext extends PrimaryValueContext {
		public Token andOperator;
		public List primaryValue() {
			return getRuleContexts(PrimaryValueContext.class);
		}
		public PrimaryValueContext primaryValue(int i) {
			return getRuleContext(PrimaryValueContext.class,i);
		}
		public TerminalNode AMP2() { return getToken(RubyParser.AMP2, 0); }
		public List NL() { return getTokens(RubyParser.NL); }
		public TerminalNode NL(int i) {
			return getToken(RubyParser.NL, i);
		}
		public LogicalAndExpressionContext(PrimaryValueContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterLogicalAndExpression(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitLogicalAndExpression(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitLogicalAndExpression(this);
			else return visitor.visitChildren(this);
		}
	}
	public static class MemberAccessExpressionContext extends PrimaryValueContext {
		public Token op;
		public PrimaryValueContext primaryValue() {
			return getRuleContext(PrimaryValueContext.class,0);
		}
		public MethodNameContext methodName() {
			return getRuleContext(MethodNameContext.class,0);
		}
		public TerminalNode AMPDOT() { return getToken(RubyParser.AMPDOT, 0); }
		public TerminalNode DOT() { return getToken(RubyParser.DOT, 0); }
		public TerminalNode COLON2() { return getToken(RubyParser.COLON2, 0); }
		public List NL() { return getTokens(RubyParser.NL); }
		public TerminalNode NL(int i) {
			return getToken(RubyParser.NL, i);
		}
		public ArgumentWithParenthesesContext argumentWithParentheses() {
			return getRuleContext(ArgumentWithParenthesesContext.class,0);
		}
		public BlockContext block() {
			return getRuleContext(BlockContext.class,0);
		}
		public MemberAccessExpressionContext(PrimaryValueContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterMemberAccessExpression(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitMemberAccessExpression(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitMemberAccessExpression(this);
			else return visitor.visitChildren(this);
		}
	}
	public static class UnaryExpressionContext extends PrimaryValueContext {
		public UnaryOperatorContext unaryOperator() {
			return getRuleContext(UnaryOperatorContext.class,0);
		}
		public PrimaryValueContext primaryValue() {
			return getRuleContext(PrimaryValueContext.class,0);
		}
		public UnaryExpressionContext(PrimaryValueContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterUnaryExpression(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitUnaryExpression(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitUnaryExpression(this);
			else return visitor.visitChildren(this);
		}
	}
	public static class NumericLiteralContext extends PrimaryValueContext {
		public Token sign;
		public UnsignedNumericLiteralContext unsignedNumericLiteral() {
			return getRuleContext(UnsignedNumericLiteralContext.class,0);
		}
		public TerminalNode PLUS() { return getToken(RubyParser.PLUS, 0); }
		public TerminalNode MINUS() { return getToken(RubyParser.MINUS, 0); }
		public NumericLiteralContext(PrimaryValueContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterNumericLiteral(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitNumericLiteral(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitNumericLiteral(this);
			else return visitor.visitChildren(this);
		}
	}
	public static class ClassDefinitionContext extends PrimaryValueContext {
		public TerminalNode CLASS() { return getToken(RubyParser.CLASS, 0); }
		public ClassPathContext classPath() {
			return getRuleContext(ClassPathContext.class,0);
		}
		public BodyStatementContext bodyStatement() {
			return getRuleContext(BodyStatementContext.class,0);
		}
		public TerminalNode END() { return getToken(RubyParser.END, 0); }
		public TerminalNode LT() { return getToken(RubyParser.LT, 0); }
		public CommandOrPrimaryValueClassContext commandOrPrimaryValueClass() {
			return getRuleContext(CommandOrPrimaryValueClassContext.class,0);
		}
		public TerminalNode SEMI() { return getToken(RubyParser.SEMI, 0); }
		public TerminalNode NL() { return getToken(RubyParser.NL, 0); }
		public ClassDefinitionContext(PrimaryValueContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterClassDefinition(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitClassDefinition(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitClassDefinition(this);
			else return visitor.visitChildren(this);
		}
	}
	public static class QuotedExpandedSymbolArrayLiteralContext extends PrimaryValueContext {
		public TerminalNode QUOTED_EXPANDED_SYMBOL_ARRAY_LITERAL_START() { return getToken(RubyParser.QUOTED_EXPANDED_SYMBOL_ARRAY_LITERAL_START, 0); }
		public TerminalNode QUOTED_EXPANDED_SYMBOL_ARRAY_LITERAL_END() { return getToken(RubyParser.QUOTED_EXPANDED_SYMBOL_ARRAY_LITERAL_END, 0); }
		public QuotedExpandedArrayElementListContext quotedExpandedArrayElementList() {
			return getRuleContext(QuotedExpandedArrayElementListContext.class,0);
		}
		public QuotedExpandedSymbolArrayLiteralContext(PrimaryValueContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterQuotedExpandedSymbolArrayLiteral(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitQuotedExpandedSymbolArrayLiteral(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitQuotedExpandedSymbolArrayLiteral(this);
			else return visitor.visitChildren(this);
		}
	}
	public static class ForExpressionContext extends PrimaryValueContext {
		public TerminalNode FOR() { return getToken(RubyParser.FOR, 0); }
		public ForVariableContext forVariable() {
			return getRuleContext(ForVariableContext.class,0);
		}
		public TerminalNode IN() { return getToken(RubyParser.IN, 0); }
		public CommandOrPrimaryValueContext commandOrPrimaryValue() {
			return getRuleContext(CommandOrPrimaryValueContext.class,0);
		}
		public DoClauseContext doClause() {
			return getRuleContext(DoClauseContext.class,0);
		}
		public TerminalNode END() { return getToken(RubyParser.END, 0); }
		public List NL() { return getTokens(RubyParser.NL); }
		public TerminalNode NL(int i) {
			return getToken(RubyParser.NL, i);
		}
		public ForExpressionContext(PrimaryValueContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterForExpression(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitForExpression(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitForExpression(this);
			else return visitor.visitChildren(this);
		}
	}
	public static class BracketedArrayLiteralContext extends PrimaryValueContext {
		public TerminalNode LBRACK() { return getToken(RubyParser.LBRACK, 0); }
		public TerminalNode RBRACK() { return getToken(RubyParser.RBRACK, 0); }
		public List NL() { return getTokens(RubyParser.NL); }
		public TerminalNode NL(int i) {
			return getToken(RubyParser.NL, i);
		}
		public IndexingArgumentListContext indexingArgumentList() {
			return getRuleContext(IndexingArgumentListContext.class,0);
		}
		public BracketedArrayLiteralContext(PrimaryValueContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterBracketedArrayLiteral(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitBracketedArrayLiteral(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitBracketedArrayLiteral(this);
			else return visitor.visitChildren(this);
		}
	}
	public static class LambdaExpressionContext extends PrimaryValueContext {
		public TerminalNode MINUSGT() { return getToken(RubyParser.MINUSGT, 0); }
		public BlockContext block() {
			return getRuleContext(BlockContext.class,0);
		}
		public TerminalNode LPAREN() { return getToken(RubyParser.LPAREN, 0); }
		public TerminalNode RPAREN() { return getToken(RubyParser.RPAREN, 0); }
		public ParameterListContext parameterList() {
			return getRuleContext(ParameterListContext.class,0);
		}
		public LambdaExpressionContext(PrimaryValueContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterLambdaExpression(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitLambdaExpression(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitLambdaExpression(this);
			else return visitor.visitChildren(this);
		}
	}
	public static class CaseWithoutExpressionContext extends PrimaryValueContext {
		public TerminalNode CASE() { return getToken(RubyParser.CASE, 0); }
		public TerminalNode END() { return getToken(RubyParser.END, 0); }
		public List whenClause() {
			return getRuleContexts(WhenClauseContext.class);
		}
		public WhenClauseContext whenClause(int i) {
			return getRuleContext(WhenClauseContext.class,i);
		}
		public ElseClauseContext elseClause() {
			return getRuleContext(ElseClauseContext.class,0);
		}
		public List SEMI() { return getTokens(RubyParser.SEMI); }
		public TerminalNode SEMI(int i) {
			return getToken(RubyParser.SEMI, i);
		}
		public List NL() { return getTokens(RubyParser.NL); }
		public TerminalNode NL(int i) {
			return getToken(RubyParser.NL, i);
		}
		public CaseWithoutExpressionContext(PrimaryValueContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterCaseWithoutExpression(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitCaseWithoutExpression(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitCaseWithoutExpression(this);
			else return visitor.visitChildren(this);
		}
	}
	public static class QuotedNonExpandedStringLiteralContext extends PrimaryValueContext {
		public TerminalNode QUOTED_NON_EXPANDED_STRING_LITERAL_START() { return getToken(RubyParser.QUOTED_NON_EXPANDED_STRING_LITERAL_START, 0); }
		public TerminalNode QUOTED_NON_EXPANDED_STRING_LITERAL_END() { return getToken(RubyParser.QUOTED_NON_EXPANDED_STRING_LITERAL_END, 0); }
		public TerminalNode NON_EXPANDED_LITERAL_CHARACTER_SEQUENCE() { return getToken(RubyParser.NON_EXPANDED_LITERAL_CHARACTER_SEQUENCE, 0); }
		public QuotedNonExpandedStringLiteralContext(PrimaryValueContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterQuotedNonExpandedStringLiteral(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitQuotedNonExpandedStringLiteral(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitQuotedNonExpandedStringLiteral(this);
			else return visitor.visitChildren(this);
		}
	}
	public static class ShiftExpressionContext extends PrimaryValueContext {
		public List primaryValue() {
			return getRuleContexts(PrimaryValueContext.class);
		}
		public PrimaryValueContext primaryValue(int i) {
			return getRuleContext(PrimaryValueContext.class,i);
		}
		public BitwiseShiftOperatorContext bitwiseShiftOperator() {
			return getRuleContext(BitwiseShiftOperatorContext.class,0);
		}
		public List NL() { return getTokens(RubyParser.NL); }
		public TerminalNode NL(int i) {
			return getToken(RubyParser.NL, i);
		}
		public ShiftExpressionContext(PrimaryValueContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterShiftExpression(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitShiftExpression(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitShiftExpression(this);
			else return visitor.visitChildren(this);
		}
	}
	public static class EndlessMethodDefinitionContext extends PrimaryValueContext {
		public TerminalNode DEF() { return getToken(RubyParser.DEF, 0); }
		public DefinedMethodNameContext definedMethodName() {
			return getRuleContext(DefinedMethodNameContext.class,0);
		}
		public TerminalNode EQ() { return getToken(RubyParser.EQ, 0); }
		public StatementContext statement() {
			return getRuleContext(StatementContext.class,0);
		}
		public TerminalNode LPAREN() { return getToken(RubyParser.LPAREN, 0); }
		public TerminalNode RPAREN() { return getToken(RubyParser.RPAREN, 0); }
		public List NL() { return getTokens(RubyParser.NL); }
		public TerminalNode NL(int i) {
			return getToken(RubyParser.NL, i);
		}
		public ParameterListContext parameterList() {
			return getRuleContext(ParameterListContext.class,0);
		}
		public EndlessMethodDefinitionContext(PrimaryValueContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterEndlessMethodDefinition(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitEndlessMethodDefinition(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitEndlessMethodDefinition(this);
			else return visitor.visitChildren(this);
		}
	}
	public static class QuotedExpandedExternalCommandLiteralContext extends PrimaryValueContext {
		public TerminalNode QUOTED_EXPANDED_EXTERNAL_COMMAND_LITERAL_START() { return getToken(RubyParser.QUOTED_EXPANDED_EXTERNAL_COMMAND_LITERAL_START, 0); }
		public TerminalNode QUOTED_EXPANDED_EXTERNAL_COMMAND_LITERAL_END() { return getToken(RubyParser.QUOTED_EXPANDED_EXTERNAL_COMMAND_LITERAL_END, 0); }
		public List quotedExpandedLiteralStringContent() {
			return getRuleContexts(QuotedExpandedLiteralStringContentContext.class);
		}
		public QuotedExpandedLiteralStringContentContext quotedExpandedLiteralStringContent(int i) {
			return getRuleContext(QuotedExpandedLiteralStringContentContext.class,i);
		}
		public QuotedExpandedExternalCommandLiteralContext(PrimaryValueContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterQuotedExpandedExternalCommandLiteral(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitQuotedExpandedExternalCommandLiteral(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitQuotedExpandedExternalCommandLiteral(this);
			else return visitor.visitChildren(this);
		}
	}
	public static class RegularExpressionLiteralContext extends PrimaryValueContext {
		public TerminalNode REGULAR_EXPRESSION_START() { return getToken(RubyParser.REGULAR_EXPRESSION_START, 0); }
		public TerminalNode REGULAR_EXPRESSION_END() { return getToken(RubyParser.REGULAR_EXPRESSION_END, 0); }
		public List regexpLiteralContent() {
			return getRuleContexts(RegexpLiteralContentContext.class);
		}
		public RegexpLiteralContentContext regexpLiteralContent(int i) {
			return getRuleContext(RegexpLiteralContentContext.class,i);
		}
		public RegularExpressionLiteralContext(PrimaryValueContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterRegularExpressionLiteral(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitRegularExpressionLiteral(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitRegularExpressionLiteral(this);
			else return visitor.visitChildren(this);
		}
	}
	public static class PowerExpressionContext extends PrimaryValueContext {
		public Token powerOperator;
		public List primaryValue() {
			return getRuleContexts(PrimaryValueContext.class);
		}
		public PrimaryValueContext primaryValue(int i) {
			return getRuleContext(PrimaryValueContext.class,i);
		}
		public TerminalNode STAR2() { return getToken(RubyParser.STAR2, 0); }
		public List NL() { return getTokens(RubyParser.NL); }
		public TerminalNode NL(int i) {
			return getToken(RubyParser.NL, i);
		}
		public PowerExpressionContext(PrimaryValueContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterPowerExpression(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitPowerExpression(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitPowerExpression(this);
			else return visitor.visitChildren(this);
		}
	}
	public static class QuotedNonExpandedSymbolArrayLiteralContext extends PrimaryValueContext {
		public TerminalNode QUOTED_NON_EXPANDED_SYMBOL_ARRAY_LITERAL_START() { return getToken(RubyParser.QUOTED_NON_EXPANDED_SYMBOL_ARRAY_LITERAL_START, 0); }
		public TerminalNode QUOTED_NON_EXPANDED_SYMBOL_ARRAY_LITERAL_END() { return getToken(RubyParser.QUOTED_NON_EXPANDED_SYMBOL_ARRAY_LITERAL_END, 0); }
		public QuotedNonExpandedArrayElementListContext quotedNonExpandedArrayElementList() {
			return getRuleContext(QuotedNonExpandedArrayElementListContext.class,0);
		}
		public QuotedNonExpandedSymbolArrayLiteralContext(PrimaryValueContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterQuotedNonExpandedSymbolArrayLiteral(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitQuotedNonExpandedSymbolArrayLiteral(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitQuotedNonExpandedSymbolArrayLiteral(this);
			else return visitor.visitChildren(this);
		}
	}
	public static class BitwiseOrExpressionContext extends PrimaryValueContext {
		public List primaryValue() {
			return getRuleContexts(PrimaryValueContext.class);
		}
		public PrimaryValueContext primaryValue(int i) {
			return getRuleContext(PrimaryValueContext.class,i);
		}
		public BitwiseOrOperatorContext bitwiseOrOperator() {
			return getRuleContext(BitwiseOrOperatorContext.class,0);
		}
		public List NL() { return getTokens(RubyParser.NL); }
		public TerminalNode NL(int i) {
			return getToken(RubyParser.NL, i);
		}
		public BitwiseOrExpressionContext(PrimaryValueContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterBitwiseOrExpression(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitBitwiseOrExpression(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitBitwiseOrExpression(this);
			else return visitor.visitChildren(this);
		}
	}
	public static class QuotedExpandedStringLiteralContext extends PrimaryValueContext {
		public TerminalNode QUOTED_EXPANDED_STRING_LITERAL_START() { return getToken(RubyParser.QUOTED_EXPANDED_STRING_LITERAL_START, 0); }
		public TerminalNode QUOTED_EXPANDED_STRING_LITERAL_END() { return getToken(RubyParser.QUOTED_EXPANDED_STRING_LITERAL_END, 0); }
		public List quotedExpandedLiteralStringContent() {
			return getRuleContexts(QuotedExpandedLiteralStringContentContext.class);
		}
		public QuotedExpandedLiteralStringContentContext quotedExpandedLiteralStringContent(int i) {
			return getRuleContext(QuotedExpandedLiteralStringContentContext.class,i);
		}
		public QuotedExpandedStringLiteralContext(PrimaryValueContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterQuotedExpandedStringLiteral(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitQuotedExpandedStringLiteral(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitQuotedExpandedStringLiteral(this);
			else return visitor.visitChildren(this);
		}
	}
	public static class AttributeAssignmentExpressionContext extends PrimaryValueContext {
		public Token op;
		public PrimaryValueContext primaryValue() {
			return getRuleContext(PrimaryValueContext.class,0);
		}
		public MethodNameContext methodName() {
			return getRuleContext(MethodNameContext.class,0);
		}
		public AssignmentOperatorContext assignmentOperator() {
			return getRuleContext(AssignmentOperatorContext.class,0);
		}
		public OperatorExpressionContext operatorExpression() {
			return getRuleContext(OperatorExpressionContext.class,0);
		}
		public TerminalNode DOT() { return getToken(RubyParser.DOT, 0); }
		public TerminalNode COLON2() { return getToken(RubyParser.COLON2, 0); }
		public List NL() { return getTokens(RubyParser.NL); }
		public TerminalNode NL(int i) {
			return getToken(RubyParser.NL, i);
		}
		public AttributeAssignmentExpressionContext(PrimaryValueContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterAttributeAssignmentExpression(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitAttributeAssignmentExpression(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitAttributeAssignmentExpression(this);
			else return visitor.visitChildren(this);
		}
	}
	public static class EqualityExpressionContext extends PrimaryValueContext {
		public List primaryValue() {
			return getRuleContexts(PrimaryValueContext.class);
		}
		public PrimaryValueContext primaryValue(int i) {
			return getRuleContext(PrimaryValueContext.class,i);
		}
		public EqualityOperatorContext equalityOperator() {
			return getRuleContext(EqualityOperatorContext.class,0);
		}
		public List NL() { return getTokens(RubyParser.NL); }
		public TerminalNode NL(int i) {
			return getToken(RubyParser.NL, i);
		}
		public EqualityExpressionContext(PrimaryValueContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterEqualityExpression(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitEqualityExpression(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitEqualityExpression(this);
			else return visitor.visitChildren(this);
		}
	}
	public static class BracketAssignmentExpressionContext extends PrimaryValueContext {
		public PrimaryValueContext primaryValue() {
			return getRuleContext(PrimaryValueContext.class,0);
		}
		public TerminalNode LBRACK() { return getToken(RubyParser.LBRACK, 0); }
		public TerminalNode RBRACK() { return getToken(RubyParser.RBRACK, 0); }
		public AssignmentOperatorContext assignmentOperator() {
			return getRuleContext(AssignmentOperatorContext.class,0);
		}
		public OperatorExpressionContext operatorExpression() {
			return getRuleContext(OperatorExpressionContext.class,0);
		}
		public IndexingArgumentListContext indexingArgumentList() {
			return getRuleContext(IndexingArgumentListContext.class,0);
		}
		public List NL() { return getTokens(RubyParser.NL); }
		public TerminalNode NL(int i) {
			return getToken(RubyParser.NL, i);
		}
		public BracketAssignmentExpressionContext(PrimaryValueContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterBracketAssignmentExpression(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitBracketAssignmentExpression(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitBracketAssignmentExpression(this);
			else return visitor.visitChildren(this);
		}
	}
	public static class RangeExpressionContext extends PrimaryValueContext {
		public List primaryValue() {
			return getRuleContexts(PrimaryValueContext.class);
		}
		public PrimaryValueContext primaryValue(int i) {
			return getRuleContext(PrimaryValueContext.class,i);
		}
		public RangeOperatorContext rangeOperator() {
			return getRuleContext(RangeOperatorContext.class,0);
		}
		public List NL() { return getTokens(RubyParser.NL); }
		public TerminalNode NL(int i) {
			return getToken(RubyParser.NL, i);
		}
		public RangeExpressionContext(PrimaryValueContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterRangeExpression(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitRangeExpression(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitRangeExpression(this);
			else return visitor.visitChildren(this);
		}
	}
	public static class AdditiveExpressionContext extends PrimaryValueContext {
		public List primaryValue() {
			return getRuleContexts(PrimaryValueContext.class);
		}
		public PrimaryValueContext primaryValue(int i) {
			return getRuleContext(PrimaryValueContext.class,i);
		}
		public AdditiveOperatorContext additiveOperator() {
			return getRuleContext(AdditiveOperatorContext.class,0);
		}
		public List NL() { return getTokens(RubyParser.NL); }
		public TerminalNode NL(int i) {
			return getToken(RubyParser.NL, i);
		}
		public AdditiveExpressionContext(PrimaryValueContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterAdditiveExpression(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitAdditiveExpression(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitAdditiveExpression(this);
			else return visitor.visitChildren(this);
		}
	}
	public static class RelationalExpressionContext extends PrimaryValueContext {
		public List primaryValue() {
			return getRuleContexts(PrimaryValueContext.class);
		}
		public PrimaryValueContext primaryValue(int i) {
			return getRuleContext(PrimaryValueContext.class,i);
		}
		public RelationalOperatorContext relationalOperator() {
			return getRuleContext(RelationalOperatorContext.class,0);
		}
		public List NL() { return getTokens(RubyParser.NL); }
		public TerminalNode NL(int i) {
			return getToken(RubyParser.NL, i);
		}
		public RelationalExpressionContext(PrimaryValueContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterRelationalExpression(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitRelationalExpression(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitRelationalExpression(this);
			else return visitor.visitChildren(this);
		}
	}
	public static class LocalVariableAssignmentExpressionContext extends PrimaryValueContext {
		public VariableContext lhs;
		public OperatorExpressionContext rhs;
		public AssignmentOperatorContext assignmentOperator() {
			return getRuleContext(AssignmentOperatorContext.class,0);
		}
		public VariableContext variable() {
			return getRuleContext(VariableContext.class,0);
		}
		public OperatorExpressionContext operatorExpression() {
			return getRuleContext(OperatorExpressionContext.class,0);
		}
		public List NL() { return getTokens(RubyParser.NL); }
		public TerminalNode NL(int i) {
			return getToken(RubyParser.NL, i);
		}
		public LocalVariableAssignmentExpressionContext(PrimaryValueContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterLocalVariableAssignmentExpression(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitLocalVariableAssignmentExpression(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitLocalVariableAssignmentExpression(this);
			else return visitor.visitChildren(this);
		}
	}
	public static class HashLiteralContext extends PrimaryValueContext {
		public TerminalNode LCURLY() { return getToken(RubyParser.LCURLY, 0); }
		public TerminalNode RCURLY() { return getToken(RubyParser.RCURLY, 0); }
		public List NL() { return getTokens(RubyParser.NL); }
		public TerminalNode NL(int i) {
			return getToken(RubyParser.NL, i);
		}
		public AssociationListContext associationList() {
			return getRuleContext(AssociationListContext.class,0);
		}
		public TerminalNode COMMA() { return getToken(RubyParser.COMMA, 0); }
		public HashLiteralContext(PrimaryValueContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterHashLiteral(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitHashLiteral(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitHashLiteral(this);
			else return visitor.visitChildren(this);
		}
	}
	public static class HereDocsContext extends PrimaryValueContext {
		public HereDocContext hereDoc() {
			return getRuleContext(HereDocContext.class,0);
		}
		public HereDocsContext(PrimaryValueContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterHereDocs(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitHereDocs(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitHereDocs(this);
			else return visitor.visitChildren(this);
		}
	}
	public static class AssignmentWithRescueContext extends PrimaryValueContext {
		public PrimaryValueContext primaryValue() {
			return getRuleContext(PrimaryValueContext.class,0);
		}
		public AssignmentOperatorContext assignmentOperator() {
			return getRuleContext(AssignmentOperatorContext.class,0);
		}
		public List operatorExpression() {
			return getRuleContexts(OperatorExpressionContext.class);
		}
		public OperatorExpressionContext operatorExpression(int i) {
			return getRuleContext(OperatorExpressionContext.class,i);
		}
		public TerminalNode RESCUE() { return getToken(RubyParser.RESCUE, 0); }
		public List NL() { return getTokens(RubyParser.NL); }
		public TerminalNode NL(int i) {
			return getToken(RubyParser.NL, i);
		}
		public AssignmentWithRescueContext(PrimaryValueContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterAssignmentWithRescue(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitAssignmentWithRescue(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitAssignmentWithRescue(this);
			else return visitor.visitChildren(this);
		}
	}
	public static class MethodCallWithParenthesesContext extends PrimaryValueContext {
		public MethodCallsWithParenthesesContext methodCallsWithParentheses() {
			return getRuleContext(MethodCallsWithParenthesesContext.class,0);
		}
		public MethodCallWithParenthesesContext(PrimaryValueContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterMethodCallWithParentheses(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitMethodCallWithParentheses(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitMethodCallWithParentheses(this);
			else return visitor.visitChildren(this);
		}
	}
	public static class GroupingStatementContext extends PrimaryValueContext {
		public TerminalNode LPAREN() { return getToken(RubyParser.LPAREN, 0); }
		public CompoundStatementContext compoundStatement() {
			return getRuleContext(CompoundStatementContext.class,0);
		}
		public TerminalNode RPAREN() { return getToken(RubyParser.RPAREN, 0); }
		public GroupingStatementContext(PrimaryValueContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterGroupingStatement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitGroupingStatement(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitGroupingStatement(this);
			else return visitor.visitChildren(this);
		}
	}
	public static class IfExpressionContext extends PrimaryValueContext {
		public TerminalNode IF() { return getToken(RubyParser.IF, 0); }
		public ExpressionOrCommandContext expressionOrCommand() {
			return getRuleContext(ExpressionOrCommandContext.class,0);
		}
		public ThenClauseContext thenClause() {
			return getRuleContext(ThenClauseContext.class,0);
		}
		public TerminalNode END() { return getToken(RubyParser.END, 0); }
		public List NL() { return getTokens(RubyParser.NL); }
		public TerminalNode NL(int i) {
			return getToken(RubyParser.NL, i);
		}
		public List elsifClause() {
			return getRuleContexts(ElsifClauseContext.class);
		}
		public ElsifClauseContext elsifClause(int i) {
			return getRuleContext(ElsifClauseContext.class,i);
		}
		public ElseClauseContext elseClause() {
			return getRuleContext(ElseClauseContext.class,0);
		}
		public IfExpressionContext(PrimaryValueContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterIfExpression(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitIfExpression(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitIfExpression(this);
			else return visitor.visitChildren(this);
		}
	}
	public static class QuotedNonExpandedStringArrayLiteralContext extends PrimaryValueContext {
		public TerminalNode QUOTED_NON_EXPANDED_STRING_ARRAY_LITERAL_START() { return getToken(RubyParser.QUOTED_NON_EXPANDED_STRING_ARRAY_LITERAL_START, 0); }
		public TerminalNode QUOTED_NON_EXPANDED_STRING_ARRAY_LITERAL_END() { return getToken(RubyParser.QUOTED_NON_EXPANDED_STRING_ARRAY_LITERAL_END, 0); }
		public QuotedNonExpandedArrayElementListContext quotedNonExpandedArrayElementList() {
			return getRuleContext(QuotedNonExpandedArrayElementListContext.class,0);
		}
		public QuotedNonExpandedStringArrayLiteralContext(PrimaryValueContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterQuotedNonExpandedStringArrayLiteral(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitQuotedNonExpandedStringArrayLiteral(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitQuotedNonExpandedStringArrayLiteral(this);
			else return visitor.visitChildren(this);
		}
	}
	public static class UnlessExpressionContext extends PrimaryValueContext {
		public TerminalNode UNLESS() { return getToken(RubyParser.UNLESS, 0); }
		public ExpressionOrCommandContext expressionOrCommand() {
			return getRuleContext(ExpressionOrCommandContext.class,0);
		}
		public ThenClauseContext thenClause() {
			return getRuleContext(ThenClauseContext.class,0);
		}
		public TerminalNode END() { return getToken(RubyParser.END, 0); }
		public List NL() { return getTokens(RubyParser.NL); }
		public TerminalNode NL(int i) {
			return getToken(RubyParser.NL, i);
		}
		public ElseClauseContext elseClause() {
			return getRuleContext(ElseClauseContext.class,0);
		}
		public UnlessExpressionContext(PrimaryValueContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterUnlessExpression(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitUnlessExpression(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitUnlessExpression(this);
			else return visitor.visitChildren(this);
		}
	}
	public static class SingletonClassDefinitionContext extends PrimaryValueContext {
		public TerminalNode CLASS() { return getToken(RubyParser.CLASS, 0); }
		public TerminalNode LT2() { return getToken(RubyParser.LT2, 0); }
		public CommandOrPrimaryValueClassContext commandOrPrimaryValueClass() {
			return getRuleContext(CommandOrPrimaryValueClassContext.class,0);
		}
		public BodyStatementContext bodyStatement() {
			return getRuleContext(BodyStatementContext.class,0);
		}
		public TerminalNode END() { return getToken(RubyParser.END, 0); }
		public TerminalNode SEMI() { return getToken(RubyParser.SEMI, 0); }
		public TerminalNode NL() { return getToken(RubyParser.NL, 0); }
		public SingletonClassDefinitionContext(PrimaryValueContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterSingletonClassDefinition(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitSingletonClassDefinition(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitSingletonClassDefinition(this);
			else return visitor.visitChildren(this);
		}
	}
	public static class QuotedExpandedStringArrayLiteralContext extends PrimaryValueContext {
		public TerminalNode QUOTED_EXPANDED_STRING_ARRAY_LITERAL_START() { return getToken(RubyParser.QUOTED_EXPANDED_STRING_ARRAY_LITERAL_START, 0); }
		public TerminalNode QUOTED_EXPANDED_STRING_ARRAY_LITERAL_END() { return getToken(RubyParser.QUOTED_EXPANDED_STRING_ARRAY_LITERAL_END, 0); }
		public QuotedExpandedArrayElementListContext quotedExpandedArrayElementList() {
			return getRuleContext(QuotedExpandedArrayElementListContext.class,0);
		}
		public QuotedExpandedStringArrayLiteralContext(PrimaryValueContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterQuotedExpandedStringArrayLiteral(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitQuotedExpandedStringArrayLiteral(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitQuotedExpandedStringArrayLiteral(this);
			else return visitor.visitChildren(this);
		}
	}
	public static class QuotedExpandedRegularExpressionLiteralContext extends PrimaryValueContext {
		public TerminalNode QUOTED_EXPANDED_REGULAR_EXPRESSION_START() { return getToken(RubyParser.QUOTED_EXPANDED_REGULAR_EXPRESSION_START, 0); }
		public TerminalNode QUOTED_EXPANDED_REGULAR_EXPRESSION_END() { return getToken(RubyParser.QUOTED_EXPANDED_REGULAR_EXPRESSION_END, 0); }
		public List quotedExpandedLiteralStringContent() {
			return getRuleContexts(QuotedExpandedLiteralStringContentContext.class);
		}
		public QuotedExpandedLiteralStringContentContext quotedExpandedLiteralStringContent(int i) {
			return getRuleContext(QuotedExpandedLiteralStringContentContext.class,i);
		}
		public QuotedExpandedRegularExpressionLiteralContext(PrimaryValueContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterQuotedExpandedRegularExpressionLiteral(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitQuotedExpandedRegularExpressionLiteral(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitQuotedExpandedRegularExpressionLiteral(this);
			else return visitor.visitChildren(this);
		}
	}
	public static class WhileExpressionContext extends PrimaryValueContext {
		public TerminalNode WHILE() { return getToken(RubyParser.WHILE, 0); }
		public ExpressionOrCommandContext expressionOrCommand() {
			return getRuleContext(ExpressionOrCommandContext.class,0);
		}
		public DoClauseContext doClause() {
			return getRuleContext(DoClauseContext.class,0);
		}
		public TerminalNode END() { return getToken(RubyParser.END, 0); }
		public List NL() { return getTokens(RubyParser.NL); }
		public TerminalNode NL(int i) {
			return getToken(RubyParser.NL, i);
		}
		public WhileExpressionContext(PrimaryValueContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterWhileExpression(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitWhileExpression(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitWhileExpression(this);
			else return visitor.visitChildren(this);
		}
	}
	public static class SingleQuotedStringExpressionContext extends PrimaryValueContext {
		public SingleQuotedStringContext singleQuotedString() {
			return getRuleContext(SingleQuotedStringContext.class,0);
		}
		public List singleOrDoubleQuotedString() {
			return getRuleContexts(SingleOrDoubleQuotedStringContext.class);
		}
		public SingleOrDoubleQuotedStringContext singleOrDoubleQuotedString(int i) {
			return getRuleContext(SingleOrDoubleQuotedStringContext.class,i);
		}
		public SingleQuotedStringExpressionContext(PrimaryValueContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterSingleQuotedStringExpression(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitSingleQuotedStringExpression(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitSingleQuotedStringExpression(this);
			else return visitor.visitChildren(this);
		}
	}
	public static class MultiplicativeExpressionContext extends PrimaryValueContext {
		public List primaryValue() {
			return getRuleContexts(PrimaryValueContext.class);
		}
		public PrimaryValueContext primaryValue(int i) {
			return getRuleContext(PrimaryValueContext.class,i);
		}
		public MultiplicativeOperatorContext multiplicativeOperator() {
			return getRuleContext(MultiplicativeOperatorContext.class,0);
		}
		public List NL() { return getTokens(RubyParser.NL); }
		public TerminalNode NL(int i) {
			return getToken(RubyParser.NL, i);
		}
		public MultiplicativeExpressionContext(PrimaryValueContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterMultiplicativeExpression(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitMultiplicativeExpression(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitMultiplicativeExpression(this);
			else return visitor.visitChildren(this);
		}
	}
	public static class LogicalOrExpressionContext extends PrimaryValueContext {
		public Token orOperator;
		public List primaryValue() {
			return getRuleContexts(PrimaryValueContext.class);
		}
		public PrimaryValueContext primaryValue(int i) {
			return getRuleContext(PrimaryValueContext.class,i);
		}
		public TerminalNode BAR2() { return getToken(RubyParser.BAR2, 0); }
		public List NL() { return getTokens(RubyParser.NL); }
		public TerminalNode NL(int i) {
			return getToken(RubyParser.NL, i);
		}
		public LogicalOrExpressionContext(PrimaryValueContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterLogicalOrExpression(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitLogicalOrExpression(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitLogicalOrExpression(this);
			else return visitor.visitChildren(this);
		}
	}
	public static class UnaryMinusExpressionContext extends PrimaryValueContext {
		public TerminalNode MINUS() { return getToken(RubyParser.MINUS, 0); }
		public PrimaryValueContext primaryValue() {
			return getRuleContext(PrimaryValueContext.class,0);
		}
		public UnaryMinusExpressionContext(PrimaryValueContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterUnaryMinusExpression(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitUnaryMinusExpression(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitUnaryMinusExpression(this);
			else return visitor.visitChildren(this);
		}
	}
	public static class SymbolExpressionContext extends PrimaryValueContext {
		public SymbolContext symbol() {
			return getRuleContext(SymbolContext.class,0);
		}
		public SymbolExpressionContext(PrimaryValueContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterSymbolExpression(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitSymbolExpression(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitSymbolExpression(this);
			else return visitor.visitChildren(this);
		}
	}
	public static class DoubleQuotedStringExpressionContext extends PrimaryValueContext {
		public DoubleQuotedStringContext doubleQuotedString() {
			return getRuleContext(DoubleQuotedStringContext.class,0);
		}
		public List singleOrDoubleQuotedString() {
			return getRuleContexts(SingleOrDoubleQuotedStringContext.class);
		}
		public SingleOrDoubleQuotedStringContext singleOrDoubleQuotedString(int i) {
			return getRuleContext(SingleOrDoubleQuotedStringContext.class,i);
		}
		public DoubleQuotedStringExpressionContext(PrimaryValueContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterDoubleQuotedStringExpression(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitDoubleQuotedStringExpression(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitDoubleQuotedStringExpression(this);
			else return visitor.visitChildren(this);
		}
	}
	public static class YieldExpressionContext extends PrimaryValueContext {
		public TerminalNode YIELD() { return getToken(RubyParser.YIELD, 0); }
		public ArgumentWithParenthesesContext argumentWithParentheses() {
			return getRuleContext(ArgumentWithParenthesesContext.class,0);
		}
		public YieldExpressionContext(PrimaryValueContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterYieldExpression(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitYieldExpression(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitYieldExpression(this);
			else return visitor.visitChildren(this);
		}
	}
	public static class CaseWithExpressionContext extends PrimaryValueContext {
		public TerminalNode CASE() { return getToken(RubyParser.CASE, 0); }
		public ExpressionOrCommandContext expressionOrCommand() {
			return getRuleContext(ExpressionOrCommandContext.class,0);
		}
		public TerminalNode END() { return getToken(RubyParser.END, 0); }
		public List NL() { return getTokens(RubyParser.NL); }
		public TerminalNode NL(int i) {
			return getToken(RubyParser.NL, i);
		}
		public List whenClause() {
			return getRuleContexts(WhenClauseContext.class);
		}
		public WhenClauseContext whenClause(int i) {
			return getRuleContext(WhenClauseContext.class,i);
		}
		public ElseClauseContext elseClause() {
			return getRuleContext(ElseClauseContext.class,0);
		}
		public List SEMI() { return getTokens(RubyParser.SEMI); }
		public TerminalNode SEMI(int i) {
			return getToken(RubyParser.SEMI, i);
		}
		public CaseWithExpressionContext(PrimaryValueContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterCaseWithExpression(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitCaseWithExpression(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitCaseWithExpression(this);
			else return visitor.visitChildren(this);
		}
	}

	public final PrimaryValueContext primaryValue() throws RecognitionException {
		return primaryValue(0);
	}

	private PrimaryValueContext primaryValue(int _p) throws RecognitionException {
		ParserRuleContext _parentctx = _ctx;
		int _parentState = getState();
		PrimaryValueContext _localctx = new PrimaryValueContext(_ctx, _parentState);
		PrimaryValueContext _prevctx = _localctx;
		int _startState = 72;
		enterRecursionRule(_localctx, 72, RULE_primaryValue, _p);
		int _la;
		try {
			int _alt;
			enterOuterAlt(_localctx, 1);
			{
			setState(1233);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,157,_ctx) ) {
			case 1:
				{
				_localctx = new LocalVariableAssignmentExpressionContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;

				setState(899);
				((LocalVariableAssignmentExpressionContext)_localctx).lhs = variable();
				setState(900);
				assignmentOperator();
				setState(904);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==NL) {
					{
					{
					setState(901);
					match(NL);
					}
					}
					setState(906);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(907);
				((LocalVariableAssignmentExpressionContext)_localctx).rhs = operatorExpression(0);
				}
				break;
			case 2:
				{
				_localctx = new ConstantAssignmentExpressionContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(909);
				match(COLON2);
				setState(910);
				match(CONSTANT_IDENTIFIER);
				setState(911);
				assignmentOperator();
				setState(915);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==NL) {
					{
					{
					setState(912);
					match(NL);
					}
					}
					setState(917);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(918);
				operatorExpression(0);
				}
				break;
			case 3:
				{
				_localctx = new ClassDefinitionContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(920);
				match(CLASS);
				setState(921);
				classPath(0);
				setState(924);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==LT) {
					{
					setState(922);
					match(LT);
					setState(923);
					commandOrPrimaryValueClass();
					}
				}

				setState(927);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,115,_ctx) ) {
				case 1:
					{
					setState(926);
					_la = _input.LA(1);
					if ( !(_la==SEMI || _la==NL) ) {
					_errHandler.recoverInline(this);
					}
					else {
						if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
						_errHandler.reportMatch(this);
						consume();
					}
					}
					break;
				}
				setState(929);
				bodyStatement();
				setState(930);
				match(END);
				}
				break;
			case 4:
				{
				_localctx = new SingletonClassDefinitionContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(932);
				match(CLASS);
				setState(933);
				match(LT2);
				setState(934);
				commandOrPrimaryValueClass();
				setState(935);
				_la = _input.LA(1);
				if ( !(_la==SEMI || _la==NL) ) {
				_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				setState(936);
				bodyStatement();
				setState(937);
				match(END);
				}
				break;
			case 5:
				{
				_localctx = new ModuleDefinitionContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(939);
				match(MODULE);
				setState(940);
				classPath(0);
				setState(941);
				bodyStatement();
				setState(942);
				match(END);
				}
				break;
			case 6:
				{
				_localctx = new MethodDefinitionContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(944);
				match(DEF);
				setState(945);
				definedMethodName();
				setState(946);
				methodParameterPart();
				setState(947);
				bodyStatement();
				setState(948);
				match(END);
				}
				break;
			case 7:
				{
				_localctx = new SingletonMethodDefinitionContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(950);
				match(DEF);
				setState(951);
				singletonObject();
				setState(952);
				((SingletonMethodDefinitionContext)_localctx).op = _input.LT(1);
				_la = _input.LA(1);
				if ( !(_la==COLON2 || _la==DOT) ) {
					((SingletonMethodDefinitionContext)_localctx).op = (Token)_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				setState(953);
				definedMethodName();
				setState(954);
				methodParameterPart();
				setState(955);
				bodyStatement();
				setState(956);
				match(END);
				}
				break;
			case 8:
				{
				_localctx = new EndlessMethodDefinitionContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(958);
				match(DEF);
				setState(959);
				definedMethodName();
				setState(965);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==LPAREN) {
					{
					setState(960);
					match(LPAREN);
					setState(962);
					_errHandler.sync(this);
					_la = _input.LA(1);
					if (((((_la - 76)) & ~0x3f) == 0 && ((1L << (_la - 76)) & ((1L << (AMP - 76)) | (1L << (STAR - 76)) | (1L << (STAR2 - 76)) | (1L << (LOCAL_VARIABLE_IDENTIFIER - 76)))) != 0)) {
						{
						setState(961);
						parameterList();
						}
					}

					setState(964);
					match(RPAREN);
					}
				}

				setState(967);
				match(EQ);
				setState(971);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==NL) {
					{
					{
					setState(968);
					match(NL);
					}
					}
					setState(973);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(974);
				statement(0);
				}
				break;
			case 9:
				{
				_localctx = new LambdaExpressionContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(976);
				match(MINUSGT);
				setState(982);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==LPAREN) {
					{
					setState(977);
					match(LPAREN);
					setState(979);
					_errHandler.sync(this);
					_la = _input.LA(1);
					if (((((_la - 76)) & ~0x3f) == 0 && ((1L << (_la - 76)) & ((1L << (AMP - 76)) | (1L << (STAR - 76)) | (1L << (STAR2 - 76)) | (1L << (LOCAL_VARIABLE_IDENTIFIER - 76)))) != 0)) {
						{
						setState(978);
						parameterList();
						}
					}

					setState(981);
					match(RPAREN);
					}
				}

				setState(984);
				block();
				}
				break;
			case 10:
				{
				_localctx = new IfExpressionContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(985);
				match(IF);
				setState(989);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==NL) {
					{
					{
					setState(986);
					match(NL);
					}
					}
					setState(991);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(992);
				expressionOrCommand(0);
				setState(993);
				thenClause();
				setState(997);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==ELSIF) {
					{
					{
					setState(994);
					elsifClause();
					}
					}
					setState(999);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(1001);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==ELSE) {
					{
					setState(1000);
					elseClause();
					}
				}

				setState(1003);
				match(END);
				}
				break;
			case 11:
				{
				_localctx = new UnlessExpressionContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(1005);
				match(UNLESS);
				setState(1009);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==NL) {
					{
					{
					setState(1006);
					match(NL);
					}
					}
					setState(1011);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(1012);
				expressionOrCommand(0);
				setState(1013);
				thenClause();
				setState(1015);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==ELSE) {
					{
					setState(1014);
					elseClause();
					}
				}

				setState(1017);
				match(END);
				}
				break;
			case 12:
				{
				_localctx = new UntilExpressionContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(1019);
				match(UNTIL);
				setState(1023);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==NL) {
					{
					{
					setState(1020);
					match(NL);
					}
					}
					setState(1025);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(1026);
				expressionOrCommand(0);
				setState(1027);
				doClause();
				setState(1028);
				match(END);
				}
				break;
			case 13:
				{
				_localctx = new YieldExpressionContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(1030);
				match(YIELD);
				setState(1032);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,127,_ctx) ) {
				case 1:
					{
					setState(1031);
					argumentWithParentheses();
					}
					break;
				}
				}
				break;
			case 14:
				{
				_localctx = new BeginEndExpressionContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(1034);
				match(BEGIN);
				setState(1035);
				bodyStatement();
				setState(1036);
				match(END);
				}
				break;
			case 15:
				{
				_localctx = new CaseWithExpressionContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(1038);
				match(CASE);
				setState(1042);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==NL) {
					{
					{
					setState(1039);
					match(NL);
					}
					}
					setState(1044);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(1045);
				expressionOrCommand(0);
				setState(1049);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==SEMI || _la==NL) {
					{
					{
					setState(1046);
					_la = _input.LA(1);
					if ( !(_la==SEMI || _la==NL) ) {
					_errHandler.recoverInline(this);
					}
					else {
						if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
						_errHandler.reportMatch(this);
						consume();
					}
					}
					}
					setState(1051);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(1053); 
				_errHandler.sync(this);
				_la = _input.LA(1);
				do {
					{
					{
					setState(1052);
					whenClause();
					}
					}
					setState(1055); 
					_errHandler.sync(this);
					_la = _input.LA(1);
				} while ( _la==WHEN );
				setState(1058);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==ELSE) {
					{
					setState(1057);
					elseClause();
					}
				}

				setState(1060);
				match(END);
				}
				break;
			case 16:
				{
				_localctx = new CaseWithoutExpressionContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(1062);
				match(CASE);
				setState(1066);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==SEMI || _la==NL) {
					{
					{
					setState(1063);
					_la = _input.LA(1);
					if ( !(_la==SEMI || _la==NL) ) {
					_errHandler.recoverInline(this);
					}
					else {
						if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
						_errHandler.reportMatch(this);
						consume();
					}
					}
					}
					setState(1068);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(1070); 
				_errHandler.sync(this);
				_la = _input.LA(1);
				do {
					{
					{
					setState(1069);
					whenClause();
					}
					}
					setState(1072); 
					_errHandler.sync(this);
					_la = _input.LA(1);
				} while ( _la==WHEN );
				setState(1075);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==ELSE) {
					{
					setState(1074);
					elseClause();
					}
				}

				setState(1077);
				match(END);
				}
				break;
			case 17:
				{
				_localctx = new WhileExpressionContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(1079);
				match(WHILE);
				setState(1083);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==NL) {
					{
					{
					setState(1080);
					match(NL);
					}
					}
					setState(1085);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(1086);
				expressionOrCommand(0);
				setState(1087);
				doClause();
				setState(1088);
				match(END);
				}
				break;
			case 18:
				{
				_localctx = new ForExpressionContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(1090);
				match(FOR);
				setState(1094);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==NL) {
					{
					{
					setState(1091);
					match(NL);
					}
					}
					setState(1096);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(1097);
				forVariable();
				setState(1098);
				match(IN);
				setState(1102);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==NL) {
					{
					{
					setState(1099);
					match(NL);
					}
					}
					setState(1104);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(1105);
				commandOrPrimaryValue(0);
				setState(1106);
				doClause();
				setState(1107);
				match(END);
				}
				break;
			case 19:
				{
				_localctx = new MethodCallWithParenthesesContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(1109);
				methodCallsWithParentheses();
				}
				break;
			case 20:
				{
				_localctx = new BracketedArrayLiteralContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(1110);
				match(LBRACK);
				setState(1114);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,138,_ctx);
				while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) {
					if ( _alt==1 ) {
						{
						{
						setState(1111);
						match(NL);
						}
						} 
					}
					setState(1116);
					_errHandler.sync(this);
					_alt = getInterpreter().adaptivePredict(_input,138,_ctx);
				}
				setState(1118);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (((((_la - 3)) & ~0x3f) == 0 && ((1L << (_la - 3)) & ((1L << (REGULAR_EXPRESSION_START - 3)) | (1L << (LINE__ - 3)) | (1L << (ENCODING__ - 3)) | (1L << (FILE__ - 3)) | (1L << (BEGIN_ - 3)) | (1L << (END_ - 3)) | (1L << (ALIAS - 3)) | (1L << (AND - 3)) | (1L << (BEGIN - 3)) | (1L << (BREAK - 3)) | (1L << (CASE - 3)) | (1L << (CLASS - 3)) | (1L << (DEF - 3)) | (1L << (IS_DEFINED - 3)) | (1L << (DO - 3)) | (1L << (ELSE - 3)) | (1L << (ELSIF - 3)) | (1L << (END - 3)) | (1L << (ENSURE - 3)) | (1L << (FOR - 3)) | (1L << (FALSE - 3)) | (1L << (IF - 3)) | (1L << (IN - 3)) | (1L << (MODULE - 3)) | (1L << (NEXT - 3)) | (1L << (NIL - 3)) | (1L << (NOT - 3)) | (1L << (OR - 3)) | (1L << (REDO - 3)) | (1L << (RESCUE - 3)) | (1L << (RETRY - 3)) | (1L << (RETURN - 3)) | (1L << (SELF - 3)) | (1L << (SUPER - 3)) | (1L << (THEN - 3)) | (1L << (TRUE - 3)) | (1L << (UNDEF - 3)) | (1L << (UNLESS - 3)) | (1L << (UNTIL - 3)) | (1L << (WHEN - 3)) | (1L << (WHILE - 3)) | (1L << (YIELD - 3)) | (1L << (LBRACK - 3)) | (1L << (LPAREN - 3)) | (1L << (LCURLY - 3)) | (1L << (COLON - 3)) | (1L << (COLON2 - 3)))) != 0) || ((((_la - 72)) & ~0x3f) == 0 && ((1L << (_la - 72)) & ((1L << (MINUSGT - 72)) | (1L << (EMARK - 72)) | (1L << (PLUS - 72)) | (1L << (MINUS - 72)) | (1L << (STAR - 72)) | (1L << (STAR2 - 72)) | (1L << (TILDE - 72)) | (1L << (SINGLE_QUOTED_STRING_LITERAL - 72)) | (1L << (DOUBLE_QUOTED_STRING_START - 72)) | (1L << (QUOTED_NON_EXPANDED_STRING_LITERAL_START - 72)) | (1L << (QUOTED_EXPANDED_STRING_LITERAL_START - 72)) | (1L << (QUOTED_EXPANDED_REGULAR_EXPRESSION_START - 72)) | (1L << (QUOTED_EXPANDED_EXTERNAL_COMMAND_LITERAL_START - 72)) | (1L << (QUOTED_NON_EXPANDED_STRING_ARRAY_LITERAL_START - 72)) | (1L << (QUOTED_EXPANDED_STRING_ARRAY_LITERAL_START - 72)) | (1L << (HERE_DOC - 72)) | (1L << (QUOTED_NON_EXPANDED_SYMBOL_ARRAY_LITERAL_START - 72)) | (1L << (QUOTED_EXPANDED_SYMBOL_ARRAY_LITERAL_START - 72)) | (1L << (DECIMAL_INTEGER_LITERAL - 72)) | (1L << (BINARY_INTEGER_LITERAL - 72)) | (1L << (OCTAL_INTEGER_LITERAL - 72)) | (1L << (HEXADECIMAL_INTEGER_LITERAL - 72)) | (1L << (FLOAT_LITERAL_WITHOUT_EXPONENT - 72)) | (1L << (FLOAT_LITERAL_WITH_EXPONENT - 72)) | (1L << (SYMBOL_LITERAL - 72)) | (1L << (LOCAL_VARIABLE_IDENTIFIER - 72)) | (1L << (GLOBAL_VARIABLE_IDENTIFIER - 72)) | (1L << (INSTANCE_VARIABLE_IDENTIFIER - 72)) | (1L << (CLASS_VARIABLE_IDENTIFIER - 72)) | (1L << (CONSTANT_IDENTIFIER - 72)))) != 0)) {
					{
					setState(1117);
					indexingArgumentList();
					}
				}

				setState(1123);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==NL) {
					{
					{
					setState(1120);
					match(NL);
					}
					}
					setState(1125);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(1126);
				match(RBRACK);
				}
				break;
			case 21:
				{
				_localctx = new QuotedNonExpandedStringArrayLiteralContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(1127);
				match(QUOTED_NON_EXPANDED_STRING_ARRAY_LITERAL_START);
				setState(1129);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==NON_EXPANDED_ARRAY_ITEM_SEPARATOR || _la==NON_EXPANDED_ARRAY_ITEM_CHARACTER) {
					{
					setState(1128);
					quotedNonExpandedArrayElementList();
					}
				}

				setState(1131);
				match(QUOTED_NON_EXPANDED_STRING_ARRAY_LITERAL_END);
				}
				break;
			case 22:
				{
				_localctx = new QuotedNonExpandedSymbolArrayLiteralContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(1132);
				match(QUOTED_NON_EXPANDED_SYMBOL_ARRAY_LITERAL_START);
				setState(1134);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==NON_EXPANDED_ARRAY_ITEM_SEPARATOR || _la==NON_EXPANDED_ARRAY_ITEM_CHARACTER) {
					{
					setState(1133);
					quotedNonExpandedArrayElementList();
					}
				}

				setState(1136);
				match(QUOTED_NON_EXPANDED_SYMBOL_ARRAY_LITERAL_END);
				}
				break;
			case 23:
				{
				_localctx = new QuotedExpandedStringArrayLiteralContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(1137);
				match(QUOTED_EXPANDED_STRING_ARRAY_LITERAL_START);
				setState(1139);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (((((_la - 142)) & ~0x3f) == 0 && ((1L << (_la - 142)) & ((1L << (DELIMITED_ARRAY_ITEM_INTERPOLATION_BEGIN - 142)) | (1L << (EXPANDED_ARRAY_ITEM_SEPARATOR - 142)) | (1L << (EXPANDED_ARRAY_ITEM_CHARACTER - 142)))) != 0)) {
					{
					setState(1138);
					quotedExpandedArrayElementList();
					}
				}

				setState(1141);
				match(QUOTED_EXPANDED_STRING_ARRAY_LITERAL_END);
				}
				break;
			case 24:
				{
				_localctx = new QuotedExpandedSymbolArrayLiteralContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(1142);
				match(QUOTED_EXPANDED_SYMBOL_ARRAY_LITERAL_START);
				setState(1144);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (((((_la - 142)) & ~0x3f) == 0 && ((1L << (_la - 142)) & ((1L << (DELIMITED_ARRAY_ITEM_INTERPOLATION_BEGIN - 142)) | (1L << (EXPANDED_ARRAY_ITEM_SEPARATOR - 142)) | (1L << (EXPANDED_ARRAY_ITEM_CHARACTER - 142)))) != 0)) {
					{
					setState(1143);
					quotedExpandedArrayElementList();
					}
				}

				setState(1146);
				match(QUOTED_EXPANDED_SYMBOL_ARRAY_LITERAL_END);
				}
				break;
			case 25:
				{
				_localctx = new HashLiteralContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(1147);
				match(LCURLY);
				setState(1151);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,145,_ctx);
				while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) {
					if ( _alt==1 ) {
						{
						{
						setState(1148);
						match(NL);
						}
						} 
					}
					setState(1153);
					_errHandler.sync(this);
					_alt = getInterpreter().adaptivePredict(_input,145,_ctx);
				}
				setState(1158);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (((((_la - 3)) & ~0x3f) == 0 && ((1L << (_la - 3)) & ((1L << (REGULAR_EXPRESSION_START - 3)) | (1L << (LINE__ - 3)) | (1L << (ENCODING__ - 3)) | (1L << (FILE__ - 3)) | (1L << (BEGIN_ - 3)) | (1L << (END_ - 3)) | (1L << (ALIAS - 3)) | (1L << (AND - 3)) | (1L << (BEGIN - 3)) | (1L << (BREAK - 3)) | (1L << (CASE - 3)) | (1L << (CLASS - 3)) | (1L << (DEF - 3)) | (1L << (IS_DEFINED - 3)) | (1L << (DO - 3)) | (1L << (ELSE - 3)) | (1L << (ELSIF - 3)) | (1L << (END - 3)) | (1L << (ENSURE - 3)) | (1L << (FOR - 3)) | (1L << (FALSE - 3)) | (1L << (IF - 3)) | (1L << (IN - 3)) | (1L << (MODULE - 3)) | (1L << (NEXT - 3)) | (1L << (NIL - 3)) | (1L << (NOT - 3)) | (1L << (OR - 3)) | (1L << (REDO - 3)) | (1L << (RESCUE - 3)) | (1L << (RETRY - 3)) | (1L << (RETURN - 3)) | (1L << (SELF - 3)) | (1L << (SUPER - 3)) | (1L << (THEN - 3)) | (1L << (TRUE - 3)) | (1L << (UNDEF - 3)) | (1L << (UNLESS - 3)) | (1L << (UNTIL - 3)) | (1L << (WHEN - 3)) | (1L << (WHILE - 3)) | (1L << (YIELD - 3)) | (1L << (LBRACK - 3)) | (1L << (LPAREN - 3)) | (1L << (LCURLY - 3)) | (1L << (COLON - 3)) | (1L << (COLON2 - 3)))) != 0) || ((((_la - 72)) & ~0x3f) == 0 && ((1L << (_la - 72)) & ((1L << (MINUSGT - 72)) | (1L << (EMARK - 72)) | (1L << (PLUS - 72)) | (1L << (MINUS - 72)) | (1L << (STAR2 - 72)) | (1L << (TILDE - 72)) | (1L << (SINGLE_QUOTED_STRING_LITERAL - 72)) | (1L << (DOUBLE_QUOTED_STRING_START - 72)) | (1L << (QUOTED_NON_EXPANDED_STRING_LITERAL_START - 72)) | (1L << (QUOTED_EXPANDED_STRING_LITERAL_START - 72)) | (1L << (QUOTED_EXPANDED_REGULAR_EXPRESSION_START - 72)) | (1L << (QUOTED_EXPANDED_EXTERNAL_COMMAND_LITERAL_START - 72)) | (1L << (QUOTED_NON_EXPANDED_STRING_ARRAY_LITERAL_START - 72)) | (1L << (QUOTED_EXPANDED_STRING_ARRAY_LITERAL_START - 72)) | (1L << (HERE_DOC - 72)) | (1L << (QUOTED_NON_EXPANDED_SYMBOL_ARRAY_LITERAL_START - 72)) | (1L << (QUOTED_EXPANDED_SYMBOL_ARRAY_LITERAL_START - 72)) | (1L << (DECIMAL_INTEGER_LITERAL - 72)) | (1L << (BINARY_INTEGER_LITERAL - 72)) | (1L << (OCTAL_INTEGER_LITERAL - 72)) | (1L << (HEXADECIMAL_INTEGER_LITERAL - 72)) | (1L << (FLOAT_LITERAL_WITHOUT_EXPONENT - 72)) | (1L << (FLOAT_LITERAL_WITH_EXPONENT - 72)) | (1L << (SYMBOL_LITERAL - 72)) | (1L << (LOCAL_VARIABLE_IDENTIFIER - 72)) | (1L << (GLOBAL_VARIABLE_IDENTIFIER - 72)) | (1L << (INSTANCE_VARIABLE_IDENTIFIER - 72)) | (1L << (CLASS_VARIABLE_IDENTIFIER - 72)) | (1L << (CONSTANT_IDENTIFIER - 72)))) != 0)) {
					{
					setState(1154);
					associationList();
					setState(1156);
					_errHandler.sync(this);
					_la = _input.LA(1);
					if (_la==COMMA) {
						{
						setState(1155);
						match(COMMA);
						}
					}

					}
				}

				setState(1163);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==NL) {
					{
					{
					setState(1160);
					match(NL);
					}
					}
					setState(1165);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(1166);
				match(RCURLY);
				}
				break;
			case 26:
				{
				_localctx = new NumericLiteralContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(1168);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==PLUS || _la==MINUS) {
					{
					setState(1167);
					((NumericLiteralContext)_localctx).sign = _input.LT(1);
					_la = _input.LA(1);
					if ( !(_la==PLUS || _la==MINUS) ) {
						((NumericLiteralContext)_localctx).sign = (Token)_errHandler.recoverInline(this);
					}
					else {
						if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
						_errHandler.reportMatch(this);
						consume();
					}
					}
				}

				setState(1170);
				unsignedNumericLiteral();
				}
				break;
			case 27:
				{
				_localctx = new SingleQuotedStringExpressionContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(1171);
				singleQuotedString();
				setState(1175);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,150,_ctx);
				while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) {
					if ( _alt==1 ) {
						{
						{
						setState(1172);
						singleOrDoubleQuotedString();
						}
						} 
					}
					setState(1177);
					_errHandler.sync(this);
					_alt = getInterpreter().adaptivePredict(_input,150,_ctx);
				}
				}
				break;
			case 28:
				{
				_localctx = new DoubleQuotedStringExpressionContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(1178);
				doubleQuotedString();
				setState(1182);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,151,_ctx);
				while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) {
					if ( _alt==1 ) {
						{
						{
						setState(1179);
						singleOrDoubleQuotedString();
						}
						} 
					}
					setState(1184);
					_errHandler.sync(this);
					_alt = getInterpreter().adaptivePredict(_input,151,_ctx);
				}
				}
				break;
			case 29:
				{
				_localctx = new QuotedNonExpandedStringLiteralContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(1185);
				match(QUOTED_NON_EXPANDED_STRING_LITERAL_START);
				setState(1187);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==NON_EXPANDED_LITERAL_CHARACTER_SEQUENCE) {
					{
					setState(1186);
					match(NON_EXPANDED_LITERAL_CHARACTER_SEQUENCE);
					}
				}

				setState(1189);
				match(QUOTED_NON_EXPANDED_STRING_LITERAL_END);
				}
				break;
			case 30:
				{
				_localctx = new QuotedExpandedStringLiteralContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(1190);
				match(QUOTED_EXPANDED_STRING_LITERAL_START);
				setState(1194);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==EXPANDED_LITERAL_CHARACTER_SEQUENCE || _la==DELIMITED_STRING_INTERPOLATION_BEGIN) {
					{
					{
					setState(1191);
					quotedExpandedLiteralStringContent();
					}
					}
					setState(1196);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(1197);
				match(QUOTED_EXPANDED_STRING_LITERAL_END);
				}
				break;
			case 31:
				{
				_localctx = new QuotedExpandedExternalCommandLiteralContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(1198);
				match(QUOTED_EXPANDED_EXTERNAL_COMMAND_LITERAL_START);
				setState(1202);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==EXPANDED_LITERAL_CHARACTER_SEQUENCE || _la==DELIMITED_STRING_INTERPOLATION_BEGIN) {
					{
					{
					setState(1199);
					quotedExpandedLiteralStringContent();
					}
					}
					setState(1204);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(1205);
				match(QUOTED_EXPANDED_EXTERNAL_COMMAND_LITERAL_END);
				}
				break;
			case 32:
				{
				_localctx = new SymbolExpressionContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(1206);
				symbol();
				}
				break;
			case 33:
				{
				_localctx = new RegularExpressionLiteralContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(1207);
				match(REGULAR_EXPRESSION_START);
				setState(1211);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==REGULAR_EXPRESSION_BODY || _la==REGULAR_EXPRESSION_INTERPOLATION_BEGIN) {
					{
					{
					setState(1208);
					regexpLiteralContent();
					}
					}
					setState(1213);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(1214);
				match(REGULAR_EXPRESSION_END);
				}
				break;
			case 34:
				{
				_localctx = new QuotedExpandedRegularExpressionLiteralContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(1215);
				match(QUOTED_EXPANDED_REGULAR_EXPRESSION_START);
				setState(1219);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==EXPANDED_LITERAL_CHARACTER_SEQUENCE || _la==DELIMITED_STRING_INTERPOLATION_BEGIN) {
					{
					{
					setState(1216);
					quotedExpandedLiteralStringContent();
					}
					}
					setState(1221);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(1222);
				match(QUOTED_EXPANDED_REGULAR_EXPRESSION_END);
				}
				break;
			case 35:
				{
				_localctx = new GroupingStatementContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(1223);
				match(LPAREN);
				setState(1224);
				compoundStatement();
				setState(1225);
				match(RPAREN);
				}
				break;
			case 36:
				{
				_localctx = new UnaryExpressionContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(1227);
				unaryOperator();
				setState(1228);
				primaryValue(14);
				}
				break;
			case 37:
				{
				_localctx = new UnaryMinusExpressionContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(1230);
				match(MINUS);
				setState(1231);
				primaryValue(12);
				}
				break;
			case 38:
				{
				_localctx = new HereDocsContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(1232);
				hereDoc();
				}
				break;
			}
			_ctx.stop = _input.LT(-1);
			setState(1409);
			_errHandler.sync(this);
			_alt = getInterpreter().adaptivePredict(_input,179,_ctx);
			while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) {
				if ( _alt==1 ) {
					if ( _parseListeners!=null ) triggerExitRuleEvent();
					_prevctx = _localctx;
					{
					setState(1407);
					_errHandler.sync(this);
					switch ( getInterpreter().adaptivePredict(_input,178,_ctx) ) {
					case 1:
						{
						_localctx = new PowerExpressionContext(new PrimaryValueContext(_parentctx, _parentState));
						pushNewRecursionContext(_localctx, _startState, RULE_primaryValue);
						setState(1235);
						if (!(precpred(_ctx, 13))) throw new FailedPredicateException(this, "precpred(_ctx, 13)");
						setState(1236);
						((PowerExpressionContext)_localctx).powerOperator = match(STAR2);
						setState(1240);
						_errHandler.sync(this);
						_la = _input.LA(1);
						while (_la==NL) {
							{
							{
							setState(1237);
							match(NL);
							}
							}
							setState(1242);
							_errHandler.sync(this);
							_la = _input.LA(1);
						}
						setState(1243);
						primaryValue(13);
						}
						break;
					case 2:
						{
						_localctx = new MultiplicativeExpressionContext(new PrimaryValueContext(_parentctx, _parentState));
						pushNewRecursionContext(_localctx, _startState, RULE_primaryValue);
						setState(1244);
						if (!(precpred(_ctx, 11))) throw new FailedPredicateException(this, "precpred(_ctx, 11)");
						setState(1245);
						multiplicativeOperator();
						setState(1249);
						_errHandler.sync(this);
						_la = _input.LA(1);
						while (_la==NL) {
							{
							{
							setState(1246);
							match(NL);
							}
							}
							setState(1251);
							_errHandler.sync(this);
							_la = _input.LA(1);
						}
						setState(1252);
						primaryValue(12);
						}
						break;
					case 3:
						{
						_localctx = new AdditiveExpressionContext(new PrimaryValueContext(_parentctx, _parentState));
						pushNewRecursionContext(_localctx, _startState, RULE_primaryValue);
						setState(1254);
						if (!(precpred(_ctx, 10))) throw new FailedPredicateException(this, "precpred(_ctx, 10)");
						setState(1255);
						additiveOperator();
						setState(1259);
						_errHandler.sync(this);
						_la = _input.LA(1);
						while (_la==NL) {
							{
							{
							setState(1256);
							match(NL);
							}
							}
							setState(1261);
							_errHandler.sync(this);
							_la = _input.LA(1);
						}
						setState(1262);
						primaryValue(11);
						}
						break;
					case 4:
						{
						_localctx = new ShiftExpressionContext(new PrimaryValueContext(_parentctx, _parentState));
						pushNewRecursionContext(_localctx, _startState, RULE_primaryValue);
						setState(1264);
						if (!(precpred(_ctx, 9))) throw new FailedPredicateException(this, "precpred(_ctx, 9)");
						setState(1265);
						bitwiseShiftOperator();
						setState(1269);
						_errHandler.sync(this);
						_la = _input.LA(1);
						while (_la==NL) {
							{
							{
							setState(1266);
							match(NL);
							}
							}
							setState(1271);
							_errHandler.sync(this);
							_la = _input.LA(1);
						}
						setState(1272);
						primaryValue(10);
						}
						break;
					case 5:
						{
						_localctx = new BitwiseAndExpressionContext(new PrimaryValueContext(_parentctx, _parentState));
						pushNewRecursionContext(_localctx, _startState, RULE_primaryValue);
						setState(1274);
						if (!(precpred(_ctx, 8))) throw new FailedPredicateException(this, "precpred(_ctx, 8)");
						setState(1275);
						((BitwiseAndExpressionContext)_localctx).bitwiseAndOperator = match(AMP);
						setState(1279);
						_errHandler.sync(this);
						_la = _input.LA(1);
						while (_la==NL) {
							{
							{
							setState(1276);
							match(NL);
							}
							}
							setState(1281);
							_errHandler.sync(this);
							_la = _input.LA(1);
						}
						setState(1282);
						primaryValue(9);
						}
						break;
					case 6:
						{
						_localctx = new BitwiseOrExpressionContext(new PrimaryValueContext(_parentctx, _parentState));
						pushNewRecursionContext(_localctx, _startState, RULE_primaryValue);
						setState(1283);
						if (!(precpred(_ctx, 7))) throw new FailedPredicateException(this, "precpred(_ctx, 7)");
						setState(1284);
						bitwiseOrOperator();
						setState(1288);
						_errHandler.sync(this);
						_la = _input.LA(1);
						while (_la==NL) {
							{
							{
							setState(1285);
							match(NL);
							}
							}
							setState(1290);
							_errHandler.sync(this);
							_la = _input.LA(1);
						}
						setState(1291);
						primaryValue(8);
						}
						break;
					case 7:
						{
						_localctx = new RelationalExpressionContext(new PrimaryValueContext(_parentctx, _parentState));
						pushNewRecursionContext(_localctx, _startState, RULE_primaryValue);
						setState(1293);
						if (!(precpred(_ctx, 6))) throw new FailedPredicateException(this, "precpred(_ctx, 6)");
						setState(1294);
						relationalOperator();
						setState(1298);
						_errHandler.sync(this);
						_la = _input.LA(1);
						while (_la==NL) {
							{
							{
							setState(1295);
							match(NL);
							}
							}
							setState(1300);
							_errHandler.sync(this);
							_la = _input.LA(1);
						}
						setState(1301);
						primaryValue(7);
						}
						break;
					case 8:
						{
						_localctx = new EqualityExpressionContext(new PrimaryValueContext(_parentctx, _parentState));
						pushNewRecursionContext(_localctx, _startState, RULE_primaryValue);
						setState(1303);
						if (!(precpred(_ctx, 5))) throw new FailedPredicateException(this, "precpred(_ctx, 5)");
						setState(1304);
						equalityOperator();
						setState(1308);
						_errHandler.sync(this);
						_la = _input.LA(1);
						while (_la==NL) {
							{
							{
							setState(1305);
							match(NL);
							}
							}
							setState(1310);
							_errHandler.sync(this);
							_la = _input.LA(1);
						}
						setState(1311);
						primaryValue(6);
						}
						break;
					case 9:
						{
						_localctx = new LogicalAndExpressionContext(new PrimaryValueContext(_parentctx, _parentState));
						pushNewRecursionContext(_localctx, _startState, RULE_primaryValue);
						setState(1313);
						if (!(precpred(_ctx, 4))) throw new FailedPredicateException(this, "precpred(_ctx, 4)");
						setState(1314);
						((LogicalAndExpressionContext)_localctx).andOperator = match(AMP2);
						setState(1318);
						_errHandler.sync(this);
						_la = _input.LA(1);
						while (_la==NL) {
							{
							{
							setState(1315);
							match(NL);
							}
							}
							setState(1320);
							_errHandler.sync(this);
							_la = _input.LA(1);
						}
						setState(1321);
						primaryValue(5);
						}
						break;
					case 10:
						{
						_localctx = new LogicalOrExpressionContext(new PrimaryValueContext(_parentctx, _parentState));
						pushNewRecursionContext(_localctx, _startState, RULE_primaryValue);
						setState(1322);
						if (!(precpred(_ctx, 3))) throw new FailedPredicateException(this, "precpred(_ctx, 3)");
						setState(1323);
						((LogicalOrExpressionContext)_localctx).orOperator = match(BAR2);
						setState(1327);
						_errHandler.sync(this);
						_la = _input.LA(1);
						while (_la==NL) {
							{
							{
							setState(1324);
							match(NL);
							}
							}
							setState(1329);
							_errHandler.sync(this);
							_la = _input.LA(1);
						}
						setState(1330);
						primaryValue(4);
						}
						break;
					case 11:
						{
						_localctx = new RangeExpressionContext(new PrimaryValueContext(_parentctx, _parentState));
						pushNewRecursionContext(_localctx, _startState, RULE_primaryValue);
						setState(1331);
						if (!(precpred(_ctx, 2))) throw new FailedPredicateException(this, "precpred(_ctx, 2)");
						setState(1332);
						rangeOperator();
						setState(1336);
						_errHandler.sync(this);
						_la = _input.LA(1);
						while (_la==NL) {
							{
							{
							setState(1333);
							match(NL);
							}
							}
							setState(1338);
							_errHandler.sync(this);
							_la = _input.LA(1);
						}
						setState(1339);
						primaryValue(3);
						}
						break;
					case 12:
						{
						_localctx = new AttributeAssignmentExpressionContext(new PrimaryValueContext(_parentctx, _parentState));
						pushNewRecursionContext(_localctx, _startState, RULE_primaryValue);
						setState(1341);
						if (!(precpred(_ctx, 53))) throw new FailedPredicateException(this, "precpred(_ctx, 53)");
						setState(1342);
						((AttributeAssignmentExpressionContext)_localctx).op = _input.LT(1);
						_la = _input.LA(1);
						if ( !(_la==COLON2 || _la==DOT) ) {
							((AttributeAssignmentExpressionContext)_localctx).op = (Token)_errHandler.recoverInline(this);
						}
						else {
							if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
							_errHandler.reportMatch(this);
							consume();
						}
						setState(1343);
						methodName();
						setState(1344);
						assignmentOperator();
						setState(1348);
						_errHandler.sync(this);
						_la = _input.LA(1);
						while (_la==NL) {
							{
							{
							setState(1345);
							match(NL);
							}
							}
							setState(1350);
							_errHandler.sync(this);
							_la = _input.LA(1);
						}
						setState(1351);
						operatorExpression(0);
						}
						break;
					case 13:
						{
						_localctx = new BracketAssignmentExpressionContext(new PrimaryValueContext(_parentctx, _parentState));
						pushNewRecursionContext(_localctx, _startState, RULE_primaryValue);
						setState(1353);
						if (!(precpred(_ctx, 51))) throw new FailedPredicateException(this, "precpred(_ctx, 51)");
						setState(1354);
						match(LBRACK);
						setState(1356);
						_errHandler.sync(this);
						_la = _input.LA(1);
						if (((((_la - 3)) & ~0x3f) == 0 && ((1L << (_la - 3)) & ((1L << (REGULAR_EXPRESSION_START - 3)) | (1L << (LINE__ - 3)) | (1L << (ENCODING__ - 3)) | (1L << (FILE__ - 3)) | (1L << (BEGIN_ - 3)) | (1L << (END_ - 3)) | (1L << (ALIAS - 3)) | (1L << (AND - 3)) | (1L << (BEGIN - 3)) | (1L << (BREAK - 3)) | (1L << (CASE - 3)) | (1L << (CLASS - 3)) | (1L << (DEF - 3)) | (1L << (IS_DEFINED - 3)) | (1L << (DO - 3)) | (1L << (ELSE - 3)) | (1L << (ELSIF - 3)) | (1L << (END - 3)) | (1L << (ENSURE - 3)) | (1L << (FOR - 3)) | (1L << (FALSE - 3)) | (1L << (IF - 3)) | (1L << (IN - 3)) | (1L << (MODULE - 3)) | (1L << (NEXT - 3)) | (1L << (NIL - 3)) | (1L << (NOT - 3)) | (1L << (OR - 3)) | (1L << (REDO - 3)) | (1L << (RESCUE - 3)) | (1L << (RETRY - 3)) | (1L << (RETURN - 3)) | (1L << (SELF - 3)) | (1L << (SUPER - 3)) | (1L << (THEN - 3)) | (1L << (TRUE - 3)) | (1L << (UNDEF - 3)) | (1L << (UNLESS - 3)) | (1L << (UNTIL - 3)) | (1L << (WHEN - 3)) | (1L << (WHILE - 3)) | (1L << (YIELD - 3)) | (1L << (LBRACK - 3)) | (1L << (LPAREN - 3)) | (1L << (LCURLY - 3)) | (1L << (COLON - 3)) | (1L << (COLON2 - 3)))) != 0) || ((((_la - 72)) & ~0x3f) == 0 && ((1L << (_la - 72)) & ((1L << (MINUSGT - 72)) | (1L << (EMARK - 72)) | (1L << (PLUS - 72)) | (1L << (MINUS - 72)) | (1L << (STAR - 72)) | (1L << (STAR2 - 72)) | (1L << (TILDE - 72)) | (1L << (SINGLE_QUOTED_STRING_LITERAL - 72)) | (1L << (DOUBLE_QUOTED_STRING_START - 72)) | (1L << (QUOTED_NON_EXPANDED_STRING_LITERAL_START - 72)) | (1L << (QUOTED_EXPANDED_STRING_LITERAL_START - 72)) | (1L << (QUOTED_EXPANDED_REGULAR_EXPRESSION_START - 72)) | (1L << (QUOTED_EXPANDED_EXTERNAL_COMMAND_LITERAL_START - 72)) | (1L << (QUOTED_NON_EXPANDED_STRING_ARRAY_LITERAL_START - 72)) | (1L << (QUOTED_EXPANDED_STRING_ARRAY_LITERAL_START - 72)) | (1L << (HERE_DOC - 72)) | (1L << (QUOTED_NON_EXPANDED_SYMBOL_ARRAY_LITERAL_START - 72)) | (1L << (QUOTED_EXPANDED_SYMBOL_ARRAY_LITERAL_START - 72)) | (1L << (DECIMAL_INTEGER_LITERAL - 72)) | (1L << (BINARY_INTEGER_LITERAL - 72)) | (1L << (OCTAL_INTEGER_LITERAL - 72)) | (1L << (HEXADECIMAL_INTEGER_LITERAL - 72)) | (1L << (FLOAT_LITERAL_WITHOUT_EXPONENT - 72)) | (1L << (FLOAT_LITERAL_WITH_EXPONENT - 72)) | (1L << (SYMBOL_LITERAL - 72)) | (1L << (LOCAL_VARIABLE_IDENTIFIER - 72)) | (1L << (GLOBAL_VARIABLE_IDENTIFIER - 72)) | (1L << (INSTANCE_VARIABLE_IDENTIFIER - 72)) | (1L << (CLASS_VARIABLE_IDENTIFIER - 72)) | (1L << (CONSTANT_IDENTIFIER - 72)))) != 0)) {
							{
							setState(1355);
							indexingArgumentList();
							}
						}

						setState(1358);
						match(RBRACK);
						setState(1359);
						assignmentOperator();
						setState(1363);
						_errHandler.sync(this);
						_la = _input.LA(1);
						while (_la==NL) {
							{
							{
							setState(1360);
							match(NL);
							}
							}
							setState(1365);
							_errHandler.sync(this);
							_la = _input.LA(1);
						}
						setState(1366);
						operatorExpression(0);
						}
						break;
					case 14:
						{
						_localctx = new AssignmentWithRescueContext(new PrimaryValueContext(_parentctx, _parentState));
						pushNewRecursionContext(_localctx, _startState, RULE_primaryValue);
						setState(1368);
						if (!(precpred(_ctx, 50))) throw new FailedPredicateException(this, "precpred(_ctx, 50)");
						setState(1369);
						assignmentOperator();
						setState(1373);
						_errHandler.sync(this);
						_la = _input.LA(1);
						while (_la==NL) {
							{
							{
							setState(1370);
							match(NL);
							}
							}
							setState(1375);
							_errHandler.sync(this);
							_la = _input.LA(1);
						}
						setState(1376);
						operatorExpression(0);
						setState(1377);
						match(RESCUE);
						setState(1378);
						operatorExpression(0);
						}
						break;
					case 15:
						{
						_localctx = new IndexingAccessExpressionContext(new PrimaryValueContext(_parentctx, _parentState));
						pushNewRecursionContext(_localctx, _startState, RULE_primaryValue);
						setState(1380);
						if (!(precpred(_ctx, 16))) throw new FailedPredicateException(this, "precpred(_ctx, 16)");
						setState(1381);
						match(LBRACK);
						setState(1383);
						_errHandler.sync(this);
						_la = _input.LA(1);
						if (((((_la - 3)) & ~0x3f) == 0 && ((1L << (_la - 3)) & ((1L << (REGULAR_EXPRESSION_START - 3)) | (1L << (LINE__ - 3)) | (1L << (ENCODING__ - 3)) | (1L << (FILE__ - 3)) | (1L << (BEGIN_ - 3)) | (1L << (END_ - 3)) | (1L << (ALIAS - 3)) | (1L << (AND - 3)) | (1L << (BEGIN - 3)) | (1L << (BREAK - 3)) | (1L << (CASE - 3)) | (1L << (CLASS - 3)) | (1L << (DEF - 3)) | (1L << (IS_DEFINED - 3)) | (1L << (DO - 3)) | (1L << (ELSE - 3)) | (1L << (ELSIF - 3)) | (1L << (END - 3)) | (1L << (ENSURE - 3)) | (1L << (FOR - 3)) | (1L << (FALSE - 3)) | (1L << (IF - 3)) | (1L << (IN - 3)) | (1L << (MODULE - 3)) | (1L << (NEXT - 3)) | (1L << (NIL - 3)) | (1L << (NOT - 3)) | (1L << (OR - 3)) | (1L << (REDO - 3)) | (1L << (RESCUE - 3)) | (1L << (RETRY - 3)) | (1L << (RETURN - 3)) | (1L << (SELF - 3)) | (1L << (SUPER - 3)) | (1L << (THEN - 3)) | (1L << (TRUE - 3)) | (1L << (UNDEF - 3)) | (1L << (UNLESS - 3)) | (1L << (UNTIL - 3)) | (1L << (WHEN - 3)) | (1L << (WHILE - 3)) | (1L << (YIELD - 3)) | (1L << (LBRACK - 3)) | (1L << (LPAREN - 3)) | (1L << (LCURLY - 3)) | (1L << (COLON - 3)) | (1L << (COLON2 - 3)))) != 0) || ((((_la - 72)) & ~0x3f) == 0 && ((1L << (_la - 72)) & ((1L << (MINUSGT - 72)) | (1L << (EMARK - 72)) | (1L << (PLUS - 72)) | (1L << (MINUS - 72)) | (1L << (STAR - 72)) | (1L << (STAR2 - 72)) | (1L << (TILDE - 72)) | (1L << (SINGLE_QUOTED_STRING_LITERAL - 72)) | (1L << (DOUBLE_QUOTED_STRING_START - 72)) | (1L << (QUOTED_NON_EXPANDED_STRING_LITERAL_START - 72)) | (1L << (QUOTED_EXPANDED_STRING_LITERAL_START - 72)) | (1L << (QUOTED_EXPANDED_REGULAR_EXPRESSION_START - 72)) | (1L << (QUOTED_EXPANDED_EXTERNAL_COMMAND_LITERAL_START - 72)) | (1L << (QUOTED_NON_EXPANDED_STRING_ARRAY_LITERAL_START - 72)) | (1L << (QUOTED_EXPANDED_STRING_ARRAY_LITERAL_START - 72)) | (1L << (HERE_DOC - 72)) | (1L << (QUOTED_NON_EXPANDED_SYMBOL_ARRAY_LITERAL_START - 72)) | (1L << (QUOTED_EXPANDED_SYMBOL_ARRAY_LITERAL_START - 72)) | (1L << (DECIMAL_INTEGER_LITERAL - 72)) | (1L << (BINARY_INTEGER_LITERAL - 72)) | (1L << (OCTAL_INTEGER_LITERAL - 72)) | (1L << (HEXADECIMAL_INTEGER_LITERAL - 72)) | (1L << (FLOAT_LITERAL_WITHOUT_EXPONENT - 72)) | (1L << (FLOAT_LITERAL_WITH_EXPONENT - 72)) | (1L << (SYMBOL_LITERAL - 72)) | (1L << (LOCAL_VARIABLE_IDENTIFIER - 72)) | (1L << (GLOBAL_VARIABLE_IDENTIFIER - 72)) | (1L << (INSTANCE_VARIABLE_IDENTIFIER - 72)) | (1L << (CLASS_VARIABLE_IDENTIFIER - 72)) | (1L << (CONSTANT_IDENTIFIER - 72)))) != 0)) {
							{
							setState(1382);
							indexingArgumentList();
							}
						}

						setState(1385);
						match(RBRACK);
						}
						break;
					case 16:
						{
						_localctx = new MemberAccessExpressionContext(new PrimaryValueContext(_parentctx, _parentState));
						pushNewRecursionContext(_localctx, _startState, RULE_primaryValue);
						setState(1386);
						if (!(precpred(_ctx, 15))) throw new FailedPredicateException(this, "precpred(_ctx, 15)");
						setState(1390);
						_errHandler.sync(this);
						_la = _input.LA(1);
						while (_la==NL) {
							{
							{
							setState(1387);
							match(NL);
							}
							}
							setState(1392);
							_errHandler.sync(this);
							_la = _input.LA(1);
						}
						setState(1393);
						((MemberAccessExpressionContext)_localctx).op = _input.LT(1);
						_la = _input.LA(1);
						if ( !(((((_la - 64)) & ~0x3f) == 0 && ((1L << (_la - 64)) & ((1L << (COLON2 - 64)) | (1L << (DOT - 64)) | (1L << (AMPDOT - 64)))) != 0)) ) {
							((MemberAccessExpressionContext)_localctx).op = (Token)_errHandler.recoverInline(this);
						}
						else {
							if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
							_errHandler.reportMatch(this);
							consume();
						}
						setState(1397);
						_errHandler.sync(this);
						_la = _input.LA(1);
						while (_la==NL) {
							{
							{
							setState(1394);
							match(NL);
							}
							}
							setState(1399);
							_errHandler.sync(this);
							_la = _input.LA(1);
						}
						setState(1400);
						methodName();
						setState(1402);
						_errHandler.sync(this);
						switch ( getInterpreter().adaptivePredict(_input,176,_ctx) ) {
						case 1:
							{
							setState(1401);
							argumentWithParentheses();
							}
							break;
						}
						setState(1405);
						_errHandler.sync(this);
						switch ( getInterpreter().adaptivePredict(_input,177,_ctx) ) {
						case 1:
							{
							setState(1404);
							block();
							}
							break;
						}
						}
						break;
					}
					} 
				}
				setState(1411);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,179,_ctx);
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			unrollRecursionContexts(_parentctx);
		}
		return _localctx;
	}

	public static class MethodCallsWithParenthesesContext extends ParserRuleContext {
		public MethodCallsWithParenthesesContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_methodCallsWithParentheses; }
	 
		public MethodCallsWithParenthesesContext() { }
		public void copyFrom(MethodCallsWithParenthesesContext ctx) {
			super.copyFrom(ctx);
		}
	}
	public static class MethodCallWithBlockExpressionContext extends MethodCallsWithParenthesesContext {
		public MethodIdentifierContext methodIdentifier() {
			return getRuleContext(MethodIdentifierContext.class,0);
		}
		public BlockContext block() {
			return getRuleContext(BlockContext.class,0);
		}
		public MethodCallWithBlockExpressionContext(MethodCallsWithParenthesesContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterMethodCallWithBlockExpression(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitMethodCallWithBlockExpression(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitMethodCallWithBlockExpression(this);
			else return visitor.visitChildren(this);
		}
	}
	public static class MethodCallWithParenthesesExpressionContext extends MethodCallsWithParenthesesContext {
		public MethodIdentifierContext methodIdentifier() {
			return getRuleContext(MethodIdentifierContext.class,0);
		}
		public ArgumentWithParenthesesContext argumentWithParentheses() {
			return getRuleContext(ArgumentWithParenthesesContext.class,0);
		}
		public BlockContext block() {
			return getRuleContext(BlockContext.class,0);
		}
		public MethodCallWithParenthesesExpressionContext(MethodCallsWithParenthesesContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterMethodCallWithParenthesesExpression(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitMethodCallWithParenthesesExpression(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitMethodCallWithParenthesesExpression(this);
			else return visitor.visitChildren(this);
		}
	}
	public static class IsDefinedExpressionContext extends MethodCallsWithParenthesesContext {
		public IsDefinedKeywordContext isDefinedKeyword() {
			return getRuleContext(IsDefinedKeywordContext.class,0);
		}
		public TerminalNode LPAREN() { return getToken(RubyParser.LPAREN, 0); }
		public ExpressionOrCommandContext expressionOrCommand() {
			return getRuleContext(ExpressionOrCommandContext.class,0);
		}
		public TerminalNode RPAREN() { return getToken(RubyParser.RPAREN, 0); }
		public IsDefinedExpressionContext(MethodCallsWithParenthesesContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterIsDefinedExpression(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitIsDefinedExpression(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitIsDefinedExpression(this);
			else return visitor.visitChildren(this);
		}
	}
	public static class MethodCallOrVariableReferenceContext extends MethodCallsWithParenthesesContext {
		public VariableReferenceContext variableReference() {
			return getRuleContext(VariableReferenceContext.class,0);
		}
		public MethodCallOrVariableReferenceContext(MethodCallsWithParenthesesContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterMethodCallOrVariableReference(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitMethodCallOrVariableReference(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitMethodCallOrVariableReference(this);
			else return visitor.visitChildren(this);
		}
	}
	public static class MethodCallExpressionContext extends MethodCallsWithParenthesesContext {
		public MethodOnlyIdentifierContext methodOnlyIdentifier() {
			return getRuleContext(MethodOnlyIdentifierContext.class,0);
		}
		public MethodCallExpressionContext(MethodCallsWithParenthesesContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterMethodCallExpression(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitMethodCallExpression(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitMethodCallExpression(this);
			else return visitor.visitChildren(this);
		}
	}
	public static class SuperWithoutParenthesesContext extends MethodCallsWithParenthesesContext {
		public TerminalNode SUPER() { return getToken(RubyParser.SUPER, 0); }
		public ArgumentListContext argumentList() {
			return getRuleContext(ArgumentListContext.class,0);
		}
		public BlockContext block() {
			return getRuleContext(BlockContext.class,0);
		}
		public SuperWithoutParenthesesContext(MethodCallsWithParenthesesContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterSuperWithoutParentheses(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitSuperWithoutParentheses(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitSuperWithoutParentheses(this);
			else return visitor.visitChildren(this);
		}
	}
	public static class IsDefinedCommandContext extends MethodCallsWithParenthesesContext {
		public IsDefinedKeywordContext isDefinedKeyword() {
			return getRuleContext(IsDefinedKeywordContext.class,0);
		}
		public PrimaryValueContext primaryValue() {
			return getRuleContext(PrimaryValueContext.class,0);
		}
		public IsDefinedCommandContext(MethodCallsWithParenthesesContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterIsDefinedCommand(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitIsDefinedCommand(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitIsDefinedCommand(this);
			else return visitor.visitChildren(this);
		}
	}
	public static class SuperWithParenthesesContext extends MethodCallsWithParenthesesContext {
		public TerminalNode SUPER() { return getToken(RubyParser.SUPER, 0); }
		public ArgumentWithParenthesesContext argumentWithParentheses() {
			return getRuleContext(ArgumentWithParenthesesContext.class,0);
		}
		public BlockContext block() {
			return getRuleContext(BlockContext.class,0);
		}
		public SuperWithParenthesesContext(MethodCallsWithParenthesesContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterSuperWithParentheses(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitSuperWithParentheses(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitSuperWithParentheses(this);
			else return visitor.visitChildren(this);
		}
	}

	public final MethodCallsWithParenthesesContext methodCallsWithParentheses() throws RecognitionException {
		MethodCallsWithParenthesesContext _localctx = new MethodCallsWithParenthesesContext(_ctx, getState());
		enterRule(_localctx, 74, RULE_methodCallsWithParentheses);
		try {
			setState(1444);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,185,_ctx) ) {
			case 1:
				_localctx = new SuperWithParenthesesContext(_localctx);
				enterOuterAlt(_localctx, 1);
				{
				setState(1412);
				match(SUPER);
				setState(1414);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,180,_ctx) ) {
				case 1:
					{
					setState(1413);
					argumentWithParentheses();
					}
					break;
				}
				setState(1417);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,181,_ctx) ) {
				case 1:
					{
					setState(1416);
					block();
					}
					break;
				}
				}
				break;
			case 2:
				_localctx = new SuperWithoutParenthesesContext(_localctx);
				enterOuterAlt(_localctx, 2);
				{
				setState(1419);
				match(SUPER);
				setState(1421);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,182,_ctx) ) {
				case 1:
					{
					setState(1420);
					argumentList();
					}
					break;
				}
				setState(1424);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,183,_ctx) ) {
				case 1:
					{
					setState(1423);
					block();
					}
					break;
				}
				}
				break;
			case 3:
				_localctx = new IsDefinedExpressionContext(_localctx);
				enterOuterAlt(_localctx, 3);
				{
				setState(1426);
				isDefinedKeyword();
				setState(1427);
				match(LPAREN);
				setState(1428);
				expressionOrCommand(0);
				setState(1429);
				match(RPAREN);
				}
				break;
			case 4:
				_localctx = new IsDefinedCommandContext(_localctx);
				enterOuterAlt(_localctx, 4);
				{
				setState(1431);
				isDefinedKeyword();
				setState(1432);
				primaryValue(0);
				}
				break;
			case 5:
				_localctx = new MethodCallExpressionContext(_localctx);
				enterOuterAlt(_localctx, 5);
				{
				setState(1434);
				methodOnlyIdentifier();
				}
				break;
			case 6:
				_localctx = new MethodCallWithBlockExpressionContext(_localctx);
				enterOuterAlt(_localctx, 6);
				{
				setState(1435);
				methodIdentifier();
				setState(1436);
				block();
				}
				break;
			case 7:
				_localctx = new MethodCallWithParenthesesExpressionContext(_localctx);
				enterOuterAlt(_localctx, 7);
				{
				setState(1438);
				methodIdentifier();
				setState(1439);
				argumentWithParentheses();
				setState(1441);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,184,_ctx) ) {
				case 1:
					{
					setState(1440);
					block();
					}
					break;
				}
				}
				break;
			case 8:
				_localctx = new MethodCallOrVariableReferenceContext(_localctx);
				enterOuterAlt(_localctx, 8);
				{
				setState(1443);
				variableReference();
				}
				break;
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class CommandOrPrimaryValueClassContext extends ParserRuleContext {
		public CommandOrPrimaryValueClassContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_commandOrPrimaryValueClass; }
	 
		public CommandOrPrimaryValueClassContext() { }
		public void copyFrom(CommandOrPrimaryValueClassContext ctx) {
			super.copyFrom(ctx);
		}
	}
	public static class PrimaryValueCommandOrPrimaryValueClassContext extends CommandOrPrimaryValueClassContext {
		public PrimaryValueContext primaryValue() {
			return getRuleContext(PrimaryValueContext.class,0);
		}
		public PrimaryValueCommandOrPrimaryValueClassContext(CommandOrPrimaryValueClassContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterPrimaryValueCommandOrPrimaryValueClass(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitPrimaryValueCommandOrPrimaryValueClass(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitPrimaryValueCommandOrPrimaryValueClass(this);
			else return visitor.visitChildren(this);
		}
	}
	public static class CommandCommandOrPrimaryValueClassContext extends CommandOrPrimaryValueClassContext {
		public CommandContext command() {
			return getRuleContext(CommandContext.class,0);
		}
		public CommandCommandOrPrimaryValueClassContext(CommandOrPrimaryValueClassContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterCommandCommandOrPrimaryValueClass(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitCommandCommandOrPrimaryValueClass(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitCommandCommandOrPrimaryValueClass(this);
			else return visitor.visitChildren(this);
		}
	}

	public final CommandOrPrimaryValueClassContext commandOrPrimaryValueClass() throws RecognitionException {
		CommandOrPrimaryValueClassContext _localctx = new CommandOrPrimaryValueClassContext(_ctx, getState());
		enterRule(_localctx, 76, RULE_commandOrPrimaryValueClass);
		try {
			setState(1448);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,186,_ctx) ) {
			case 1:
				_localctx = new CommandCommandOrPrimaryValueClassContext(_localctx);
				enterOuterAlt(_localctx, 1);
				{
				setState(1446);
				command();
				}
				break;
			case 2:
				_localctx = new PrimaryValueCommandOrPrimaryValueClassContext(_localctx);
				enterOuterAlt(_localctx, 2);
				{
				setState(1447);
				primaryValue(0);
				}
				break;
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class CommandOrPrimaryValueContext extends ParserRuleContext {
		public CommandOrPrimaryValueContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_commandOrPrimaryValue; }
	 
		public CommandOrPrimaryValueContext() { }
		public void copyFrom(CommandOrPrimaryValueContext ctx) {
			super.copyFrom(ctx);
		}
	}
	public static class KeywordAndOrCommandOrPrimaryValueContext extends CommandOrPrimaryValueContext {
		public List commandOrPrimaryValue() {
			return getRuleContexts(CommandOrPrimaryValueContext.class);
		}
		public CommandOrPrimaryValueContext commandOrPrimaryValue(int i) {
			return getRuleContext(CommandOrPrimaryValueContext.class,i);
		}
		public TerminalNode AND() { return getToken(RubyParser.AND, 0); }
		public TerminalNode OR() { return getToken(RubyParser.OR, 0); }
		public List NL() { return getTokens(RubyParser.NL); }
		public TerminalNode NL(int i) {
			return getToken(RubyParser.NL, i);
		}
		public KeywordAndOrCommandOrPrimaryValueContext(CommandOrPrimaryValueContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterKeywordAndOrCommandOrPrimaryValue(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitKeywordAndOrCommandOrPrimaryValue(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitKeywordAndOrCommandOrPrimaryValue(this);
			else return visitor.visitChildren(this);
		}
	}
	public static class CommandCommandOrPrimaryValueContext extends CommandOrPrimaryValueContext {
		public CommandContext command() {
			return getRuleContext(CommandContext.class,0);
		}
		public CommandCommandOrPrimaryValueContext(CommandOrPrimaryValueContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterCommandCommandOrPrimaryValue(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitCommandCommandOrPrimaryValue(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitCommandCommandOrPrimaryValue(this);
			else return visitor.visitChildren(this);
		}
	}
	public static class NotCommandOrPrimaryValueContext extends CommandOrPrimaryValueContext {
		public TerminalNode NOT() { return getToken(RubyParser.NOT, 0); }
		public CommandOrPrimaryValueContext commandOrPrimaryValue() {
			return getRuleContext(CommandOrPrimaryValueContext.class,0);
		}
		public NotCommandOrPrimaryValueContext(CommandOrPrimaryValueContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterNotCommandOrPrimaryValue(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitNotCommandOrPrimaryValue(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitNotCommandOrPrimaryValue(this);
			else return visitor.visitChildren(this);
		}
	}
	public static class PrimaryValueCommandOrPrimaryValueContext extends CommandOrPrimaryValueContext {
		public PrimaryValueContext primaryValue() {
			return getRuleContext(PrimaryValueContext.class,0);
		}
		public PrimaryValueCommandOrPrimaryValueContext(CommandOrPrimaryValueContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterPrimaryValueCommandOrPrimaryValue(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitPrimaryValueCommandOrPrimaryValue(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitPrimaryValueCommandOrPrimaryValue(this);
			else return visitor.visitChildren(this);
		}
	}

	public final CommandOrPrimaryValueContext commandOrPrimaryValue() throws RecognitionException {
		return commandOrPrimaryValue(0);
	}

	private CommandOrPrimaryValueContext commandOrPrimaryValue(int _p) throws RecognitionException {
		ParserRuleContext _parentctx = _ctx;
		int _parentState = getState();
		CommandOrPrimaryValueContext _localctx = new CommandOrPrimaryValueContext(_ctx, _parentState);
		CommandOrPrimaryValueContext _prevctx = _localctx;
		int _startState = 78;
		enterRecursionRule(_localctx, 78, RULE_commandOrPrimaryValue, _p);
		int _la;
		try {
			int _alt;
			enterOuterAlt(_localctx, 1);
			{
			setState(1455);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,187,_ctx) ) {
			case 1:
				{
				_localctx = new PrimaryValueCommandOrPrimaryValueContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;

				setState(1451);
				primaryValue(0);
				}
				break;
			case 2:
				{
				_localctx = new CommandCommandOrPrimaryValueContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(1452);
				command();
				}
				break;
			case 3:
				{
				_localctx = new NotCommandOrPrimaryValueContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(1453);
				match(NOT);
				setState(1454);
				commandOrPrimaryValue(2);
				}
				break;
			}
			_ctx.stop = _input.LT(-1);
			setState(1468);
			_errHandler.sync(this);
			_alt = getInterpreter().adaptivePredict(_input,189,_ctx);
			while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) {
				if ( _alt==1 ) {
					if ( _parseListeners!=null ) triggerExitRuleEvent();
					_prevctx = _localctx;
					{
					{
					_localctx = new KeywordAndOrCommandOrPrimaryValueContext(new CommandOrPrimaryValueContext(_parentctx, _parentState));
					pushNewRecursionContext(_localctx, _startState, RULE_commandOrPrimaryValue);
					setState(1457);
					if (!(precpred(_ctx, 1))) throw new FailedPredicateException(this, "precpred(_ctx, 1)");
					setState(1458);
					_la = _input.LA(1);
					if ( !(_la==AND || _la==OR) ) {
					_errHandler.recoverInline(this);
					}
					else {
						if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
						_errHandler.reportMatch(this);
						consume();
					}
					setState(1462);
					_errHandler.sync(this);
					_la = _input.LA(1);
					while (_la==NL) {
						{
						{
						setState(1459);
						match(NL);
						}
						}
						setState(1464);
						_errHandler.sync(this);
						_la = _input.LA(1);
					}
					setState(1465);
					commandOrPrimaryValue(2);
					}
					} 
				}
				setState(1470);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,189,_ctx);
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			unrollRecursionContexts(_parentctx);
		}
		return _localctx;
	}

	public static class BlockContext extends ParserRuleContext {
		public BlockContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_block; }
	 
		public BlockContext() { }
		public void copyFrom(BlockContext ctx) {
			super.copyFrom(ctx);
		}
	}
	public static class CurlyBracesBlockContext extends BlockContext {
		public TerminalNode LCURLY() { return getToken(RubyParser.LCURLY, 0); }
		public CompoundStatementContext compoundStatement() {
			return getRuleContext(CompoundStatementContext.class,0);
		}
		public TerminalNode RCURLY() { return getToken(RubyParser.RCURLY, 0); }
		public List NL() { return getTokens(RubyParser.NL); }
		public TerminalNode NL(int i) {
			return getToken(RubyParser.NL, i);
		}
		public BlockParameterContext blockParameter() {
			return getRuleContext(BlockParameterContext.class,0);
		}
		public CurlyBracesBlockContext(BlockContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterCurlyBracesBlock(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitCurlyBracesBlock(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitCurlyBracesBlock(this);
			else return visitor.visitChildren(this);
		}
	}
	public static class DoBlockBlockContext extends BlockContext {
		public DoBlockContext doBlock() {
			return getRuleContext(DoBlockContext.class,0);
		}
		public DoBlockBlockContext(BlockContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterDoBlockBlock(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitDoBlockBlock(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitDoBlockBlock(this);
			else return visitor.visitChildren(this);
		}
	}

	public final BlockContext block() throws RecognitionException {
		BlockContext _localctx = new BlockContext(_ctx, getState());
		enterRule(_localctx, 80, RULE_block);
		int _la;
		try {
			int _alt;
			setState(1485);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case LCURLY:
				_localctx = new CurlyBracesBlockContext(_localctx);
				enterOuterAlt(_localctx, 1);
				{
				setState(1471);
				match(LCURLY);
				setState(1475);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,190,_ctx);
				while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) {
					if ( _alt==1 ) {
						{
						{
						setState(1472);
						match(NL);
						}
						} 
					}
					setState(1477);
					_errHandler.sync(this);
					_alt = getInterpreter().adaptivePredict(_input,190,_ctx);
				}
				setState(1479);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==BAR) {
					{
					setState(1478);
					blockParameter();
					}
				}

				setState(1481);
				compoundStatement();
				setState(1482);
				match(RCURLY);
				}
				break;
			case DO:
				_localctx = new DoBlockBlockContext(_localctx);
				enterOuterAlt(_localctx, 2);
				{
				setState(1484);
				doBlock();
				}
				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 DoBlockContext extends ParserRuleContext {
		public TerminalNode DO() { return getToken(RubyParser.DO, 0); }
		public BodyStatementContext bodyStatement() {
			return getRuleContext(BodyStatementContext.class,0);
		}
		public TerminalNode END() { return getToken(RubyParser.END, 0); }
		public List NL() { return getTokens(RubyParser.NL); }
		public TerminalNode NL(int i) {
			return getToken(RubyParser.NL, i);
		}
		public BlockParameterContext blockParameter() {
			return getRuleContext(BlockParameterContext.class,0);
		}
		public DoBlockContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_doBlock; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterDoBlock(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitDoBlock(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitDoBlock(this);
			else return visitor.visitChildren(this);
		}
	}

	public final DoBlockContext doBlock() throws RecognitionException {
		DoBlockContext _localctx = new DoBlockContext(_ctx, getState());
		enterRule(_localctx, 82, RULE_doBlock);
		int _la;
		try {
			int _alt;
			enterOuterAlt(_localctx, 1);
			{
			setState(1487);
			match(DO);
			setState(1491);
			_errHandler.sync(this);
			_alt = getInterpreter().adaptivePredict(_input,193,_ctx);
			while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) {
				if ( _alt==1 ) {
					{
					{
					setState(1488);
					match(NL);
					}
					} 
				}
				setState(1493);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,193,_ctx);
			}
			setState(1495);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==BAR) {
				{
				setState(1494);
				blockParameter();
				}
			}

			setState(1497);
			bodyStatement();
			setState(1498);
			match(END);
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class BlockParameterContext extends ParserRuleContext {
		public List BAR() { return getTokens(RubyParser.BAR); }
		public TerminalNode BAR(int i) {
			return getToken(RubyParser.BAR, i);
		}
		public List NL() { return getTokens(RubyParser.NL); }
		public TerminalNode NL(int i) {
			return getToken(RubyParser.NL, i);
		}
		public ParameterListContext parameterList() {
			return getRuleContext(ParameterListContext.class,0);
		}
		public BlockParameterContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_blockParameter; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterBlockParameter(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitBlockParameter(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitBlockParameter(this);
			else return visitor.visitChildren(this);
		}
	}

	public final BlockParameterContext blockParameter() throws RecognitionException {
		BlockParameterContext _localctx = new BlockParameterContext(_ctx, getState());
		enterRule(_localctx, 84, RULE_blockParameter);
		int _la;
		try {
			setState(1524);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,198,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(1500);
				match(BAR);
				setState(1504);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==NL) {
					{
					{
					setState(1501);
					match(NL);
					}
					}
					setState(1506);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(1507);
				match(BAR);
				}
				break;
			case 2:
				enterOuterAlt(_localctx, 2);
				{
				setState(1508);
				match(BAR);
				setState(1512);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==NL) {
					{
					{
					setState(1509);
					match(NL);
					}
					}
					setState(1514);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(1515);
				parameterList();
				setState(1519);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==NL) {
					{
					{
					setState(1516);
					match(NL);
					}
					}
					setState(1521);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(1522);
				match(BAR);
				}
				break;
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class ThenClauseContext extends ParserRuleContext {
		public CompoundStatementContext compoundStatement() {
			return getRuleContext(CompoundStatementContext.class,0);
		}
		public List SEMI() { return getTokens(RubyParser.SEMI); }
		public TerminalNode SEMI(int i) {
			return getToken(RubyParser.SEMI, i);
		}
		public List NL() { return getTokens(RubyParser.NL); }
		public TerminalNode NL(int i) {
			return getToken(RubyParser.NL, i);
		}
		public TerminalNode THEN() { return getToken(RubyParser.THEN, 0); }
		public ThenClauseContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_thenClause; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterThenClause(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitThenClause(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitThenClause(this);
			else return visitor.visitChildren(this);
		}
	}

	public final ThenClauseContext thenClause() throws RecognitionException {
		ThenClauseContext _localctx = new ThenClauseContext(_ctx, getState());
		enterRule(_localctx, 86, RULE_thenClause);
		int _la;
		try {
			int _alt;
			setState(1537);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,201,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(1527); 
				_errHandler.sync(this);
				_alt = 1;
				do {
					switch (_alt) {
					case 1:
						{
						{
						setState(1526);
						_la = _input.LA(1);
						if ( !(_la==SEMI || _la==NL) ) {
						_errHandler.recoverInline(this);
						}
						else {
							if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
							_errHandler.reportMatch(this);
							consume();
						}
						}
						}
						break;
					default:
						throw new NoViableAltException(this);
					}
					setState(1529); 
					_errHandler.sync(this);
					_alt = getInterpreter().adaptivePredict(_input,199,_ctx);
				} while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER );
				setState(1531);
				compoundStatement();
				}
				break;
			case 2:
				enterOuterAlt(_localctx, 2);
				{
				setState(1533);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==SEMI || _la==NL) {
					{
					setState(1532);
					_la = _input.LA(1);
					if ( !(_la==SEMI || _la==NL) ) {
					_errHandler.recoverInline(this);
					}
					else {
						if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
						_errHandler.reportMatch(this);
						consume();
					}
					}
				}

				setState(1535);
				match(THEN);
				setState(1536);
				compoundStatement();
				}
				break;
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class ElseClauseContext extends ParserRuleContext {
		public TerminalNode ELSE() { return getToken(RubyParser.ELSE, 0); }
		public CompoundStatementContext compoundStatement() {
			return getRuleContext(CompoundStatementContext.class,0);
		}
		public ElseClauseContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_elseClause; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterElseClause(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitElseClause(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitElseClause(this);
			else return visitor.visitChildren(this);
		}
	}

	public final ElseClauseContext elseClause() throws RecognitionException {
		ElseClauseContext _localctx = new ElseClauseContext(_ctx, getState());
		enterRule(_localctx, 88, RULE_elseClause);
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(1539);
			match(ELSE);
			setState(1540);
			compoundStatement();
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class ElsifClauseContext extends ParserRuleContext {
		public TerminalNode ELSIF() { return getToken(RubyParser.ELSIF, 0); }
		public ExpressionOrCommandContext expressionOrCommand() {
			return getRuleContext(ExpressionOrCommandContext.class,0);
		}
		public ThenClauseContext thenClause() {
			return getRuleContext(ThenClauseContext.class,0);
		}
		public List NL() { return getTokens(RubyParser.NL); }
		public TerminalNode NL(int i) {
			return getToken(RubyParser.NL, i);
		}
		public ElsifClauseContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_elsifClause; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterElsifClause(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitElsifClause(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitElsifClause(this);
			else return visitor.visitChildren(this);
		}
	}

	public final ElsifClauseContext elsifClause() throws RecognitionException {
		ElsifClauseContext _localctx = new ElsifClauseContext(_ctx, getState());
		enterRule(_localctx, 90, RULE_elsifClause);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(1542);
			match(ELSIF);
			setState(1546);
			_errHandler.sync(this);
			_la = _input.LA(1);
			while (_la==NL) {
				{
				{
				setState(1543);
				match(NL);
				}
				}
				setState(1548);
				_errHandler.sync(this);
				_la = _input.LA(1);
			}
			setState(1549);
			expressionOrCommand(0);
			setState(1550);
			thenClause();
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class WhenClauseContext extends ParserRuleContext {
		public TerminalNode WHEN() { return getToken(RubyParser.WHEN, 0); }
		public WhenArgumentContext whenArgument() {
			return getRuleContext(WhenArgumentContext.class,0);
		}
		public ThenClauseContext thenClause() {
			return getRuleContext(ThenClauseContext.class,0);
		}
		public List NL() { return getTokens(RubyParser.NL); }
		public TerminalNode NL(int i) {
			return getToken(RubyParser.NL, i);
		}
		public WhenClauseContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_whenClause; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterWhenClause(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitWhenClause(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitWhenClause(this);
			else return visitor.visitChildren(this);
		}
	}

	public final WhenClauseContext whenClause() throws RecognitionException {
		WhenClauseContext _localctx = new WhenClauseContext(_ctx, getState());
		enterRule(_localctx, 92, RULE_whenClause);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(1552);
			match(WHEN);
			setState(1556);
			_errHandler.sync(this);
			_la = _input.LA(1);
			while (_la==NL) {
				{
				{
				setState(1553);
				match(NL);
				}
				}
				setState(1558);
				_errHandler.sync(this);
				_la = _input.LA(1);
			}
			setState(1559);
			whenArgument();
			setState(1560);
			thenClause();
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class WhenArgumentContext extends ParserRuleContext {
		public OperatorExpressionListContext operatorExpressionList() {
			return getRuleContext(OperatorExpressionListContext.class,0);
		}
		public TerminalNode COMMA() { return getToken(RubyParser.COMMA, 0); }
		public SplattingArgumentContext splattingArgument() {
			return getRuleContext(SplattingArgumentContext.class,0);
		}
		public WhenArgumentContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_whenArgument; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterWhenArgument(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitWhenArgument(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitWhenArgument(this);
			else return visitor.visitChildren(this);
		}
	}

	public final WhenArgumentContext whenArgument() throws RecognitionException {
		WhenArgumentContext _localctx = new WhenArgumentContext(_ctx, getState());
		enterRule(_localctx, 94, RULE_whenArgument);
		int _la;
		try {
			setState(1568);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case REGULAR_EXPRESSION_START:
			case LINE__:
			case ENCODING__:
			case FILE__:
			case BEGIN:
			case BREAK:
			case CASE:
			case CLASS:
			case DEF:
			case IS_DEFINED:
			case FOR:
			case FALSE:
			case IF:
			case MODULE:
			case NEXT:
			case NIL:
			case REDO:
			case RETRY:
			case RETURN:
			case SELF:
			case SUPER:
			case TRUE:
			case UNLESS:
			case UNTIL:
			case WHILE:
			case YIELD:
			case LBRACK:
			case LPAREN:
			case LCURLY:
			case COLON:
			case COLON2:
			case MINUSGT:
			case EMARK:
			case PLUS:
			case MINUS:
			case TILDE:
			case SINGLE_QUOTED_STRING_LITERAL:
			case DOUBLE_QUOTED_STRING_START:
			case QUOTED_NON_EXPANDED_STRING_LITERAL_START:
			case QUOTED_EXPANDED_STRING_LITERAL_START:
			case QUOTED_EXPANDED_REGULAR_EXPRESSION_START:
			case QUOTED_EXPANDED_EXTERNAL_COMMAND_LITERAL_START:
			case QUOTED_NON_EXPANDED_STRING_ARRAY_LITERAL_START:
			case QUOTED_EXPANDED_STRING_ARRAY_LITERAL_START:
			case HERE_DOC:
			case QUOTED_NON_EXPANDED_SYMBOL_ARRAY_LITERAL_START:
			case QUOTED_EXPANDED_SYMBOL_ARRAY_LITERAL_START:
			case DECIMAL_INTEGER_LITERAL:
			case BINARY_INTEGER_LITERAL:
			case OCTAL_INTEGER_LITERAL:
			case HEXADECIMAL_INTEGER_LITERAL:
			case FLOAT_LITERAL_WITHOUT_EXPONENT:
			case FLOAT_LITERAL_WITH_EXPONENT:
			case SYMBOL_LITERAL:
			case LOCAL_VARIABLE_IDENTIFIER:
			case GLOBAL_VARIABLE_IDENTIFIER:
			case INSTANCE_VARIABLE_IDENTIFIER:
			case CLASS_VARIABLE_IDENTIFIER:
			case CONSTANT_IDENTIFIER:
				enterOuterAlt(_localctx, 1);
				{
				setState(1562);
				operatorExpressionList();
				setState(1565);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==COMMA) {
					{
					setState(1563);
					match(COMMA);
					setState(1564);
					splattingArgument();
					}
				}

				}
				break;
			case STAR:
			case STAR2:
				enterOuterAlt(_localctx, 2);
				{
				setState(1567);
				splattingArgument();
				}
				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 DoClauseContext extends ParserRuleContext {
		public CompoundStatementContext compoundStatement() {
			return getRuleContext(CompoundStatementContext.class,0);
		}
		public List SEMI() { return getTokens(RubyParser.SEMI); }
		public TerminalNode SEMI(int i) {
			return getToken(RubyParser.SEMI, i);
		}
		public List NL() { return getTokens(RubyParser.NL); }
		public TerminalNode NL(int i) {
			return getToken(RubyParser.NL, i);
		}
		public TerminalNode DO() { return getToken(RubyParser.DO, 0); }
		public DoClauseContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_doClause; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterDoClause(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitDoClause(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitDoClause(this);
			else return visitor.visitChildren(this);
		}
	}

	public final DoClauseContext doClause() throws RecognitionException {
		DoClauseContext _localctx = new DoClauseContext(_ctx, getState());
		enterRule(_localctx, 96, RULE_doClause);
		int _la;
		try {
			int _alt;
			setState(1578);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case SEMI:
			case NL:
				enterOuterAlt(_localctx, 1);
				{
				setState(1571); 
				_errHandler.sync(this);
				_alt = 1;
				do {
					switch (_alt) {
					case 1:
						{
						{
						setState(1570);
						_la = _input.LA(1);
						if ( !(_la==SEMI || _la==NL) ) {
						_errHandler.recoverInline(this);
						}
						else {
							if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
							_errHandler.reportMatch(this);
							consume();
						}
						}
						}
						break;
					default:
						throw new NoViableAltException(this);
					}
					setState(1573); 
					_errHandler.sync(this);
					_alt = getInterpreter().adaptivePredict(_input,206,_ctx);
				} while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER );
				setState(1575);
				compoundStatement();
				}
				break;
			case DO:
				enterOuterAlt(_localctx, 2);
				{
				setState(1576);
				match(DO);
				setState(1577);
				compoundStatement();
				}
				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 ForVariableContext extends ParserRuleContext {
		public LeftHandSideContext leftHandSide() {
			return getRuleContext(LeftHandSideContext.class,0);
		}
		public MultipleLeftHandSideContext multipleLeftHandSide() {
			return getRuleContext(MultipleLeftHandSideContext.class,0);
		}
		public ForVariableContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_forVariable; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterForVariable(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitForVariable(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitForVariable(this);
			else return visitor.visitChildren(this);
		}
	}

	public final ForVariableContext forVariable() throws RecognitionException {
		ForVariableContext _localctx = new ForVariableContext(_ctx, getState());
		enterRule(_localctx, 98, RULE_forVariable);
		try {
			setState(1582);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,208,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(1580);
				leftHandSide();
				}
				break;
			case 2:
				enterOuterAlt(_localctx, 2);
				{
				setState(1581);
				multipleLeftHandSide();
				}
				break;
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class BodyStatementContext extends ParserRuleContext {
		public CompoundStatementContext compoundStatement() {
			return getRuleContext(CompoundStatementContext.class,0);
		}
		public List rescueClause() {
			return getRuleContexts(RescueClauseContext.class);
		}
		public RescueClauseContext rescueClause(int i) {
			return getRuleContext(RescueClauseContext.class,i);
		}
		public ElseClauseContext elseClause() {
			return getRuleContext(ElseClauseContext.class,0);
		}
		public EnsureClauseContext ensureClause() {
			return getRuleContext(EnsureClauseContext.class,0);
		}
		public BodyStatementContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_bodyStatement; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterBodyStatement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitBodyStatement(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitBodyStatement(this);
			else return visitor.visitChildren(this);
		}
	}

	public final BodyStatementContext bodyStatement() throws RecognitionException {
		BodyStatementContext _localctx = new BodyStatementContext(_ctx, getState());
		enterRule(_localctx, 100, RULE_bodyStatement);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(1584);
			compoundStatement();
			setState(1588);
			_errHandler.sync(this);
			_la = _input.LA(1);
			while (_la==RESCUE) {
				{
				{
				setState(1585);
				rescueClause();
				}
				}
				setState(1590);
				_errHandler.sync(this);
				_la = _input.LA(1);
			}
			setState(1592);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==ELSE) {
				{
				setState(1591);
				elseClause();
				}
			}

			setState(1595);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==ENSURE) {
				{
				setState(1594);
				ensureClause();
				}
			}

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

	public static class RescueClauseContext extends ParserRuleContext {
		public TerminalNode RESCUE() { return getToken(RubyParser.RESCUE, 0); }
		public ThenClauseContext thenClause() {
			return getRuleContext(ThenClauseContext.class,0);
		}
		public ExceptionClassListContext exceptionClassList() {
			return getRuleContext(ExceptionClassListContext.class,0);
		}
		public ExceptionVariableAssignmentContext exceptionVariableAssignment() {
			return getRuleContext(ExceptionVariableAssignmentContext.class,0);
		}
		public RescueClauseContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_rescueClause; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterRescueClause(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitRescueClause(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitRescueClause(this);
			else return visitor.visitChildren(this);
		}
	}

	public final RescueClauseContext rescueClause() throws RecognitionException {
		RescueClauseContext _localctx = new RescueClauseContext(_ctx, getState());
		enterRule(_localctx, 102, RULE_rescueClause);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(1597);
			match(RESCUE);
			setState(1599);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (((((_la - 3)) & ~0x3f) == 0 && ((1L << (_la - 3)) & ((1L << (REGULAR_EXPRESSION_START - 3)) | (1L << (LINE__ - 3)) | (1L << (ENCODING__ - 3)) | (1L << (FILE__ - 3)) | (1L << (BEGIN - 3)) | (1L << (BREAK - 3)) | (1L << (CASE - 3)) | (1L << (CLASS - 3)) | (1L << (DEF - 3)) | (1L << (IS_DEFINED - 3)) | (1L << (FOR - 3)) | (1L << (FALSE - 3)) | (1L << (IF - 3)) | (1L << (MODULE - 3)) | (1L << (NEXT - 3)) | (1L << (NIL - 3)) | (1L << (REDO - 3)) | (1L << (RETRY - 3)) | (1L << (RETURN - 3)) | (1L << (SELF - 3)) | (1L << (SUPER - 3)) | (1L << (TRUE - 3)) | (1L << (UNLESS - 3)) | (1L << (UNTIL - 3)) | (1L << (WHILE - 3)) | (1L << (YIELD - 3)) | (1L << (LBRACK - 3)) | (1L << (LPAREN - 3)) | (1L << (LCURLY - 3)) | (1L << (COLON - 3)) | (1L << (COLON2 - 3)))) != 0) || ((((_la - 72)) & ~0x3f) == 0 && ((1L << (_la - 72)) & ((1L << (MINUSGT - 72)) | (1L << (EMARK - 72)) | (1L << (PLUS - 72)) | (1L << (MINUS - 72)) | (1L << (STAR - 72)) | (1L << (STAR2 - 72)) | (1L << (TILDE - 72)) | (1L << (SINGLE_QUOTED_STRING_LITERAL - 72)) | (1L << (DOUBLE_QUOTED_STRING_START - 72)) | (1L << (QUOTED_NON_EXPANDED_STRING_LITERAL_START - 72)) | (1L << (QUOTED_EXPANDED_STRING_LITERAL_START - 72)) | (1L << (QUOTED_EXPANDED_REGULAR_EXPRESSION_START - 72)) | (1L << (QUOTED_EXPANDED_EXTERNAL_COMMAND_LITERAL_START - 72)) | (1L << (QUOTED_NON_EXPANDED_STRING_ARRAY_LITERAL_START - 72)) | (1L << (QUOTED_EXPANDED_STRING_ARRAY_LITERAL_START - 72)) | (1L << (HERE_DOC - 72)) | (1L << (QUOTED_NON_EXPANDED_SYMBOL_ARRAY_LITERAL_START - 72)) | (1L << (QUOTED_EXPANDED_SYMBOL_ARRAY_LITERAL_START - 72)) | (1L << (DECIMAL_INTEGER_LITERAL - 72)) | (1L << (BINARY_INTEGER_LITERAL - 72)) | (1L << (OCTAL_INTEGER_LITERAL - 72)) | (1L << (HEXADECIMAL_INTEGER_LITERAL - 72)) | (1L << (FLOAT_LITERAL_WITHOUT_EXPONENT - 72)) | (1L << (FLOAT_LITERAL_WITH_EXPONENT - 72)) | (1L << (SYMBOL_LITERAL - 72)) | (1L << (LOCAL_VARIABLE_IDENTIFIER - 72)) | (1L << (GLOBAL_VARIABLE_IDENTIFIER - 72)) | (1L << (INSTANCE_VARIABLE_IDENTIFIER - 72)) | (1L << (CLASS_VARIABLE_IDENTIFIER - 72)) | (1L << (CONSTANT_IDENTIFIER - 72)))) != 0)) {
				{
				setState(1598);
				exceptionClassList();
				}
			}

			setState(1602);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==EQGT) {
				{
				setState(1601);
				exceptionVariableAssignment();
				}
			}

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

	public static class ExceptionClassListContext extends ParserRuleContext {
		public OperatorExpressionContext operatorExpression() {
			return getRuleContext(OperatorExpressionContext.class,0);
		}
		public MultipleRightHandSideContext multipleRightHandSide() {
			return getRuleContext(MultipleRightHandSideContext.class,0);
		}
		public ExceptionClassListContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_exceptionClassList; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterExceptionClassList(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitExceptionClassList(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitExceptionClassList(this);
			else return visitor.visitChildren(this);
		}
	}

	public final ExceptionClassListContext exceptionClassList() throws RecognitionException {
		ExceptionClassListContext _localctx = new ExceptionClassListContext(_ctx, getState());
		enterRule(_localctx, 104, RULE_exceptionClassList);
		try {
			setState(1608);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,214,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(1606);
				operatorExpression(0);
				}
				break;
			case 2:
				enterOuterAlt(_localctx, 2);
				{
				setState(1607);
				multipleRightHandSide();
				}
				break;
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class ExceptionVariableAssignmentContext extends ParserRuleContext {
		public TerminalNode EQGT() { return getToken(RubyParser.EQGT, 0); }
		public LeftHandSideContext leftHandSide() {
			return getRuleContext(LeftHandSideContext.class,0);
		}
		public ExceptionVariableAssignmentContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_exceptionVariableAssignment; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterExceptionVariableAssignment(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitExceptionVariableAssignment(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitExceptionVariableAssignment(this);
			else return visitor.visitChildren(this);
		}
	}

	public final ExceptionVariableAssignmentContext exceptionVariableAssignment() throws RecognitionException {
		ExceptionVariableAssignmentContext _localctx = new ExceptionVariableAssignmentContext(_ctx, getState());
		enterRule(_localctx, 106, RULE_exceptionVariableAssignment);
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(1610);
			match(EQGT);
			setState(1611);
			leftHandSide();
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class EnsureClauseContext extends ParserRuleContext {
		public TerminalNode ENSURE() { return getToken(RubyParser.ENSURE, 0); }
		public CompoundStatementContext compoundStatement() {
			return getRuleContext(CompoundStatementContext.class,0);
		}
		public EnsureClauseContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_ensureClause; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterEnsureClause(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitEnsureClause(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitEnsureClause(this);
			else return visitor.visitChildren(this);
		}
	}

	public final EnsureClauseContext ensureClause() throws RecognitionException {
		EnsureClauseContext _localctx = new EnsureClauseContext(_ctx, getState());
		enterRule(_localctx, 108, RULE_ensureClause);
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(1613);
			match(ENSURE);
			setState(1614);
			compoundStatement();
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class DefinedMethodNameContext extends ParserRuleContext {
		public MethodNameContext methodName() {
			return getRuleContext(MethodNameContext.class,0);
		}
		public TerminalNode ASSIGNMENT_LIKE_METHOD_IDENTIFIER() { return getToken(RubyParser.ASSIGNMENT_LIKE_METHOD_IDENTIFIER, 0); }
		public TerminalNode LBRACK() { return getToken(RubyParser.LBRACK, 0); }
		public TerminalNode RBRACK() { return getToken(RubyParser.RBRACK, 0); }
		public TerminalNode EQ() { return getToken(RubyParser.EQ, 0); }
		public TerminalNode EQ2() { return getToken(RubyParser.EQ2, 0); }
		public TerminalNode EQ3() { return getToken(RubyParser.EQ3, 0); }
		public TerminalNode LTEQGT() { return getToken(RubyParser.LTEQGT, 0); }
		public TerminalNode LT2() { return getToken(RubyParser.LT2, 0); }
		public DefinedMethodNameContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_definedMethodName; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterDefinedMethodName(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitDefinedMethodName(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitDefinedMethodName(this);
			else return visitor.visitChildren(this);
		}
	}

	public final DefinedMethodNameContext definedMethodName() throws RecognitionException {
		DefinedMethodNameContext _localctx = new DefinedMethodNameContext(_ctx, getState());
		enterRule(_localctx, 110, RULE_definedMethodName);
		try {
			setState(1627);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case LINE__:
			case ENCODING__:
			case FILE__:
			case BEGIN_:
			case END_:
			case ALIAS:
			case AND:
			case BEGIN:
			case BREAK:
			case CASE:
			case CLASS:
			case DEF:
			case IS_DEFINED:
			case DO:
			case ELSE:
			case ELSIF:
			case END:
			case ENSURE:
			case FOR:
			case FALSE:
			case IF:
			case IN:
			case MODULE:
			case NEXT:
			case NIL:
			case NOT:
			case OR:
			case REDO:
			case RESCUE:
			case RETRY:
			case RETURN:
			case SELF:
			case SUPER:
			case THEN:
			case TRUE:
			case UNDEF:
			case UNLESS:
			case UNTIL:
			case WHEN:
			case WHILE:
			case YIELD:
			case LOCAL_VARIABLE_IDENTIFIER:
			case CONSTANT_IDENTIFIER:
				enterOuterAlt(_localctx, 1);
				{
				setState(1616);
				methodName();
				}
				break;
			case ASSIGNMENT_LIKE_METHOD_IDENTIFIER:
				enterOuterAlt(_localctx, 2);
				{
				setState(1617);
				match(ASSIGNMENT_LIKE_METHOD_IDENTIFIER);
				}
				break;
			case LBRACK:
				enterOuterAlt(_localctx, 3);
				{
				setState(1618);
				match(LBRACK);
				setState(1619);
				match(RBRACK);
				setState(1621);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,215,_ctx) ) {
				case 1:
					{
					setState(1620);
					match(EQ);
					}
					break;
				}
				}
				break;
			case EQ2:
				enterOuterAlt(_localctx, 4);
				{
				setState(1623);
				match(EQ2);
				}
				break;
			case EQ3:
				enterOuterAlt(_localctx, 5);
				{
				setState(1624);
				match(EQ3);
				}
				break;
			case LTEQGT:
				enterOuterAlt(_localctx, 6);
				{
				setState(1625);
				match(LTEQGT);
				}
				break;
			case LT2:
				enterOuterAlt(_localctx, 7);
				{
				setState(1626);
				match(LT2);
				}
				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 MethodParameterPartContext extends ParserRuleContext {
		public TerminalNode LPAREN() { return getToken(RubyParser.LPAREN, 0); }
		public TerminalNode RPAREN() { return getToken(RubyParser.RPAREN, 0); }
		public List NL() { return getTokens(RubyParser.NL); }
		public TerminalNode NL(int i) {
			return getToken(RubyParser.NL, i);
		}
		public ParameterListContext parameterList() {
			return getRuleContext(ParameterListContext.class,0);
		}
		public TerminalNode SEMI() { return getToken(RubyParser.SEMI, 0); }
		public MethodParameterPartContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_methodParameterPart; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterMethodParameterPart(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitMethodParameterPart(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitMethodParameterPart(this);
			else return visitor.visitChildren(this);
		}
	}

	public final MethodParameterPartContext methodParameterPart() throws RecognitionException {
		MethodParameterPartContext _localctx = new MethodParameterPartContext(_ctx, getState());
		enterRule(_localctx, 112, RULE_methodParameterPart);
		int _la;
		try {
			int _alt;
			setState(1650);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case LPAREN:
				enterOuterAlt(_localctx, 1);
				{
				setState(1629);
				match(LPAREN);
				setState(1633);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,217,_ctx);
				while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) {
					if ( _alt==1 ) {
						{
						{
						setState(1630);
						match(NL);
						}
						} 
					}
					setState(1635);
					_errHandler.sync(this);
					_alt = getInterpreter().adaptivePredict(_input,217,_ctx);
				}
				setState(1637);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (((((_la - 76)) & ~0x3f) == 0 && ((1L << (_la - 76)) & ((1L << (AMP - 76)) | (1L << (STAR - 76)) | (1L << (STAR2 - 76)) | (1L << (LOCAL_VARIABLE_IDENTIFIER - 76)))) != 0)) {
					{
					setState(1636);
					parameterList();
					}
				}

				setState(1642);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==NL) {
					{
					{
					setState(1639);
					match(NL);
					}
					}
					setState(1644);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(1645);
				match(RPAREN);
				}
				break;
			case SEMI:
			case AMP:
			case STAR:
			case STAR2:
			case NL:
			case LOCAL_VARIABLE_IDENTIFIER:
				enterOuterAlt(_localctx, 2);
				{
				setState(1647);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (((((_la - 76)) & ~0x3f) == 0 && ((1L << (_la - 76)) & ((1L << (AMP - 76)) | (1L << (STAR - 76)) | (1L << (STAR2 - 76)) | (1L << (LOCAL_VARIABLE_IDENTIFIER - 76)))) != 0)) {
					{
					setState(1646);
					parameterList();
					}
				}

				setState(1649);
				_la = _input.LA(1);
				if ( !(_la==SEMI || _la==NL) ) {
				_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				}
				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 ParameterListContext extends ParserRuleContext {
		public MandatoryOrOptionalParameterListContext mandatoryOrOptionalParameterList() {
			return getRuleContext(MandatoryOrOptionalParameterListContext.class,0);
		}
		public List COMMA() { return getTokens(RubyParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(RubyParser.COMMA, i);
		}
		public ArrayParameterContext arrayParameter() {
			return getRuleContext(ArrayParameterContext.class,0);
		}
		public HashParameterContext hashParameter() {
			return getRuleContext(HashParameterContext.class,0);
		}
		public ProcParameterContext procParameter() {
			return getRuleContext(ProcParameterContext.class,0);
		}
		public List NL() { return getTokens(RubyParser.NL); }
		public TerminalNode NL(int i) {
			return getToken(RubyParser.NL, i);
		}
		public ParameterListContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_parameterList; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterParameterList(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitParameterList(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitParameterList(this);
			else return visitor.visitChildren(this);
		}
	}

	public final ParameterListContext parameterList() throws RecognitionException {
		ParameterListContext _localctx = new ParameterListContext(_ctx, getState());
		enterRule(_localctx, 114, RULE_parameterList);
		int _la;
		try {
			setState(1726);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case LOCAL_VARIABLE_IDENTIFIER:
				enterOuterAlt(_localctx, 1);
				{
				setState(1652);
				mandatoryOrOptionalParameterList();
				setState(1661);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,223,_ctx) ) {
				case 1:
					{
					setState(1653);
					match(COMMA);
					setState(1657);
					_errHandler.sync(this);
					_la = _input.LA(1);
					while (_la==NL) {
						{
						{
						setState(1654);
						match(NL);
						}
						}
						setState(1659);
						_errHandler.sync(this);
						_la = _input.LA(1);
					}
					setState(1660);
					arrayParameter();
					}
					break;
				}
				setState(1671);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,225,_ctx) ) {
				case 1:
					{
					setState(1663);
					match(COMMA);
					setState(1667);
					_errHandler.sync(this);
					_la = _input.LA(1);
					while (_la==NL) {
						{
						{
						setState(1664);
						match(NL);
						}
						}
						setState(1669);
						_errHandler.sync(this);
						_la = _input.LA(1);
					}
					setState(1670);
					hashParameter();
					}
					break;
				}
				setState(1681);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==COMMA) {
					{
					setState(1673);
					match(COMMA);
					setState(1677);
					_errHandler.sync(this);
					_la = _input.LA(1);
					while (_la==NL) {
						{
						{
						setState(1674);
						match(NL);
						}
						}
						setState(1679);
						_errHandler.sync(this);
						_la = _input.LA(1);
					}
					setState(1680);
					procParameter();
					}
				}

				}
				break;
			case STAR:
				enterOuterAlt(_localctx, 2);
				{
				setState(1683);
				arrayParameter();
				setState(1692);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,229,_ctx) ) {
				case 1:
					{
					setState(1684);
					match(COMMA);
					setState(1688);
					_errHandler.sync(this);
					_la = _input.LA(1);
					while (_la==NL) {
						{
						{
						setState(1685);
						match(NL);
						}
						}
						setState(1690);
						_errHandler.sync(this);
						_la = _input.LA(1);
					}
					setState(1691);
					hashParameter();
					}
					break;
				}
				setState(1702);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,231,_ctx) ) {
				case 1:
					{
					setState(1694);
					match(COMMA);
					setState(1698);
					_errHandler.sync(this);
					_la = _input.LA(1);
					while (_la==NL) {
						{
						{
						setState(1695);
						match(NL);
						}
						}
						setState(1700);
						_errHandler.sync(this);
						_la = _input.LA(1);
					}
					setState(1701);
					procParameter();
					}
					break;
				}
				setState(1712);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==COMMA) {
					{
					setState(1704);
					match(COMMA);
					setState(1708);
					_errHandler.sync(this);
					_la = _input.LA(1);
					while (_la==NL) {
						{
						{
						setState(1705);
						match(NL);
						}
						}
						setState(1710);
						_errHandler.sync(this);
						_la = _input.LA(1);
					}
					setState(1711);
					mandatoryOrOptionalParameterList();
					}
				}

				}
				break;
			case STAR2:
				enterOuterAlt(_localctx, 3);
				{
				setState(1714);
				hashParameter();
				setState(1723);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==COMMA) {
					{
					setState(1715);
					match(COMMA);
					setState(1719);
					_errHandler.sync(this);
					_la = _input.LA(1);
					while (_la==NL) {
						{
						{
						setState(1716);
						match(NL);
						}
						}
						setState(1721);
						_errHandler.sync(this);
						_la = _input.LA(1);
					}
					setState(1722);
					procParameter();
					}
				}

				}
				break;
			case AMP:
				enterOuterAlt(_localctx, 4);
				{
				setState(1725);
				procParameter();
				}
				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 MandatoryOrOptionalParameterListContext extends ParserRuleContext {
		public List mandatoryOrOptionalParameter() {
			return getRuleContexts(MandatoryOrOptionalParameterContext.class);
		}
		public MandatoryOrOptionalParameterContext mandatoryOrOptionalParameter(int i) {
			return getRuleContext(MandatoryOrOptionalParameterContext.class,i);
		}
		public List COMMA() { return getTokens(RubyParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(RubyParser.COMMA, i);
		}
		public List NL() { return getTokens(RubyParser.NL); }
		public TerminalNode NL(int i) {
			return getToken(RubyParser.NL, i);
		}
		public MandatoryOrOptionalParameterListContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_mandatoryOrOptionalParameterList; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterMandatoryOrOptionalParameterList(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitMandatoryOrOptionalParameterList(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitMandatoryOrOptionalParameterList(this);
			else return visitor.visitChildren(this);
		}
	}

	public final MandatoryOrOptionalParameterListContext mandatoryOrOptionalParameterList() throws RecognitionException {
		MandatoryOrOptionalParameterListContext _localctx = new MandatoryOrOptionalParameterListContext(_ctx, getState());
		enterRule(_localctx, 116, RULE_mandatoryOrOptionalParameterList);
		int _la;
		try {
			int _alt;
			enterOuterAlt(_localctx, 1);
			{
			setState(1728);
			mandatoryOrOptionalParameter();
			setState(1739);
			_errHandler.sync(this);
			_alt = getInterpreter().adaptivePredict(_input,238,_ctx);
			while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) {
				if ( _alt==1 ) {
					{
					{
					setState(1729);
					match(COMMA);
					setState(1733);
					_errHandler.sync(this);
					_la = _input.LA(1);
					while (_la==NL) {
						{
						{
						setState(1730);
						match(NL);
						}
						}
						setState(1735);
						_errHandler.sync(this);
						_la = _input.LA(1);
					}
					setState(1736);
					mandatoryOrOptionalParameter();
					}
					} 
				}
				setState(1741);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,238,_ctx);
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class MandatoryOrOptionalParameterContext extends ParserRuleContext {
		public MandatoryOrOptionalParameterContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_mandatoryOrOptionalParameter; }
	 
		public MandatoryOrOptionalParameterContext() { }
		public void copyFrom(MandatoryOrOptionalParameterContext ctx) {
			super.copyFrom(ctx);
		}
	}
	public static class OptionalMandatoryOrOptionalParameterContext extends MandatoryOrOptionalParameterContext {
		public OptionalParameterContext optionalParameter() {
			return getRuleContext(OptionalParameterContext.class,0);
		}
		public OptionalMandatoryOrOptionalParameterContext(MandatoryOrOptionalParameterContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterOptionalMandatoryOrOptionalParameter(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitOptionalMandatoryOrOptionalParameter(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitOptionalMandatoryOrOptionalParameter(this);
			else return visitor.visitChildren(this);
		}
	}
	public static class MandatoryMandatoryOrOptionalParameterContext extends MandatoryOrOptionalParameterContext {
		public MandatoryParameterContext mandatoryParameter() {
			return getRuleContext(MandatoryParameterContext.class,0);
		}
		public MandatoryMandatoryOrOptionalParameterContext(MandatoryOrOptionalParameterContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterMandatoryMandatoryOrOptionalParameter(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitMandatoryMandatoryOrOptionalParameter(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitMandatoryMandatoryOrOptionalParameter(this);
			else return visitor.visitChildren(this);
		}
	}

	public final MandatoryOrOptionalParameterContext mandatoryOrOptionalParameter() throws RecognitionException {
		MandatoryOrOptionalParameterContext _localctx = new MandatoryOrOptionalParameterContext(_ctx, getState());
		enterRule(_localctx, 118, RULE_mandatoryOrOptionalParameter);
		try {
			setState(1744);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,239,_ctx) ) {
			case 1:
				_localctx = new MandatoryMandatoryOrOptionalParameterContext(_localctx);
				enterOuterAlt(_localctx, 1);
				{
				setState(1742);
				mandatoryParameter();
				}
				break;
			case 2:
				_localctx = new OptionalMandatoryOrOptionalParameterContext(_localctx);
				enterOuterAlt(_localctx, 2);
				{
				setState(1743);
				optionalParameter();
				}
				break;
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class MandatoryParameterContext extends ParserRuleContext {
		public TerminalNode LOCAL_VARIABLE_IDENTIFIER() { return getToken(RubyParser.LOCAL_VARIABLE_IDENTIFIER, 0); }
		public TerminalNode COLON() { return getToken(RubyParser.COLON, 0); }
		public MandatoryParameterContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_mandatoryParameter; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterMandatoryParameter(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitMandatoryParameter(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitMandatoryParameter(this);
			else return visitor.visitChildren(this);
		}
	}

	public final MandatoryParameterContext mandatoryParameter() throws RecognitionException {
		MandatoryParameterContext _localctx = new MandatoryParameterContext(_ctx, getState());
		enterRule(_localctx, 120, RULE_mandatoryParameter);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(1746);
			match(LOCAL_VARIABLE_IDENTIFIER);
			setState(1748);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==COLON) {
				{
				setState(1747);
				match(COLON);
				}
			}

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

	public static class OptionalParameterContext extends ParserRuleContext {
		public OptionalParameterNameContext optionalParameterName() {
			return getRuleContext(OptionalParameterNameContext.class,0);
		}
		public OperatorExpressionContext operatorExpression() {
			return getRuleContext(OperatorExpressionContext.class,0);
		}
		public TerminalNode EQ() { return getToken(RubyParser.EQ, 0); }
		public TerminalNode COLON() { return getToken(RubyParser.COLON, 0); }
		public List NL() { return getTokens(RubyParser.NL); }
		public TerminalNode NL(int i) {
			return getToken(RubyParser.NL, i);
		}
		public OptionalParameterContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_optionalParameter; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterOptionalParameter(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitOptionalParameter(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitOptionalParameter(this);
			else return visitor.visitChildren(this);
		}
	}

	public final OptionalParameterContext optionalParameter() throws RecognitionException {
		OptionalParameterContext _localctx = new OptionalParameterContext(_ctx, getState());
		enterRule(_localctx, 122, RULE_optionalParameter);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(1750);
			optionalParameterName();
			setState(1751);
			_la = _input.LA(1);
			if ( !(_la==COLON || _la==EQ) ) {
			_errHandler.recoverInline(this);
			}
			else {
				if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
				_errHandler.reportMatch(this);
				consume();
			}
			setState(1755);
			_errHandler.sync(this);
			_la = _input.LA(1);
			while (_la==NL) {
				{
				{
				setState(1752);
				match(NL);
				}
				}
				setState(1757);
				_errHandler.sync(this);
				_la = _input.LA(1);
			}
			setState(1758);
			operatorExpression(0);
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class OptionalParameterNameContext extends ParserRuleContext {
		public TerminalNode LOCAL_VARIABLE_IDENTIFIER() { return getToken(RubyParser.LOCAL_VARIABLE_IDENTIFIER, 0); }
		public OptionalParameterNameContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_optionalParameterName; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterOptionalParameterName(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitOptionalParameterName(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitOptionalParameterName(this);
			else return visitor.visitChildren(this);
		}
	}

	public final OptionalParameterNameContext optionalParameterName() throws RecognitionException {
		OptionalParameterNameContext _localctx = new OptionalParameterNameContext(_ctx, getState());
		enterRule(_localctx, 124, RULE_optionalParameterName);
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(1760);
			match(LOCAL_VARIABLE_IDENTIFIER);
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class ArrayParameterContext extends ParserRuleContext {
		public TerminalNode STAR() { return getToken(RubyParser.STAR, 0); }
		public TerminalNode LOCAL_VARIABLE_IDENTIFIER() { return getToken(RubyParser.LOCAL_VARIABLE_IDENTIFIER, 0); }
		public ArrayParameterContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_arrayParameter; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterArrayParameter(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitArrayParameter(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitArrayParameter(this);
			else return visitor.visitChildren(this);
		}
	}

	public final ArrayParameterContext arrayParameter() throws RecognitionException {
		ArrayParameterContext _localctx = new ArrayParameterContext(_ctx, getState());
		enterRule(_localctx, 126, RULE_arrayParameter);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(1762);
			match(STAR);
			setState(1764);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==LOCAL_VARIABLE_IDENTIFIER) {
				{
				setState(1763);
				match(LOCAL_VARIABLE_IDENTIFIER);
				}
			}

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

	public static class HashParameterContext extends ParserRuleContext {
		public TerminalNode STAR2() { return getToken(RubyParser.STAR2, 0); }
		public TerminalNode LOCAL_VARIABLE_IDENTIFIER() { return getToken(RubyParser.LOCAL_VARIABLE_IDENTIFIER, 0); }
		public HashParameterContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_hashParameter; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterHashParameter(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitHashParameter(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitHashParameter(this);
			else return visitor.visitChildren(this);
		}
	}

	public final HashParameterContext hashParameter() throws RecognitionException {
		HashParameterContext _localctx = new HashParameterContext(_ctx, getState());
		enterRule(_localctx, 128, RULE_hashParameter);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(1766);
			match(STAR2);
			setState(1768);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==LOCAL_VARIABLE_IDENTIFIER) {
				{
				setState(1767);
				match(LOCAL_VARIABLE_IDENTIFIER);
				}
			}

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

	public static class ProcParameterContext extends ParserRuleContext {
		public TerminalNode AMP() { return getToken(RubyParser.AMP, 0); }
		public ProcParameterNameContext procParameterName() {
			return getRuleContext(ProcParameterNameContext.class,0);
		}
		public ProcParameterContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_procParameter; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterProcParameter(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitProcParameter(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitProcParameter(this);
			else return visitor.visitChildren(this);
		}
	}

	public final ProcParameterContext procParameter() throws RecognitionException {
		ProcParameterContext _localctx = new ProcParameterContext(_ctx, getState());
		enterRule(_localctx, 130, RULE_procParameter);
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(1770);
			match(AMP);
			setState(1771);
			procParameterName();
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class ProcParameterNameContext extends ParserRuleContext {
		public TerminalNode LOCAL_VARIABLE_IDENTIFIER() { return getToken(RubyParser.LOCAL_VARIABLE_IDENTIFIER, 0); }
		public ProcParameterNameContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_procParameterName; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterProcParameterName(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitProcParameterName(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitProcParameterName(this);
			else return visitor.visitChildren(this);
		}
	}

	public final ProcParameterNameContext procParameterName() throws RecognitionException {
		ProcParameterNameContext _localctx = new ProcParameterNameContext(_ctx, getState());
		enterRule(_localctx, 132, RULE_procParameterName);
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(1773);
			match(LOCAL_VARIABLE_IDENTIFIER);
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class ClassPathContext extends ParserRuleContext {
		public ClassPathContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_classPath; }
	 
		public ClassPathContext() { }
		public void copyFrom(ClassPathContext ctx) {
			super.copyFrom(ctx);
		}
	}
	public static class ClassNameContext extends ClassPathContext {
		public TerminalNode CONSTANT_IDENTIFIER() { return getToken(RubyParser.CONSTANT_IDENTIFIER, 0); }
		public ClassNameContext(ClassPathContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterClassName(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitClassName(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitClassName(this);
			else return visitor.visitChildren(this);
		}
	}
	public static class TopClassPathContext extends ClassPathContext {
		public TerminalNode COLON2() { return getToken(RubyParser.COLON2, 0); }
		public TerminalNode CONSTANT_IDENTIFIER() { return getToken(RubyParser.CONSTANT_IDENTIFIER, 0); }
		public TopClassPathContext(ClassPathContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterTopClassPath(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitTopClassPath(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitTopClassPath(this);
			else return visitor.visitChildren(this);
		}
	}
	public static class NestedClassPathContext extends ClassPathContext {
		public ClassPathContext classPath() {
			return getRuleContext(ClassPathContext.class,0);
		}
		public TerminalNode COLON2() { return getToken(RubyParser.COLON2, 0); }
		public TerminalNode CONSTANT_IDENTIFIER() { return getToken(RubyParser.CONSTANT_IDENTIFIER, 0); }
		public NestedClassPathContext(ClassPathContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterNestedClassPath(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitNestedClassPath(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitNestedClassPath(this);
			else return visitor.visitChildren(this);
		}
	}

	public final ClassPathContext classPath() throws RecognitionException {
		return classPath(0);
	}

	private ClassPathContext classPath(int _p) throws RecognitionException {
		ParserRuleContext _parentctx = _ctx;
		int _parentState = getState();
		ClassPathContext _localctx = new ClassPathContext(_ctx, _parentState);
		ClassPathContext _prevctx = _localctx;
		int _startState = 134;
		enterRecursionRule(_localctx, 134, RULE_classPath, _p);
		try {
			int _alt;
			enterOuterAlt(_localctx, 1);
			{
			setState(1779);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case COLON2:
				{
				_localctx = new TopClassPathContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;

				setState(1776);
				match(COLON2);
				setState(1777);
				match(CONSTANT_IDENTIFIER);
				}
				break;
			case CONSTANT_IDENTIFIER:
				{
				_localctx = new ClassNameContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(1778);
				match(CONSTANT_IDENTIFIER);
				}
				break;
			default:
				throw new NoViableAltException(this);
			}
			_ctx.stop = _input.LT(-1);
			setState(1786);
			_errHandler.sync(this);
			_alt = getInterpreter().adaptivePredict(_input,245,_ctx);
			while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) {
				if ( _alt==1 ) {
					if ( _parseListeners!=null ) triggerExitRuleEvent();
					_prevctx = _localctx;
					{
					{
					_localctx = new NestedClassPathContext(new ClassPathContext(_parentctx, _parentState));
					pushNewRecursionContext(_localctx, _startState, RULE_classPath);
					setState(1781);
					if (!(precpred(_ctx, 1))) throw new FailedPredicateException(this, "precpred(_ctx, 1)");
					setState(1782);
					match(COLON2);
					setState(1783);
					match(CONSTANT_IDENTIFIER);
					}
					} 
				}
				setState(1788);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,245,_ctx);
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			unrollRecursionContexts(_parentctx);
		}
		return _localctx;
	}

	public static class SingletonObjectContext extends ParserRuleContext {
		public SingletonObjectContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_singletonObject; }
	 
		public SingletonObjectContext() { }
		public void copyFrom(SingletonObjectContext ctx) {
			super.copyFrom(ctx);
		}
	}
	public static class VariableReferenceSingletonObjectContext extends SingletonObjectContext {
		public VariableReferenceContext variableReference() {
			return getRuleContext(VariableReferenceContext.class,0);
		}
		public VariableReferenceSingletonObjectContext(SingletonObjectContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterVariableReferenceSingletonObject(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitVariableReferenceSingletonObject(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitVariableReferenceSingletonObject(this);
			else return visitor.visitChildren(this);
		}
	}
	public static class ExpressionSingletonObjectContext extends SingletonObjectContext {
		public TerminalNode LPAREN() { return getToken(RubyParser.LPAREN, 0); }
		public ExpressionOrCommandContext expressionOrCommand() {
			return getRuleContext(ExpressionOrCommandContext.class,0);
		}
		public TerminalNode RPAREN() { return getToken(RubyParser.RPAREN, 0); }
		public ExpressionSingletonObjectContext(SingletonObjectContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterExpressionSingletonObject(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitExpressionSingletonObject(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitExpressionSingletonObject(this);
			else return visitor.visitChildren(this);
		}
	}

	public final SingletonObjectContext singletonObject() throws RecognitionException {
		SingletonObjectContext _localctx = new SingletonObjectContext(_ctx, getState());
		enterRule(_localctx, 136, RULE_singletonObject);
		try {
			setState(1794);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case LINE__:
			case ENCODING__:
			case FILE__:
			case FALSE:
			case NIL:
			case SELF:
			case TRUE:
			case COLON2:
			case LOCAL_VARIABLE_IDENTIFIER:
			case GLOBAL_VARIABLE_IDENTIFIER:
			case INSTANCE_VARIABLE_IDENTIFIER:
			case CLASS_VARIABLE_IDENTIFIER:
			case CONSTANT_IDENTIFIER:
				_localctx = new VariableReferenceSingletonObjectContext(_localctx);
				enterOuterAlt(_localctx, 1);
				{
				setState(1789);
				variableReference();
				}
				break;
			case LPAREN:
				_localctx = new ExpressionSingletonObjectContext(_localctx);
				enterOuterAlt(_localctx, 2);
				{
				setState(1790);
				match(LPAREN);
				setState(1791);
				expressionOrCommand(0);
				setState(1792);
				match(RPAREN);
				}
				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 VariableReferenceContext extends ParserRuleContext {
		public VariableReferenceContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_variableReference; }
	 
		public VariableReferenceContext() { }
		public void copyFrom(VariableReferenceContext ctx) {
			super.copyFrom(ctx);
		}
	}
	public static class ConstantVariableReferenceContext extends VariableReferenceContext {
		public TerminalNode COLON2() { return getToken(RubyParser.COLON2, 0); }
		public TerminalNode CONSTANT_IDENTIFIER() { return getToken(RubyParser.CONSTANT_IDENTIFIER, 0); }
		public ConstantVariableReferenceContext(VariableReferenceContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterConstantVariableReference(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitConstantVariableReference(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitConstantVariableReference(this);
			else return visitor.visitChildren(this);
		}
	}
	public static class PseudoVariableVariableReferenceContext extends VariableReferenceContext {
		public PseudoVariableContext pseudoVariable() {
			return getRuleContext(PseudoVariableContext.class,0);
		}
		public PseudoVariableVariableReferenceContext(VariableReferenceContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterPseudoVariableVariableReference(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitPseudoVariableVariableReference(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitPseudoVariableVariableReference(this);
			else return visitor.visitChildren(this);
		}
	}
	public static class VariableVariableReferenceContext extends VariableReferenceContext {
		public VariableContext variable() {
			return getRuleContext(VariableContext.class,0);
		}
		public VariableVariableReferenceContext(VariableReferenceContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterVariableVariableReference(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitVariableVariableReference(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitVariableVariableReference(this);
			else return visitor.visitChildren(this);
		}
	}

	public final VariableReferenceContext variableReference() throws RecognitionException {
		VariableReferenceContext _localctx = new VariableReferenceContext(_ctx, getState());
		enterRule(_localctx, 138, RULE_variableReference);
		try {
			setState(1800);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case LOCAL_VARIABLE_IDENTIFIER:
			case GLOBAL_VARIABLE_IDENTIFIER:
			case INSTANCE_VARIABLE_IDENTIFIER:
			case CLASS_VARIABLE_IDENTIFIER:
			case CONSTANT_IDENTIFIER:
				_localctx = new VariableVariableReferenceContext(_localctx);
				enterOuterAlt(_localctx, 1);
				{
				setState(1796);
				variable();
				}
				break;
			case LINE__:
			case ENCODING__:
			case FILE__:
			case FALSE:
			case NIL:
			case SELF:
			case TRUE:
				_localctx = new PseudoVariableVariableReferenceContext(_localctx);
				enterOuterAlt(_localctx, 2);
				{
				setState(1797);
				pseudoVariable();
				}
				break;
			case COLON2:
				_localctx = new ConstantVariableReferenceContext(_localctx);
				enterOuterAlt(_localctx, 3);
				{
				setState(1798);
				match(COLON2);
				setState(1799);
				match(CONSTANT_IDENTIFIER);
				}
				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 AssociationListContext extends ParserRuleContext {
		public List association() {
			return getRuleContexts(AssociationContext.class);
		}
		public AssociationContext association(int i) {
			return getRuleContext(AssociationContext.class,i);
		}
		public List COMMA() { return getTokens(RubyParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(RubyParser.COMMA, i);
		}
		public List NL() { return getTokens(RubyParser.NL); }
		public TerminalNode NL(int i) {
			return getToken(RubyParser.NL, i);
		}
		public AssociationListContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_associationList; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterAssociationList(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitAssociationList(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitAssociationList(this);
			else return visitor.visitChildren(this);
		}
	}

	public final AssociationListContext associationList() throws RecognitionException {
		AssociationListContext _localctx = new AssociationListContext(_ctx, getState());
		enterRule(_localctx, 140, RULE_associationList);
		int _la;
		try {
			int _alt;
			enterOuterAlt(_localctx, 1);
			{
			setState(1802);
			association();
			setState(1813);
			_errHandler.sync(this);
			_alt = getInterpreter().adaptivePredict(_input,249,_ctx);
			while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) {
				if ( _alt==1 ) {
					{
					{
					setState(1803);
					match(COMMA);
					setState(1807);
					_errHandler.sync(this);
					_la = _input.LA(1);
					while (_la==NL) {
						{
						{
						setState(1804);
						match(NL);
						}
						}
						setState(1809);
						_errHandler.sync(this);
						_la = _input.LA(1);
					}
					setState(1810);
					association();
					}
					} 
				}
				setState(1815);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,249,_ctx);
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class AssociationContext extends ParserRuleContext {
		public AssociationContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_association; }
	 
		public AssociationContext() { }
		public void copyFrom(AssociationContext ctx) {
			super.copyFrom(ctx);
		}
	}
	public static class AssociationElementContext extends AssociationContext {
		public AssociationKeyContext associationKey() {
			return getRuleContext(AssociationKeyContext.class,0);
		}
		public OperatorExpressionContext operatorExpression() {
			return getRuleContext(OperatorExpressionContext.class,0);
		}
		public TerminalNode EQGT() { return getToken(RubyParser.EQGT, 0); }
		public TerminalNode COLON() { return getToken(RubyParser.COLON, 0); }
		public List NL() { return getTokens(RubyParser.NL); }
		public TerminalNode NL(int i) {
			return getToken(RubyParser.NL, i);
		}
		public AssociationElementContext(AssociationContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterAssociationElement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitAssociationElement(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitAssociationElement(this);
			else return visitor.visitChildren(this);
		}
	}
	public static class AssociationHashArgContext extends AssociationContext {
		public AssociationHashArgumentContext associationHashArgument() {
			return getRuleContext(AssociationHashArgumentContext.class,0);
		}
		public AssociationHashArgContext(AssociationContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterAssociationHashArg(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitAssociationHashArg(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitAssociationHashArg(this);
			else return visitor.visitChildren(this);
		}
	}

	public final AssociationContext association() throws RecognitionException {
		AssociationContext _localctx = new AssociationContext(_ctx, getState());
		enterRule(_localctx, 142, RULE_association);
		int _la;
		try {
			setState(1827);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case REGULAR_EXPRESSION_START:
			case LINE__:
			case ENCODING__:
			case FILE__:
			case BEGIN_:
			case END_:
			case ALIAS:
			case AND:
			case BEGIN:
			case BREAK:
			case CASE:
			case CLASS:
			case DEF:
			case IS_DEFINED:
			case DO:
			case ELSE:
			case ELSIF:
			case END:
			case ENSURE:
			case FOR:
			case FALSE:
			case IF:
			case IN:
			case MODULE:
			case NEXT:
			case NIL:
			case NOT:
			case OR:
			case REDO:
			case RESCUE:
			case RETRY:
			case RETURN:
			case SELF:
			case SUPER:
			case THEN:
			case TRUE:
			case UNDEF:
			case UNLESS:
			case UNTIL:
			case WHEN:
			case WHILE:
			case YIELD:
			case LBRACK:
			case LPAREN:
			case LCURLY:
			case COLON:
			case COLON2:
			case MINUSGT:
			case EMARK:
			case PLUS:
			case MINUS:
			case TILDE:
			case SINGLE_QUOTED_STRING_LITERAL:
			case DOUBLE_QUOTED_STRING_START:
			case QUOTED_NON_EXPANDED_STRING_LITERAL_START:
			case QUOTED_EXPANDED_STRING_LITERAL_START:
			case QUOTED_EXPANDED_REGULAR_EXPRESSION_START:
			case QUOTED_EXPANDED_EXTERNAL_COMMAND_LITERAL_START:
			case QUOTED_NON_EXPANDED_STRING_ARRAY_LITERAL_START:
			case QUOTED_EXPANDED_STRING_ARRAY_LITERAL_START:
			case HERE_DOC:
			case QUOTED_NON_EXPANDED_SYMBOL_ARRAY_LITERAL_START:
			case QUOTED_EXPANDED_SYMBOL_ARRAY_LITERAL_START:
			case DECIMAL_INTEGER_LITERAL:
			case BINARY_INTEGER_LITERAL:
			case OCTAL_INTEGER_LITERAL:
			case HEXADECIMAL_INTEGER_LITERAL:
			case FLOAT_LITERAL_WITHOUT_EXPONENT:
			case FLOAT_LITERAL_WITH_EXPONENT:
			case SYMBOL_LITERAL:
			case LOCAL_VARIABLE_IDENTIFIER:
			case GLOBAL_VARIABLE_IDENTIFIER:
			case INSTANCE_VARIABLE_IDENTIFIER:
			case CLASS_VARIABLE_IDENTIFIER:
			case CONSTANT_IDENTIFIER:
				_localctx = new AssociationElementContext(_localctx);
				enterOuterAlt(_localctx, 1);
				{
				setState(1816);
				associationKey();
				setState(1817);
				_la = _input.LA(1);
				if ( !(_la==COLON || _la==EQGT) ) {
				_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				setState(1821);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==NL) {
					{
					{
					setState(1818);
					match(NL);
					}
					}
					setState(1823);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(1824);
				operatorExpression(0);
				}
				break;
			case STAR2:
				_localctx = new AssociationHashArgContext(_localctx);
				enterOuterAlt(_localctx, 2);
				{
				setState(1826);
				associationHashArgument();
				}
				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 AssociationKeyContext extends ParserRuleContext {
		public OperatorExpressionContext operatorExpression() {
			return getRuleContext(OperatorExpressionContext.class,0);
		}
		public KeywordContext keyword() {
			return getRuleContext(KeywordContext.class,0);
		}
		public AssociationKeyContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_associationKey; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterAssociationKey(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitAssociationKey(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitAssociationKey(this);
			else return visitor.visitChildren(this);
		}
	}

	public final AssociationKeyContext associationKey() throws RecognitionException {
		AssociationKeyContext _localctx = new AssociationKeyContext(_ctx, getState());
		enterRule(_localctx, 144, RULE_associationKey);
		try {
			setState(1831);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,252,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(1829);
				operatorExpression(0);
				}
				break;
			case 2:
				enterOuterAlt(_localctx, 2);
				{
				setState(1830);
				keyword();
				}
				break;
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class AssociationHashArgumentContext extends ParserRuleContext {
		public TerminalNode STAR2() { return getToken(RubyParser.STAR2, 0); }
		public TerminalNode LOCAL_VARIABLE_IDENTIFIER() { return getToken(RubyParser.LOCAL_VARIABLE_IDENTIFIER, 0); }
		public MethodCallsWithParenthesesContext methodCallsWithParentheses() {
			return getRuleContext(MethodCallsWithParenthesesContext.class,0);
		}
		public TerminalNode LPAREN() { return getToken(RubyParser.LPAREN, 0); }
		public MethodInvocationWithoutParenthesesContext methodInvocationWithoutParentheses() {
			return getRuleContext(MethodInvocationWithoutParenthesesContext.class,0);
		}
		public TerminalNode RPAREN() { return getToken(RubyParser.RPAREN, 0); }
		public AssociationHashArgumentContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_associationHashArgument; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterAssociationHashArgument(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitAssociationHashArgument(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitAssociationHashArgument(this);
			else return visitor.visitChildren(this);
		}
	}

	public final AssociationHashArgumentContext associationHashArgument() throws RecognitionException {
		AssociationHashArgumentContext _localctx = new AssociationHashArgumentContext(_ctx, getState());
		enterRule(_localctx, 146, RULE_associationHashArgument);
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(1833);
			match(STAR2);
			setState(1840);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,253,_ctx) ) {
			case 1:
				{
				setState(1834);
				match(LOCAL_VARIABLE_IDENTIFIER);
				}
				break;
			case 2:
				{
				setState(1835);
				methodCallsWithParentheses();
				}
				break;
			case 3:
				{
				{
				setState(1836);
				match(LPAREN);
				setState(1837);
				methodInvocationWithoutParentheses();
				setState(1838);
				match(RPAREN);
				}
				}
				break;
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class RegexpLiteralContentContext extends ParserRuleContext {
		public TerminalNode REGULAR_EXPRESSION_BODY() { return getToken(RubyParser.REGULAR_EXPRESSION_BODY, 0); }
		public TerminalNode REGULAR_EXPRESSION_INTERPOLATION_BEGIN() { return getToken(RubyParser.REGULAR_EXPRESSION_INTERPOLATION_BEGIN, 0); }
		public CompoundStatementContext compoundStatement() {
			return getRuleContext(CompoundStatementContext.class,0);
		}
		public TerminalNode REGULAR_EXPRESSION_INTERPOLATION_END() { return getToken(RubyParser.REGULAR_EXPRESSION_INTERPOLATION_END, 0); }
		public RegexpLiteralContentContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_regexpLiteralContent; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterRegexpLiteralContent(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitRegexpLiteralContent(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitRegexpLiteralContent(this);
			else return visitor.visitChildren(this);
		}
	}

	public final RegexpLiteralContentContext regexpLiteralContent() throws RecognitionException {
		RegexpLiteralContentContext _localctx = new RegexpLiteralContentContext(_ctx, getState());
		enterRule(_localctx, 148, RULE_regexpLiteralContent);
		try {
			setState(1847);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case REGULAR_EXPRESSION_BODY:
				enterOuterAlt(_localctx, 1);
				{
				setState(1842);
				match(REGULAR_EXPRESSION_BODY);
				}
				break;
			case REGULAR_EXPRESSION_INTERPOLATION_BEGIN:
				enterOuterAlt(_localctx, 2);
				{
				setState(1843);
				match(REGULAR_EXPRESSION_INTERPOLATION_BEGIN);
				setState(1844);
				compoundStatement();
				setState(1845);
				match(REGULAR_EXPRESSION_INTERPOLATION_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 SingleQuotedStringContext extends ParserRuleContext {
		public TerminalNode SINGLE_QUOTED_STRING_LITERAL() { return getToken(RubyParser.SINGLE_QUOTED_STRING_LITERAL, 0); }
		public SingleQuotedStringContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_singleQuotedString; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterSingleQuotedString(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitSingleQuotedString(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitSingleQuotedString(this);
			else return visitor.visitChildren(this);
		}
	}

	public final SingleQuotedStringContext singleQuotedString() throws RecognitionException {
		SingleQuotedStringContext _localctx = new SingleQuotedStringContext(_ctx, getState());
		enterRule(_localctx, 150, RULE_singleQuotedString);
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(1849);
			match(SINGLE_QUOTED_STRING_LITERAL);
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class SingleOrDoubleQuotedStringContext extends ParserRuleContext {
		public SingleQuotedStringContext singleQuotedString() {
			return getRuleContext(SingleQuotedStringContext.class,0);
		}
		public DoubleQuotedStringContext doubleQuotedString() {
			return getRuleContext(DoubleQuotedStringContext.class,0);
		}
		public SingleOrDoubleQuotedStringContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_singleOrDoubleQuotedString; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterSingleOrDoubleQuotedString(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitSingleOrDoubleQuotedString(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitSingleOrDoubleQuotedString(this);
			else return visitor.visitChildren(this);
		}
	}

	public final SingleOrDoubleQuotedStringContext singleOrDoubleQuotedString() throws RecognitionException {
		SingleOrDoubleQuotedStringContext _localctx = new SingleOrDoubleQuotedStringContext(_ctx, getState());
		enterRule(_localctx, 152, RULE_singleOrDoubleQuotedString);
		try {
			setState(1853);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case SINGLE_QUOTED_STRING_LITERAL:
				enterOuterAlt(_localctx, 1);
				{
				setState(1851);
				singleQuotedString();
				}
				break;
			case DOUBLE_QUOTED_STRING_START:
				enterOuterAlt(_localctx, 2);
				{
				setState(1852);
				doubleQuotedString();
				}
				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 DoubleQuotedStringContext extends ParserRuleContext {
		public TerminalNode DOUBLE_QUOTED_STRING_START() { return getToken(RubyParser.DOUBLE_QUOTED_STRING_START, 0); }
		public TerminalNode DOUBLE_QUOTED_STRING_END() { return getToken(RubyParser.DOUBLE_QUOTED_STRING_END, 0); }
		public List doubleQuotedStringContent() {
			return getRuleContexts(DoubleQuotedStringContentContext.class);
		}
		public DoubleQuotedStringContentContext doubleQuotedStringContent(int i) {
			return getRuleContext(DoubleQuotedStringContentContext.class,i);
		}
		public DoubleQuotedStringContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_doubleQuotedString; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterDoubleQuotedString(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitDoubleQuotedString(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitDoubleQuotedString(this);
			else return visitor.visitChildren(this);
		}
	}

	public final DoubleQuotedStringContext doubleQuotedString() throws RecognitionException {
		DoubleQuotedStringContext _localctx = new DoubleQuotedStringContext(_ctx, getState());
		enterRule(_localctx, 154, RULE_doubleQuotedString);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(1855);
			match(DOUBLE_QUOTED_STRING_START);
			setState(1859);
			_errHandler.sync(this);
			_la = _input.LA(1);
			while (_la==DOUBLE_QUOTED_STRING_CHARACTER_SEQUENCE || _la==STRING_INTERPOLATION_BEGIN) {
				{
				{
				setState(1856);
				doubleQuotedStringContent();
				}
				}
				setState(1861);
				_errHandler.sync(this);
				_la = _input.LA(1);
			}
			setState(1862);
			match(DOUBLE_QUOTED_STRING_END);
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class QuotedExpandedExternalCommandStringContext extends ParserRuleContext {
		public TerminalNode QUOTED_EXPANDED_EXTERNAL_COMMAND_LITERAL_START() { return getToken(RubyParser.QUOTED_EXPANDED_EXTERNAL_COMMAND_LITERAL_START, 0); }
		public TerminalNode QUOTED_EXPANDED_EXTERNAL_COMMAND_LITERAL_END() { return getToken(RubyParser.QUOTED_EXPANDED_EXTERNAL_COMMAND_LITERAL_END, 0); }
		public List quotedExpandedLiteralStringContent() {
			return getRuleContexts(QuotedExpandedLiteralStringContentContext.class);
		}
		public QuotedExpandedLiteralStringContentContext quotedExpandedLiteralStringContent(int i) {
			return getRuleContext(QuotedExpandedLiteralStringContentContext.class,i);
		}
		public QuotedExpandedExternalCommandStringContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_quotedExpandedExternalCommandString; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterQuotedExpandedExternalCommandString(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitQuotedExpandedExternalCommandString(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitQuotedExpandedExternalCommandString(this);
			else return visitor.visitChildren(this);
		}
	}

	public final QuotedExpandedExternalCommandStringContext quotedExpandedExternalCommandString() throws RecognitionException {
		QuotedExpandedExternalCommandStringContext _localctx = new QuotedExpandedExternalCommandStringContext(_ctx, getState());
		enterRule(_localctx, 156, RULE_quotedExpandedExternalCommandString);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(1864);
			match(QUOTED_EXPANDED_EXTERNAL_COMMAND_LITERAL_START);
			setState(1868);
			_errHandler.sync(this);
			_la = _input.LA(1);
			while (_la==EXPANDED_LITERAL_CHARACTER_SEQUENCE || _la==DELIMITED_STRING_INTERPOLATION_BEGIN) {
				{
				{
				setState(1865);
				quotedExpandedLiteralStringContent();
				}
				}
				setState(1870);
				_errHandler.sync(this);
				_la = _input.LA(1);
			}
			setState(1871);
			match(QUOTED_EXPANDED_EXTERNAL_COMMAND_LITERAL_END);
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class DoubleQuotedStringContentContext extends ParserRuleContext {
		public TerminalNode DOUBLE_QUOTED_STRING_CHARACTER_SEQUENCE() { return getToken(RubyParser.DOUBLE_QUOTED_STRING_CHARACTER_SEQUENCE, 0); }
		public TerminalNode STRING_INTERPOLATION_BEGIN() { return getToken(RubyParser.STRING_INTERPOLATION_BEGIN, 0); }
		public CompoundStatementContext compoundStatement() {
			return getRuleContext(CompoundStatementContext.class,0);
		}
		public TerminalNode STRING_INTERPOLATION_END() { return getToken(RubyParser.STRING_INTERPOLATION_END, 0); }
		public DoubleQuotedStringContentContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_doubleQuotedStringContent; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterDoubleQuotedStringContent(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitDoubleQuotedStringContent(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitDoubleQuotedStringContent(this);
			else return visitor.visitChildren(this);
		}
	}

	public final DoubleQuotedStringContentContext doubleQuotedStringContent() throws RecognitionException {
		DoubleQuotedStringContentContext _localctx = new DoubleQuotedStringContentContext(_ctx, getState());
		enterRule(_localctx, 158, RULE_doubleQuotedStringContent);
		try {
			setState(1878);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case DOUBLE_QUOTED_STRING_CHARACTER_SEQUENCE:
				enterOuterAlt(_localctx, 1);
				{
				setState(1873);
				match(DOUBLE_QUOTED_STRING_CHARACTER_SEQUENCE);
				}
				break;
			case STRING_INTERPOLATION_BEGIN:
				enterOuterAlt(_localctx, 2);
				{
				setState(1874);
				match(STRING_INTERPOLATION_BEGIN);
				setState(1875);
				compoundStatement();
				setState(1876);
				match(STRING_INTERPOLATION_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 QuotedNonExpandedLiteralStringContext extends ParserRuleContext {
		public TerminalNode QUOTED_NON_EXPANDED_STRING_LITERAL_START() { return getToken(RubyParser.QUOTED_NON_EXPANDED_STRING_LITERAL_START, 0); }
		public TerminalNode QUOTED_NON_EXPANDED_STRING_LITERAL_END() { return getToken(RubyParser.QUOTED_NON_EXPANDED_STRING_LITERAL_END, 0); }
		public TerminalNode NON_EXPANDED_LITERAL_CHARACTER_SEQUENCE() { return getToken(RubyParser.NON_EXPANDED_LITERAL_CHARACTER_SEQUENCE, 0); }
		public QuotedNonExpandedLiteralStringContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_quotedNonExpandedLiteralString; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterQuotedNonExpandedLiteralString(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitQuotedNonExpandedLiteralString(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitQuotedNonExpandedLiteralString(this);
			else return visitor.visitChildren(this);
		}
	}

	public final QuotedNonExpandedLiteralStringContext quotedNonExpandedLiteralString() throws RecognitionException {
		QuotedNonExpandedLiteralStringContext _localctx = new QuotedNonExpandedLiteralStringContext(_ctx, getState());
		enterRule(_localctx, 160, RULE_quotedNonExpandedLiteralString);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(1880);
			match(QUOTED_NON_EXPANDED_STRING_LITERAL_START);
			setState(1882);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==NON_EXPANDED_LITERAL_CHARACTER_SEQUENCE) {
				{
				setState(1881);
				match(NON_EXPANDED_LITERAL_CHARACTER_SEQUENCE);
				}
			}

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

	public static class QuotedExpandedLiteralStringContext extends ParserRuleContext {
		public TerminalNode QUOTED_EXPANDED_STRING_LITERAL_START() { return getToken(RubyParser.QUOTED_EXPANDED_STRING_LITERAL_START, 0); }
		public TerminalNode QUOTED_EXPANDED_STRING_LITERAL_END() { return getToken(RubyParser.QUOTED_EXPANDED_STRING_LITERAL_END, 0); }
		public List quotedExpandedLiteralStringContent() {
			return getRuleContexts(QuotedExpandedLiteralStringContentContext.class);
		}
		public QuotedExpandedLiteralStringContentContext quotedExpandedLiteralStringContent(int i) {
			return getRuleContext(QuotedExpandedLiteralStringContentContext.class,i);
		}
		public QuotedExpandedLiteralStringContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_quotedExpandedLiteralString; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterQuotedExpandedLiteralString(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitQuotedExpandedLiteralString(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitQuotedExpandedLiteralString(this);
			else return visitor.visitChildren(this);
		}
	}

	public final QuotedExpandedLiteralStringContext quotedExpandedLiteralString() throws RecognitionException {
		QuotedExpandedLiteralStringContext _localctx = new QuotedExpandedLiteralStringContext(_ctx, getState());
		enterRule(_localctx, 162, RULE_quotedExpandedLiteralString);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(1886);
			match(QUOTED_EXPANDED_STRING_LITERAL_START);
			setState(1890);
			_errHandler.sync(this);
			_la = _input.LA(1);
			while (_la==EXPANDED_LITERAL_CHARACTER_SEQUENCE || _la==DELIMITED_STRING_INTERPOLATION_BEGIN) {
				{
				{
				setState(1887);
				quotedExpandedLiteralStringContent();
				}
				}
				setState(1892);
				_errHandler.sync(this);
				_la = _input.LA(1);
			}
			setState(1893);
			match(QUOTED_EXPANDED_STRING_LITERAL_END);
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class QuotedExpandedLiteralStringContentContext extends ParserRuleContext {
		public TerminalNode EXPANDED_LITERAL_CHARACTER_SEQUENCE() { return getToken(RubyParser.EXPANDED_LITERAL_CHARACTER_SEQUENCE, 0); }
		public TerminalNode DELIMITED_STRING_INTERPOLATION_BEGIN() { return getToken(RubyParser.DELIMITED_STRING_INTERPOLATION_BEGIN, 0); }
		public CompoundStatementContext compoundStatement() {
			return getRuleContext(CompoundStatementContext.class,0);
		}
		public TerminalNode DELIMITED_STRING_INTERPOLATION_END() { return getToken(RubyParser.DELIMITED_STRING_INTERPOLATION_END, 0); }
		public QuotedExpandedLiteralStringContentContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_quotedExpandedLiteralStringContent; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterQuotedExpandedLiteralStringContent(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitQuotedExpandedLiteralStringContent(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitQuotedExpandedLiteralStringContent(this);
			else return visitor.visitChildren(this);
		}
	}

	public final QuotedExpandedLiteralStringContentContext quotedExpandedLiteralStringContent() throws RecognitionException {
		QuotedExpandedLiteralStringContentContext _localctx = new QuotedExpandedLiteralStringContentContext(_ctx, getState());
		enterRule(_localctx, 164, RULE_quotedExpandedLiteralStringContent);
		try {
			setState(1900);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case EXPANDED_LITERAL_CHARACTER_SEQUENCE:
				enterOuterAlt(_localctx, 1);
				{
				setState(1895);
				match(EXPANDED_LITERAL_CHARACTER_SEQUENCE);
				}
				break;
			case DELIMITED_STRING_INTERPOLATION_BEGIN:
				enterOuterAlt(_localctx, 2);
				{
				setState(1896);
				match(DELIMITED_STRING_INTERPOLATION_BEGIN);
				setState(1897);
				compoundStatement();
				setState(1898);
				match(DELIMITED_STRING_INTERPOLATION_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 QuotedNonExpandedArrayElementContentContext extends ParserRuleContext {
		public List NON_EXPANDED_ARRAY_ITEM_CHARACTER() { return getTokens(RubyParser.NON_EXPANDED_ARRAY_ITEM_CHARACTER); }
		public TerminalNode NON_EXPANDED_ARRAY_ITEM_CHARACTER(int i) {
			return getToken(RubyParser.NON_EXPANDED_ARRAY_ITEM_CHARACTER, i);
		}
		public QuotedNonExpandedArrayElementContentContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_quotedNonExpandedArrayElementContent; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterQuotedNonExpandedArrayElementContent(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitQuotedNonExpandedArrayElementContent(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitQuotedNonExpandedArrayElementContent(this);
			else return visitor.visitChildren(this);
		}
	}

	public final QuotedNonExpandedArrayElementContentContext quotedNonExpandedArrayElementContent() throws RecognitionException {
		QuotedNonExpandedArrayElementContentContext _localctx = new QuotedNonExpandedArrayElementContentContext(_ctx, getState());
		enterRule(_localctx, 166, RULE_quotedNonExpandedArrayElementContent);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(1903); 
			_errHandler.sync(this);
			_la = _input.LA(1);
			do {
				{
				{
				setState(1902);
				match(NON_EXPANDED_ARRAY_ITEM_CHARACTER);
				}
				}
				setState(1905); 
				_errHandler.sync(this);
				_la = _input.LA(1);
			} while ( _la==NON_EXPANDED_ARRAY_ITEM_CHARACTER );
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class QuotedExpandedArrayElementContentContext extends ParserRuleContext {
		public TerminalNode EXPANDED_ARRAY_ITEM_CHARACTER() { return getToken(RubyParser.EXPANDED_ARRAY_ITEM_CHARACTER, 0); }
		public TerminalNode DELIMITED_ARRAY_ITEM_INTERPOLATION_BEGIN() { return getToken(RubyParser.DELIMITED_ARRAY_ITEM_INTERPOLATION_BEGIN, 0); }
		public CompoundStatementContext compoundStatement() {
			return getRuleContext(CompoundStatementContext.class,0);
		}
		public TerminalNode DELIMITED_ARRAY_ITEM_INTERPOLATION_END() { return getToken(RubyParser.DELIMITED_ARRAY_ITEM_INTERPOLATION_END, 0); }
		public QuotedExpandedArrayElementContentContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_quotedExpandedArrayElementContent; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterQuotedExpandedArrayElementContent(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitQuotedExpandedArrayElementContent(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitQuotedExpandedArrayElementContent(this);
			else return visitor.visitChildren(this);
		}
	}

	public final QuotedExpandedArrayElementContentContext quotedExpandedArrayElementContent() throws RecognitionException {
		QuotedExpandedArrayElementContentContext _localctx = new QuotedExpandedArrayElementContentContext(_ctx, getState());
		enterRule(_localctx, 168, RULE_quotedExpandedArrayElementContent);
		try {
			setState(1912);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case EXPANDED_ARRAY_ITEM_CHARACTER:
				enterOuterAlt(_localctx, 1);
				{
				setState(1907);
				match(EXPANDED_ARRAY_ITEM_CHARACTER);
				}
				break;
			case DELIMITED_ARRAY_ITEM_INTERPOLATION_BEGIN:
				enterOuterAlt(_localctx, 2);
				{
				setState(1908);
				match(DELIMITED_ARRAY_ITEM_INTERPOLATION_BEGIN);
				setState(1909);
				compoundStatement();
				setState(1910);
				match(DELIMITED_ARRAY_ITEM_INTERPOLATION_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 QuotedExpandedArrayElementContext extends ParserRuleContext {
		public List quotedExpandedArrayElementContent() {
			return getRuleContexts(QuotedExpandedArrayElementContentContext.class);
		}
		public QuotedExpandedArrayElementContentContext quotedExpandedArrayElementContent(int i) {
			return getRuleContext(QuotedExpandedArrayElementContentContext.class,i);
		}
		public QuotedExpandedArrayElementContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_quotedExpandedArrayElement; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterQuotedExpandedArrayElement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitQuotedExpandedArrayElement(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitQuotedExpandedArrayElement(this);
			else return visitor.visitChildren(this);
		}
	}

	public final QuotedExpandedArrayElementContext quotedExpandedArrayElement() throws RecognitionException {
		QuotedExpandedArrayElementContext _localctx = new QuotedExpandedArrayElementContext(_ctx, getState());
		enterRule(_localctx, 170, RULE_quotedExpandedArrayElement);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(1915); 
			_errHandler.sync(this);
			_la = _input.LA(1);
			do {
				{
				{
				setState(1914);
				quotedExpandedArrayElementContent();
				}
				}
				setState(1917); 
				_errHandler.sync(this);
				_la = _input.LA(1);
			} while ( _la==DELIMITED_ARRAY_ITEM_INTERPOLATION_BEGIN || _la==EXPANDED_ARRAY_ITEM_CHARACTER );
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class QuotedNonExpandedArrayElementListContext extends ParserRuleContext {
		public List quotedNonExpandedArrayElementContent() {
			return getRuleContexts(QuotedNonExpandedArrayElementContentContext.class);
		}
		public QuotedNonExpandedArrayElementContentContext quotedNonExpandedArrayElementContent(int i) {
			return getRuleContext(QuotedNonExpandedArrayElementContentContext.class,i);
		}
		public List NON_EXPANDED_ARRAY_ITEM_SEPARATOR() { return getTokens(RubyParser.NON_EXPANDED_ARRAY_ITEM_SEPARATOR); }
		public TerminalNode NON_EXPANDED_ARRAY_ITEM_SEPARATOR(int i) {
			return getToken(RubyParser.NON_EXPANDED_ARRAY_ITEM_SEPARATOR, i);
		}
		public QuotedNonExpandedArrayElementListContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_quotedNonExpandedArrayElementList; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterQuotedNonExpandedArrayElementList(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitQuotedNonExpandedArrayElementList(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitQuotedNonExpandedArrayElementList(this);
			else return visitor.visitChildren(this);
		}
	}

	public final QuotedNonExpandedArrayElementListContext quotedNonExpandedArrayElementList() throws RecognitionException {
		QuotedNonExpandedArrayElementListContext _localctx = new QuotedNonExpandedArrayElementListContext(_ctx, getState());
		enterRule(_localctx, 172, RULE_quotedNonExpandedArrayElementList);
		int _la;
		try {
			int _alt;
			enterOuterAlt(_localctx, 1);
			{
			setState(1922);
			_errHandler.sync(this);
			_la = _input.LA(1);
			while (_la==NON_EXPANDED_ARRAY_ITEM_SEPARATOR) {
				{
				{
				setState(1919);
				match(NON_EXPANDED_ARRAY_ITEM_SEPARATOR);
				}
				}
				setState(1924);
				_errHandler.sync(this);
				_la = _input.LA(1);
			}
			setState(1925);
			quotedNonExpandedArrayElementContent();
			setState(1934);
			_errHandler.sync(this);
			_alt = getInterpreter().adaptivePredict(_input,267,_ctx);
			while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) {
				if ( _alt==1 ) {
					{
					{
					setState(1927); 
					_errHandler.sync(this);
					_la = _input.LA(1);
					do {
						{
						{
						setState(1926);
						match(NON_EXPANDED_ARRAY_ITEM_SEPARATOR);
						}
						}
						setState(1929); 
						_errHandler.sync(this);
						_la = _input.LA(1);
					} while ( _la==NON_EXPANDED_ARRAY_ITEM_SEPARATOR );
					setState(1931);
					quotedNonExpandedArrayElementContent();
					}
					} 
				}
				setState(1936);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,267,_ctx);
			}
			setState(1940);
			_errHandler.sync(this);
			_la = _input.LA(1);
			while (_la==NON_EXPANDED_ARRAY_ITEM_SEPARATOR) {
				{
				{
				setState(1937);
				match(NON_EXPANDED_ARRAY_ITEM_SEPARATOR);
				}
				}
				setState(1942);
				_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 QuotedExpandedArrayElementListContext extends ParserRuleContext {
		public List quotedExpandedArrayElement() {
			return getRuleContexts(QuotedExpandedArrayElementContext.class);
		}
		public QuotedExpandedArrayElementContext quotedExpandedArrayElement(int i) {
			return getRuleContext(QuotedExpandedArrayElementContext.class,i);
		}
		public List EXPANDED_ARRAY_ITEM_SEPARATOR() { return getTokens(RubyParser.EXPANDED_ARRAY_ITEM_SEPARATOR); }
		public TerminalNode EXPANDED_ARRAY_ITEM_SEPARATOR(int i) {
			return getToken(RubyParser.EXPANDED_ARRAY_ITEM_SEPARATOR, i);
		}
		public QuotedExpandedArrayElementListContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_quotedExpandedArrayElementList; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterQuotedExpandedArrayElementList(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitQuotedExpandedArrayElementList(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitQuotedExpandedArrayElementList(this);
			else return visitor.visitChildren(this);
		}
	}

	public final QuotedExpandedArrayElementListContext quotedExpandedArrayElementList() throws RecognitionException {
		QuotedExpandedArrayElementListContext _localctx = new QuotedExpandedArrayElementListContext(_ctx, getState());
		enterRule(_localctx, 174, RULE_quotedExpandedArrayElementList);
		int _la;
		try {
			int _alt;
			enterOuterAlt(_localctx, 1);
			{
			setState(1946);
			_errHandler.sync(this);
			_la = _input.LA(1);
			while (_la==EXPANDED_ARRAY_ITEM_SEPARATOR) {
				{
				{
				setState(1943);
				match(EXPANDED_ARRAY_ITEM_SEPARATOR);
				}
				}
				setState(1948);
				_errHandler.sync(this);
				_la = _input.LA(1);
			}
			setState(1949);
			quotedExpandedArrayElement();
			setState(1958);
			_errHandler.sync(this);
			_alt = getInterpreter().adaptivePredict(_input,271,_ctx);
			while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) {
				if ( _alt==1 ) {
					{
					{
					setState(1951); 
					_errHandler.sync(this);
					_la = _input.LA(1);
					do {
						{
						{
						setState(1950);
						match(EXPANDED_ARRAY_ITEM_SEPARATOR);
						}
						}
						setState(1953); 
						_errHandler.sync(this);
						_la = _input.LA(1);
					} while ( _la==EXPANDED_ARRAY_ITEM_SEPARATOR );
					setState(1955);
					quotedExpandedArrayElement();
					}
					} 
				}
				setState(1960);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,271,_ctx);
			}
			setState(1964);
			_errHandler.sync(this);
			_la = _input.LA(1);
			while (_la==EXPANDED_ARRAY_ITEM_SEPARATOR) {
				{
				{
				setState(1961);
				match(EXPANDED_ARRAY_ITEM_SEPARATOR);
				}
				}
				setState(1966);
				_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 SymbolContext extends ParserRuleContext {
		public SymbolContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_symbol; }
	 
		public SymbolContext() { }
		public void copyFrom(SymbolContext ctx) {
			super.copyFrom(ctx);
		}
	}
	public static class SingleQuotedSymbolLiteralContext extends SymbolContext {
		public TerminalNode COLON() { return getToken(RubyParser.COLON, 0); }
		public SingleQuotedStringContext singleQuotedString() {
			return getRuleContext(SingleQuotedStringContext.class,0);
		}
		public SingleQuotedSymbolLiteralContext(SymbolContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterSingleQuotedSymbolLiteral(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitSingleQuotedSymbolLiteral(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitSingleQuotedSymbolLiteral(this);
			else return visitor.visitChildren(this);
		}
	}
	public static class DoubleQuotedSymbolLiteralContext extends SymbolContext {
		public TerminalNode COLON() { return getToken(RubyParser.COLON, 0); }
		public DoubleQuotedStringContext doubleQuotedString() {
			return getRuleContext(DoubleQuotedStringContext.class,0);
		}
		public DoubleQuotedSymbolLiteralContext(SymbolContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterDoubleQuotedSymbolLiteral(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitDoubleQuotedSymbolLiteral(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitDoubleQuotedSymbolLiteral(this);
			else return visitor.visitChildren(this);
		}
	}
	public static class PureSymbolLiteralContext extends SymbolContext {
		public TerminalNode SYMBOL_LITERAL() { return getToken(RubyParser.SYMBOL_LITERAL, 0); }
		public PureSymbolLiteralContext(SymbolContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterPureSymbolLiteral(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitPureSymbolLiteral(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitPureSymbolLiteral(this);
			else return visitor.visitChildren(this);
		}
	}

	public final SymbolContext symbol() throws RecognitionException {
		SymbolContext _localctx = new SymbolContext(_ctx, getState());
		enterRule(_localctx, 176, RULE_symbol);
		try {
			setState(1972);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,273,_ctx) ) {
			case 1:
				_localctx = new PureSymbolLiteralContext(_localctx);
				enterOuterAlt(_localctx, 1);
				{
				setState(1967);
				match(SYMBOL_LITERAL);
				}
				break;
			case 2:
				_localctx = new SingleQuotedSymbolLiteralContext(_localctx);
				enterOuterAlt(_localctx, 2);
				{
				setState(1968);
				match(COLON);
				setState(1969);
				singleQuotedString();
				}
				break;
			case 3:
				_localctx = new DoubleQuotedSymbolLiteralContext(_localctx);
				enterOuterAlt(_localctx, 3);
				{
				setState(1970);
				match(COLON);
				setState(1971);
				doubleQuotedString();
				}
				break;
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class HereDocContext extends ParserRuleContext {
		public TerminalNode HERE_DOC() { return getToken(RubyParser.HERE_DOC, 0); }
		public HereDocContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_hereDoc; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterHereDoc(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitHereDoc(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitHereDoc(this);
			else return visitor.visitChildren(this);
		}
	}

	public final HereDocContext hereDoc() throws RecognitionException {
		HereDocContext _localctx = new HereDocContext(_ctx, getState());
		enterRule(_localctx, 178, RULE_hereDoc);
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(1974);
			match(HERE_DOC);
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class IsDefinedKeywordContext extends ParserRuleContext {
		public TerminalNode IS_DEFINED() { return getToken(RubyParser.IS_DEFINED, 0); }
		public IsDefinedKeywordContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_isDefinedKeyword; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterIsDefinedKeyword(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitIsDefinedKeyword(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitIsDefinedKeyword(this);
			else return visitor.visitChildren(this);
		}
	}

	public final IsDefinedKeywordContext isDefinedKeyword() throws RecognitionException {
		IsDefinedKeywordContext _localctx = new IsDefinedKeywordContext(_ctx, getState());
		enterRule(_localctx, 180, RULE_isDefinedKeyword);
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(1976);
			match(IS_DEFINED);
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class AssignmentOperatorContext extends ParserRuleContext {
		public TerminalNode EQ() { return getToken(RubyParser.EQ, 0); }
		public TerminalNode ASSIGNMENT_OPERATOR() { return getToken(RubyParser.ASSIGNMENT_OPERATOR, 0); }
		public AssignmentOperatorContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_assignmentOperator; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterAssignmentOperator(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitAssignmentOperator(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitAssignmentOperator(this);
			else return visitor.visitChildren(this);
		}
	}

	public final AssignmentOperatorContext assignmentOperator() throws RecognitionException {
		AssignmentOperatorContext _localctx = new AssignmentOperatorContext(_ctx, getState());
		enterRule(_localctx, 182, RULE_assignmentOperator);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(1978);
			_la = _input.LA(1);
			if ( !(_la==EQ || _la==ASSIGNMENT_OPERATOR) ) {
			_errHandler.recoverInline(this);
			}
			else {
				if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
				_errHandler.reportMatch(this);
				consume();
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class StatementModifierContext extends ParserRuleContext {
		public TerminalNode IF() { return getToken(RubyParser.IF, 0); }
		public TerminalNode UNLESS() { return getToken(RubyParser.UNLESS, 0); }
		public TerminalNode WHILE() { return getToken(RubyParser.WHILE, 0); }
		public TerminalNode UNTIL() { return getToken(RubyParser.UNTIL, 0); }
		public TerminalNode RESCUE() { return getToken(RubyParser.RESCUE, 0); }
		public StatementModifierContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_statementModifier; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterStatementModifier(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitStatementModifier(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitStatementModifier(this);
			else return visitor.visitChildren(this);
		}
	}

	public final StatementModifierContext statementModifier() throws RecognitionException {
		StatementModifierContext _localctx = new StatementModifierContext(_ctx, getState());
		enterRule(_localctx, 184, RULE_statementModifier);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(1980);
			_la = _input.LA(1);
			if ( !((((_la) & ~0x3f) == 0 && ((1L << _la) & ((1L << IF) | (1L << RESCUE) | (1L << UNLESS) | (1L << UNTIL) | (1L << WHILE))) != 0)) ) {
			_errHandler.recoverInline(this);
			}
			else {
				if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
				_errHandler.reportMatch(this);
				consume();
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class VariableContext extends ParserRuleContext {
		public VariableContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_variable; }
	 
		public VariableContext() { }
		public void copyFrom(VariableContext ctx) {
			super.copyFrom(ctx);
		}
	}
	public static class ConstantIdentifierVariableContext extends VariableContext {
		public TerminalNode CONSTANT_IDENTIFIER() { return getToken(RubyParser.CONSTANT_IDENTIFIER, 0); }
		public ConstantIdentifierVariableContext(VariableContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterConstantIdentifierVariable(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitConstantIdentifierVariable(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitConstantIdentifierVariable(this);
			else return visitor.visitChildren(this);
		}
	}
	public static class ClassIdentifierVariableContext extends VariableContext {
		public TerminalNode CLASS_VARIABLE_IDENTIFIER() { return getToken(RubyParser.CLASS_VARIABLE_IDENTIFIER, 0); }
		public ClassIdentifierVariableContext(VariableContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterClassIdentifierVariable(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitClassIdentifierVariable(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitClassIdentifierVariable(this);
			else return visitor.visitChildren(this);
		}
	}
	public static class InstanceIdentifierVariableContext extends VariableContext {
		public TerminalNode INSTANCE_VARIABLE_IDENTIFIER() { return getToken(RubyParser.INSTANCE_VARIABLE_IDENTIFIER, 0); }
		public InstanceIdentifierVariableContext(VariableContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterInstanceIdentifierVariable(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitInstanceIdentifierVariable(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitInstanceIdentifierVariable(this);
			else return visitor.visitChildren(this);
		}
	}
	public static class GlobalIdentifierVariableContext extends VariableContext {
		public TerminalNode GLOBAL_VARIABLE_IDENTIFIER() { return getToken(RubyParser.GLOBAL_VARIABLE_IDENTIFIER, 0); }
		public GlobalIdentifierVariableContext(VariableContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterGlobalIdentifierVariable(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitGlobalIdentifierVariable(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitGlobalIdentifierVariable(this);
			else return visitor.visitChildren(this);
		}
	}
	public static class LocalIdentifierVariableContext extends VariableContext {
		public TerminalNode LOCAL_VARIABLE_IDENTIFIER() { return getToken(RubyParser.LOCAL_VARIABLE_IDENTIFIER, 0); }
		public LocalIdentifierVariableContext(VariableContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterLocalIdentifierVariable(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitLocalIdentifierVariable(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitLocalIdentifierVariable(this);
			else return visitor.visitChildren(this);
		}
	}

	public final VariableContext variable() throws RecognitionException {
		VariableContext _localctx = new VariableContext(_ctx, getState());
		enterRule(_localctx, 186, RULE_variable);
		try {
			setState(1987);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case CONSTANT_IDENTIFIER:
				_localctx = new ConstantIdentifierVariableContext(_localctx);
				enterOuterAlt(_localctx, 1);
				{
				setState(1982);
				match(CONSTANT_IDENTIFIER);
				}
				break;
			case GLOBAL_VARIABLE_IDENTIFIER:
				_localctx = new GlobalIdentifierVariableContext(_localctx);
				enterOuterAlt(_localctx, 2);
				{
				setState(1983);
				match(GLOBAL_VARIABLE_IDENTIFIER);
				}
				break;
			case CLASS_VARIABLE_IDENTIFIER:
				_localctx = new ClassIdentifierVariableContext(_localctx);
				enterOuterAlt(_localctx, 3);
				{
				setState(1984);
				match(CLASS_VARIABLE_IDENTIFIER);
				}
				break;
			case INSTANCE_VARIABLE_IDENTIFIER:
				_localctx = new InstanceIdentifierVariableContext(_localctx);
				enterOuterAlt(_localctx, 4);
				{
				setState(1985);
				match(INSTANCE_VARIABLE_IDENTIFIER);
				}
				break;
			case LOCAL_VARIABLE_IDENTIFIER:
				_localctx = new LocalIdentifierVariableContext(_localctx);
				enterOuterAlt(_localctx, 5);
				{
				setState(1986);
				match(LOCAL_VARIABLE_IDENTIFIER);
				}
				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 PseudoVariableContext extends ParserRuleContext {
		public PseudoVariableContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_pseudoVariable; }
	 
		public PseudoVariableContext() { }
		public void copyFrom(PseudoVariableContext ctx) {
			super.copyFrom(ctx);
		}
	}
	public static class FalsePseudoVariableContext extends PseudoVariableContext {
		public TerminalNode FALSE() { return getToken(RubyParser.FALSE, 0); }
		public FalsePseudoVariableContext(PseudoVariableContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterFalsePseudoVariable(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitFalsePseudoVariable(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitFalsePseudoVariable(this);
			else return visitor.visitChildren(this);
		}
	}
	public static class SelfPseudoVariableContext extends PseudoVariableContext {
		public TerminalNode SELF() { return getToken(RubyParser.SELF, 0); }
		public SelfPseudoVariableContext(PseudoVariableContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterSelfPseudoVariable(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitSelfPseudoVariable(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitSelfPseudoVariable(this);
			else return visitor.visitChildren(this);
		}
	}
	public static class TruePseudoVariableContext extends PseudoVariableContext {
		public TerminalNode TRUE() { return getToken(RubyParser.TRUE, 0); }
		public TruePseudoVariableContext(PseudoVariableContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterTruePseudoVariable(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitTruePseudoVariable(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitTruePseudoVariable(this);
			else return visitor.visitChildren(this);
		}
	}
	public static class LinePseudoVariableContext extends PseudoVariableContext {
		public TerminalNode LINE__() { return getToken(RubyParser.LINE__, 0); }
		public LinePseudoVariableContext(PseudoVariableContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterLinePseudoVariable(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitLinePseudoVariable(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitLinePseudoVariable(this);
			else return visitor.visitChildren(this);
		}
	}
	public static class NilPseudoVariableContext extends PseudoVariableContext {
		public TerminalNode NIL() { return getToken(RubyParser.NIL, 0); }
		public NilPseudoVariableContext(PseudoVariableContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterNilPseudoVariable(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitNilPseudoVariable(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitNilPseudoVariable(this);
			else return visitor.visitChildren(this);
		}
	}
	public static class FilePseudoVariableContext extends PseudoVariableContext {
		public TerminalNode FILE__() { return getToken(RubyParser.FILE__, 0); }
		public FilePseudoVariableContext(PseudoVariableContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterFilePseudoVariable(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitFilePseudoVariable(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitFilePseudoVariable(this);
			else return visitor.visitChildren(this);
		}
	}
	public static class EncodingPseudoVariableContext extends PseudoVariableContext {
		public TerminalNode ENCODING__() { return getToken(RubyParser.ENCODING__, 0); }
		public EncodingPseudoVariableContext(PseudoVariableContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterEncodingPseudoVariable(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitEncodingPseudoVariable(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitEncodingPseudoVariable(this);
			else return visitor.visitChildren(this);
		}
	}

	public final PseudoVariableContext pseudoVariable() throws RecognitionException {
		PseudoVariableContext _localctx = new PseudoVariableContext(_ctx, getState());
		enterRule(_localctx, 188, RULE_pseudoVariable);
		try {
			setState(1996);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case NIL:
				_localctx = new NilPseudoVariableContext(_localctx);
				enterOuterAlt(_localctx, 1);
				{
				setState(1989);
				match(NIL);
				}
				break;
			case TRUE:
				_localctx = new TruePseudoVariableContext(_localctx);
				enterOuterAlt(_localctx, 2);
				{
				setState(1990);
				match(TRUE);
				}
				break;
			case FALSE:
				_localctx = new FalsePseudoVariableContext(_localctx);
				enterOuterAlt(_localctx, 3);
				{
				setState(1991);
				match(FALSE);
				}
				break;
			case SELF:
				_localctx = new SelfPseudoVariableContext(_localctx);
				enterOuterAlt(_localctx, 4);
				{
				setState(1992);
				match(SELF);
				}
				break;
			case LINE__:
				_localctx = new LinePseudoVariableContext(_localctx);
				enterOuterAlt(_localctx, 5);
				{
				setState(1993);
				match(LINE__);
				}
				break;
			case FILE__:
				_localctx = new FilePseudoVariableContext(_localctx);
				enterOuterAlt(_localctx, 6);
				{
				setState(1994);
				match(FILE__);
				}
				break;
			case ENCODING__:
				_localctx = new EncodingPseudoVariableContext(_localctx);
				enterOuterAlt(_localctx, 7);
				{
				setState(1995);
				match(ENCODING__);
				}
				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 UnsignedNumericLiteralContext extends ParserRuleContext {
		public UnsignedNumericLiteralContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_unsignedNumericLiteral; }
	 
		public UnsignedNumericLiteralContext() { }
		public void copyFrom(UnsignedNumericLiteralContext ctx) {
			super.copyFrom(ctx);
		}
	}
	public static class FloatWithoutExponentUnsignedLiteralContext extends UnsignedNumericLiteralContext {
		public TerminalNode FLOAT_LITERAL_WITHOUT_EXPONENT() { return getToken(RubyParser.FLOAT_LITERAL_WITHOUT_EXPONENT, 0); }
		public FloatWithoutExponentUnsignedLiteralContext(UnsignedNumericLiteralContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterFloatWithoutExponentUnsignedLiteral(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitFloatWithoutExponentUnsignedLiteral(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitFloatWithoutExponentUnsignedLiteral(this);
			else return visitor.visitChildren(this);
		}
	}
	public static class FloatWithExponentUnsignedLiteralContext extends UnsignedNumericLiteralContext {
		public TerminalNode FLOAT_LITERAL_WITH_EXPONENT() { return getToken(RubyParser.FLOAT_LITERAL_WITH_EXPONENT, 0); }
		public FloatWithExponentUnsignedLiteralContext(UnsignedNumericLiteralContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterFloatWithExponentUnsignedLiteral(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitFloatWithExponentUnsignedLiteral(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitFloatWithExponentUnsignedLiteral(this);
			else return visitor.visitChildren(this);
		}
	}
	public static class DecimalUnsignedLiteralContext extends UnsignedNumericLiteralContext {
		public TerminalNode DECIMAL_INTEGER_LITERAL() { return getToken(RubyParser.DECIMAL_INTEGER_LITERAL, 0); }
		public DecimalUnsignedLiteralContext(UnsignedNumericLiteralContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterDecimalUnsignedLiteral(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitDecimalUnsignedLiteral(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitDecimalUnsignedLiteral(this);
			else return visitor.visitChildren(this);
		}
	}
	public static class BinaryUnsignedLiteralContext extends UnsignedNumericLiteralContext {
		public TerminalNode BINARY_INTEGER_LITERAL() { return getToken(RubyParser.BINARY_INTEGER_LITERAL, 0); }
		public BinaryUnsignedLiteralContext(UnsignedNumericLiteralContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterBinaryUnsignedLiteral(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitBinaryUnsignedLiteral(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitBinaryUnsignedLiteral(this);
			else return visitor.visitChildren(this);
		}
	}
	public static class OctalUnsignedLiteralContext extends UnsignedNumericLiteralContext {
		public TerminalNode OCTAL_INTEGER_LITERAL() { return getToken(RubyParser.OCTAL_INTEGER_LITERAL, 0); }
		public OctalUnsignedLiteralContext(UnsignedNumericLiteralContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterOctalUnsignedLiteral(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitOctalUnsignedLiteral(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitOctalUnsignedLiteral(this);
			else return visitor.visitChildren(this);
		}
	}
	public static class HexadecimalUnsignedLiteralContext extends UnsignedNumericLiteralContext {
		public TerminalNode HEXADECIMAL_INTEGER_LITERAL() { return getToken(RubyParser.HEXADECIMAL_INTEGER_LITERAL, 0); }
		public HexadecimalUnsignedLiteralContext(UnsignedNumericLiteralContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterHexadecimalUnsignedLiteral(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitHexadecimalUnsignedLiteral(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitHexadecimalUnsignedLiteral(this);
			else return visitor.visitChildren(this);
		}
	}

	public final UnsignedNumericLiteralContext unsignedNumericLiteral() throws RecognitionException {
		UnsignedNumericLiteralContext _localctx = new UnsignedNumericLiteralContext(_ctx, getState());
		enterRule(_localctx, 190, RULE_unsignedNumericLiteral);
		try {
			setState(2004);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case DECIMAL_INTEGER_LITERAL:
				_localctx = new DecimalUnsignedLiteralContext(_localctx);
				enterOuterAlt(_localctx, 1);
				{
				setState(1998);
				match(DECIMAL_INTEGER_LITERAL);
				}
				break;
			case BINARY_INTEGER_LITERAL:
				_localctx = new BinaryUnsignedLiteralContext(_localctx);
				enterOuterAlt(_localctx, 2);
				{
				setState(1999);
				match(BINARY_INTEGER_LITERAL);
				}
				break;
			case OCTAL_INTEGER_LITERAL:
				_localctx = new OctalUnsignedLiteralContext(_localctx);
				enterOuterAlt(_localctx, 3);
				{
				setState(2000);
				match(OCTAL_INTEGER_LITERAL);
				}
				break;
			case HEXADECIMAL_INTEGER_LITERAL:
				_localctx = new HexadecimalUnsignedLiteralContext(_localctx);
				enterOuterAlt(_localctx, 4);
				{
				setState(2001);
				match(HEXADECIMAL_INTEGER_LITERAL);
				}
				break;
			case FLOAT_LITERAL_WITHOUT_EXPONENT:
				_localctx = new FloatWithoutExponentUnsignedLiteralContext(_localctx);
				enterOuterAlt(_localctx, 5);
				{
				setState(2002);
				match(FLOAT_LITERAL_WITHOUT_EXPONENT);
				}
				break;
			case FLOAT_LITERAL_WITH_EXPONENT:
				_localctx = new FloatWithExponentUnsignedLiteralContext(_localctx);
				enterOuterAlt(_localctx, 6);
				{
				setState(2003);
				match(FLOAT_LITERAL_WITH_EXPONENT);
				}
				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 UnaryOperatorContext extends ParserRuleContext {
		public TerminalNode TILDE() { return getToken(RubyParser.TILDE, 0); }
		public TerminalNode PLUS() { return getToken(RubyParser.PLUS, 0); }
		public TerminalNode EMARK() { return getToken(RubyParser.EMARK, 0); }
		public UnaryOperatorContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_unaryOperator; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterUnaryOperator(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitUnaryOperator(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitUnaryOperator(this);
			else return visitor.visitChildren(this);
		}
	}

	public final UnaryOperatorContext unaryOperator() throws RecognitionException {
		UnaryOperatorContext _localctx = new UnaryOperatorContext(_ctx, getState());
		enterRule(_localctx, 192, RULE_unaryOperator);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(2006);
			_la = _input.LA(1);
			if ( !(((((_la - 73)) & ~0x3f) == 0 && ((1L << (_la - 73)) & ((1L << (EMARK - 73)) | (1L << (PLUS - 73)) | (1L << (TILDE - 73)))) != 0)) ) {
			_errHandler.recoverInline(this);
			}
			else {
				if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
				_errHandler.reportMatch(this);
				consume();
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class MultiplicativeOperatorContext extends ParserRuleContext {
		public TerminalNode STAR() { return getToken(RubyParser.STAR, 0); }
		public TerminalNode SLASH() { return getToken(RubyParser.SLASH, 0); }
		public TerminalNode PERCENT() { return getToken(RubyParser.PERCENT, 0); }
		public MultiplicativeOperatorContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_multiplicativeOperator; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterMultiplicativeOperator(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitMultiplicativeOperator(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitMultiplicativeOperator(this);
			else return visitor.visitChildren(this);
		}
	}

	public final MultiplicativeOperatorContext multiplicativeOperator() throws RecognitionException {
		MultiplicativeOperatorContext _localctx = new MultiplicativeOperatorContext(_ctx, getState());
		enterRule(_localctx, 194, RULE_multiplicativeOperator);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(2008);
			_la = _input.LA(1);
			if ( !(((((_la - 95)) & ~0x3f) == 0 && ((1L << (_la - 95)) & ((1L << (STAR - 95)) | (1L << (SLASH - 95)) | (1L << (PERCENT - 95)))) != 0)) ) {
			_errHandler.recoverInline(this);
			}
			else {
				if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
				_errHandler.reportMatch(this);
				consume();
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class AdditiveOperatorContext extends ParserRuleContext {
		public TerminalNode PLUS() { return getToken(RubyParser.PLUS, 0); }
		public TerminalNode MINUS() { return getToken(RubyParser.MINUS, 0); }
		public AdditiveOperatorContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_additiveOperator; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterAdditiveOperator(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitAdditiveOperator(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitAdditiveOperator(this);
			else return visitor.visitChildren(this);
		}
	}

	public final AdditiveOperatorContext additiveOperator() throws RecognitionException {
		AdditiveOperatorContext _localctx = new AdditiveOperatorContext(_ctx, getState());
		enterRule(_localctx, 196, RULE_additiveOperator);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(2010);
			_la = _input.LA(1);
			if ( !(_la==PLUS || _la==MINUS) ) {
			_errHandler.recoverInline(this);
			}
			else {
				if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
				_errHandler.reportMatch(this);
				consume();
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class BitwiseShiftOperatorContext extends ParserRuleContext {
		public TerminalNode LT2() { return getToken(RubyParser.LT2, 0); }
		public TerminalNode GT2() { return getToken(RubyParser.GT2, 0); }
		public BitwiseShiftOperatorContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_bitwiseShiftOperator; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterBitwiseShiftOperator(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitBitwiseShiftOperator(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitBitwiseShiftOperator(this);
			else return visitor.visitChildren(this);
		}
	}

	public final BitwiseShiftOperatorContext bitwiseShiftOperator() throws RecognitionException {
		BitwiseShiftOperatorContext _localctx = new BitwiseShiftOperatorContext(_ctx, getState());
		enterRule(_localctx, 198, RULE_bitwiseShiftOperator);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(2012);
			_la = _input.LA(1);
			if ( !(_la==LT2 || _la==GT2) ) {
			_errHandler.recoverInline(this);
			}
			else {
				if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
				_errHandler.reportMatch(this);
				consume();
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class BitwiseOrOperatorContext extends ParserRuleContext {
		public TerminalNode BAR() { return getToken(RubyParser.BAR, 0); }
		public TerminalNode CARET() { return getToken(RubyParser.CARET, 0); }
		public BitwiseOrOperatorContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_bitwiseOrOperator; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterBitwiseOrOperator(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitBitwiseOrOperator(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitBitwiseOrOperator(this);
			else return visitor.visitChildren(this);
		}
	}

	public final BitwiseOrOperatorContext bitwiseOrOperator() throws RecognitionException {
		BitwiseOrOperatorContext _localctx = new BitwiseOrOperatorContext(_ctx, getState());
		enterRule(_localctx, 200, RULE_bitwiseOrOperator);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(2014);
			_la = _input.LA(1);
			if ( !(_la==BAR || _la==CARET) ) {
			_errHandler.recoverInline(this);
			}
			else {
				if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
				_errHandler.reportMatch(this);
				consume();
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class RelationalOperatorContext extends ParserRuleContext {
		public TerminalNode GT() { return getToken(RubyParser.GT, 0); }
		public TerminalNode GTEQ() { return getToken(RubyParser.GTEQ, 0); }
		public TerminalNode LT() { return getToken(RubyParser.LT, 0); }
		public TerminalNode LTEQ() { return getToken(RubyParser.LTEQ, 0); }
		public RelationalOperatorContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_relationalOperator; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterRelationalOperator(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitRelationalOperator(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitRelationalOperator(this);
			else return visitor.visitChildren(this);
		}
	}

	public final RelationalOperatorContext relationalOperator() throws RecognitionException {
		RelationalOperatorContext _localctx = new RelationalOperatorContext(_ctx, getState());
		enterRule(_localctx, 202, RULE_relationalOperator);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(2016);
			_la = _input.LA(1);
			if ( !(((((_la - 87)) & ~0x3f) == 0 && ((1L << (_la - 87)) & ((1L << (GT - 87)) | (1L << (GTEQ - 87)) | (1L << (LT - 87)) | (1L << (LTEQ - 87)))) != 0)) ) {
			_errHandler.recoverInline(this);
			}
			else {
				if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
				_errHandler.reportMatch(this);
				consume();
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class EqualityOperatorContext extends ParserRuleContext {
		public TerminalNode LTEQGT() { return getToken(RubyParser.LTEQGT, 0); }
		public TerminalNode EQ2() { return getToken(RubyParser.EQ2, 0); }
		public TerminalNode EQ3() { return getToken(RubyParser.EQ3, 0); }
		public TerminalNode EMARKEQ() { return getToken(RubyParser.EMARKEQ, 0); }
		public TerminalNode EQTILDE() { return getToken(RubyParser.EQTILDE, 0); }
		public TerminalNode EMARKTILDE() { return getToken(RubyParser.EMARKTILDE, 0); }
		public EqualityOperatorContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_equalityOperator; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterEqualityOperator(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitEqualityOperator(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitEqualityOperator(this);
			else return visitor.visitChildren(this);
		}
	}

	public final EqualityOperatorContext equalityOperator() throws RecognitionException {
		EqualityOperatorContext _localctx = new EqualityOperatorContext(_ctx, getState());
		enterRule(_localctx, 204, RULE_equalityOperator);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(2018);
			_la = _input.LA(1);
			if ( !(((((_la - 74)) & ~0x3f) == 0 && ((1L << (_la - 74)) & ((1L << (EMARKEQ - 74)) | (1L << (EMARKTILDE - 74)) | (1L << (EQ2 - 74)) | (1L << (EQ3 - 74)) | (1L << (LTEQGT - 74)) | (1L << (EQTILDE - 74)))) != 0)) ) {
			_errHandler.recoverInline(this);
			}
			else {
				if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
				_errHandler.reportMatch(this);
				consume();
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class RangeOperatorContext extends ParserRuleContext {
		public TerminalNode DOT2() { return getToken(RubyParser.DOT2, 0); }
		public TerminalNode DOT3() { return getToken(RubyParser.DOT3, 0); }
		public RangeOperatorContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_rangeOperator; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterRangeOperator(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitRangeOperator(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitRangeOperator(this);
			else return visitor.visitChildren(this);
		}
	}

	public final RangeOperatorContext rangeOperator() throws RecognitionException {
		RangeOperatorContext _localctx = new RangeOperatorContext(_ctx, getState());
		enterRule(_localctx, 206, RULE_rangeOperator);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(2020);
			_la = _input.LA(1);
			if ( !(_la==DOT2 || _la==DOT3) ) {
			_errHandler.recoverInline(this);
			}
			else {
				if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
				_errHandler.reportMatch(this);
				consume();
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class KeywordContext extends ParserRuleContext {
		public TerminalNode BEGIN_() { return getToken(RubyParser.BEGIN_, 0); }
		public TerminalNode END_() { return getToken(RubyParser.END_, 0); }
		public TerminalNode ALIAS() { return getToken(RubyParser.ALIAS, 0); }
		public TerminalNode AND() { return getToken(RubyParser.AND, 0); }
		public TerminalNode BEGIN() { return getToken(RubyParser.BEGIN, 0); }
		public TerminalNode BREAK() { return getToken(RubyParser.BREAK, 0); }
		public TerminalNode CASE() { return getToken(RubyParser.CASE, 0); }
		public TerminalNode CLASS() { return getToken(RubyParser.CLASS, 0); }
		public TerminalNode DEF() { return getToken(RubyParser.DEF, 0); }
		public TerminalNode IS_DEFINED() { return getToken(RubyParser.IS_DEFINED, 0); }
		public TerminalNode DO() { return getToken(RubyParser.DO, 0); }
		public TerminalNode ELSE() { return getToken(RubyParser.ELSE, 0); }
		public TerminalNode ELSIF() { return getToken(RubyParser.ELSIF, 0); }
		public TerminalNode END() { return getToken(RubyParser.END, 0); }
		public TerminalNode ENSURE() { return getToken(RubyParser.ENSURE, 0); }
		public TerminalNode FOR() { return getToken(RubyParser.FOR, 0); }
		public TerminalNode IF() { return getToken(RubyParser.IF, 0); }
		public TerminalNode IN() { return getToken(RubyParser.IN, 0); }
		public TerminalNode MODULE() { return getToken(RubyParser.MODULE, 0); }
		public TerminalNode NEXT() { return getToken(RubyParser.NEXT, 0); }
		public TerminalNode NOT() { return getToken(RubyParser.NOT, 0); }
		public TerminalNode OR() { return getToken(RubyParser.OR, 0); }
		public TerminalNode REDO() { return getToken(RubyParser.REDO, 0); }
		public TerminalNode RESCUE() { return getToken(RubyParser.RESCUE, 0); }
		public TerminalNode RETRY() { return getToken(RubyParser.RETRY, 0); }
		public TerminalNode RETURN() { return getToken(RubyParser.RETURN, 0); }
		public TerminalNode SUPER() { return getToken(RubyParser.SUPER, 0); }
		public TerminalNode THEN() { return getToken(RubyParser.THEN, 0); }
		public TerminalNode UNDEF() { return getToken(RubyParser.UNDEF, 0); }
		public TerminalNode UNLESS() { return getToken(RubyParser.UNLESS, 0); }
		public TerminalNode UNTIL() { return getToken(RubyParser.UNTIL, 0); }
		public TerminalNode WHEN() { return getToken(RubyParser.WHEN, 0); }
		public TerminalNode WHILE() { return getToken(RubyParser.WHILE, 0); }
		public TerminalNode YIELD() { return getToken(RubyParser.YIELD, 0); }
		public KeywordContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_keyword; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterKeyword(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitKeyword(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitKeyword(this);
			else return visitor.visitChildren(this);
		}
	}

	public final KeywordContext keyword() throws RecognitionException {
		KeywordContext _localctx = new KeywordContext(_ctx, getState());
		enterRule(_localctx, 208, RULE_keyword);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(2022);
			_la = _input.LA(1);
			if ( !((((_la) & ~0x3f) == 0 && ((1L << _la) & ((1L << BEGIN_) | (1L << END_) | (1L << ALIAS) | (1L << AND) | (1L << BEGIN) | (1L << BREAK) | (1L << CASE) | (1L << CLASS) | (1L << DEF) | (1L << IS_DEFINED) | (1L << DO) | (1L << ELSE) | (1L << ELSIF) | (1L << END) | (1L << ENSURE) | (1L << FOR) | (1L << IF) | (1L << IN) | (1L << MODULE) | (1L << NEXT) | (1L << NOT) | (1L << OR) | (1L << REDO) | (1L << RESCUE) | (1L << RETRY) | (1L << RETURN) | (1L << SUPER) | (1L << THEN) | (1L << UNDEF) | (1L << UNLESS) | (1L << UNTIL) | (1L << WHEN) | (1L << WHILE) | (1L << YIELD))) != 0)) ) {
			_errHandler.recoverInline(this);
			}
			else {
				if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
				_errHandler.reportMatch(this);
				consume();
			}
			}
		}
		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 3:
			return statement_sempred((StatementContext)_localctx, predIndex);
		case 33:
			return expressionOrCommand_sempred((ExpressionOrCommandContext)_localctx, predIndex);
		case 34:
			return operatorExpression_sempred((OperatorExpressionContext)_localctx, predIndex);
		case 36:
			return primaryValue_sempred((PrimaryValueContext)_localctx, predIndex);
		case 39:
			return commandOrPrimaryValue_sempred((CommandOrPrimaryValueContext)_localctx, predIndex);
		case 67:
			return classPath_sempred((ClassPathContext)_localctx, predIndex);
		}
		return true;
	}
	private boolean statement_sempred(StatementContext _localctx, int predIndex) {
		switch (predIndex) {
		case 0:
			return precpred(_ctx, 3);
		}
		return true;
	}
	private boolean expressionOrCommand_sempred(ExpressionOrCommandContext _localctx, int predIndex) {
		switch (predIndex) {
		case 1:
			return precpred(_ctx, 1);
		}
		return true;
	}
	private boolean operatorExpression_sempred(OperatorExpressionContext _localctx, int predIndex) {
		switch (predIndex) {
		case 2:
			return precpred(_ctx, 1);
		}
		return true;
	}
	private boolean primaryValue_sempred(PrimaryValueContext _localctx, int predIndex) {
		switch (predIndex) {
		case 3:
			return precpred(_ctx, 13);
		case 4:
			return precpred(_ctx, 11);
		case 5:
			return precpred(_ctx, 10);
		case 6:
			return precpred(_ctx, 9);
		case 7:
			return precpred(_ctx, 8);
		case 8:
			return precpred(_ctx, 7);
		case 9:
			return precpred(_ctx, 6);
		case 10:
			return precpred(_ctx, 5);
		case 11:
			return precpred(_ctx, 4);
		case 12:
			return precpred(_ctx, 3);
		case 13:
			return precpred(_ctx, 2);
		case 14:
			return precpred(_ctx, 53);
		case 15:
			return precpred(_ctx, 51);
		case 16:
			return precpred(_ctx, 50);
		case 17:
			return precpred(_ctx, 16);
		case 18:
			return precpred(_ctx, 15);
		}
		return true;
	}
	private boolean commandOrPrimaryValue_sempred(CommandOrPrimaryValueContext _localctx, int predIndex) {
		switch (predIndex) {
		case 19:
			return precpred(_ctx, 1);
		}
		return true;
	}
	private boolean classPath_sempred(ClassPathContext _localctx, int predIndex) {
		switch (predIndex) {
		case 20:
			return precpred(_ctx, 1);
		}
		return true;
	}

	public static final String _serializedATN =
		"\3\u608b\ua72a\u8133\ub9ed\u417c\u3be7\u7786\u5964\3\u0098\u07eb\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 \4!"+
		"\t!\4\"\t\"\4#\t#\4$\t$\4%\t%\4&\t&\4\'\t\'\4(\t(\4)\t)\4*\t*\4+\t+\4"+
		",\t,\4-\t-\4.\t.\4/\t/\4\60\t\60\4\61\t\61\4\62\t\62\4\63\t\63\4\64\t"+
		"\64\4\65\t\65\4\66\t\66\4\67\t\67\48\t8\49\t9\4:\t:\4;\t;\4<\t<\4=\t="+
		"\4>\t>\4?\t?\4@\t@\4A\tA\4B\tB\4C\tC\4D\tD\4E\tE\4F\tF\4G\tG\4H\tH\4I"+
		"\tI\4J\tJ\4K\tK\4L\tL\4M\tM\4N\tN\4O\tO\4P\tP\4Q\tQ\4R\tR\4S\tS\4T\tT"+
		"\4U\tU\4V\tV\4W\tW\4X\tX\4Y\tY\4Z\tZ\4[\t[\4\\\t\\\4]\t]\4^\t^\4_\t_\4"+
		"`\t`\4a\ta\4b\tb\4c\tc\4d\td\4e\te\4f\tf\4g\tg\4h\th\4i\ti\4j\tj\3\2\3"+
		"\2\3\2\3\3\5\3\u00d9\n\3\3\3\7\3\u00dc\n\3\f\3\16\3\u00df\13\3\3\4\7\4"+
		"\u00e2\n\4\f\4\16\4\u00e5\13\4\3\4\3\4\6\4\u00e9\n\4\r\4\16\4\u00ea\3"+
		"\4\7\4\u00ee\n\4\f\4\16\4\u00f1\13\4\3\5\3\5\3\5\3\5\7\5\u00f7\n\5\f\5"+
		"\16\5\u00fa\13\5\3\5\3\5\3\5\3\5\3\5\7\5\u0101\n\5\f\5\16\5\u0104\13\5"+
		"\3\5\3\5\3\5\7\5\u0109\n\5\f\5\16\5\u010c\13\5\3\5\7\5\u010f\n\5\f\5\16"+
		"\5\u0112\13\5\3\5\3\5\5\5\u0116\n\5\3\5\3\5\3\5\7\5\u011b\n\5\f\5\16\5"+
		"\u011e\13\5\3\5\3\5\7\5\u0122\n\5\f\5\16\5\u0125\13\5\3\6\3\6\5\6\u0129"+
		"\n\6\3\7\3\7\3\7\7\7\u012e\n\7\f\7\16\7\u0131\13\7\3\7\3\7\3\7\3\7\3\7"+
		"\3\7\7\7\u0139\n\7\f\7\16\7\u013c\13\7\3\7\3\7\3\7\3\7\3\7\5\7\u0143\n"+
		"\7\3\7\3\7\3\7\7\7\u0148\n\7\f\7\16\7\u014b\13\7\3\7\3\7\3\7\3\7\3\7\3"+
		"\7\3\7\7\7\u0154\n\7\f\7\16\7\u0157\13\7\3\7\3\7\5\7\u015b\n\7\3\b\3\b"+
		"\3\b\7\b\u0160\n\b\f\b\16\b\u0163\13\b\3\b\3\b\3\b\3\b\3\b\7\b\u016a\n"+
		"\b\f\b\16\b\u016d\13\b\3\b\3\b\5\b\u0171\n\b\3\b\3\b\3\b\7\b\u0176\n\b"+
		"\f\b\16\b\u0179\13\b\3\b\3\b\3\b\3\b\3\b\7\b\u0180\n\b\f\b\16\b\u0183"+
		"\13\b\3\b\3\b\5\b\u0187\n\b\5\b\u0189\n\b\3\t\3\t\3\t\5\t\u018e\n\t\3"+
		"\t\3\t\3\t\5\t\u0193\n\t\3\t\3\t\3\t\3\t\3\t\3\t\3\t\3\t\5\t\u019d\n\t"+
		"\3\n\3\n\3\n\6\n\u01a2\n\n\r\n\16\n\u01a3\3\n\5\n\u01a7\n\n\3\n\3\n\3"+
		"\n\6\n\u01ac\n\n\r\n\16\n\u01ad\3\n\5\n\u01b1\n\n\3\n\5\n\u01b4\n\n\3"+
		"\n\7\n\u01b7\n\n\f\n\16\n\u01ba\13\n\3\n\5\n\u01bd\n\n\3\n\5\n\u01c0\n"+
		"\n\3\n\3\n\5\n\u01c4\n\n\3\13\3\13\3\13\6\13\u01c9\n\13\r\13\16\13\u01ca"+
		"\3\13\5\13\u01ce\n\13\3\13\3\13\3\13\6\13\u01d3\n\13\r\13\16\13\u01d4"+
		"\3\13\5\13\u01d8\n\13\3\13\5\13\u01db\n\13\3\f\3\f\5\f\u01df\n\f\3\f\3"+
		"\f\3\f\3\f\7\f\u01e5\n\f\f\f\16\f\u01e8\13\f\5\f\u01ea\n\f\3\r\3\r\3\r"+
		"\3\r\3\16\3\16\5\16\u01f2\n\16\3\17\3\17\3\17\5\17\u01f7\n\17\3\17\5\17"+
		"\u01fa\n\17\3\20\3\20\3\21\3\21\3\21\5\21\u0201\n\21\3\22\3\22\3\22\5"+
		"\22\u0206\n\22\3\23\3\23\3\23\5\23\u020b\n\23\3\23\3\23\3\24\3\24\3\24"+
		"\3\24\3\24\3\24\5\24\u0215\n\24\3\24\3\24\3\24\3\24\3\24\3\24\3\24\3\24"+
		"\5\24\u021f\n\24\3\25\3\25\5\25\u0223\n\25\3\25\3\25\3\25\3\25\3\25\3"+
		"\25\3\25\5\25\u022c\n\25\3\26\3\26\5\26\u0230\n\26\3\27\3\27\7\27\u0234"+
		"\n\27\f\27\16\27\u0237\13\27\3\30\3\30\3\30\5\30\u023c\n\30\3\31\3\31"+
		"\3\31\3\31\3\31\3\31\3\31\3\31\3\31\3\31\3\31\3\31\3\31\3\31\5\31\u024c"+
		"\n\31\3\32\3\32\3\32\5\32\u0251\n\32\3\32\3\32\3\32\3\32\3\32\3\32\5\32"+
		"\u0259\n\32\3\32\5\32\u025c\n\32\3\33\3\33\3\33\3\33\5\33\u0262\n\33\3"+
		"\34\3\34\3\34\7\34\u0267\n\34\f\34\16\34\u026a\13\34\3\34\7\34\u026d\n"+
		"\34\f\34\16\34\u0270\13\34\3\35\3\35\3\35\7\35\u0275\n\35\f\35\16\35\u0278"+
		"\13\35\3\35\6\35\u027b\n\35\r\35\16\35\u027c\3\36\3\36\7\36\u0281\n\36"+
		"\f\36\16\36\u0284\13\36\3\36\5\36\u0287\n\36\3\36\7\36\u028a\n\36\f\36"+
		"\16\36\u028d\13\36\3\36\3\36\3\36\7\36\u0292\n\36\f\36\16\36\u0295\13"+
		"\36\3\36\3\36\5\36\u0299\n\36\3\36\7\36\u029c\n\36\f\36\16\36\u029f\13"+
		"\36\3\36\3\36\3\36\3\36\7\36\u02a5\n\36\f\36\16\36\u02a8\13\36\3\36\3"+
		"\36\3\36\7\36\u02ad\n\36\f\36\16\36\u02b0\13\36\3\36\3\36\5\36\u02b4\n"+
		"\36\3\36\7\36\u02b7\n\36\f\36\16\36\u02ba\13\36\3\36\3\36\3\36\3\36\7"+
		"\36\u02c0\n\36\f\36\16\36\u02c3\13\36\3\36\3\36\5\36\u02c7\n\36\3\36\7"+
		"\36\u02ca\n\36\f\36\16\36\u02cd\13\36\3\36\3\36\5\36\u02d1\n\36\3\37\3"+
		"\37\3\37\3\37\7\37\u02d7\n\37\f\37\16\37\u02da\13\37\3\37\5\37\u02dd\n"+
		"\37\3\37\3\37\7\37\u02e1\n\37\f\37\16\37\u02e4\13\37\3\37\5\37\u02e7\n"+
		"\37\3\37\3\37\3\37\7\37\u02ec\n\37\f\37\16\37\u02ef\13\37\3\37\5\37\u02f2"+
		"\n\37\3\37\3\37\7\37\u02f6\n\37\f\37\16\37\u02f9\13\37\3\37\5\37\u02fc"+
		"\n\37\3\37\3\37\7\37\u0300\n\37\f\37\16\37\u0303\13\37\3\37\5\37\u0306"+
		"\n\37\3\37\3\37\3\37\7\37\u030b\n\37\f\37\16\37\u030e\13\37\3\37\5\37"+
		"\u0311\n\37\3\37\3\37\7\37\u0315\n\37\f\37\16\37\u0318\13\37\3\37\5\37"+
		"\u031b\n\37\3\37\5\37\u031e\n\37\3 \3 \3 \3 \7 \u0324\n \f \16 \u0327"+
		"\13 \3 \5 \u032a\n \5 \u032c\n \3!\3!\3!\7!\u0331\n!\f!\16!\u0334\13!"+
		"\3!\7!\u0337\n!\f!\16!\u033a\13!\3\"\3\"\3\"\3#\3#\3#\5#\u0342\n#\3#\3"+
		"#\3#\7#\u0347\n#\f#\16#\u034a\13#\3#\5#\u034d\n#\3#\3#\3#\7#\u0352\n#"+
		"\f#\16#\u0355\13#\3#\7#\u0358\n#\f#\16#\u035b\13#\3$\3$\3$\3$\3$\3$\7"+
		"$\u0363\n$\f$\16$\u0366\13$\3$\3$\7$\u036a\n$\f$\16$\u036d\13$\3$\3$\7"+
		"$\u0371\n$\f$\16$\u0374\13$\3$\3$\7$\u0378\n$\f$\16$\u037b\13$\3%\3%\3"+
		"%\3%\3%\3%\5%\u0383\n%\3&\3&\3&\3&\7&\u0389\n&\f&\16&\u038c\13&\3&\3&"+
		"\3&\3&\3&\3&\7&\u0394\n&\f&\16&\u0397\13&\3&\3&\3&\3&\3&\3&\5&\u039f\n"+
		"&\3&\5&\u03a2\n&\3&\3&\3&\3&\3&\3&\3&\3&\3&\3&\3&\3&\3&\3&\3&\3&\3&\3"+
		"&\3&\3&\3&\3&\3&\3&\3&\3&\3&\3&\3&\3&\3&\3&\3&\5&\u03c5\n&\3&\5&\u03c8"+
		"\n&\3&\3&\7&\u03cc\n&\f&\16&\u03cf\13&\3&\3&\3&\3&\3&\5&\u03d6\n&\3&\5"+
		"&\u03d9\n&\3&\3&\3&\7&\u03de\n&\f&\16&\u03e1\13&\3&\3&\3&\7&\u03e6\n&"+
		"\f&\16&\u03e9\13&\3&\5&\u03ec\n&\3&\3&\3&\3&\7&\u03f2\n&\f&\16&\u03f5"+
		"\13&\3&\3&\3&\5&\u03fa\n&\3&\3&\3&\3&\7&\u0400\n&\f&\16&\u0403\13&\3&"+
		"\3&\3&\3&\3&\3&\5&\u040b\n&\3&\3&\3&\3&\3&\3&\7&\u0413\n&\f&\16&\u0416"+
		"\13&\3&\3&\7&\u041a\n&\f&\16&\u041d\13&\3&\6&\u0420\n&\r&\16&\u0421\3"+
		"&\5&\u0425\n&\3&\3&\3&\3&\7&\u042b\n&\f&\16&\u042e\13&\3&\6&\u0431\n&"+
		"\r&\16&\u0432\3&\5&\u0436\n&\3&\3&\3&\3&\7&\u043c\n&\f&\16&\u043f\13&"+
		"\3&\3&\3&\3&\3&\3&\7&\u0447\n&\f&\16&\u044a\13&\3&\3&\3&\7&\u044f\n&\f"+
		"&\16&\u0452\13&\3&\3&\3&\3&\3&\3&\3&\7&\u045b\n&\f&\16&\u045e\13&\3&\5"+
		"&\u0461\n&\3&\7&\u0464\n&\f&\16&\u0467\13&\3&\3&\3&\5&\u046c\n&\3&\3&"+
		"\3&\5&\u0471\n&\3&\3&\3&\5&\u0476\n&\3&\3&\3&\5&\u047b\n&\3&\3&\3&\7&"+
		"\u0480\n&\f&\16&\u0483\13&\3&\3&\5&\u0487\n&\5&\u0489\n&\3&\7&\u048c\n"+
		"&\f&\16&\u048f\13&\3&\3&\5&\u0493\n&\3&\3&\3&\7&\u0498\n&\f&\16&\u049b"+
		"\13&\3&\3&\7&\u049f\n&\f&\16&\u04a2\13&\3&\3&\5&\u04a6\n&\3&\3&\3&\7&"+
		"\u04ab\n&\f&\16&\u04ae\13&\3&\3&\3&\7&\u04b3\n&\f&\16&\u04b6\13&\3&\3"+
		"&\3&\3&\7&\u04bc\n&\f&\16&\u04bf\13&\3&\3&\3&\7&\u04c4\n&\f&\16&\u04c7"+
		"\13&\3&\3&\3&\3&\3&\3&\3&\3&\3&\3&\3&\5&\u04d4\n&\3&\3&\3&\7&\u04d9\n"+
		"&\f&\16&\u04dc\13&\3&\3&\3&\3&\7&\u04e2\n&\f&\16&\u04e5\13&\3&\3&\3&\3"+
		"&\3&\7&\u04ec\n&\f&\16&\u04ef\13&\3&\3&\3&\3&\3&\7&\u04f6\n&\f&\16&\u04f9"+
		"\13&\3&\3&\3&\3&\3&\7&\u0500\n&\f&\16&\u0503\13&\3&\3&\3&\3&\7&\u0509"+
		"\n&\f&\16&\u050c\13&\3&\3&\3&\3&\3&\7&\u0513\n&\f&\16&\u0516\13&\3&\3"+
		"&\3&\3&\3&\7&\u051d\n&\f&\16&\u0520\13&\3&\3&\3&\3&\3&\7&\u0527\n&\f&"+
		"\16&\u052a\13&\3&\3&\3&\3&\7&\u0530\n&\f&\16&\u0533\13&\3&\3&\3&\3&\7"+
		"&\u0539\n&\f&\16&\u053c\13&\3&\3&\3&\3&\3&\3&\3&\7&\u0545\n&\f&\16&\u0548"+
		"\13&\3&\3&\3&\3&\3&\5&\u054f\n&\3&\3&\3&\7&\u0554\n&\f&\16&\u0557\13&"+
		"\3&\3&\3&\3&\3&\7&\u055e\n&\f&\16&\u0561\13&\3&\3&\3&\3&\3&\3&\3&\5&\u056a"+
		"\n&\3&\3&\3&\7&\u056f\n&\f&\16&\u0572\13&\3&\3&\7&\u0576\n&\f&\16&\u0579"+
		"\13&\3&\3&\5&\u057d\n&\3&\5&\u0580\n&\7&\u0582\n&\f&\16&\u0585\13&\3\'"+
		"\3\'\5\'\u0589\n\'\3\'\5\'\u058c\n\'\3\'\3\'\5\'\u0590\n\'\3\'\5\'\u0593"+
		"\n\'\3\'\3\'\3\'\3\'\3\'\3\'\3\'\3\'\3\'\3\'\3\'\3\'\3\'\3\'\3\'\5\'\u05a4"+
		"\n\'\3\'\5\'\u05a7\n\'\3(\3(\5(\u05ab\n(\3)\3)\3)\3)\3)\5)\u05b2\n)\3"+
		")\3)\3)\7)\u05b7\n)\f)\16)\u05ba\13)\3)\7)\u05bd\n)\f)\16)\u05c0\13)\3"+
		"*\3*\7*\u05c4\n*\f*\16*\u05c7\13*\3*\5*\u05ca\n*\3*\3*\3*\3*\5*\u05d0"+
		"\n*\3+\3+\7+\u05d4\n+\f+\16+\u05d7\13+\3+\5+\u05da\n+\3+\3+\3+\3,\3,\7"+
		",\u05e1\n,\f,\16,\u05e4\13,\3,\3,\3,\7,\u05e9\n,\f,\16,\u05ec\13,\3,\3"+
		",\7,\u05f0\n,\f,\16,\u05f3\13,\3,\3,\5,\u05f7\n,\3-\6-\u05fa\n-\r-\16"+
		"-\u05fb\3-\3-\5-\u0600\n-\3-\3-\5-\u0604\n-\3.\3.\3.\3/\3/\7/\u060b\n"+
		"/\f/\16/\u060e\13/\3/\3/\3/\3\60\3\60\7\60\u0615\n\60\f\60\16\60\u0618"+
		"\13\60\3\60\3\60\3\60\3\61\3\61\3\61\5\61\u0620\n\61\3\61\5\61\u0623\n"+
		"\61\3\62\6\62\u0626\n\62\r\62\16\62\u0627\3\62\3\62\3\62\5\62\u062d\n"+
		"\62\3\63\3\63\5\63\u0631\n\63\3\64\3\64\7\64\u0635\n\64\f\64\16\64\u0638"+
		"\13\64\3\64\5\64\u063b\n\64\3\64\5\64\u063e\n\64\3\65\3\65\5\65\u0642"+
		"\n\65\3\65\5\65\u0645\n\65\3\65\3\65\3\66\3\66\5\66\u064b\n\66\3\67\3"+
		"\67\3\67\38\38\38\39\39\39\39\39\59\u0658\n9\39\39\39\39\59\u065e\n9\3"+
		":\3:\7:\u0662\n:\f:\16:\u0665\13:\3:\5:\u0668\n:\3:\7:\u066b\n:\f:\16"+
		":\u066e\13:\3:\3:\5:\u0672\n:\3:\5:\u0675\n:\3;\3;\3;\7;\u067a\n;\f;\16"+
		";\u067d\13;\3;\5;\u0680\n;\3;\3;\7;\u0684\n;\f;\16;\u0687\13;\3;\5;\u068a"+
		"\n;\3;\3;\7;\u068e\n;\f;\16;\u0691\13;\3;\5;\u0694\n;\3;\3;\3;\7;\u0699"+
		"\n;\f;\16;\u069c\13;\3;\5;\u069f\n;\3;\3;\7;\u06a3\n;\f;\16;\u06a6\13"+
		";\3;\5;\u06a9\n;\3;\3;\7;\u06ad\n;\f;\16;\u06b0\13;\3;\5;\u06b3\n;\3;"+
		"\3;\3;\7;\u06b8\n;\f;\16;\u06bb\13;\3;\5;\u06be\n;\3;\5;\u06c1\n;\3<\3"+
		"<\3<\7<\u06c6\n<\f<\16<\u06c9\13<\3<\7<\u06cc\n<\f<\16<\u06cf\13<\3=\3"+
		"=\5=\u06d3\n=\3>\3>\5>\u06d7\n>\3?\3?\3?\7?\u06dc\n?\f?\16?\u06df\13?"+
		"\3?\3?\3@\3@\3A\3A\5A\u06e7\nA\3B\3B\5B\u06eb\nB\3C\3C\3C\3D\3D\3E\3E"+
		"\3E\3E\5E\u06f6\nE\3E\3E\3E\7E\u06fb\nE\fE\16E\u06fe\13E\3F\3F\3F\3F\3"+
		"F\5F\u0705\nF\3G\3G\3G\3G\5G\u070b\nG\3H\3H\3H\7H\u0710\nH\fH\16H\u0713"+
		"\13H\3H\7H\u0716\nH\fH\16H\u0719\13H\3I\3I\3I\7I\u071e\nI\fI\16I\u0721"+
		"\13I\3I\3I\3I\5I\u0726\nI\3J\3J\5J\u072a\nJ\3K\3K\3K\3K\3K\3K\3K\5K\u0733"+
		"\nK\3L\3L\3L\3L\3L\5L\u073a\nL\3M\3M\3N\3N\5N\u0740\nN\3O\3O\7O\u0744"+
		"\nO\fO\16O\u0747\13O\3O\3O\3P\3P\7P\u074d\nP\fP\16P\u0750\13P\3P\3P\3"+
		"Q\3Q\3Q\3Q\3Q\5Q\u0759\nQ\3R\3R\5R\u075d\nR\3R\3R\3S\3S\7S\u0763\nS\f"+
		"S\16S\u0766\13S\3S\3S\3T\3T\3T\3T\3T\5T\u076f\nT\3U\6U\u0772\nU\rU\16"+
		"U\u0773\3V\3V\3V\3V\3V\5V\u077b\nV\3W\6W\u077e\nW\rW\16W\u077f\3X\7X\u0783"+
		"\nX\fX\16X\u0786\13X\3X\3X\6X\u078a\nX\rX\16X\u078b\3X\7X\u078f\nX\fX"+
		"\16X\u0792\13X\3X\7X\u0795\nX\fX\16X\u0798\13X\3Y\7Y\u079b\nY\fY\16Y\u079e"+
		"\13Y\3Y\3Y\6Y\u07a2\nY\rY\16Y\u07a3\3Y\7Y\u07a7\nY\fY\16Y\u07aa\13Y\3"+
		"Y\7Y\u07ad\nY\fY\16Y\u07b0\13Y\3Z\3Z\3Z\3Z\3Z\5Z\u07b7\nZ\3[\3[\3\\\3"+
		"\\\3]\3]\3^\3^\3_\3_\3_\3_\3_\5_\u07c6\n_\3`\3`\3`\3`\3`\3`\3`\5`\u07cf"+
		"\n`\3a\3a\3a\3a\3a\3a\5a\u07d7\na\3b\3b\3c\3c\3d\3d\3e\3e\3f\3f\3g\3g"+
		"\3h\3h\3i\3i\3j\3j\3j\2\b\bDFJP\u0088k\2\4\6\b\n\f\16\20\22\24\26\30\32"+
		"\34\36 \"$&(*,.\60\62\64\668:<>@BDFHJLNPRTVXZ\\^`bdfhjlnprtvxz|~\u0080"+
		"\u0082\u0084\u0086\u0088\u008a\u008c\u008e\u0090\u0092\u0094\u0096\u0098"+
		"\u009a\u009c\u009e\u00a0\u00a2\u00a4\u00a6\u00a8\u00aa\u00ac\u00ae\u00b0"+
		"\u00b2\u00b4\u00b6\u00b8\u00ba\u00bc\u00be\u00c0\u00c2\u00c4\u00c6\u00c8"+
		"\u00ca\u00cc\u00ce\u00d0\u00d2\2\25\4\2DD||\4\2BBEE\4\2\177\177\u0083"+
		"\u0083\5\2HHKKSS\5\2BBEEPP\4\2\30\30,,\3\2_`\4\2AASS\4\2AAII\4\2SShh\6"+
		"\2&&..\66\6799\5\2KK__ee\4\2aacd\3\2]^\4\2QQVV\3\2Y\\\5\2LMTUWX\3\2FG"+
		"\7\2\25$&)+\60\62\63\65:\2\u0907\2\u00d4\3\2\2\2\4\u00d8\3\2\2\2\6\u00e3"+
		"\3\2\2\2\b\u0115\3\2\2\2\n\u0128\3\2\2\2\f\u015a\3\2\2\2\16\u0188\3\2"+
		"\2\2\20\u019c\3\2\2\2\22\u01c3\3\2\2\2\24\u01da\3\2\2\2\26\u01e9\3\2\2"+
		"\2\30\u01eb\3\2\2\2\32\u01f1\3\2\2\2\34\u01f9\3\2\2\2\36\u01fb\3\2\2\2"+
		" \u0200\3\2\2\2\"\u0205\3\2\2\2$\u020a\3\2\2\2&\u021e\3\2\2\2(\u022b\3"+
		"\2\2\2*\u022f\3\2\2\2,\u0231\3\2\2\2.\u0238\3\2\2\2\60\u024b\3\2\2\2\62"+
		"\u025b\3\2\2\2\64\u0261\3\2\2\2\66\u0263\3\2\2\28\u0271\3\2\2\2:\u02d0"+
		"\3\2\2\2<\u031d\3\2\2\2>\u032b\3\2\2\2@\u032d\3\2\2\2B\u033b\3\2\2\2D"+
		"\u034c\3\2\2\2F\u035c\3\2\2\2H\u0382\3\2\2\2J\u04d3\3\2\2\2L\u05a6\3\2"+
		"\2\2N\u05aa\3\2\2\2P\u05b1\3\2\2\2R\u05cf\3\2\2\2T\u05d1\3\2\2\2V\u05f6"+
		"\3\2\2\2X\u0603\3\2\2\2Z\u0605\3\2\2\2\\\u0608\3\2\2\2^\u0612\3\2\2\2"+
		"`\u0622\3\2\2\2b\u062c\3\2\2\2d\u0630\3\2\2\2f\u0632\3\2\2\2h\u063f\3"+
		"\2\2\2j\u064a\3\2\2\2l\u064c\3\2\2\2n\u064f\3\2\2\2p\u065d\3\2\2\2r\u0674"+
		"\3\2\2\2t\u06c0\3\2\2\2v\u06c2\3\2\2\2x\u06d2\3\2\2\2z\u06d4\3\2\2\2|"+
		"\u06d8\3\2\2\2~\u06e2\3\2\2\2\u0080\u06e4\3\2\2\2\u0082\u06e8\3\2\2\2"+
		"\u0084\u06ec\3\2\2\2\u0086\u06ef\3\2\2\2\u0088\u06f5\3\2\2\2\u008a\u0704"+
		"\3\2\2\2\u008c\u070a\3\2\2\2\u008e\u070c\3\2\2\2\u0090\u0725\3\2\2\2\u0092"+
		"\u0729\3\2\2\2\u0094\u072b\3\2\2\2\u0096\u0739\3\2\2\2\u0098\u073b\3\2"+
		"\2\2\u009a\u073f\3\2\2\2\u009c\u0741\3\2\2\2\u009e\u074a\3\2\2\2\u00a0"+
		"\u0758\3\2\2\2\u00a2\u075a\3\2\2\2\u00a4\u0760\3\2\2\2\u00a6\u076e\3\2"+
		"\2\2\u00a8\u0771\3\2\2\2\u00aa\u077a\3\2\2\2\u00ac\u077d\3\2\2\2\u00ae"+
		"\u0784\3\2\2\2\u00b0\u079c\3\2\2\2\u00b2\u07b6\3\2\2\2\u00b4\u07b8\3\2"+
		"\2\2\u00b6\u07ba\3\2\2\2\u00b8\u07bc\3\2\2\2\u00ba\u07be\3\2\2\2\u00bc"+
		"\u07c5\3\2\2\2\u00be\u07ce\3\2\2\2\u00c0\u07d6\3\2\2\2\u00c2\u07d8\3\2"+
		"\2\2\u00c4\u07da\3\2\2\2\u00c6\u07dc\3\2\2\2\u00c8\u07de\3\2\2\2\u00ca"+
		"\u07e0\3\2\2\2\u00cc\u07e2\3\2\2\2\u00ce\u07e4\3\2\2\2\u00d0\u07e6\3\2"+
		"\2\2\u00d2\u07e8\3\2\2\2\u00d4\u00d5\5\4\3\2\u00d5\u00d6\7\2\2\3\u00d6"+
		"\3\3\2\2\2\u00d7\u00d9\5\6\4\2\u00d8\u00d7\3\2\2\2\u00d8\u00d9\3\2\2\2"+
		"\u00d9\u00dd\3\2\2\2\u00da\u00dc\t\2\2\2\u00db\u00da\3\2\2\2\u00dc\u00df"+
		"\3\2\2\2\u00dd\u00db\3\2\2\2\u00dd\u00de\3\2\2\2\u00de\5\3\2\2\2\u00df"+
		"\u00dd\3\2\2\2\u00e0\u00e2\t\2\2\2\u00e1\u00e0\3\2\2\2\u00e2\u00e5\3\2"+
		"\2\2\u00e3\u00e1\3\2\2\2\u00e3\u00e4\3\2\2\2\u00e4\u00e6\3\2\2\2\u00e5"+
		"\u00e3\3\2\2\2\u00e6\u00ef\5\b\5\2\u00e7\u00e9\t\2\2\2\u00e8\u00e7\3\2"+
		"\2\2\u00e9\u00ea\3\2\2\2\u00ea\u00e8\3\2\2\2\u00ea\u00eb\3\2\2\2\u00eb"+
		"\u00ec\3\2\2\2\u00ec\u00ee\5\b\5\2\u00ed\u00e8\3\2\2\2\u00ee\u00f1\3\2"+
		"\2\2\u00ef\u00ed\3\2\2\2\u00ef\u00f0\3\2\2\2\u00f0\7\3\2\2\2\u00f1\u00ef"+
		"\3\2\2\2\u00f2\u00f3\b\5\1\2\u00f3\u0116\5D#\2\u00f4\u00f8\7\27\2\2\u00f5"+
		"\u00f7\7|\2\2\u00f6\u00f5\3\2\2\2\u00f7\u00fa\3\2\2\2\u00f8\u00f6\3\2"+
		"\2\2\u00f8\u00f9\3\2\2\2\u00f9\u00fb\3\2\2\2\u00fa\u00f8\3\2\2\2\u00fb"+
		"\u00fc\5\n\6\2\u00fc\u00fd\5\n\6\2\u00fd\u0116\3\2\2\2\u00fe\u0102\7\65"+
		"\2\2\u00ff\u0101\7|\2\2\u0100\u00ff\3\2\2\2\u0101\u0104\3\2\2\2\u0102"+
		"\u0100\3\2\2\2\u0102\u0103\3\2\2\2\u0103\u0105\3\2\2\2\u0104\u0102\3\2"+
		"\2\2\u0105\u0110\5\n\6\2\u0106\u010a\7C\2\2\u0107\u0109\7|\2\2\u0108\u0107"+
		"\3\2\2\2\u0109\u010c\3\2\2\2\u010a\u0108\3\2\2\2\u010a\u010b\3\2\2\2\u010b"+
		"\u010d\3\2\2\2\u010c\u010a\3\2\2\2\u010d\u010f\5\n\6\2\u010e\u0106\3\2"+
		"\2\2\u010f\u0112\3\2\2\2\u0110\u010e\3\2\2\2\u0110\u0111\3\2\2\2\u0111"+
		"\u0116\3\2\2\2\u0112\u0110\3\2\2\2\u0113\u0116\5\f\7\2\u0114\u0116\5\16"+
		"\b\2\u0115\u00f2\3\2\2\2\u0115\u00f4\3\2\2\2\u0115\u00fe\3\2\2\2\u0115"+
		"\u0113\3\2\2\2\u0115\u0114\3\2\2\2\u0116\u0123\3\2\2\2\u0117\u0118\f\5"+
		"\2\2\u0118\u011c\5\u00ba^\2\u0119\u011b\7|\2\2\u011a\u0119\3\2\2\2\u011b"+
		"\u011e\3\2\2\2\u011c\u011a\3\2\2\2\u011c\u011d\3\2\2\2\u011d\u011f\3\2"+
		"\2\2\u011e\u011c\3\2\2\2\u011f\u0120\5D#\2\u0120\u0122\3\2\2\2\u0121\u0117"+
		"\3\2\2\2\u0122\u0125\3\2\2\2\u0123\u0121\3\2\2\2\u0123\u0124\3\2\2\2\u0124"+
		"\t\3\2\2\2\u0125\u0123\3\2\2\2\u0126\u0129\5p9\2\u0127\u0129\5\u00b2Z"+
		"\2\u0128\u0126\3\2\2\2\u0128\u0127\3\2\2\2\u0129\13\3\2\2\2\u012a\u012b"+
		"\5\u00bc_\2\u012b\u012f\5\u00b8]\2\u012c\u012e\7|\2\2\u012d\u012c\3\2"+
		"\2\2\u012e\u0131\3\2\2\2\u012f\u012d\3\2\2\2\u012f\u0130\3\2\2\2\u0130"+
		"\u0132\3\2\2\2\u0131\u012f\3\2\2\2\u0132\u0133\5&\24\2\u0133\u015b\3\2"+
		"\2\2\u0134\u0135\7B\2\2\u0135\u0136\7\u0083\2\2\u0136\u013a\5\u00b8]\2"+
		"\u0137\u0139\7|\2\2\u0138\u0137\3\2\2\2\u0139\u013c\3\2\2\2\u013a\u0138"+
		"\3\2\2\2\u013a\u013b\3\2\2\2\u013b\u013d\3\2\2\2\u013c\u013a\3\2\2\2\u013d"+
		"\u013e\5&\24\2\u013e\u015b\3\2\2\2\u013f\u0140\5H%\2\u0140\u0142\7;\2"+
		"\2\u0141\u0143\5\62\32\2\u0142\u0141\3\2\2\2\u0142\u0143\3\2\2\2\u0143"+
		"\u0144\3\2\2\2\u0144\u0145\7<\2\2\u0145\u0149\5\u00b8]\2\u0146\u0148\7"+
		"|\2\2\u0147\u0146\3\2\2\2\u0148\u014b\3\2\2\2\u0149\u0147\3\2\2\2\u0149"+
		"\u014a\3\2\2\2\u014a\u014c\3\2\2\2\u014b\u0149\3\2\2\2\u014c\u014d\5&"+
		"\24\2\u014d\u015b\3\2\2\2\u014e\u014f\5H%\2\u014f\u0150\t\3\2\2\u0150"+
		"\u0151\5\"\22\2\u0151\u0155\5\u00b8]\2\u0152\u0154\7|\2\2\u0153\u0152"+
		"\3\2\2\2\u0154\u0157\3\2\2\2\u0155\u0153\3\2\2\2\u0155\u0156\3\2\2\2\u0156"+
		"\u0158\3\2\2\2\u0157\u0155\3\2\2\2\u0158\u0159\5&\24\2\u0159\u015b\3\2"+
		"\2\2\u015a\u012a\3\2\2\2\u015a\u0134\3\2\2\2\u015a\u013f\3\2\2\2\u015a"+
		"\u014e\3\2\2\2\u015b\r\3\2\2\2\u015c\u015d\5\20\t\2\u015d\u0161\7S\2\2"+
		"\u015e\u0160\7|\2\2\u015f\u015e\3\2\2\2\u0160\u0163\3\2\2\2\u0161\u015f"+
		"\3\2\2\2\u0161\u0162\3\2\2\2\u0162\u0164\3\2\2\2\u0163\u0161\3\2\2\2\u0164"+
		"\u0165\5\34\17\2\u0165\u0189\3\2\2\2\u0166\u0167\5\26\f\2\u0167\u016b"+
		"\7S\2\2\u0168\u016a\7|\2\2\u0169\u0168\3\2\2\2\u016a\u016d\3\2\2\2\u016b"+
		"\u0169\3\2\2\2\u016b\u016c\3\2\2\2\u016c\u0170\3\2\2\2\u016d\u016b\3\2"+
		"\2\2\u016e\u0171\5&\24\2\u016f\u0171\5F$\2\u0170\u016e\3\2\2\2\u0170\u016f"+
		"\3\2\2\2\u0171\u0189\3\2\2\2\u0172\u0173\5\22\n\2\u0173\u0177\7S\2\2\u0174"+
		"\u0176\7|\2\2\u0175\u0174\3\2\2\2\u0176\u0179\3\2\2\2\u0177\u0175\3\2"+
		"\2\2\u0177\u0178\3\2\2\2\u0178\u017a\3\2\2\2\u0179\u0177\3\2\2\2\u017a"+
		"\u017b\5\34\17\2\u017b\u0189\3\2\2\2\u017c\u017d\5\24\13\2\u017d\u0181"+
		"\7S\2\2\u017e\u0180\7|\2\2\u017f\u017e\3\2\2\2\u0180\u0183\3\2\2\2\u0181"+
		"\u017f\3\2\2\2\u0181\u0182\3\2\2\2\u0182\u0186\3\2\2\2\u0183\u0181\3\2"+
		"\2\2\u0184\u0187\5&\24\2\u0185\u0187\5F$\2\u0186\u0184\3\2\2\2\u0186\u0185"+
		"\3\2\2\2\u0187\u0189\3\2\2\2\u0188\u015c\3\2\2\2\u0188\u0166\3\2\2\2\u0188"+
		"\u0172\3\2\2\2\u0188\u017c\3\2\2\2\u0189\17\3\2\2\2\u018a\u018d\5\u00bc"+
		"_\2\u018b\u018c\7S\2\2\u018c\u018e\5H%\2\u018d\u018b\3\2\2\2\u018d\u018e"+
		"\3\2\2\2\u018e\u019d\3\2\2\2\u018f\u0190\5H%\2\u0190\u0192\7;\2\2\u0191"+
		"\u0193\5\62\32\2\u0192\u0191\3\2\2\2\u0192\u0193\3\2\2\2\u0193\u0194\3"+
		"\2\2\2\u0194\u0195\7<\2\2\u0195\u019d\3\2\2\2\u0196\u0197\5H%\2\u0197"+
		"\u0198\t\3\2\2\u0198\u0199\t\4\2\2\u0199\u019d\3\2\2\2\u019a\u019b\7B"+
		"\2\2\u019b\u019d\7\u0083\2\2\u019c\u018a\3\2\2\2\u019c\u018f\3\2\2\2\u019c"+
		"\u0196\3\2\2\2\u019c\u019a\3\2\2\2\u019d\21\3\2\2\2\u019e\u019f\5\32\16"+
		"\2\u019f\u01a0\7C\2\2\u01a0\u01a2\3\2\2\2\u01a1\u019e\3\2\2\2\u01a2\u01a3"+
		"\3\2\2\2\u01a3\u01a1\3\2\2\2\u01a3\u01a4\3\2\2\2\u01a4\u01a6\3\2\2\2\u01a5"+
		"\u01a7\5\32\16\2\u01a6\u01a5\3\2\2\2\u01a6\u01a7\3\2\2\2\u01a7\u01c4\3"+
		"\2\2\2\u01a8\u01a9\5\32\16\2\u01a9\u01aa\7C\2\2\u01aa\u01ac\3\2\2\2\u01ab"+
		"\u01a8\3\2\2\2\u01ac\u01ad\3\2\2\2\u01ad\u01ab\3\2\2\2\u01ad\u01ae\3\2"+
		"\2\2\u01ae\u01b0\3\2\2\2\u01af\u01b1\5\26\f\2\u01b0\u01af\3\2\2\2\u01b0"+
		"\u01b1\3\2\2\2\u01b1\u01bc\3\2\2\2\u01b2\u01b4\7C\2\2\u01b3\u01b2\3\2"+
		"\2\2\u01b3\u01b4\3\2\2\2\u01b4\u01b8\3\2\2\2\u01b5\u01b7\7|\2\2\u01b6"+
		"\u01b5\3\2\2\2\u01b7\u01ba\3\2\2\2\u01b8\u01b6\3\2\2\2\u01b8\u01b9\3\2"+
		"\2\2\u01b9\u01bb\3\2\2\2\u01ba\u01b8\3\2\2\2\u01bb\u01bd\5\u0084C\2\u01bc"+
		"\u01b3\3\2\2\2\u01bc\u01bd\3\2\2\2\u01bd\u01bf\3\2\2\2\u01be\u01c0\7C"+
		"\2\2\u01bf\u01be\3\2\2\2\u01bf\u01c0\3\2\2\2\u01c0\u01c4\3\2\2\2\u01c1"+
		"\u01c4\5\26\f\2\u01c2\u01c4\5\30\r\2\u01c3\u01a1\3\2\2\2\u01c3\u01ab\3"+
		"\2\2\2\u01c3\u01c1\3\2\2\2\u01c3\u01c2\3\2\2\2\u01c4\23\3\2\2\2\u01c5"+
		"\u01c6\5\32\16\2\u01c6\u01c7\7C\2\2\u01c7\u01c9\3\2\2\2\u01c8\u01c5\3"+
		"\2\2\2\u01c9\u01ca\3\2\2\2\u01ca\u01c8\3\2\2\2\u01ca\u01cb\3\2\2\2\u01cb"+
		"\u01cd\3\2\2\2\u01cc\u01ce\5\32\16\2\u01cd\u01cc\3\2\2\2\u01cd\u01ce\3"+
		"\2\2\2\u01ce\u01db\3\2\2\2\u01cf\u01d0\5\32\16\2\u01d0\u01d1\7C\2\2\u01d1"+
		"\u01d3\3\2\2\2\u01d2\u01cf\3\2\2\2\u01d3\u01d4\3\2\2\2\u01d4\u01d2\3\2"+
		"\2\2\u01d4\u01d5\3\2\2\2\u01d5\u01d7\3\2\2\2\u01d6\u01d8\5\26\f\2\u01d7"+
		"\u01d6\3\2\2\2\u01d7\u01d8\3\2\2\2\u01d8\u01db\3\2\2\2\u01d9\u01db\5\30"+
		"\r\2\u01da\u01c8\3\2\2\2\u01da\u01d2\3\2\2\2\u01da\u01d9\3\2\2\2\u01db"+
		"\25\3\2\2\2\u01dc\u01de\7a\2\2\u01dd\u01df\5\20\t\2\u01de\u01dd\3\2\2"+
		"\2\u01de\u01df\3\2\2\2\u01df\u01ea\3\2\2\2\u01e0\u01e1\7a\2\2\u01e1\u01e6"+
		"\5\20\t\2\u01e2\u01e3\7C\2\2\u01e3\u01e5\5\32\16\2\u01e4\u01e2\3\2\2\2"+
		"\u01e5\u01e8\3\2\2\2\u01e6\u01e4\3\2\2\2\u01e6\u01e7\3\2\2\2\u01e7\u01ea"+
		"\3\2\2\2\u01e8\u01e6\3\2\2\2\u01e9\u01dc\3\2\2\2\u01e9\u01e0\3\2\2\2\u01ea"+
		"\27\3\2\2\2\u01eb\u01ec\7=\2\2\u01ec\u01ed\5\22\n\2\u01ed\u01ee\7>\2\2"+
		"\u01ee\31\3\2\2\2\u01ef\u01f2\5\20\t\2\u01f0\u01f2\5\30\r\2\u01f1\u01ef"+
		"\3\2\2\2\u01f1\u01f0\3\2\2\2\u01f2\33\3\2\2\2\u01f3\u01f6\5\66\34\2\u01f4"+
		"\u01f5\7C\2\2\u01f5\u01f7\5\36\20\2\u01f6\u01f4\3\2\2\2\u01f6\u01f7\3"+
		"\2\2\2\u01f7\u01fa\3\2\2\2\u01f8\u01fa\5\36\20\2\u01f9\u01f3\3\2\2\2\u01f9"+
		"\u01f8\3\2\2\2\u01fa\35\3\2\2\2\u01fb\u01fc\5\64\33\2\u01fc\37\3\2\2\2"+
		"\u01fd\u0201\7\177\2\2\u01fe\u0201\7\u0083\2\2\u01ff\u0201\5$\23\2\u0200"+
		"\u01fd\3\2\2\2\u0200\u01fe\3\2\2\2\u0200\u01ff\3\2\2\2\u0201!\3\2\2\2"+
		"\u0202\u0206\5 \21\2\u0203\u0206\5\u00d2j\2\u0204\u0206\5\u00be`\2\u0205"+
		"\u0202\3\2\2\2\u0205\u0203\3\2\2\2\u0205\u0204\3\2\2\2\u0206#\3\2\2\2"+
		"\u0207\u020b\7\u0083\2\2\u0208\u020b\7\177\2\2\u0209\u020b\5\u00be`\2"+
		"\u020a\u0207\3\2\2\2\u020a\u0208\3\2\2\2\u020a\u0209\3\2\2\2\u020b\u020c"+
		"\3\2\2\2\u020c\u020d\t\5\2\2\u020d%\3\2\2\2\u020e\u021f\5(\25\2\u020f"+
		"\u0214\5,\27\2\u0210\u0211\t\3\2\2\u0211\u0212\5\"\22\2\u0212\u0213\5"+
		"> \2\u0213\u0215\3\2\2\2\u0214\u0210\3\2\2\2\u0214\u0215\3\2\2\2\u0215"+
		"\u021f\3\2\2\2\u0216\u0217\7\60\2\2\u0217\u021f\5@!\2\u0218\u0219\7\32"+
		"\2\2\u0219\u021f\5@!\2\u021a\u021b\7)\2\2\u021b\u021f\5@!\2\u021c\u021d"+
		"\7:\2\2\u021d\u021f\5@!\2\u021e\u020e\3\2\2\2\u021e\u020f\3\2\2\2\u021e"+
		"\u0216\3\2\2\2\u021e\u0218\3\2\2\2\u021e\u021a\3\2\2\2\u021e\u021c\3\2"+
		"\2\2\u021f\'\3\2\2\2\u0220\u0222\5H%\2\u0221\u0223\7|\2\2\u0222\u0221"+
		"\3\2\2\2\u0222\u0223\3\2\2\2\u0223\u0224\3\2\2\2\u0224\u0225\t\6\2\2\u0225"+
		"\u0226\5\"\22\2\u0226\u0227\5*\26\2\u0227\u022c\3\2\2\2\u0228\u0229\5"+
		" \21\2\u0229\u022a\5*\26\2\u022a\u022c\3\2\2\2\u022b\u0220\3\2\2\2\u022b"+
		"\u0228\3\2\2\2\u022c)\3\2\2\2\u022d\u0230\5> \2\u022e\u0230\5(\25\2\u022f"+
		"\u022d\3\2\2\2\u022f\u022e\3\2\2\2\u0230+\3\2\2\2\u0231\u0235\5\60\31"+
		"\2\u0232\u0234\5.\30\2\u0233\u0232\3\2\2\2\u0234\u0237\3\2\2\2\u0235\u0233"+
		"\3\2\2\2\u0235\u0236\3\2\2\2\u0236-\3\2\2\2\u0237\u0235\3\2\2\2\u0238"+
		"\u0239\t\3\2\2\u0239\u023b\5\"\22\2\u023a\u023c\5:\36\2\u023b\u023a\3"+
		"\2\2\2\u023b\u023c\3\2\2\2\u023c/\3\2\2\2\u023d\u023e\7\62\2\2\u023e\u023f"+
		"\5<\37\2\u023f\u0240\5T+\2\u0240\u024c\3\2\2\2\u0241\u0242\5 \21\2\u0242"+
		"\u0243\5<\37\2\u0243\u0244\5T+\2\u0244\u024c\3\2\2\2\u0245\u0246\5H%\2"+
		"\u0246\u0247\t\3\2\2\u0247\u0248\5\"\22\2\u0248\u0249\5<\37\2\u0249\u024a"+
		"\5T+\2\u024a\u024c\3\2\2\2\u024b\u023d\3\2\2\2\u024b\u0241\3\2\2\2\u024b"+
		"\u0245\3\2\2\2\u024c\61\3\2\2\2\u024d\u025c\5(\25\2\u024e\u0250\5\66\34"+
		"\2\u024f\u0251\7C\2\2\u0250\u024f\3\2\2\2\u0250\u0251\3\2\2\2\u0251\u025c"+
		"\3\2\2\2\u0252\u0253\5\66\34\2\u0253\u0254\7C\2\2\u0254\u0255\5\64\33"+
		"\2\u0255\u025c\3\2\2\2\u0256\u0258\5\u008eH\2\u0257\u0259\7C\2\2\u0258"+
		"\u0257\3\2\2\2\u0258\u0259\3\2\2\2\u0259\u025c\3\2\2\2\u025a\u025c\5\64"+
		"\33\2\u025b\u024d\3\2\2\2\u025b\u024e\3\2\2\2\u025b\u0252\3\2\2\2\u025b"+
		"\u0256\3\2\2\2\u025b\u025a\3\2\2\2\u025c\63\3\2\2\2\u025d\u025e\7a\2\2"+
		"\u025e\u0262\5F$\2\u025f\u0260\7b\2\2\u0260\u0262\5F$\2\u0261\u025d\3"+
		"\2\2\2\u0261\u025f\3\2\2\2\u0262\65\3\2\2\2\u0263\u026e\5F$\2\u0264\u0268"+
		"\7C\2\2\u0265\u0267\7|\2\2\u0266\u0265\3\2\2\2\u0267\u026a\3\2\2\2\u0268"+
		"\u0266\3\2\2\2\u0268\u0269\3\2\2\2\u0269\u026b\3\2\2\2\u026a\u0268\3\2"+
		"\2\2\u026b\u026d\5F$\2\u026c\u0264\3\2\2\2\u026d\u0270\3\2\2\2\u026e\u026c"+
		"\3\2\2\2\u026e\u026f\3\2\2\2\u026f\67\3\2\2\2\u0270\u026e\3\2\2\2\u0271"+
		"\u027a\5F$\2\u0272\u0276\7C\2\2\u0273\u0275\7|\2\2\u0274\u0273\3\2\2\2"+
		"\u0275\u0278\3\2\2\2\u0276\u0274\3\2\2\2\u0276\u0277\3\2\2\2\u0277\u0279"+
		"\3\2\2\2\u0278\u0276\3\2\2\2\u0279\u027b\5F$\2\u027a\u0272\3\2\2\2\u027b"+
		"\u027c\3\2\2\2\u027c\u027a\3\2\2\2\u027c\u027d\3\2\2\2\u027d9\3\2\2\2"+
		"\u027e\u0282\7=\2\2\u027f\u0281\7|\2\2\u0280\u027f\3\2\2\2\u0281\u0284"+
		"\3\2\2\2\u0282\u0280\3\2\2\2\u0282\u0283\3\2\2\2\u0283\u0286\3\2\2\2\u0284"+
		"\u0282\3\2\2\2\u0285\u0287\7C\2\2\u0286\u0285\3\2\2\2\u0286\u0287\3\2"+
		"\2\2\u0287\u028b\3\2\2\2\u0288\u028a\7|\2\2\u0289\u0288\3\2\2\2\u028a"+
		"\u028d\3\2\2\2\u028b\u0289\3\2\2\2\u028b\u028c\3\2\2\2\u028c\u028e\3\2"+
		"\2\2\u028d\u028b\3\2\2\2\u028e\u02d1\7>\2\2\u028f\u0293\7=\2\2\u0290\u0292"+
		"\7|\2\2\u0291\u0290\3\2\2\2\u0292\u0295\3\2\2\2\u0293\u0291\3\2\2\2\u0293"+
		"\u0294\3\2\2\2\u0294\u0296\3\2\2\2\u0295\u0293\3\2\2\2\u0296\u0298\5<"+
		"\37\2\u0297\u0299\7C\2\2\u0298\u0297\3\2\2\2\u0298\u0299\3\2\2\2\u0299"+
		"\u029d\3\2\2\2\u029a\u029c\7|\2\2\u029b\u029a\3\2\2\2\u029c\u029f\3\2"+
		"\2\2\u029d\u029b\3\2\2\2\u029d\u029e\3\2\2\2\u029e\u02a0\3\2\2\2\u029f"+
		"\u029d\3\2\2\2\u02a0\u02a1\7>\2\2\u02a1\u02d1\3\2\2\2\u02a2\u02a6\7=\2"+
		"\2\u02a3\u02a5\7|\2\2\u02a4\u02a3\3\2\2\2\u02a5\u02a8\3\2\2\2\u02a6\u02a4"+
		"\3\2\2\2\u02a6\u02a7\3\2\2\2\u02a7\u02a9\3\2\2\2\u02a8\u02a6\3\2\2\2\u02a9"+
		"\u02aa\5\66\34\2\u02aa\u02ae\7C\2\2\u02ab\u02ad\7|\2\2\u02ac\u02ab\3\2"+
		"\2\2\u02ad\u02b0\3\2\2\2\u02ae\u02ac\3\2\2\2\u02ae\u02af\3\2\2\2\u02af"+
		"\u02b1\3\2\2\2\u02b0\u02ae\3\2\2\2\u02b1\u02b3\5,\27\2\u02b2\u02b4\7C"+
		"\2\2\u02b3\u02b2\3\2\2\2\u02b3\u02b4\3\2\2\2\u02b4\u02b8\3\2\2\2\u02b5"+
		"\u02b7\7|\2\2\u02b6\u02b5\3\2\2\2\u02b7\u02ba\3\2\2\2\u02b8\u02b6\3\2"+
		"\2\2\u02b8\u02b9\3\2\2\2\u02b9\u02bb\3\2\2\2\u02ba\u02b8\3\2\2\2\u02bb"+
		"\u02bc\7>\2\2\u02bc\u02d1\3\2\2\2\u02bd\u02c1\7=\2\2\u02be\u02c0\7|\2"+
		"\2\u02bf\u02be\3\2\2\2\u02c0\u02c3\3\2\2\2\u02c1\u02bf\3\2\2\2\u02c1\u02c2"+
		"\3\2\2\2\u02c2\u02c4\3\2\2\2\u02c3\u02c1\3\2\2\2\u02c4\u02c6\5,\27\2\u02c5"+
		"\u02c7\7C\2\2\u02c6\u02c5\3\2\2\2\u02c6\u02c7\3\2\2\2\u02c7\u02cb\3\2"+
		"\2\2\u02c8\u02ca\7|\2\2\u02c9\u02c8\3\2\2\2\u02ca\u02cd\3\2\2\2\u02cb"+
		"\u02c9\3\2\2\2\u02cb\u02cc\3\2\2\2\u02cc\u02ce\3\2\2\2\u02cd\u02cb\3\2"+
		"\2\2\u02ce\u02cf\7>\2\2\u02cf\u02d1\3\2\2\2\u02d0\u027e\3\2\2\2\u02d0"+
		"\u028f\3\2\2\2\u02d0\u02a2\3\2\2\2\u02d0\u02bd\3\2\2\2\u02d1;\3\2\2\2"+
		"\u02d2\u031e\5B\"\2\u02d3\u02dc\5\64\33\2\u02d4\u02d8\7C\2\2\u02d5\u02d7"+
		"\7|\2\2\u02d6\u02d5\3\2\2\2\u02d7\u02da\3\2\2\2\u02d8\u02d6\3\2\2\2\u02d8"+
		"\u02d9\3\2\2\2\u02d9\u02db\3\2\2\2\u02da\u02d8\3\2\2\2\u02db\u02dd\5B"+
		"\"\2\u02dc\u02d4\3\2\2\2\u02dc\u02dd\3\2\2\2\u02dd\u02e6\3\2\2\2\u02de"+
		"\u02e2\7C\2\2\u02df\u02e1\7|\2\2\u02e0\u02df\3\2\2\2\u02e1\u02e4\3\2\2"+
		"\2\u02e2\u02e0\3\2\2\2\u02e2\u02e3\3\2\2\2\u02e3\u02e5\3\2\2\2\u02e4\u02e2"+
		"\3\2\2\2\u02e5\u02e7\5\66\34\2\u02e6\u02de\3\2\2\2\u02e6\u02e7\3\2\2\2"+
		"\u02e7\u031e\3\2\2\2\u02e8\u02f1\5\66\34\2\u02e9\u02ed\7C\2\2\u02ea\u02ec"+
		"\7|\2\2\u02eb\u02ea\3\2\2\2\u02ec\u02ef\3\2\2\2\u02ed\u02eb\3\2\2\2\u02ed"+
		"\u02ee\3\2\2\2\u02ee\u02f0\3\2\2\2\u02ef\u02ed\3\2\2\2\u02f0\u02f2\5\u008e"+
		"H\2\u02f1\u02e9\3\2\2\2\u02f1\u02f2\3\2\2\2\u02f2\u02fb\3\2\2\2\u02f3"+
		"\u02f7\7C\2\2\u02f4\u02f6\7|\2\2\u02f5\u02f4\3\2\2\2\u02f6\u02f9\3\2\2"+
		"\2\u02f7\u02f5\3\2\2\2\u02f7\u02f8\3\2\2\2\u02f8\u02fa\3\2\2\2\u02f9\u02f7"+
		"\3\2\2\2\u02fa\u02fc\5\64\33\2\u02fb\u02f3\3\2\2\2\u02fb\u02fc\3\2\2\2"+
		"\u02fc\u0305\3\2\2\2\u02fd\u0301\7C\2\2\u02fe\u0300\7|\2\2\u02ff\u02fe"+
		"\3\2\2\2\u0300\u0303\3\2\2\2\u0301\u02ff\3\2\2\2\u0301\u0302\3\2\2\2\u0302"+
		"\u0304\3\2\2\2\u0303\u0301\3\2\2\2\u0304\u0306\5B\"\2\u0305\u02fd\3\2"+
		"\2\2\u0305\u0306\3\2\2\2\u0306\u031e\3\2\2\2\u0307\u0310\5\u008eH\2\u0308"+
		"\u030c\7C\2\2\u0309\u030b\7|\2\2\u030a\u0309\3\2\2\2\u030b\u030e\3\2\2"+
		"\2\u030c\u030a\3\2\2\2\u030c\u030d\3\2\2\2\u030d\u030f\3\2\2\2\u030e\u030c"+
		"\3\2\2\2\u030f\u0311\5\64\33\2\u0310\u0308\3\2\2\2\u0310\u0311\3\2\2\2"+
		"\u0311\u031a\3\2\2\2\u0312\u0316\7C\2\2\u0313\u0315\7|\2\2\u0314\u0313"+
		"\3\2\2\2\u0315\u0318\3\2\2\2\u0316\u0314\3\2\2\2\u0316\u0317\3\2\2\2\u0317"+
		"\u0319\3\2\2\2\u0318\u0316\3\2\2\2\u0319\u031b\5B\"\2\u031a\u0312\3\2"+
		"\2\2\u031a\u031b\3\2\2\2\u031b\u031e\3\2\2\2\u031c\u031e\5(\25\2\u031d"+
		"\u02d2\3\2\2\2\u031d\u02d3\3\2\2\2\u031d\u02e8\3\2\2\2\u031d\u0307\3\2"+
		"\2\2\u031d\u031c\3\2\2\2\u031e=\3\2\2\2\u031f\u032c\5\u008eH\2\u0320\u0329"+
		"\5@!\2\u0321\u0325\7C\2\2\u0322\u0324\7|\2\2\u0323\u0322\3\2\2\2\u0324"+
		"\u0327\3\2\2\2\u0325\u0323\3\2\2\2\u0325\u0326\3\2\2\2\u0326\u0328\3\2"+
		"\2\2\u0327\u0325\3\2\2\2\u0328\u032a\5\u008eH\2\u0329\u0321\3\2\2\2\u0329"+
		"\u032a\3\2\2\2\u032a\u032c\3\2\2\2\u032b\u031f\3\2\2\2\u032b\u0320\3\2"+
		"\2\2\u032c?\3\2\2\2\u032d\u0338\5J&\2\u032e\u0332\7C\2\2\u032f\u0331\7"+
		"|\2\2\u0330\u032f\3\2\2\2\u0331\u0334\3\2\2\2\u0332\u0330\3\2\2\2\u0332"+
		"\u0333\3\2\2\2\u0333\u0335\3\2\2\2\u0334\u0332\3\2\2\2\u0335\u0337\5J"+
		"&\2\u0336\u032e\3\2\2\2\u0337\u033a\3\2\2\2\u0338\u0336\3\2\2\2\u0338"+
		"\u0339\3\2\2\2\u0339A\3\2\2\2\u033a\u0338\3\2\2\2\u033b\u033c\7N\2\2\u033c"+
		"\u033d\5F$\2\u033dC\3\2\2\2\u033e\u033f\b#\1\2\u033f\u034d\5F$\2\u0340"+
		"\u0342\7K\2\2\u0341\u0340\3\2\2\2\u0341\u0342\3\2\2\2\u0342\u0343\3\2"+
		"\2\2\u0343\u034d\5&\24\2\u0344\u0348\7+\2\2\u0345\u0347\7|\2\2\u0346\u0345"+
		"\3\2\2\2\u0347\u034a\3\2\2\2\u0348\u0346\3\2\2\2\u0348\u0349\3\2\2\2\u0349"+
		"\u034b\3\2\2\2\u034a\u0348\3\2\2\2\u034b\u034d\5D#\4\u034c\u033e\3\2\2"+
		"\2\u034c\u0341\3\2\2\2\u034c\u0344\3\2\2\2\u034d\u0359\3\2\2\2\u034e\u034f"+
		"\f\3\2\2\u034f\u0353\t\7\2\2\u0350\u0352\7|\2\2\u0351\u0350\3\2\2\2\u0352"+
		"\u0355\3\2\2\2\u0353\u0351\3\2\2\2\u0353\u0354\3\2\2\2\u0354\u0356\3\2"+
		"\2\2\u0355\u0353\3\2\2\2\u0356\u0358\5D#\4\u0357\u034e\3\2\2\2\u0358\u035b"+
		"\3\2\2\2\u0359\u0357\3\2\2\2\u0359\u035a\3\2\2\2\u035aE\3\2\2\2\u035b"+
		"\u0359\3\2\2\2\u035c\u035d\b$\1\2\u035d\u035e\5H%\2\u035e\u0379\3\2\2"+
		"\2\u035f\u0360\f\3\2\2\u0360\u0364\7H\2\2\u0361\u0363\7|\2\2\u0362\u0361"+
		"\3\2\2\2\u0363\u0366\3\2\2\2\u0364\u0362\3\2\2\2\u0364\u0365\3\2\2\2\u0365"+
		"\u0367\3\2\2\2\u0366\u0364\3\2\2\2\u0367\u036b\5F$\2\u0368\u036a\7|\2"+
		"\2\u0369\u0368\3\2\2\2\u036a\u036d\3\2\2\2\u036b\u0369\3\2\2\2\u036b\u036c"+
		"\3\2\2\2\u036c\u036e\3\2\2\2\u036d\u036b\3\2\2\2\u036e\u0372\7A\2\2\u036f"+
		"\u0371\7|\2\2\u0370\u036f\3\2\2\2\u0371\u0374\3\2\2\2\u0372\u0370\3\2"+
		"\2\2\u0372\u0373\3\2\2\2\u0373\u0375\3\2\2\2\u0374\u0372\3\2\2\2\u0375"+
		"\u0376\5F$\4\u0376\u0378\3\2\2\2\u0377\u035f\3\2\2\2\u0378\u037b\3\2\2"+
		"\2\u0379\u0377\3\2\2\2\u0379\u037a\3\2\2\2\u037aG\3\2\2\2\u037b\u0379"+
		"\3\2\2\2\u037c\u0383\7\60\2\2\u037d\u0383\7\32\2\2\u037e\u0383\7)\2\2"+
		"\u037f\u0383\7-\2\2\u0380\u0383\7/\2\2\u0381\u0383\5J&\2\u0382\u037c\3"+
		"\2\2\2\u0382\u037d\3\2\2\2\u0382\u037e\3\2\2\2\u0382\u037f\3\2\2\2\u0382"+
		"\u0380\3\2\2\2\u0382\u0381\3\2\2\2\u0383I\3\2\2\2\u0384\u0385\b&\1\2\u0385"+
		"\u0386\5\u00bc_\2\u0386\u038a\5\u00b8]\2\u0387\u0389\7|\2\2\u0388\u0387"+
		"\3\2\2\2\u0389\u038c\3\2\2\2\u038a\u0388\3\2\2\2\u038a\u038b\3\2\2\2\u038b"+
		"\u038d\3\2\2\2\u038c\u038a\3\2\2\2\u038d\u038e\5F$\2\u038e\u04d4\3\2\2"+
		"\2\u038f\u0390\7B\2\2\u0390\u0391\7\u0083\2\2\u0391\u0395\5\u00b8]\2\u0392"+
		"\u0394\7|\2\2\u0393\u0392\3\2\2\2\u0394\u0397\3\2\2\2\u0395\u0393\3\2"+
		"\2\2\u0395\u0396\3\2\2\2\u0396\u0398\3\2\2\2\u0397\u0395\3\2\2\2\u0398"+
		"\u0399\5F$\2\u0399\u04d4\3\2\2\2\u039a\u039b\7\34\2\2\u039b\u039e\5\u0088"+
		"E\2\u039c\u039d\7[\2\2\u039d\u039f\5N(\2\u039e\u039c\3\2\2\2\u039e\u039f"+
		"\3\2\2\2\u039f\u03a1\3\2\2\2\u03a0\u03a2\t\2\2\2\u03a1\u03a0\3\2\2\2\u03a1"+
		"\u03a2\3\2\2\2\u03a2\u03a3\3\2\2\2\u03a3\u03a4\5f\64\2\u03a4\u03a5\7\""+
		"\2\2\u03a5\u04d4\3\2\2\2\u03a6\u03a7\7\34\2\2\u03a7\u03a8\7]\2\2\u03a8"+
		"\u03a9\5N(\2\u03a9\u03aa\t\2\2\2\u03aa\u03ab\5f\64\2\u03ab\u03ac\7\"\2"+
		"\2\u03ac\u04d4\3\2\2\2\u03ad\u03ae\7(\2\2\u03ae\u03af\5\u0088E\2\u03af"+
		"\u03b0\5f\64\2\u03b0\u03b1\7\"\2\2\u03b1\u04d4\3\2\2\2\u03b2\u03b3\7\35"+
		"\2\2\u03b3\u03b4\5p9\2\u03b4\u03b5\5r:\2\u03b5\u03b6\5f\64\2\u03b6\u03b7"+
		"\7\"\2\2\u03b7\u04d4\3\2\2\2\u03b8\u03b9\7\35\2\2\u03b9\u03ba\5\u008a"+
		"F\2\u03ba\u03bb\t\3\2\2\u03bb\u03bc\5p9\2\u03bc\u03bd\5r:\2\u03bd\u03be"+
		"\5f\64\2\u03be\u03bf\7\"\2\2\u03bf\u04d4\3\2\2\2\u03c0\u03c1\7\35\2\2"+
		"\u03c1\u03c7\5p9\2\u03c2\u03c4\7=\2\2\u03c3\u03c5\5t;\2\u03c4\u03c3\3"+
		"\2\2\2\u03c4\u03c5\3\2\2\2\u03c5\u03c6\3\2\2\2\u03c6\u03c8\7>\2\2\u03c7"+
		"\u03c2\3\2\2\2\u03c7\u03c8\3\2\2\2\u03c8\u03c9\3\2\2\2\u03c9\u03cd\7S"+
		"\2\2\u03ca\u03cc\7|\2\2\u03cb\u03ca\3\2\2\2\u03cc\u03cf\3\2\2\2\u03cd"+
		"\u03cb\3\2\2\2\u03cd\u03ce\3\2\2\2\u03ce\u03d0\3\2\2\2\u03cf\u03cd\3\2"+
		"\2\2\u03d0\u03d1\5\b\5\2\u03d1\u04d4\3\2\2\2\u03d2\u03d8\7J\2\2\u03d3"+
		"\u03d5\7=\2\2\u03d4\u03d6\5t;\2\u03d5\u03d4\3\2\2\2\u03d5\u03d6\3\2\2"+
		"\2\u03d6\u03d7\3\2\2\2\u03d7\u03d9\7>\2\2\u03d8\u03d3\3\2\2\2\u03d8\u03d9"+
		"\3\2\2\2\u03d9\u03da\3\2\2\2\u03da\u04d4\5R*\2\u03db\u03df\7&\2\2\u03dc"+
		"\u03de\7|\2\2\u03dd\u03dc\3\2\2\2\u03de\u03e1\3\2\2\2\u03df\u03dd\3\2"+
		"\2\2\u03df\u03e0\3\2\2\2\u03e0\u03e2\3\2\2\2\u03e1\u03df\3\2\2\2\u03e2"+
		"\u03e3\5D#\2\u03e3\u03e7\5X-\2\u03e4\u03e6\5\\/\2\u03e5\u03e4\3\2\2\2"+
		"\u03e6\u03e9\3\2\2\2\u03e7\u03e5\3\2\2\2\u03e7\u03e8\3\2\2\2\u03e8\u03eb"+
		"\3\2\2\2\u03e9\u03e7\3\2\2\2\u03ea\u03ec\5Z.\2\u03eb\u03ea\3\2\2\2\u03eb"+
		"\u03ec\3\2\2\2\u03ec\u03ed\3\2\2\2\u03ed\u03ee\7\"\2\2\u03ee\u04d4\3\2"+
		"\2\2\u03ef\u03f3\7\66\2\2\u03f0\u03f2\7|\2\2\u03f1\u03f0\3\2\2\2\u03f2"+
		"\u03f5\3\2\2\2\u03f3\u03f1\3\2\2\2\u03f3\u03f4\3\2\2\2\u03f4\u03f6\3\2"+
		"\2\2\u03f5\u03f3\3\2\2\2\u03f6\u03f7\5D#\2\u03f7\u03f9\5X-\2\u03f8\u03fa"+
		"\5Z.\2\u03f9\u03f8\3\2\2\2\u03f9\u03fa\3\2\2\2\u03fa\u03fb\3\2\2\2\u03fb"+
		"\u03fc\7\"\2\2\u03fc\u04d4\3\2\2\2\u03fd\u0401\7\67\2\2\u03fe\u0400\7"+
		"|\2\2\u03ff\u03fe\3\2\2\2\u0400\u0403\3\2\2\2\u0401\u03ff\3\2\2\2\u0401"+
		"\u0402\3\2\2\2\u0402\u0404\3\2\2\2\u0403\u0401\3\2\2\2\u0404\u0405\5D"+
		"#\2\u0405\u0406\5b\62\2\u0406\u0407\7\"\2\2\u0407\u04d4\3\2\2\2\u0408"+
		"\u040a\7:\2\2\u0409\u040b\5:\36\2\u040a\u0409\3\2\2\2\u040a\u040b\3\2"+
		"\2\2\u040b\u04d4\3\2\2\2\u040c\u040d\7\31\2\2\u040d\u040e\5f\64\2\u040e"+
		"\u040f\7\"\2\2\u040f\u04d4\3\2\2\2\u0410\u0414\7\33\2\2\u0411\u0413\7"+
		"|\2\2\u0412\u0411\3\2\2\2\u0413\u0416\3\2\2\2\u0414\u0412\3\2\2\2\u0414"+
		"\u0415\3\2\2\2\u0415\u0417\3\2\2\2\u0416\u0414\3\2\2\2\u0417\u041b\5D"+
		"#\2\u0418\u041a\t\2\2\2\u0419\u0418\3\2\2\2\u041a\u041d\3\2\2\2\u041b"+
		"\u0419\3\2\2\2\u041b\u041c\3\2\2\2\u041c\u041f\3\2\2\2\u041d\u041b\3\2"+
		"\2\2\u041e\u0420\5^\60\2\u041f\u041e\3\2\2\2\u0420\u0421\3\2\2\2\u0421"+
		"\u041f\3\2\2\2\u0421\u0422\3\2\2\2\u0422\u0424\3\2\2\2\u0423\u0425\5Z"+
		".\2\u0424\u0423\3\2\2\2\u0424\u0425\3\2\2\2\u0425\u0426\3\2\2\2\u0426"+
		"\u0427\7\"\2\2\u0427\u04d4\3\2\2\2\u0428\u042c\7\33\2\2\u0429\u042b\t"+
		"\2\2\2\u042a\u0429\3\2\2\2\u042b\u042e\3\2\2\2\u042c\u042a\3\2\2\2\u042c"+
		"\u042d\3\2\2\2\u042d\u0430\3\2\2\2\u042e\u042c\3\2\2\2\u042f\u0431\5^"+
		"\60\2\u0430\u042f\3\2\2\2\u0431\u0432\3\2\2\2\u0432\u0430\3\2\2\2\u0432"+
		"\u0433\3\2\2\2\u0433\u0435\3\2\2\2\u0434\u0436\5Z.\2\u0435\u0434\3\2\2"+
		"\2\u0435\u0436\3\2\2\2\u0436\u0437\3\2\2\2\u0437\u0438\7\"\2\2\u0438\u04d4"+
		"\3\2\2\2\u0439\u043d\79\2\2\u043a\u043c\7|\2\2\u043b\u043a\3\2\2\2\u043c"+
		"\u043f\3\2\2\2\u043d\u043b\3\2\2\2\u043d\u043e\3\2\2\2\u043e\u0440\3\2"+
		"\2\2\u043f\u043d\3\2\2\2\u0440\u0441\5D#\2\u0441\u0442\5b\62\2\u0442\u0443"+
		"\7\"\2\2\u0443\u04d4\3\2\2\2\u0444\u0448\7$\2\2\u0445\u0447\7|\2\2\u0446"+
		"\u0445\3\2\2\2\u0447\u044a\3\2\2\2\u0448\u0446\3\2\2\2\u0448\u0449\3\2"+
		"\2\2\u0449\u044b\3\2\2\2\u044a\u0448\3\2\2\2\u044b\u044c\5d\63\2\u044c"+
		"\u0450\7\'\2\2\u044d\u044f\7|\2\2\u044e\u044d\3\2\2\2\u044f\u0452\3\2"+
		"\2\2\u0450\u044e\3\2\2\2\u0450\u0451\3\2\2\2\u0451\u0453\3\2\2\2\u0452"+
		"\u0450\3\2\2\2\u0453\u0454\5P)\2\u0454\u0455\5b\62\2\u0455\u0456\7\"\2"+
		"\2\u0456\u04d4\3\2\2\2\u0457\u04d4\5L\'\2\u0458\u045c\7;\2\2\u0459\u045b"+
		"\7|\2\2\u045a\u0459\3\2\2\2\u045b\u045e\3\2\2\2\u045c\u045a\3\2\2\2\u045c"+
		"\u045d\3\2\2\2\u045d\u0460\3\2\2\2\u045e\u045c\3\2\2\2\u045f\u0461\5\62"+
		"\32\2\u0460\u045f\3\2\2\2\u0460\u0461\3\2\2\2\u0461\u0465\3\2\2\2\u0462"+
		"\u0464\7|\2\2\u0463\u0462\3\2\2\2\u0464\u0467\3\2\2\2\u0465\u0463\3\2"+
		"\2\2\u0465\u0466\3\2\2\2\u0466\u0468\3\2\2\2\u0467\u0465\3\2\2\2\u0468"+
		"\u04d4\7<\2\2\u0469\u046b\7o\2\2\u046a\u046c\5\u00aeX\2\u046b\u046a\3"+
		"\2\2\2\u046b\u046c\3\2\2\2\u046c\u046d\3\2\2\2\u046d\u04d4\7\7\2\2\u046e"+
		"\u0470\7s\2\2\u046f\u0471\5\u00aeX\2\u0470\u046f\3\2\2\2\u0470\u0471\3"+
		"\2\2\2\u0471\u0472\3\2\2\2\u0472\u04d4\7\b\2\2\u0473\u0475\7p\2\2\u0474"+
		"\u0476\5\u00b0Y\2\u0475\u0474\3\2\2\2\u0475\u0476\3\2\2\2\u0476\u0477"+
		"\3\2\2\2\u0477\u04d4\7\f\2\2\u0478\u047a\7t\2\2\u0479\u047b\5\u00b0Y\2"+
		"\u047a\u0479\3\2\2\2\u047a\u047b\3\2\2\2\u047b\u047c\3\2\2\2\u047c\u04d4"+
		"\7\r\2\2\u047d\u0481\7?\2\2\u047e\u0480\7|\2\2\u047f\u047e\3\2\2\2\u0480"+
		"\u0483\3\2\2\2\u0481\u047f\3\2\2\2\u0481\u0482\3\2\2\2\u0482\u0488\3\2"+
		"\2\2\u0483\u0481\3\2\2\2\u0484\u0486\5\u008eH\2\u0485\u0487\7C\2\2\u0486"+
		"\u0485\3\2\2\2\u0486\u0487\3\2\2\2\u0487\u0489\3\2\2\2\u0488\u0484\3\2"+
		"\2\2\u0488\u0489\3\2\2\2\u0489\u048d\3\2\2\2\u048a\u048c\7|\2\2\u048b"+
		"\u048a\3\2\2\2\u048c\u048f\3\2\2\2\u048d\u048b\3\2\2\2\u048d\u048e\3\2"+
		"\2\2\u048e\u0490\3\2\2\2\u048f\u048d\3\2\2\2\u0490\u04d4\7@\2\2\u0491"+
		"\u0493\t\b\2\2\u0492\u0491\3\2\2\2\u0492\u0493\3\2\2\2\u0493\u0494\3\2"+
		"\2\2\u0494\u04d4\5\u00c0a\2\u0495\u0499\5\u0098M\2\u0496\u0498\5\u009a"+
		"N\2\u0497\u0496\3\2\2\2\u0498\u049b\3\2\2\2\u0499\u0497\3\2\2\2\u0499"+
		"\u049a\3\2\2\2\u049a\u04d4\3\2\2\2\u049b\u0499\3\2\2\2\u049c\u04a0\5\u009c"+
		"O\2\u049d\u049f\5\u009aN\2\u049e\u049d\3\2\2\2\u049f\u04a2\3\2\2\2\u04a0"+
		"\u049e\3\2\2\2\u04a0\u04a1\3\2\2\2\u04a1\u04d4\3\2\2\2\u04a2\u04a0\3\2"+
		"\2\2\u04a3\u04a5\7k\2\2\u04a4\u04a6\7\20\2\2\u04a5\u04a4\3\2\2\2\u04a5"+
		"\u04a6\3\2\2\2\u04a6\u04a7\3\2\2\2\u04a7\u04d4\7\6\2\2\u04a8\u04ac\7l"+
		"\2\2\u04a9\u04ab\5\u00a6T\2\u04aa\u04a9\3\2\2\2\u04ab\u04ae\3\2\2\2\u04ac"+
		"\u04aa\3\2\2\2\u04ac\u04ad\3\2\2\2\u04ad\u04af\3\2\2\2\u04ae\u04ac\3\2"+
		"\2\2\u04af\u04d4\7\n\2\2\u04b0\u04b4\7n\2\2\u04b1\u04b3\5\u00a6T\2\u04b2"+
		"\u04b1\3\2\2\2\u04b3\u04b6\3\2\2\2\u04b4\u04b2\3\2\2\2\u04b4\u04b5\3\2"+
		"\2\2\u04b5\u04b7\3\2\2\2\u04b6\u04b4\3\2\2\2\u04b7\u04d4\7\13\2\2\u04b8"+
		"\u04d4\5\u00b2Z\2\u04b9\u04bd\7\5\2\2\u04ba\u04bc\5\u0096L\2\u04bb\u04ba"+
		"\3\2\2\2\u04bc\u04bf\3\2\2\2\u04bd\u04bb\3\2\2\2\u04bd\u04be\3\2\2\2\u04be"+
		"\u04c0\3\2\2\2\u04bf\u04bd\3\2\2\2\u04c0\u04d4\7\u0095\2\2\u04c1\u04c5"+
		"\7m\2\2\u04c2\u04c4\5\u00a6T\2\u04c3\u04c2\3\2\2\2\u04c4\u04c7\3\2\2\2"+
		"\u04c5\u04c3\3\2\2\2\u04c5\u04c6\3\2\2\2\u04c6\u04c8\3\2\2\2\u04c7\u04c5"+
		"\3\2\2\2\u04c8\u04d4\7\t\2\2\u04c9\u04ca\7=\2\2\u04ca\u04cb\5\4\3\2\u04cb"+
		"\u04cc\7>\2\2\u04cc\u04d4\3\2\2\2\u04cd\u04ce\5\u00c2b\2\u04ce\u04cf\5"+
		"J&\20\u04cf\u04d4\3\2\2\2\u04d0\u04d1\7`\2\2\u04d1\u04d4\5J&\16\u04d2"+
		"\u04d4\5\u00b4[\2\u04d3\u0384\3\2\2\2\u04d3\u038f\3\2\2\2\u04d3\u039a"+
		"\3\2\2\2\u04d3\u03a6\3\2\2\2\u04d3\u03ad\3\2\2\2\u04d3\u03b2\3\2\2\2\u04d3"+
		"\u03b8\3\2\2\2\u04d3\u03c0\3\2\2\2\u04d3\u03d2\3\2\2\2\u04d3\u03db\3\2"+
		"\2\2\u04d3\u03ef\3\2\2\2\u04d3\u03fd\3\2\2\2\u04d3\u0408\3\2\2\2\u04d3"+
		"\u040c\3\2\2\2\u04d3\u0410\3\2\2\2\u04d3\u0428\3\2\2\2\u04d3\u0439\3\2"+
		"\2\2\u04d3\u0444\3\2\2\2\u04d3\u0457\3\2\2\2\u04d3\u0458\3\2\2\2\u04d3"+
		"\u0469\3\2\2\2\u04d3\u046e\3\2\2\2\u04d3\u0473\3\2\2\2\u04d3\u0478\3\2"+
		"\2\2\u04d3\u047d\3\2\2\2\u04d3\u0492\3\2\2\2\u04d3\u0495\3\2\2\2\u04d3"+
		"\u049c\3\2\2\2\u04d3\u04a3\3\2\2\2\u04d3\u04a8\3\2\2\2\u04d3\u04b0\3\2"+
		"\2\2\u04d3\u04b8\3\2\2\2\u04d3\u04b9\3\2\2\2\u04d3\u04c1\3\2\2\2\u04d3"+
		"\u04c9\3\2\2\2\u04d3\u04cd\3\2\2\2\u04d3\u04d0\3\2\2\2\u04d3\u04d2\3\2"+
		"\2\2\u04d4\u0583\3\2\2\2\u04d5\u04d6\f\17\2\2\u04d6\u04da\7b\2\2\u04d7"+
		"\u04d9\7|\2\2\u04d8\u04d7\3\2\2\2\u04d9\u04dc\3\2\2\2\u04da\u04d8\3\2"+
		"\2\2\u04da\u04db\3\2\2\2\u04db\u04dd\3\2\2\2\u04dc\u04da\3\2\2\2\u04dd"+
		"\u0582\5J&\17\u04de\u04df\f\r\2\2\u04df\u04e3\5\u00c4c\2\u04e0\u04e2\7"+
		"|\2\2\u04e1\u04e0\3\2\2\2\u04e2\u04e5\3\2\2\2\u04e3\u04e1\3\2\2\2\u04e3"+
		"\u04e4\3\2\2\2\u04e4\u04e6\3\2\2\2\u04e5\u04e3\3\2\2\2\u04e6\u04e7\5J"+
		"&\16\u04e7\u0582\3\2\2\2\u04e8\u04e9\f\f\2\2\u04e9\u04ed\5\u00c6d\2\u04ea"+
		"\u04ec\7|\2\2\u04eb\u04ea\3\2\2\2\u04ec\u04ef\3\2\2\2\u04ed\u04eb\3\2"+
		"\2\2\u04ed\u04ee\3\2\2\2\u04ee\u04f0\3\2\2\2\u04ef\u04ed\3\2\2\2\u04f0"+
		"\u04f1\5J&\r\u04f1\u0582\3\2\2\2\u04f2\u04f3\f\13\2\2\u04f3\u04f7\5\u00c8"+
		"e\2\u04f4\u04f6\7|\2\2\u04f5\u04f4\3\2\2\2\u04f6\u04f9\3\2\2\2\u04f7\u04f5"+
		"\3\2\2\2\u04f7\u04f8\3\2\2\2\u04f8\u04fa\3\2\2\2\u04f9\u04f7\3\2\2\2\u04fa"+
		"\u04fb\5J&\f\u04fb\u0582\3\2\2\2\u04fc\u04fd\f\n\2\2\u04fd\u0501\7N\2"+
		"\2\u04fe\u0500\7|\2\2\u04ff\u04fe\3\2\2\2\u0500\u0503\3\2\2\2\u0501\u04ff"+
		"\3\2\2\2\u0501\u0502\3\2\2\2\u0502\u0504\3\2\2\2\u0503\u0501\3\2\2\2\u0504"+
		"\u0582\5J&\13\u0505\u0506\f\t\2\2\u0506\u050a\5\u00caf\2\u0507\u0509\7"+
		"|\2\2\u0508\u0507\3\2\2\2\u0509\u050c\3\2\2\2\u050a\u0508\3\2\2\2\u050a"+
		"\u050b\3\2\2\2\u050b\u050d\3\2\2\2\u050c\u050a\3\2\2\2\u050d\u050e\5J"+
		"&\n\u050e\u0582\3\2\2\2\u050f\u0510\f\b\2\2\u0510\u0514\5\u00ccg\2\u0511"+
		"\u0513\7|\2\2\u0512\u0511\3\2\2\2\u0513\u0516\3\2\2\2\u0514\u0512\3\2"+
		"\2\2\u0514\u0515\3\2\2\2\u0515\u0517\3\2\2\2\u0516\u0514\3\2\2\2\u0517"+
		"\u0518\5J&\t\u0518\u0582\3\2\2\2\u0519\u051a\f\7\2\2\u051a\u051e\5\u00ce"+
		"h\2\u051b\u051d\7|\2\2\u051c\u051b\3\2\2\2\u051d\u0520\3\2\2\2\u051e\u051c"+
		"\3\2\2\2\u051e\u051f\3\2\2\2\u051f\u0521\3\2\2\2\u0520\u051e\3\2\2\2\u0521"+
		"\u0522\5J&\b\u0522\u0582\3\2\2\2\u0523\u0524\f\6\2\2\u0524\u0528\7O\2"+
		"\2\u0525\u0527\7|\2\2\u0526\u0525\3\2\2\2\u0527\u052a\3\2\2\2\u0528\u0526"+
		"\3\2\2\2\u0528\u0529\3\2\2\2\u0529\u052b\3\2\2\2\u052a\u0528\3\2\2\2\u052b"+
		"\u0582\5J&\7\u052c\u052d\f\5\2\2\u052d\u0531\7R\2\2\u052e\u0530\7|\2\2"+
		"\u052f\u052e\3\2\2\2\u0530\u0533\3\2\2\2\u0531\u052f\3\2\2\2\u0531\u0532"+
		"\3\2\2\2\u0532\u0534\3\2\2\2\u0533\u0531\3\2\2\2\u0534\u0582\5J&\6\u0535"+
		"\u0536\f\4\2\2\u0536\u053a\5\u00d0i\2\u0537\u0539\7|\2\2\u0538\u0537\3"+
		"\2\2\2\u0539\u053c\3\2\2\2\u053a\u0538\3\2\2\2\u053a\u053b\3\2\2\2\u053b"+
		"\u053d\3\2\2\2\u053c\u053a\3\2\2\2\u053d\u053e\5J&\5\u053e\u0582\3\2\2"+
		"\2\u053f\u0540\f\67\2\2\u0540\u0541\t\3\2\2\u0541\u0542\5\"\22\2\u0542"+
		"\u0546\5\u00b8]\2\u0543\u0545\7|\2\2\u0544\u0543\3\2\2\2\u0545\u0548\3"+
		"\2\2\2\u0546\u0544\3\2\2\2\u0546\u0547\3\2\2\2\u0547\u0549\3\2\2\2\u0548"+
		"\u0546\3\2\2\2\u0549\u054a\5F$\2\u054a\u0582\3\2\2\2\u054b\u054c\f\65"+
		"\2\2\u054c\u054e\7;\2\2\u054d\u054f\5\62\32\2\u054e\u054d\3\2\2\2\u054e"+
		"\u054f\3\2\2\2\u054f\u0550\3\2\2\2\u0550\u0551\7<\2\2\u0551\u0555\5\u00b8"+
		"]\2\u0552\u0554\7|\2\2\u0553\u0552\3\2\2\2\u0554\u0557\3\2\2\2\u0555\u0553"+
		"\3\2\2\2\u0555\u0556\3\2\2\2\u0556\u0558\3\2\2\2\u0557\u0555\3\2\2\2\u0558"+
		"\u0559\5F$\2\u0559\u0582\3\2\2\2\u055a\u055b\f\64\2\2\u055b\u055f\5\u00b8"+
		"]\2\u055c\u055e\7|\2\2\u055d\u055c\3\2\2\2\u055e\u0561\3\2\2\2\u055f\u055d"+
		"\3\2\2\2\u055f\u0560\3\2\2\2\u0560\u0562\3\2\2\2\u0561\u055f\3\2\2\2\u0562"+
		"\u0563\5F$\2\u0563\u0564\7.\2\2\u0564\u0565\5F$\2\u0565\u0582\3\2\2\2"+
		"\u0566\u0567\f\22\2\2\u0567\u0569\7;\2\2\u0568\u056a\5\62\32\2\u0569\u0568"+
		"\3\2\2\2\u0569\u056a\3\2\2\2\u056a\u056b\3\2\2\2\u056b\u0582\7<\2\2\u056c"+
		"\u0570\f\21\2\2\u056d\u056f\7|\2\2\u056e\u056d\3\2\2\2\u056f\u0572\3\2"+
		"\2\2\u0570\u056e\3\2\2\2\u0570\u0571\3\2\2\2\u0571\u0573\3\2\2\2\u0572"+
		"\u0570\3\2\2\2\u0573\u0577\t\6\2\2\u0574\u0576\7|\2\2\u0575\u0574\3\2"+
		"\2\2\u0576\u0579\3\2\2\2\u0577\u0575\3\2\2\2\u0577\u0578\3\2\2\2\u0578"+
		"\u057a\3\2\2\2\u0579\u0577\3\2\2\2\u057a\u057c\5\"\22\2\u057b\u057d\5"+
		":\36\2\u057c\u057b\3\2\2\2\u057c\u057d\3\2\2\2\u057d\u057f\3\2\2\2\u057e"+
		"\u0580\5R*\2\u057f\u057e\3\2\2\2\u057f\u0580\3\2\2\2\u0580\u0582\3\2\2"+
		"\2\u0581\u04d5\3\2\2\2\u0581\u04de\3\2\2\2\u0581\u04e8\3\2\2\2\u0581\u04f2"+
		"\3\2\2\2\u0581\u04fc\3\2\2\2\u0581\u0505\3\2\2\2\u0581\u050f\3\2\2\2\u0581"+
		"\u0519\3\2\2\2\u0581\u0523\3\2\2\2\u0581\u052c\3\2\2\2\u0581\u0535\3\2"+
		"\2\2\u0581\u053f\3\2\2\2\u0581\u054b\3\2\2\2\u0581\u055a\3\2\2\2\u0581"+
		"\u0566\3\2\2\2\u0581\u056c\3\2\2\2\u0582\u0585\3\2\2\2\u0583\u0581\3\2"+
		"\2\2\u0583\u0584\3\2\2\2\u0584K\3\2\2\2\u0585\u0583\3\2\2\2\u0586\u0588"+
		"\7\62\2\2\u0587\u0589\5:\36\2\u0588\u0587\3\2\2\2\u0588\u0589\3\2\2\2"+
		"\u0589\u058b\3\2\2\2\u058a\u058c\5R*\2\u058b\u058a\3\2\2\2\u058b\u058c"+
		"\3\2\2\2\u058c\u05a7\3\2\2\2\u058d\u058f\7\62\2\2\u058e\u0590\5<\37\2"+
		"\u058f\u058e\3\2\2\2\u058f\u0590\3\2\2\2\u0590\u0592\3\2\2\2\u0591\u0593"+
		"\5R*\2\u0592\u0591\3\2\2\2\u0592\u0593\3\2\2\2\u0593\u05a7\3\2\2\2\u0594"+
		"\u0595\5\u00b6\\\2\u0595\u0596\7=\2\2\u0596\u0597\5D#\2\u0597\u0598\7"+
		">\2\2\u0598\u05a7\3\2\2\2\u0599\u059a\5\u00b6\\\2\u059a\u059b\5J&\2\u059b"+
		"\u05a7\3\2\2\2\u059c\u05a7\5$\23\2\u059d\u059e\5 \21\2\u059e\u059f\5R"+
		"*\2\u059f\u05a7\3\2\2\2\u05a0\u05a1\5 \21\2\u05a1\u05a3\5:\36\2\u05a2"+
		"\u05a4\5R*\2\u05a3\u05a2\3\2\2\2\u05a3\u05a4\3\2\2\2\u05a4\u05a7\3\2\2"+
		"\2\u05a5\u05a7\5\u008cG\2\u05a6\u0586\3\2\2\2\u05a6\u058d\3\2\2\2\u05a6"+
		"\u0594\3\2\2\2\u05a6\u0599\3\2\2\2\u05a6\u059c\3\2\2\2\u05a6\u059d\3\2"+
		"\2\2\u05a6\u05a0\3\2\2\2\u05a6\u05a5\3\2\2\2\u05a7M\3\2\2\2\u05a8\u05ab"+
		"\5(\25\2\u05a9\u05ab\5J&\2\u05aa\u05a8\3\2\2\2\u05aa\u05a9\3\2\2\2\u05ab"+
		"O\3\2\2\2\u05ac\u05ad\b)\1\2\u05ad\u05b2\5J&\2\u05ae\u05b2\5(\25\2\u05af"+
		"\u05b0\7+\2\2\u05b0\u05b2\5P)\4\u05b1\u05ac\3\2\2\2\u05b1\u05ae\3\2\2"+
		"\2\u05b1\u05af\3\2\2\2\u05b2\u05be\3\2\2\2\u05b3\u05b4\f\3\2\2\u05b4\u05b8"+
		"\t\7\2\2\u05b5\u05b7\7|\2\2\u05b6\u05b5\3\2\2\2\u05b7\u05ba\3\2\2\2\u05b8"+
		"\u05b6\3\2\2\2\u05b8\u05b9\3\2\2\2\u05b9\u05bb\3\2\2\2\u05ba\u05b8\3\2"+
		"\2\2\u05bb\u05bd\5P)\4\u05bc\u05b3\3\2\2\2\u05bd\u05c0\3\2\2\2\u05be\u05bc"+
		"\3\2\2\2\u05be\u05bf\3\2\2\2\u05bfQ\3\2\2\2\u05c0\u05be\3\2\2\2\u05c1"+
		"\u05c5\7?\2\2\u05c2\u05c4\7|\2\2\u05c3\u05c2\3\2\2\2\u05c4\u05c7\3\2\2"+
		"\2\u05c5\u05c3\3\2\2\2\u05c5\u05c6\3\2\2\2\u05c6\u05c9\3\2\2\2\u05c7\u05c5"+
		"\3\2\2\2\u05c8\u05ca\5V,\2\u05c9\u05c8\3\2\2\2\u05c9\u05ca\3\2\2\2\u05ca"+
		"\u05cb\3\2\2\2\u05cb\u05cc\5\4\3\2\u05cc\u05cd\7@\2\2\u05cd\u05d0\3\2"+
		"\2\2\u05ce\u05d0\5T+\2\u05cf\u05c1\3\2\2\2\u05cf\u05ce\3\2\2\2\u05d0S"+
		"\3\2\2\2\u05d1\u05d5\7\37\2\2\u05d2\u05d4\7|\2\2\u05d3\u05d2\3\2\2\2\u05d4"+
		"\u05d7\3\2\2\2\u05d5\u05d3\3\2\2\2\u05d5\u05d6\3\2\2\2\u05d6\u05d9\3\2"+
		"\2\2\u05d7\u05d5\3\2\2\2\u05d8\u05da\5V,\2\u05d9\u05d8\3\2\2\2\u05d9\u05da"+
		"\3\2\2\2\u05da\u05db\3\2\2\2\u05db\u05dc\5f\64\2\u05dc\u05dd\7\"\2\2\u05dd"+
		"U\3\2\2\2\u05de\u05e2\7Q\2\2\u05df\u05e1\7|\2\2\u05e0\u05df\3\2\2\2\u05e1"+
		"\u05e4\3\2\2\2\u05e2\u05e0\3\2\2\2\u05e2\u05e3\3\2\2\2\u05e3\u05e5\3\2"+
		"\2\2\u05e4\u05e2\3\2\2\2\u05e5\u05f7\7Q\2\2\u05e6\u05ea\7Q\2\2\u05e7\u05e9"+
		"\7|\2\2\u05e8\u05e7\3\2\2\2\u05e9\u05ec\3\2\2\2\u05ea\u05e8\3\2\2\2\u05ea"+
		"\u05eb\3\2\2\2\u05eb\u05ed\3\2\2\2\u05ec\u05ea\3\2\2\2\u05ed\u05f1\5t"+
		";\2\u05ee\u05f0\7|\2\2\u05ef\u05ee\3\2\2\2\u05f0\u05f3\3\2\2\2\u05f1\u05ef"+
		"\3\2\2\2\u05f1\u05f2\3\2\2\2\u05f2\u05f4\3\2\2\2\u05f3\u05f1\3\2\2\2\u05f4"+
		"\u05f5\7Q\2\2\u05f5\u05f7\3\2\2\2\u05f6\u05de\3\2\2\2\u05f6\u05e6\3\2"+
		"\2\2\u05f7W\3\2\2\2\u05f8\u05fa\t\2\2\2\u05f9\u05f8\3\2\2\2\u05fa\u05fb"+
		"\3\2\2\2\u05fb\u05f9\3\2\2\2\u05fb\u05fc\3\2\2\2\u05fc\u05fd\3\2\2\2\u05fd"+
		"\u0604\5\4\3\2\u05fe\u0600\t\2\2\2\u05ff\u05fe\3\2\2\2\u05ff\u0600\3\2"+
		"\2\2\u0600\u0601\3\2\2\2\u0601\u0602\7\63\2\2\u0602\u0604\5\4\3\2\u0603"+
		"\u05f9\3\2\2\2\u0603\u05ff\3\2\2\2\u0604Y\3\2\2\2\u0605\u0606\7 \2\2\u0606"+
		"\u0607\5\4\3\2\u0607[\3\2\2\2\u0608\u060c\7!\2\2\u0609\u060b\7|\2\2\u060a"+
		"\u0609\3\2\2\2\u060b\u060e\3\2\2\2\u060c\u060a\3\2\2\2\u060c\u060d\3\2"+
		"\2\2\u060d\u060f\3\2\2\2\u060e\u060c\3\2\2\2\u060f\u0610\5D#\2\u0610\u0611"+
		"\5X-\2\u0611]\3\2\2\2\u0612\u0616\78\2\2\u0613\u0615\7|\2\2\u0614\u0613"+
		"\3\2\2\2\u0615\u0618\3\2\2\2\u0616\u0614\3\2\2\2\u0616\u0617\3\2\2\2\u0617"+
		"\u0619\3\2\2\2\u0618\u0616\3\2\2\2\u0619\u061a\5`\61\2\u061a\u061b\5X"+
		"-\2\u061b_\3\2\2\2\u061c\u061f\5\66\34\2\u061d\u061e\7C\2\2\u061e\u0620"+
		"\5\64\33\2\u061f\u061d\3\2\2\2\u061f\u0620\3\2\2\2\u0620\u0623\3\2\2\2"+
		"\u0621\u0623\5\64\33\2\u0622\u061c\3\2\2\2\u0622\u0621\3\2\2\2\u0623a"+
		"\3\2\2\2\u0624\u0626\t\2\2\2\u0625\u0624\3\2\2\2\u0626\u0627\3\2\2\2\u0627"+
		"\u0625\3\2\2\2\u0627\u0628\3\2\2\2\u0628\u0629\3\2\2\2\u0629\u062d\5\4"+
		"\3\2\u062a\u062b\7\37\2\2\u062b\u062d\5\4\3\2\u062c\u0625\3\2\2\2\u062c"+
		"\u062a\3\2\2\2\u062dc\3\2\2\2\u062e\u0631\5\20\t\2\u062f\u0631\5\22\n"+
		"\2\u0630\u062e\3\2\2\2\u0630\u062f\3\2\2\2\u0631e\3\2\2\2\u0632\u0636"+
		"\5\4\3\2\u0633\u0635\5h\65\2\u0634\u0633\3\2\2\2\u0635\u0638\3\2\2\2\u0636"+
		"\u0634\3\2\2\2\u0636\u0637\3\2\2\2\u0637\u063a\3\2\2\2\u0638\u0636\3\2"+
		"\2\2\u0639\u063b\5Z.\2\u063a\u0639\3\2\2\2\u063a\u063b\3\2\2\2\u063b\u063d"+
		"\3\2\2\2\u063c\u063e\5n8\2\u063d\u063c\3\2\2\2\u063d\u063e\3\2\2\2\u063e"+
		"g\3\2\2\2\u063f\u0641\7.\2\2\u0640\u0642\5j\66\2\u0641\u0640\3\2\2\2\u0641"+
		"\u0642\3\2\2\2\u0642\u0644\3\2\2\2\u0643\u0645\5l\67\2\u0644\u0643\3\2"+
		"\2\2\u0644\u0645\3\2\2\2\u0645\u0646\3\2\2\2\u0646\u0647\5X-\2\u0647i"+
		"\3\2\2\2\u0648\u064b\5F$\2\u0649\u064b\5\34\17\2\u064a\u0648\3\2\2\2\u064a"+
		"\u0649\3\2\2\2\u064bk\3\2\2\2\u064c\u064d\7I\2\2\u064d\u064e\5\20\t\2"+
		"\u064em\3\2\2\2\u064f\u0650\7#\2\2\u0650\u0651\5\4\3\2\u0651o\3\2\2\2"+
		"\u0652\u065e\5\"\22\2\u0653\u065e\7\u0084\2\2\u0654\u0655\7;\2\2\u0655"+
		"\u0657\7<\2\2\u0656\u0658\7S\2\2\u0657\u0656\3\2\2\2\u0657\u0658\3\2\2"+
		"\2\u0658\u065e\3\2\2\2\u0659\u065e\7T\2\2\u065a\u065e\7U\2\2\u065b\u065e"+
		"\7W\2\2\u065c\u065e\7]\2\2\u065d\u0652\3\2\2\2\u065d\u0653\3\2\2\2\u065d"+
		"\u0654\3\2\2\2\u065d\u0659\3\2\2\2\u065d\u065a\3\2\2\2\u065d\u065b\3\2"+
		"\2\2\u065d\u065c\3\2\2\2\u065eq\3\2\2\2\u065f\u0663\7=\2\2\u0660\u0662"+
		"\7|\2\2\u0661\u0660\3\2\2\2\u0662\u0665\3\2\2\2\u0663\u0661\3\2\2\2\u0663"+
		"\u0664\3\2\2\2\u0664\u0667\3\2\2\2\u0665\u0663\3\2\2\2\u0666\u0668\5t"+
		";\2\u0667\u0666\3\2\2\2\u0667\u0668\3\2\2\2\u0668\u066c\3\2\2\2\u0669"+
		"\u066b\7|\2\2\u066a\u0669\3\2\2\2\u066b\u066e\3\2\2\2\u066c\u066a\3\2"+
		"\2\2\u066c\u066d\3\2\2\2\u066d\u066f\3\2\2\2\u066e\u066c\3\2\2\2\u066f"+
		"\u0675\7>\2\2\u0670\u0672\5t;\2\u0671\u0670\3\2\2\2\u0671\u0672\3\2\2"+
		"\2\u0672\u0673\3\2\2\2\u0673\u0675\t\2\2\2\u0674\u065f\3\2\2\2\u0674\u0671"+
		"\3\2\2\2\u0675s\3\2\2\2\u0676\u067f\5v<\2\u0677\u067b\7C\2\2\u0678\u067a"+
		"\7|\2\2\u0679\u0678\3\2\2\2\u067a\u067d\3\2\2\2\u067b\u0679\3\2\2\2\u067b"+
		"\u067c\3\2\2\2\u067c\u067e\3\2\2\2\u067d\u067b\3\2\2\2\u067e\u0680\5\u0080"+
		"A\2\u067f\u0677\3\2\2\2\u067f\u0680\3\2\2\2\u0680\u0689\3\2\2\2\u0681"+
		"\u0685\7C\2\2\u0682\u0684\7|\2\2\u0683\u0682\3\2\2\2\u0684\u0687\3\2\2"+
		"\2\u0685\u0683\3\2\2\2\u0685\u0686\3\2\2\2\u0686\u0688\3\2\2\2\u0687\u0685"+
		"\3\2\2\2\u0688\u068a\5\u0082B\2\u0689\u0681\3\2\2\2\u0689\u068a\3\2\2"+
		"\2\u068a\u0693\3\2\2\2\u068b\u068f\7C\2\2\u068c\u068e\7|\2\2\u068d\u068c"+
		"\3\2\2\2\u068e\u0691\3\2\2\2\u068f\u068d\3\2\2\2\u068f\u0690\3\2\2\2\u0690"+
		"\u0692\3\2\2\2\u0691\u068f\3\2\2\2\u0692\u0694\5\u0084C\2\u0693\u068b"+
		"\3\2\2\2\u0693\u0694\3\2\2\2\u0694\u06c1\3\2\2\2\u0695\u069e\5\u0080A"+
		"\2\u0696\u069a\7C\2\2\u0697\u0699\7|\2\2\u0698\u0697\3\2\2\2\u0699\u069c"+
		"\3\2\2\2\u069a\u0698\3\2\2\2\u069a\u069b\3\2\2\2\u069b\u069d\3\2\2\2\u069c"+
		"\u069a\3\2\2\2\u069d\u069f\5\u0082B\2\u069e\u0696\3\2\2\2\u069e\u069f"+
		"\3\2\2\2\u069f\u06a8\3\2\2\2\u06a0\u06a4\7C\2\2\u06a1\u06a3\7|\2\2\u06a2"+
		"\u06a1\3\2\2\2\u06a3\u06a6\3\2\2\2\u06a4\u06a2\3\2\2\2\u06a4\u06a5\3\2"+
		"\2\2\u06a5\u06a7\3\2\2\2\u06a6\u06a4\3\2\2\2\u06a7\u06a9\5\u0084C\2\u06a8"+
		"\u06a0\3\2\2\2\u06a8\u06a9\3\2\2\2\u06a9\u06b2\3\2\2\2\u06aa\u06ae\7C"+
		"\2\2\u06ab\u06ad\7|\2\2\u06ac\u06ab\3\2\2\2\u06ad\u06b0\3\2\2\2\u06ae"+
		"\u06ac\3\2\2\2\u06ae\u06af\3\2\2\2\u06af\u06b1\3\2\2\2\u06b0\u06ae\3\2"+
		"\2\2\u06b1\u06b3\5v<\2\u06b2\u06aa\3\2\2\2\u06b2\u06b3\3\2\2\2\u06b3\u06c1"+
		"\3\2\2\2\u06b4\u06bd\5\u0082B\2\u06b5\u06b9\7C\2\2\u06b6\u06b8\7|\2\2"+
		"\u06b7\u06b6\3\2\2\2\u06b8\u06bb\3\2\2\2\u06b9\u06b7\3\2\2\2\u06b9\u06ba"+
		"\3\2\2\2\u06ba\u06bc\3\2\2\2\u06bb\u06b9\3\2\2\2\u06bc\u06be\5\u0084C"+
		"\2\u06bd\u06b5\3\2\2\2\u06bd\u06be\3\2\2\2\u06be\u06c1\3\2\2\2\u06bf\u06c1"+
		"\5\u0084C\2\u06c0\u0676\3\2\2\2\u06c0\u0695\3\2\2\2\u06c0\u06b4\3\2\2"+
		"\2\u06c0\u06bf\3\2\2\2\u06c1u\3\2\2\2\u06c2\u06cd\5x=\2\u06c3\u06c7\7"+
		"C\2\2\u06c4\u06c6\7|\2\2\u06c5\u06c4\3\2\2\2\u06c6\u06c9\3\2\2\2\u06c7"+
		"\u06c5\3\2\2\2\u06c7\u06c8\3\2\2\2\u06c8\u06ca\3\2\2\2\u06c9\u06c7\3\2"+
		"\2\2\u06ca\u06cc\5x=\2\u06cb\u06c3\3\2\2\2\u06cc\u06cf\3\2\2\2\u06cd\u06cb"+
		"\3\2\2\2\u06cd\u06ce\3\2\2\2\u06cew\3\2\2\2\u06cf\u06cd\3\2\2\2\u06d0"+
		"\u06d3\5z>\2\u06d1\u06d3\5|?\2\u06d2\u06d0\3\2\2\2\u06d2\u06d1\3\2\2\2"+
		"\u06d3y\3\2\2\2\u06d4\u06d6\7\177\2\2\u06d5\u06d7\7A\2\2\u06d6\u06d5\3"+
		"\2\2\2\u06d6\u06d7\3\2\2\2\u06d7{\3\2\2\2\u06d8\u06d9\5~@\2\u06d9\u06dd"+
		"\t\t\2\2\u06da\u06dc\7|\2\2\u06db\u06da\3\2\2\2\u06dc\u06df\3\2\2\2\u06dd"+
		"\u06db\3\2\2\2\u06dd\u06de\3\2\2\2\u06de\u06e0\3\2\2\2\u06df\u06dd\3\2"+
		"\2\2\u06e0\u06e1\5F$\2\u06e1}\3\2\2\2\u06e2\u06e3\7\177\2\2\u06e3\177"+
		"\3\2\2\2\u06e4\u06e6\7a\2\2\u06e5\u06e7\7\177\2\2\u06e6\u06e5\3\2\2\2"+
		"\u06e6\u06e7\3\2\2\2\u06e7\u0081\3\2\2\2\u06e8\u06ea\7b\2\2\u06e9\u06eb"+
		"\7\177\2\2\u06ea\u06e9\3\2\2\2\u06ea\u06eb\3\2\2\2\u06eb\u0083\3\2\2\2"+
		"\u06ec\u06ed\7N\2\2\u06ed\u06ee\5\u0086D\2\u06ee\u0085\3\2\2\2\u06ef\u06f0"+
		"\7\177\2\2\u06f0\u0087\3\2\2\2\u06f1\u06f2\bE\1\2\u06f2\u06f3\7B\2\2\u06f3"+
		"\u06f6\7\u0083\2\2\u06f4\u06f6\7\u0083\2\2\u06f5\u06f1\3\2\2\2\u06f5\u06f4"+
		"\3\2\2\2\u06f6\u06fc\3\2\2\2\u06f7\u06f8\f\3\2\2\u06f8\u06f9\7B\2\2\u06f9"+
		"\u06fb\7\u0083\2\2\u06fa\u06f7\3\2\2\2\u06fb\u06fe\3\2\2\2\u06fc\u06fa"+
		"\3\2\2\2\u06fc\u06fd\3\2\2\2\u06fd\u0089\3\2\2\2\u06fe\u06fc\3\2\2\2\u06ff"+
		"\u0705\5\u008cG\2\u0700\u0701\7=\2\2\u0701\u0702\5D#\2\u0702\u0703\7>"+
		"\2\2\u0703\u0705\3\2\2\2\u0704\u06ff\3\2\2\2\u0704\u0700\3\2\2\2\u0705"+
		"\u008b\3\2\2\2\u0706\u070b\5\u00bc_\2\u0707\u070b\5\u00be`\2\u0708\u0709"+
		"\7B\2\2\u0709\u070b\7\u0083\2\2\u070a\u0706\3\2\2\2\u070a\u0707\3\2\2"+
		"\2\u070a\u0708\3\2\2\2\u070b\u008d\3\2\2\2\u070c\u0717\5\u0090I\2\u070d"+
		"\u0711\7C\2\2\u070e\u0710\7|\2\2\u070f\u070e\3\2\2\2\u0710\u0713\3\2\2"+
		"\2\u0711\u070f\3\2\2\2\u0711\u0712\3\2\2\2\u0712\u0714\3\2\2\2\u0713\u0711"+
		"\3\2\2\2\u0714\u0716\5\u0090I\2\u0715\u070d\3\2\2\2\u0716\u0719\3\2\2"+
		"\2\u0717\u0715\3\2\2\2\u0717\u0718\3\2\2\2\u0718\u008f\3\2\2\2\u0719\u0717"+
		"\3\2\2\2\u071a\u071b\5\u0092J\2\u071b\u071f\t\n\2\2\u071c\u071e\7|\2\2"+
		"\u071d\u071c\3\2\2\2\u071e\u0721\3\2\2\2\u071f\u071d\3\2\2\2\u071f\u0720"+
		"\3\2\2\2\u0720\u0722\3\2\2\2\u0721\u071f\3\2\2\2\u0722\u0723\5F$\2\u0723"+
		"\u0726\3\2\2\2\u0724\u0726\5\u0094K\2\u0725\u071a\3\2\2\2\u0725\u0724"+
		"\3\2\2\2\u0726\u0091\3\2\2\2\u0727\u072a\5F$\2\u0728\u072a\5\u00d2j\2"+
		"\u0729\u0727\3\2\2\2\u0729\u0728\3\2\2\2\u072a\u0093\3\2\2\2\u072b\u0732"+
		"\7b\2\2\u072c\u0733\7\177\2\2\u072d\u0733\5L\'\2\u072e\u072f\7=\2\2\u072f"+
		"\u0730\5&\24\2\u0730\u0731\7>\2\2\u0731\u0733\3\2\2\2\u0732\u072c\3\2"+
		"\2\2\u0732\u072d\3\2\2\2\u0732\u072e\3\2\2\2\u0732\u0733\3\2\2\2\u0733"+
		"\u0095\3\2\2\2\u0734\u073a\7\u0096\2\2\u0735\u0736\7\u0097\2\2\u0736\u0737"+
		"\5\4\3\2\u0737\u0738\7\4\2\2\u0738\u073a\3\2\2\2\u0739\u0734\3\2\2\2\u0739"+
		"\u0735\3\2\2\2\u073a\u0097\3\2\2\2\u073b\u073c\7i\2\2\u073c\u0099\3\2"+
		"\2\2\u073d\u0740\5\u0098M\2\u073e\u0740\5\u009cO\2\u073f\u073d\3\2\2\2"+
		"\u073f\u073e\3\2\2\2\u0740\u009b\3\2\2\2\u0741\u0745\7j\2\2\u0742\u0744"+
		"\5\u00a0Q\2\u0743\u0742\3\2\2\2\u0744\u0747\3\2\2\2\u0745\u0743\3\2\2"+
		"\2\u0745\u0746\3\2\2\2\u0746\u0748\3\2\2\2\u0747\u0745\3\2\2\2\u0748\u0749"+
		"\7\u0088\2\2\u0749\u009d\3\2\2\2\u074a\u074e\7n\2\2\u074b\u074d\5\u00a6"+
		"T\2\u074c\u074b\3\2\2\2\u074d\u0750\3\2\2\2\u074e\u074c\3\2\2\2\u074e"+
		"\u074f\3\2\2\2\u074f\u0751\3\2\2\2\u0750\u074e\3\2\2\2\u0751\u0752\7\13"+
		"\2\2\u0752\u009f\3\2\2\2\u0753\u0759\7\u0089\2\2\u0754\u0755\7\u008b\2"+
		"\2\u0755\u0756\5\4\3\2\u0756\u0757\7\3\2\2\u0757\u0759\3\2\2\2\u0758\u0753"+
		"\3\2\2\2\u0758\u0754\3\2\2\2\u0759\u00a1\3\2\2\2\u075a\u075c\7k\2\2\u075b"+
		"\u075d\7\20\2\2\u075c\u075b\3\2\2\2\u075c\u075d\3\2\2\2\u075d\u075e\3"+
		"\2\2\2\u075e\u075f\7\6\2\2\u075f\u00a3\3\2\2\2\u0760\u0764\7l\2\2\u0761"+
		"\u0763\5\u00a6T\2\u0762\u0761\3\2\2\2\u0763\u0766\3\2\2\2\u0764\u0762"+
		"\3\2\2\2\u0764\u0765\3\2\2\2\u0765\u0767\3\2\2\2\u0766\u0764\3\2\2\2\u0767"+
		"\u0768\7\n\2\2\u0768\u00a5\3\2\2\2\u0769\u076f\7\21\2\2\u076a\u076b\7"+
		"\u008c\2\2\u076b\u076c\5\4\3\2\u076c\u076d\7\16\2\2\u076d\u076f\3\2\2"+
		"\2\u076e\u0769\3\2\2\2\u076e\u076a\3\2\2\2\u076f\u00a7\3\2\2\2\u0770\u0772"+
		"\7\u0094\2\2\u0771\u0770\3\2\2\2\u0772\u0773\3\2\2\2\u0773\u0771\3\2\2"+
		"\2\u0773\u0774\3\2\2\2\u0774\u00a9\3\2\2\2\u0775\u077b\7\u0092\2\2\u0776"+
		"\u0777\7\u0090\2\2\u0777\u0778\5\4\3\2\u0778\u0779\7\17\2\2\u0779\u077b"+
		"\3\2\2\2\u077a\u0775\3\2\2\2\u077a\u0776\3\2\2\2\u077b\u00ab\3\2\2\2\u077c"+
		"\u077e\5\u00aaV\2\u077d\u077c\3\2\2\2\u077e\u077f\3\2\2\2\u077f\u077d"+
		"\3\2\2\2\u077f\u0780\3\2\2\2\u0780\u00ad\3\2\2\2\u0781\u0783\7\u0093\2"+
		"\2\u0782\u0781\3\2\2\2\u0783\u0786\3\2\2\2\u0784\u0782\3\2\2\2\u0784\u0785"+
		"\3\2\2\2\u0785\u0787\3\2\2\2\u0786\u0784\3\2\2\2\u0787\u0790\5\u00a8U"+
		"\2\u0788\u078a\7\u0093\2\2\u0789\u0788\3\2\2\2\u078a\u078b\3\2\2\2\u078b"+
		"\u0789\3\2\2\2\u078b\u078c\3\2\2\2\u078c\u078d\3\2\2\2\u078d\u078f\5\u00a8"+
		"U\2\u078e\u0789\3\2\2\2\u078f\u0792\3\2\2\2\u0790\u078e\3\2\2\2\u0790"+
		"\u0791\3\2\2\2\u0791\u0796\3\2\2\2\u0792\u0790\3\2\2\2\u0793\u0795\7\u0093"+
		"\2\2\u0794\u0793\3\2\2\2\u0795\u0798\3\2\2\2\u0796\u0794\3\2\2\2\u0796"+
		"\u0797\3\2\2\2\u0797\u00af\3\2\2\2\u0798\u0796\3\2\2\2\u0799\u079b\7\u0091"+
		"\2\2\u079a\u0799\3\2\2\2\u079b\u079e\3\2\2\2\u079c\u079a\3\2\2\2\u079c"+
		"\u079d\3\2\2\2\u079d\u079f\3\2\2\2\u079e\u079c\3\2\2\2\u079f\u07a8\5\u00ac"+
		"W\2\u07a0\u07a2\7\u0091\2\2\u07a1\u07a0\3\2\2\2\u07a2\u07a3\3\2\2\2\u07a3"+
		"\u07a1\3\2\2\2\u07a3\u07a4\3\2\2\2\u07a4\u07a5\3\2\2\2\u07a5\u07a7\5\u00ac"+
		"W\2\u07a6\u07a1\3\2\2\2\u07a7\u07aa\3\2\2\2\u07a8\u07a6\3\2\2\2\u07a8"+
		"\u07a9\3\2\2\2\u07a9\u07ae\3\2\2\2\u07aa\u07a8\3\2\2\2\u07ab\u07ad\7\u0091"+
		"\2\2\u07ac\u07ab\3\2\2\2\u07ad\u07b0\3\2\2\2\u07ae\u07ac\3\2\2\2\u07ae"+
		"\u07af\3\2\2\2\u07af\u00b1\3\2\2\2\u07b0\u07ae\3\2\2\2\u07b1\u07b7\7~"+
		"\2\2\u07b2\u07b3\7A\2\2\u07b3\u07b7\5\u0098M\2\u07b4\u07b5\7A\2\2\u07b5"+
		"\u07b7\5\u009cO\2\u07b6\u07b1\3\2\2\2\u07b6\u07b2\3\2\2\2\u07b6\u07b4"+
		"\3\2\2\2\u07b7\u00b3\3\2\2\2\u07b8\u07b9\7r\2\2\u07b9\u00b5\3\2\2\2\u07ba"+
		"\u07bb\7\36\2\2\u07bb\u00b7\3\2\2\2\u07bc\u07bd\t\13\2\2\u07bd\u00b9\3"+
		"\2\2\2\u07be\u07bf\t\f\2\2\u07bf\u00bb\3\2\2\2\u07c0\u07c6\7\u0083\2\2"+
		"\u07c1\u07c6\7\u0080\2\2\u07c2\u07c6\7\u0082\2\2\u07c3\u07c6\7\u0081\2"+
		"\2\u07c4\u07c6\7\177\2\2\u07c5\u07c0\3\2\2\2\u07c5\u07c1\3\2\2\2\u07c5"+
		"\u07c2\3\2\2\2\u07c5\u07c3\3\2\2\2\u07c5\u07c4\3\2\2\2\u07c6\u00bd\3\2"+
		"\2\2\u07c7\u07cf\7*\2\2\u07c8\u07cf\7\64\2\2\u07c9\u07cf\7%\2\2\u07ca"+
		"\u07cf\7\61\2\2\u07cb\u07cf\7\22\2\2\u07cc\u07cf\7\24\2\2\u07cd\u07cf"+
		"\7\23\2\2\u07ce\u07c7\3\2\2\2\u07ce\u07c8\3\2\2\2\u07ce\u07c9\3\2\2\2"+
		"\u07ce\u07ca\3\2\2\2\u07ce\u07cb\3\2\2\2\u07ce\u07cc\3\2\2\2\u07ce\u07cd"+
		"\3\2\2\2\u07cf\u00bf\3\2\2\2\u07d0\u07d7\7v\2\2\u07d1\u07d7\7w\2\2\u07d2"+
		"\u07d7\7x\2\2\u07d3\u07d7\7y\2\2\u07d4\u07d7\7z\2\2\u07d5\u07d7\7{\2\2"+
		"\u07d6\u07d0\3\2\2\2\u07d6\u07d1\3\2\2\2\u07d6\u07d2\3\2\2\2\u07d6\u07d3"+
		"\3\2\2\2\u07d6\u07d4\3\2\2\2\u07d6\u07d5\3\2\2\2\u07d7\u00c1\3\2\2\2\u07d8"+
		"\u07d9\t\r\2\2\u07d9\u00c3\3\2\2\2\u07da\u07db\t\16\2\2\u07db\u00c5\3"+
		"\2\2\2\u07dc\u07dd\t\b\2\2\u07dd\u00c7\3\2\2\2\u07de\u07df\t\17\2\2\u07df"+
		"\u00c9\3\2\2\2\u07e0\u07e1\t\20\2\2\u07e1\u00cb\3\2\2\2\u07e2\u07e3\t"+
		"\21\2\2\u07e3\u00cd\3\2\2\2\u07e4\u07e5\t\22\2\2\u07e5\u00cf\3\2\2\2\u07e6"+
		"\u07e7\t\23\2\2\u07e7\u00d1\3\2\2\2\u07e8\u07e9\t\24\2\2\u07e9\u00d3\3"+
		"\2\2\2\u0117\u00d8\u00dd\u00e3\u00ea\u00ef\u00f8\u0102\u010a\u0110\u0115"+
		"\u011c\u0123\u0128\u012f\u013a\u0142\u0149\u0155\u015a\u0161\u016b\u0170"+
		"\u0177\u0181\u0186\u0188\u018d\u0192\u019c\u01a3\u01a6\u01ad\u01b0\u01b3"+
		"\u01b8\u01bc\u01bf\u01c3\u01ca\u01cd\u01d4\u01d7\u01da\u01de\u01e6\u01e9"+
		"\u01f1\u01f6\u01f9\u0200\u0205\u020a\u0214\u021e\u0222\u022b\u022f\u0235"+
		"\u023b\u024b\u0250\u0258\u025b\u0261\u0268\u026e\u0276\u027c\u0282\u0286"+
		"\u028b\u0293\u0298\u029d\u02a6\u02ae\u02b3\u02b8\u02c1\u02c6\u02cb\u02d0"+
		"\u02d8\u02dc\u02e2\u02e6\u02ed\u02f1\u02f7\u02fb\u0301\u0305\u030c\u0310"+
		"\u0316\u031a\u031d\u0325\u0329\u032b\u0332\u0338\u0341\u0348\u034c\u0353"+
		"\u0359\u0364\u036b\u0372\u0379\u0382\u038a\u0395\u039e\u03a1\u03c4\u03c7"+
		"\u03cd\u03d5\u03d8\u03df\u03e7\u03eb\u03f3\u03f9\u0401\u040a\u0414\u041b"+
		"\u0421\u0424\u042c\u0432\u0435\u043d\u0448\u0450\u045c\u0460\u0465\u046b"+
		"\u0470\u0475\u047a\u0481\u0486\u0488\u048d\u0492\u0499\u04a0\u04a5\u04ac"+
		"\u04b4\u04bd\u04c5\u04d3\u04da\u04e3\u04ed\u04f7\u0501\u050a\u0514\u051e"+
		"\u0528\u0531\u053a\u0546\u054e\u0555\u055f\u0569\u0570\u0577\u057c\u057f"+
		"\u0581\u0583\u0588\u058b\u058f\u0592\u05a3\u05a6\u05aa\u05b1\u05b8\u05be"+
		"\u05c5\u05c9\u05cf\u05d5\u05d9\u05e2\u05ea\u05f1\u05f6\u05fb\u05ff\u0603"+
		"\u060c\u0616\u061f\u0622\u0627\u062c\u0630\u0636\u063a\u063d\u0641\u0644"+
		"\u064a\u0657\u065d\u0663\u0667\u066c\u0671\u0674\u067b\u067f\u0685\u0689"+
		"\u068f\u0693\u069a\u069e\u06a4\u06a8\u06ae\u06b2\u06b9\u06bd\u06c0\u06c7"+
		"\u06cd\u06d2\u06d6\u06dd\u06e6\u06ea\u06f5\u06fc\u0704\u070a\u0711\u0717"+
		"\u071f\u0725\u0729\u0732\u0739\u073f\u0745\u074e\u0758\u075c\u0764\u076e"+
		"\u0773\u077a\u077f\u0784\u078b\u0790\u0796\u079c\u07a3\u07a8\u07ae\u07b6"+
		"\u07c5\u07ce\u07d6";
	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