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

src2cpg_3.4.0.81.source-code.RubyParser Maven / Gradle / Ivy

There is a newer version: 4.0.78
Show newest version
// Generated from /home/runner/work/joern/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, 
		LBRACK=16, RBRACK=17, LPAREN=18, RPAREN=19, LCURLY=20, RCURLY=21, COLON=22, 
		COLON2=23, COMMA=24, SEMI=25, DOT=26, DOT2=27, DOT3=28, QMARK=29, EQGT=30, 
		MINUSGT=31, EMARK=32, EMARKEQ=33, EMARKTILDE=34, AMP=35, AMP2=36, AMPDOT=37, 
		BAR=38, BAR2=39, EQ=40, EQ2=41, EQ3=42, CARET=43, LTEQGT=44, EQTILDE=45, 
		GT=46, GTEQ=47, LT=48, LTEQ=49, LT2=50, GT2=51, PLUS=52, MINUS=53, STAR=54, 
		STAR2=55, SLASH=56, PERCENT=57, TILDE=58, PLUSAT=59, MINUSAT=60, ASSIGNMENT_OPERATOR=61, 
		SINGLE_QUOTED_STRING_LITERAL=62, DOUBLE_QUOTED_STRING_START=63, QUOTED_NON_EXPANDED_STRING_LITERAL_START=64, 
		QUOTED_EXPANDED_STRING_LITERAL_START=65, QUOTED_EXPANDED_REGULAR_EXPRESSION_START=66, 
		QUOTED_EXPANDED_EXTERNAL_COMMAND_LITERAL_START=67, QUOTED_NON_EXPANDED_STRING_ARRAY_LITERAL_START=68, 
		QUOTED_EXPANDED_STRING_ARRAY_LITERAL_START=69, HERE_DOC_IDENTIFIER=70, 
		HERE_DOC=71, QUOTED_NON_EXPANDED_SYMBOL_ARRAY_LITERAL_START=72, QUOTED_EXPANDED_SYMBOL_ARRAY_LITERAL_START=73, 
		END_OF_PROGRAM_MARKER=74, DECIMAL_INTEGER_LITERAL=75, BINARY_INTEGER_LITERAL=76, 
		OCTAL_INTEGER_LITERAL=77, HEXADECIMAL_INTEGER_LITERAL=78, FLOAT_LITERAL_WITHOUT_EXPONENT=79, 
		FLOAT_LITERAL_WITH_EXPONENT=80, NL=81, WS=82, SYMBOL_LITERAL=83, LOCAL_VARIABLE_IDENTIFIER=84, 
		LINE__=85, ENCODING__=86, FILE__=87, BEGIN_=88, END_=89, ALIAS=90, AND=91, 
		BEGIN=92, BREAK=93, CASE=94, CLASS=95, DEF=96, IS_DEFINED=97, DO=98, ELSE=99, 
		ELSIF=100, END=101, ENSURE=102, FOR=103, FALSE=104, IF=105, IN=106, MODULE=107, 
		NEXT=108, NIL=109, NOT=110, OR=111, REDO=112, RESCUE=113, RETRY=114, RETURN=115, 
		SELF=116, SUPER=117, THEN=118, TRUE=119, UNDEF=120, UNLESS=121, UNTIL=122, 
		WHEN=123, WHILE=124, YIELD=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_bracketedArrayElementList = 24, 
		RULE_bracketedArrayElement = 25, RULE_indexingArgumentList = 26, RULE_indexingArgument = 27, 
		RULE_splattingArgument = 28, RULE_operatorExpressionList = 29, RULE_operatorExpressionList2 = 30, 
		RULE_argumentWithParentheses = 31, RULE_argumentList = 32, RULE_commandArgumentList = 33, 
		RULE_primaryValueList = 34, RULE_primaryValueListWithAssociation = 35, 
		RULE_blockArgument = 36, RULE_expressionOrCommand = 37, RULE_operatorExpression = 38, 
		RULE_primary = 39, RULE_hashLiteral = 40, RULE_primaryValue = 41, RULE_lambdaExpressionParameterList = 42, 
		RULE_methodCallsWithParentheses = 43, RULE_commandOrPrimaryValueClass = 44, 
		RULE_commandOrPrimaryValue = 45, RULE_block = 46, RULE_doBlock = 47, RULE_blockParameter = 48, 
		RULE_blockParameterList = 49, RULE_mandatoryOrOptionalOrGroupedParameterList = 50, 
		RULE_mandatoryOrOptionalOrGroupedParameter = 51, RULE_mandatoryOrGroupedParameterList = 52, 
		RULE_mandatoryOrGroupedParameter = 53, RULE_groupedParameterList = 54, 
		RULE_thenClause = 55, RULE_elseClause = 56, RULE_elsifClause = 57, RULE_whenClause = 58, 
		RULE_whenArgument = 59, RULE_doClause = 60, RULE_forVariable = 61, RULE_bodyStatement = 62, 
		RULE_rescueClause = 63, RULE_exceptionClassList = 64, RULE_exceptionVariableAssignment = 65, 
		RULE_ensureClause = 66, RULE_definedMethodName = 67, RULE_methodParameterPart = 68, 
		RULE_parameterList = 69, RULE_mandatoryOrOptionalParameterList = 70, RULE_mandatoryParameterList = 71, 
		RULE_mandatoryOrOptionalParameter = 72, RULE_mandatoryParameter = 73, 
		RULE_optionalParameter = 74, RULE_optionalParameterName = 75, RULE_arrayParameter = 76, 
		RULE_hashParameter = 77, RULE_procParameter = 78, RULE_procParameterName = 79, 
		RULE_classPath = 80, RULE_singletonObject = 81, RULE_variableReference = 82, 
		RULE_associationList = 83, RULE_association = 84, RULE_associationKey = 85, 
		RULE_associationHashArgument = 86, RULE_regexpLiteralContent = 87, RULE_singleQuotedString = 88, 
		RULE_singleOrDoubleQuotedString = 89, RULE_doubleQuotedString = 90, RULE_quotedExpandedExternalCommandString = 91, 
		RULE_doubleQuotedStringContent = 92, RULE_quotedNonExpandedLiteralString = 93, 
		RULE_quotedExpandedLiteralString = 94, RULE_quotedExpandedLiteralStringContent = 95, 
		RULE_quotedNonExpandedArrayElementContent = 96, RULE_quotedExpandedArrayElementContent = 97, 
		RULE_quotedExpandedArrayElement = 98, RULE_quotedNonExpandedArrayElementList = 99, 
		RULE_quotedExpandedArrayElementList = 100, RULE_symbol = 101, RULE_hereDoc = 102, 
		RULE_isDefinedKeyword = 103, RULE_assignmentOperator = 104, RULE_statementModifier = 105, 
		RULE_variable = 106, RULE_pseudoVariable = 107, RULE_unsignedNumericLiteral = 108, 
		RULE_unaryOperator = 109, RULE_multiplicativeOperator = 110, RULE_additiveOperator = 111, 
		RULE_bitwiseShiftOperator = 112, RULE_bitwiseOrOperator = 113, RULE_relationalOperator = 114, 
		RULE_equalityOperator = 115, RULE_rangeOperator = 116, RULE_keyword = 117;
	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", "bracketedArrayElementList", 
			"bracketedArrayElement", "indexingArgumentList", "indexingArgument", 
			"splattingArgument", "operatorExpressionList", "operatorExpressionList2", 
			"argumentWithParentheses", "argumentList", "commandArgumentList", "primaryValueList", 
			"primaryValueListWithAssociation", "blockArgument", "expressionOrCommand", 
			"operatorExpression", "primary", "hashLiteral", "primaryValue", "lambdaExpressionParameterList", 
			"methodCallsWithParentheses", "commandOrPrimaryValueClass", "commandOrPrimaryValue", 
			"block", "doBlock", "blockParameter", "blockParameterList", "mandatoryOrOptionalOrGroupedParameterList", 
			"mandatoryOrOptionalOrGroupedParameter", "mandatoryOrGroupedParameterList", 
			"mandatoryOrGroupedParameter", "groupedParameterList", "thenClause", 
			"elseClause", "elsifClause", "whenClause", "whenArgument", "doClause", 
			"forVariable", "bodyStatement", "rescueClause", "exceptionClassList", 
			"exceptionVariableAssignment", "ensureClause", "definedMethodName", "methodParameterPart", 
			"parameterList", "mandatoryOrOptionalParameterList", "mandatoryParameterList", 
			"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, "'['", "']'", "'('", "')'", "'{'", "'}'", "':'", 
			"'::'", "','", "';'", "'.'", "'..'", "'...'", "'?'", "'=>'", "'->'", 
			"'!'", "'!='", "'!~'", "'&'", "'&&'", "'&.'", "'|'", "'||'", "'='", "'=='", 
			"'==='", "'^'", "'<=>'", "'=~'", "'>'", "'>='", "'<'", "'<='", "'<<'", 
			"'>>'", "'+'", "'-'", "'*'", "'**'", "'/'", "'%'", "'~'", "'+@'", "'-@'", 
			null, null, null, null, null, null, null, null, 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", "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", "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", "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(236);
			compoundStatement();
			setState(237);
			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(240);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,0,_ctx) ) {
			case 1:
				{
				setState(239);
				statements();
				}
				break;
			}
			setState(245);
			_errHandler.sync(this);
			_la = _input.LA(1);
			while (_la==SEMI || _la==NL) {
				{
				{
				setState(242);
				_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(247);
				_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(251);
			_errHandler.sync(this);
			_la = _input.LA(1);
			while (_la==SEMI || _la==NL) {
				{
				{
				setState(248);
				_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(253);
				_errHandler.sync(this);
				_la = _input.LA(1);
			}
			setState(254);
			statement(0);
			setState(263);
			_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(256); 
					_errHandler.sync(this);
					_la = _input.LA(1);
					do {
						{
						{
						setState(255);
						_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(258); 
						_errHandler.sync(this);
						_la = _input.LA(1);
					} while ( _la==SEMI || _la==NL );
					setState(260);
					statement(0);
					}
					} 
				}
				setState(265);
				_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(301);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,9,_ctx) ) {
			case 1:
				{
				_localctx = new ExpressionOrCommandStatementContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;

				setState(267);
				expressionOrCommand(0);
				}
				break;
			case 2:
				{
				_localctx = new AliasStatementContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(268);
				match(ALIAS);
				setState(272);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==NL) {
					{
					{
					setState(269);
					match(NL);
					}
					}
					setState(274);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(275);
				((AliasStatementContext)_localctx).oldName = definedMethodNameOrSymbol();
				setState(276);
				((AliasStatementContext)_localctx).newName = definedMethodNameOrSymbol();
				}
				break;
			case 3:
				{
				_localctx = new UndefStatementContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(278);
				match(UNDEF);
				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);
				definedMethodNameOrSymbol();
				setState(296);
				_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(286);
						match(COMMA);
						setState(290);
						_errHandler.sync(this);
						_la = _input.LA(1);
						while (_la==NL) {
							{
							{
							setState(287);
							match(NL);
							}
							}
							setState(292);
							_errHandler.sync(this);
							_la = _input.LA(1);
						}
						setState(293);
						definedMethodNameOrSymbol();
						}
						} 
					}
					setState(298);
					_errHandler.sync(this);
					_alt = getInterpreter().adaptivePredict(_input,8,_ctx);
				}
				}
				break;
			case 4:
				{
				_localctx = new SingleAssignmentStatementStatementContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(299);
				singleAssignmentStatement();
				}
				break;
			case 5:
				{
				_localctx = new MultipleAssignmentStatementStatementContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(300);
				multipleAssignmentStatement();
				}
				break;
			}
			_ctx.stop = _input.LT(-1);
			setState(315);
			_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(303);
					if (!(precpred(_ctx, 3))) throw new FailedPredicateException(this, "precpred(_ctx, 3)");
					setState(304);
					statementModifier();
					setState(308);
					_errHandler.sync(this);
					_la = _input.LA(1);
					while (_la==NL) {
						{
						{
						setState(305);
						match(NL);
						}
						}
						setState(310);
						_errHandler.sync(this);
						_la = _input.LA(1);
					}
					setState(311);
					expressionOrCommand(0);
					}
					} 
				}
				setState(317);
				_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(320);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case LBRACK:
			case EQ2:
			case EQ3:
			case LTEQGT:
			case LT2:
			case LOCAL_VARIABLE_IDENTIFIER:
			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 CONSTANT_IDENTIFIER:
			case ASSIGNMENT_LIKE_METHOD_IDENTIFIER:
				enterOuterAlt(_localctx, 1);
				{
				setState(318);
				definedMethodName();
				}
				break;
			case COLON:
			case SYMBOL_LITERAL:
				enterOuterAlt(_localctx, 2);
				{
				setState(319);
				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(370);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,18,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(322);
				variable();
				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 2:
				enterOuterAlt(_localctx, 2);
				{
				setState(332);
				match(COLON2);
				setState(333);
				match(CONSTANT_IDENTIFIER);
				setState(334);
				assignmentOperator();
				setState(338);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==NL) {
					{
					{
					setState(335);
					match(NL);
					}
					}
					setState(340);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(341);
				methodInvocationWithoutParentheses();
				}
				break;
			case 3:
				enterOuterAlt(_localctx, 3);
				{
				setState(343);
				primary();
				setState(344);
				match(LBRACK);
				setState(346);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (((((_la - 3)) & ~0x3f) == 0 && ((1L << (_la - 3)) & ((1L << (REGULAR_EXPRESSION_START - 3)) | (1L << (LBRACK - 3)) | (1L << (LPAREN - 3)) | (1L << (LCURLY - 3)) | (1L << (COLON - 3)) | (1L << (COLON2 - 3)) | (1L << (DOT2 - 3)) | (1L << (DOT3 - 3)) | (1L << (MINUSGT - 3)) | (1L << (EMARK - 3)) | (1L << (PLUS - 3)) | (1L << (MINUS - 3)) | (1L << (STAR - 3)) | (1L << (STAR2 - 3)) | (1L << (TILDE - 3)) | (1L << (SINGLE_QUOTED_STRING_LITERAL - 3)) | (1L << (DOUBLE_QUOTED_STRING_START - 3)) | (1L << (QUOTED_NON_EXPANDED_STRING_LITERAL_START - 3)) | (1L << (QUOTED_EXPANDED_STRING_LITERAL_START - 3)) | (1L << (QUOTED_EXPANDED_REGULAR_EXPRESSION_START - 3)))) != 0) || ((((_la - 67)) & ~0x3f) == 0 && ((1L << (_la - 67)) & ((1L << (QUOTED_EXPANDED_EXTERNAL_COMMAND_LITERAL_START - 67)) | (1L << (QUOTED_NON_EXPANDED_STRING_ARRAY_LITERAL_START - 67)) | (1L << (QUOTED_EXPANDED_STRING_ARRAY_LITERAL_START - 67)) | (1L << (HERE_DOC - 67)) | (1L << (QUOTED_NON_EXPANDED_SYMBOL_ARRAY_LITERAL_START - 67)) | (1L << (QUOTED_EXPANDED_SYMBOL_ARRAY_LITERAL_START - 67)) | (1L << (DECIMAL_INTEGER_LITERAL - 67)) | (1L << (BINARY_INTEGER_LITERAL - 67)) | (1L << (OCTAL_INTEGER_LITERAL - 67)) | (1L << (HEXADECIMAL_INTEGER_LITERAL - 67)) | (1L << (FLOAT_LITERAL_WITHOUT_EXPONENT - 67)) | (1L << (FLOAT_LITERAL_WITH_EXPONENT - 67)) | (1L << (SYMBOL_LITERAL - 67)) | (1L << (LOCAL_VARIABLE_IDENTIFIER - 67)) | (1L << (LINE__ - 67)) | (1L << (ENCODING__ - 67)) | (1L << (FILE__ - 67)) | (1L << (BEGIN_ - 67)) | (1L << (END_ - 67)) | (1L << (ALIAS - 67)) | (1L << (AND - 67)) | (1L << (BEGIN - 67)) | (1L << (BREAK - 67)) | (1L << (CASE - 67)) | (1L << (CLASS - 67)) | (1L << (DEF - 67)) | (1L << (IS_DEFINED - 67)) | (1L << (DO - 67)) | (1L << (ELSE - 67)) | (1L << (ELSIF - 67)) | (1L << (END - 67)) | (1L << (ENSURE - 67)) | (1L << (FOR - 67)) | (1L << (FALSE - 67)) | (1L << (IF - 67)) | (1L << (IN - 67)) | (1L << (MODULE - 67)) | (1L << (NEXT - 67)) | (1L << (NIL - 67)) | (1L << (NOT - 67)) | (1L << (OR - 67)) | (1L << (REDO - 67)) | (1L << (RESCUE - 67)) | (1L << (RETRY - 67)) | (1L << (RETURN - 67)) | (1L << (SELF - 67)) | (1L << (SUPER - 67)) | (1L << (THEN - 67)) | (1L << (TRUE - 67)) | (1L << (UNDEF - 67)) | (1L << (UNLESS - 67)) | (1L << (UNTIL - 67)) | (1L << (WHEN - 67)) | (1L << (WHILE - 67)) | (1L << (YIELD - 67)) | (1L << (GLOBAL_VARIABLE_IDENTIFIER - 67)) | (1L << (INSTANCE_VARIABLE_IDENTIFIER - 67)) | (1L << (CLASS_VARIABLE_IDENTIFIER - 67)) | (1L << (CONSTANT_IDENTIFIER - 67)))) != 0)) {
					{
					setState(345);
					indexingArgumentList();
					}
				}

				setState(348);
				match(RBRACK);
				setState(349);
				assignmentOperator();
				setState(353);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==NL) {
					{
					{
					setState(350);
					match(NL);
					}
					}
					setState(355);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(356);
				methodInvocationWithoutParentheses();
				}
				break;
			case 4:
				enterOuterAlt(_localctx, 4);
				{
				setState(358);
				primary();
				setState(359);
				_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(360);
				methodName();
				setState(361);
				assignmentOperator();
				setState(365);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==NL) {
					{
					{
					setState(362);
					match(NL);
					}
					}
					setState(367);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(368);
				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(416);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,25,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(372);
				leftHandSide();
				setState(373);
				match(EQ);
				setState(377);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==NL) {
					{
					{
					setState(374);
					match(NL);
					}
					}
					setState(379);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(380);
				multipleRightHandSide();
				}
				break;
			case 2:
				enterOuterAlt(_localctx, 2);
				{
				setState(382);
				packingLeftHandSide();
				setState(383);
				match(EQ);
				setState(387);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==NL) {
					{
					{
					setState(384);
					match(NL);
					}
					}
					setState(389);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(392);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,21,_ctx) ) {
				case 1:
					{
					setState(390);
					methodInvocationWithoutParentheses();
					}
					break;
				case 2:
					{
					setState(391);
					operatorExpression(0);
					}
					break;
				}
				}
				break;
			case 3:
				enterOuterAlt(_localctx, 3);
				{
				setState(394);
				multipleLeftHandSide();
				setState(395);
				match(EQ);
				setState(399);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==NL) {
					{
					{
					setState(396);
					match(NL);
					}
					}
					setState(401);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(402);
				multipleRightHandSide();
				}
				break;
			case 4:
				enterOuterAlt(_localctx, 4);
				{
				setState(404);
				multipleLeftHandSideExceptPacking();
				setState(405);
				match(EQ);
				setState(409);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==NL) {
					{
					{
					setState(406);
					match(NL);
					}
					}
					setState(411);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(414);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,24,_ctx) ) {
				case 1:
					{
					setState(412);
					methodInvocationWithoutParentheses();
					}
					break;
				case 2:
					{
					setState(413);
					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(436);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,28,_ctx) ) {
			case 1:
				_localctx = new VariableLeftHandSideContext(_localctx);
				enterOuterAlt(_localctx, 1);
				{
				setState(418);
				variable();
				setState(421);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,26,_ctx) ) {
				case 1:
					{
					setState(419);
					match(EQ);
					setState(420);
					primary();
					}
					break;
				}
				}
				break;
			case 2:
				_localctx = new IndexingLeftHandSideContext(_localctx);
				enterOuterAlt(_localctx, 2);
				{
				setState(423);
				primary();
				setState(424);
				match(LBRACK);
				setState(426);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (((((_la - 3)) & ~0x3f) == 0 && ((1L << (_la - 3)) & ((1L << (REGULAR_EXPRESSION_START - 3)) | (1L << (LBRACK - 3)) | (1L << (LPAREN - 3)) | (1L << (LCURLY - 3)) | (1L << (COLON - 3)) | (1L << (COLON2 - 3)) | (1L << (DOT2 - 3)) | (1L << (DOT3 - 3)) | (1L << (MINUSGT - 3)) | (1L << (EMARK - 3)) | (1L << (PLUS - 3)) | (1L << (MINUS - 3)) | (1L << (STAR - 3)) | (1L << (STAR2 - 3)) | (1L << (TILDE - 3)) | (1L << (SINGLE_QUOTED_STRING_LITERAL - 3)) | (1L << (DOUBLE_QUOTED_STRING_START - 3)) | (1L << (QUOTED_NON_EXPANDED_STRING_LITERAL_START - 3)) | (1L << (QUOTED_EXPANDED_STRING_LITERAL_START - 3)) | (1L << (QUOTED_EXPANDED_REGULAR_EXPRESSION_START - 3)))) != 0) || ((((_la - 67)) & ~0x3f) == 0 && ((1L << (_la - 67)) & ((1L << (QUOTED_EXPANDED_EXTERNAL_COMMAND_LITERAL_START - 67)) | (1L << (QUOTED_NON_EXPANDED_STRING_ARRAY_LITERAL_START - 67)) | (1L << (QUOTED_EXPANDED_STRING_ARRAY_LITERAL_START - 67)) | (1L << (HERE_DOC - 67)) | (1L << (QUOTED_NON_EXPANDED_SYMBOL_ARRAY_LITERAL_START - 67)) | (1L << (QUOTED_EXPANDED_SYMBOL_ARRAY_LITERAL_START - 67)) | (1L << (DECIMAL_INTEGER_LITERAL - 67)) | (1L << (BINARY_INTEGER_LITERAL - 67)) | (1L << (OCTAL_INTEGER_LITERAL - 67)) | (1L << (HEXADECIMAL_INTEGER_LITERAL - 67)) | (1L << (FLOAT_LITERAL_WITHOUT_EXPONENT - 67)) | (1L << (FLOAT_LITERAL_WITH_EXPONENT - 67)) | (1L << (SYMBOL_LITERAL - 67)) | (1L << (LOCAL_VARIABLE_IDENTIFIER - 67)) | (1L << (LINE__ - 67)) | (1L << (ENCODING__ - 67)) | (1L << (FILE__ - 67)) | (1L << (BEGIN_ - 67)) | (1L << (END_ - 67)) | (1L << (ALIAS - 67)) | (1L << (AND - 67)) | (1L << (BEGIN - 67)) | (1L << (BREAK - 67)) | (1L << (CASE - 67)) | (1L << (CLASS - 67)) | (1L << (DEF - 67)) | (1L << (IS_DEFINED - 67)) | (1L << (DO - 67)) | (1L << (ELSE - 67)) | (1L << (ELSIF - 67)) | (1L << (END - 67)) | (1L << (ENSURE - 67)) | (1L << (FOR - 67)) | (1L << (FALSE - 67)) | (1L << (IF - 67)) | (1L << (IN - 67)) | (1L << (MODULE - 67)) | (1L << (NEXT - 67)) | (1L << (NIL - 67)) | (1L << (NOT - 67)) | (1L << (OR - 67)) | (1L << (REDO - 67)) | (1L << (RESCUE - 67)) | (1L << (RETRY - 67)) | (1L << (RETURN - 67)) | (1L << (SELF - 67)) | (1L << (SUPER - 67)) | (1L << (THEN - 67)) | (1L << (TRUE - 67)) | (1L << (UNDEF - 67)) | (1L << (UNLESS - 67)) | (1L << (UNTIL - 67)) | (1L << (WHEN - 67)) | (1L << (WHILE - 67)) | (1L << (YIELD - 67)) | (1L << (GLOBAL_VARIABLE_IDENTIFIER - 67)) | (1L << (INSTANCE_VARIABLE_IDENTIFIER - 67)) | (1L << (CLASS_VARIABLE_IDENTIFIER - 67)) | (1L << (CONSTANT_IDENTIFIER - 67)))) != 0)) {
					{
					setState(425);
					indexingArgumentList();
					}
				}

				setState(428);
				match(RBRACK);
				}
				break;
			case 3:
				_localctx = new MemberAccessLeftHandSideContext(_localctx);
				enterOuterAlt(_localctx, 3);
				{
				setState(430);
				primary();
				setState(431);
				_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(432);
				_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(434);
				match(COLON2);
				setState(435);
				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(475);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,37,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(441); 
				_errHandler.sync(this);
				_alt = 1;
				do {
					switch (_alt) {
					case 1:
						{
						{
						setState(438);
						multipleLeftHandSideItem();
						setState(439);
						match(COMMA);
						}
						}
						break;
					default:
						throw new NoViableAltException(this);
					}
					setState(443); 
					_errHandler.sync(this);
					_alt = getInterpreter().adaptivePredict(_input,29,_ctx);
				} while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER );
				setState(446);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (((((_la - 3)) & ~0x3f) == 0 && ((1L << (_la - 3)) & ((1L << (REGULAR_EXPRESSION_START - 3)) | (1L << (LBRACK - 3)) | (1L << (LPAREN - 3)) | (1L << (LCURLY - 3)) | (1L << (COLON - 3)) | (1L << (COLON2 - 3)) | (1L << (DOT2 - 3)) | (1L << (DOT3 - 3)) | (1L << (MINUSGT - 3)) | (1L << (EMARK - 3)) | (1L << (PLUS - 3)) | (1L << (MINUS - 3)) | (1L << (TILDE - 3)) | (1L << (SINGLE_QUOTED_STRING_LITERAL - 3)) | (1L << (DOUBLE_QUOTED_STRING_START - 3)) | (1L << (QUOTED_NON_EXPANDED_STRING_LITERAL_START - 3)) | (1L << (QUOTED_EXPANDED_STRING_LITERAL_START - 3)) | (1L << (QUOTED_EXPANDED_REGULAR_EXPRESSION_START - 3)))) != 0) || ((((_la - 67)) & ~0x3f) == 0 && ((1L << (_la - 67)) & ((1L << (QUOTED_EXPANDED_EXTERNAL_COMMAND_LITERAL_START - 67)) | (1L << (QUOTED_NON_EXPANDED_STRING_ARRAY_LITERAL_START - 67)) | (1L << (QUOTED_EXPANDED_STRING_ARRAY_LITERAL_START - 67)) | (1L << (HERE_DOC - 67)) | (1L << (QUOTED_NON_EXPANDED_SYMBOL_ARRAY_LITERAL_START - 67)) | (1L << (QUOTED_EXPANDED_SYMBOL_ARRAY_LITERAL_START - 67)) | (1L << (DECIMAL_INTEGER_LITERAL - 67)) | (1L << (BINARY_INTEGER_LITERAL - 67)) | (1L << (OCTAL_INTEGER_LITERAL - 67)) | (1L << (HEXADECIMAL_INTEGER_LITERAL - 67)) | (1L << (FLOAT_LITERAL_WITHOUT_EXPONENT - 67)) | (1L << (FLOAT_LITERAL_WITH_EXPONENT - 67)) | (1L << (SYMBOL_LITERAL - 67)) | (1L << (LOCAL_VARIABLE_IDENTIFIER - 67)) | (1L << (LINE__ - 67)) | (1L << (ENCODING__ - 67)) | (1L << (FILE__ - 67)) | (1L << (BEGIN - 67)) | (1L << (BREAK - 67)) | (1L << (CASE - 67)) | (1L << (CLASS - 67)) | (1L << (DEF - 67)) | (1L << (IS_DEFINED - 67)) | (1L << (FOR - 67)) | (1L << (FALSE - 67)) | (1L << (IF - 67)) | (1L << (MODULE - 67)) | (1L << (NEXT - 67)) | (1L << (NIL - 67)) | (1L << (REDO - 67)) | (1L << (RETRY - 67)) | (1L << (RETURN - 67)) | (1L << (SELF - 67)) | (1L << (SUPER - 67)) | (1L << (TRUE - 67)) | (1L << (UNLESS - 67)) | (1L << (UNTIL - 67)) | (1L << (WHILE - 67)) | (1L << (YIELD - 67)) | (1L << (GLOBAL_VARIABLE_IDENTIFIER - 67)) | (1L << (INSTANCE_VARIABLE_IDENTIFIER - 67)) | (1L << (CLASS_VARIABLE_IDENTIFIER - 67)) | (1L << (CONSTANT_IDENTIFIER - 67)))) != 0)) {
					{
					setState(445);
					multipleLeftHandSideItem();
					}
				}

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

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

					setState(464);
					_errHandler.sync(this);
					_la = _input.LA(1);
					while (_la==NL) {
						{
						{
						setState(461);
						match(NL);
						}
						}
						setState(466);
						_errHandler.sync(this);
						_la = _input.LA(1);
					}
					setState(467);
					procParameter();
					}
					break;
				}
				setState(471);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==COMMA) {
					{
					setState(470);
					match(COMMA);
					}
				}

				}
				break;
			case 3:
				enterOuterAlt(_localctx, 3);
				{
				setState(473);
				packingLeftHandSide();
				}
				break;
			case 4:
				enterOuterAlt(_localctx, 4);
				{
				setState(474);
				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(498);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,42,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(480); 
				_errHandler.sync(this);
				_alt = 1;
				do {
					switch (_alt) {
					case 1:
						{
						{
						setState(477);
						multipleLeftHandSideItem();
						setState(478);
						match(COMMA);
						}
						}
						break;
					default:
						throw new NoViableAltException(this);
					}
					setState(482); 
					_errHandler.sync(this);
					_alt = getInterpreter().adaptivePredict(_input,38,_ctx);
				} while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER );
				setState(485);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (((((_la - 3)) & ~0x3f) == 0 && ((1L << (_la - 3)) & ((1L << (REGULAR_EXPRESSION_START - 3)) | (1L << (LBRACK - 3)) | (1L << (LPAREN - 3)) | (1L << (LCURLY - 3)) | (1L << (COLON - 3)) | (1L << (COLON2 - 3)) | (1L << (DOT2 - 3)) | (1L << (DOT3 - 3)) | (1L << (MINUSGT - 3)) | (1L << (EMARK - 3)) | (1L << (PLUS - 3)) | (1L << (MINUS - 3)) | (1L << (TILDE - 3)) | (1L << (SINGLE_QUOTED_STRING_LITERAL - 3)) | (1L << (DOUBLE_QUOTED_STRING_START - 3)) | (1L << (QUOTED_NON_EXPANDED_STRING_LITERAL_START - 3)) | (1L << (QUOTED_EXPANDED_STRING_LITERAL_START - 3)) | (1L << (QUOTED_EXPANDED_REGULAR_EXPRESSION_START - 3)))) != 0) || ((((_la - 67)) & ~0x3f) == 0 && ((1L << (_la - 67)) & ((1L << (QUOTED_EXPANDED_EXTERNAL_COMMAND_LITERAL_START - 67)) | (1L << (QUOTED_NON_EXPANDED_STRING_ARRAY_LITERAL_START - 67)) | (1L << (QUOTED_EXPANDED_STRING_ARRAY_LITERAL_START - 67)) | (1L << (HERE_DOC - 67)) | (1L << (QUOTED_NON_EXPANDED_SYMBOL_ARRAY_LITERAL_START - 67)) | (1L << (QUOTED_EXPANDED_SYMBOL_ARRAY_LITERAL_START - 67)) | (1L << (DECIMAL_INTEGER_LITERAL - 67)) | (1L << (BINARY_INTEGER_LITERAL - 67)) | (1L << (OCTAL_INTEGER_LITERAL - 67)) | (1L << (HEXADECIMAL_INTEGER_LITERAL - 67)) | (1L << (FLOAT_LITERAL_WITHOUT_EXPONENT - 67)) | (1L << (FLOAT_LITERAL_WITH_EXPONENT - 67)) | (1L << (SYMBOL_LITERAL - 67)) | (1L << (LOCAL_VARIABLE_IDENTIFIER - 67)) | (1L << (LINE__ - 67)) | (1L << (ENCODING__ - 67)) | (1L << (FILE__ - 67)) | (1L << (BEGIN - 67)) | (1L << (BREAK - 67)) | (1L << (CASE - 67)) | (1L << (CLASS - 67)) | (1L << (DEF - 67)) | (1L << (IS_DEFINED - 67)) | (1L << (FOR - 67)) | (1L << (FALSE - 67)) | (1L << (IF - 67)) | (1L << (MODULE - 67)) | (1L << (NEXT - 67)) | (1L << (NIL - 67)) | (1L << (REDO - 67)) | (1L << (RETRY - 67)) | (1L << (RETURN - 67)) | (1L << (SELF - 67)) | (1L << (SUPER - 67)) | (1L << (TRUE - 67)) | (1L << (UNLESS - 67)) | (1L << (UNTIL - 67)) | (1L << (WHILE - 67)) | (1L << (YIELD - 67)) | (1L << (GLOBAL_VARIABLE_IDENTIFIER - 67)) | (1L << (INSTANCE_VARIABLE_IDENTIFIER - 67)) | (1L << (CLASS_VARIABLE_IDENTIFIER - 67)) | (1L << (CONSTANT_IDENTIFIER - 67)))) != 0)) {
					{
					setState(484);
					multipleLeftHandSideItem();
					}
				}

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

				}
				break;
			case 3:
				enterOuterAlt(_localctx, 3);
				{
				setState(497);
				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;
			enterOuterAlt(_localctx, 1);
			{
			setState(500);
			match(STAR);
			setState(502);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (((((_la - 3)) & ~0x3f) == 0 && ((1L << (_la - 3)) & ((1L << (REGULAR_EXPRESSION_START - 3)) | (1L << (LBRACK - 3)) | (1L << (LPAREN - 3)) | (1L << (LCURLY - 3)) | (1L << (COLON - 3)) | (1L << (COLON2 - 3)) | (1L << (DOT2 - 3)) | (1L << (DOT3 - 3)) | (1L << (MINUSGT - 3)) | (1L << (EMARK - 3)) | (1L << (PLUS - 3)) | (1L << (MINUS - 3)) | (1L << (TILDE - 3)) | (1L << (SINGLE_QUOTED_STRING_LITERAL - 3)) | (1L << (DOUBLE_QUOTED_STRING_START - 3)) | (1L << (QUOTED_NON_EXPANDED_STRING_LITERAL_START - 3)) | (1L << (QUOTED_EXPANDED_STRING_LITERAL_START - 3)) | (1L << (QUOTED_EXPANDED_REGULAR_EXPRESSION_START - 3)))) != 0) || ((((_la - 67)) & ~0x3f) == 0 && ((1L << (_la - 67)) & ((1L << (QUOTED_EXPANDED_EXTERNAL_COMMAND_LITERAL_START - 67)) | (1L << (QUOTED_NON_EXPANDED_STRING_ARRAY_LITERAL_START - 67)) | (1L << (QUOTED_EXPANDED_STRING_ARRAY_LITERAL_START - 67)) | (1L << (HERE_DOC - 67)) | (1L << (QUOTED_NON_EXPANDED_SYMBOL_ARRAY_LITERAL_START - 67)) | (1L << (QUOTED_EXPANDED_SYMBOL_ARRAY_LITERAL_START - 67)) | (1L << (DECIMAL_INTEGER_LITERAL - 67)) | (1L << (BINARY_INTEGER_LITERAL - 67)) | (1L << (OCTAL_INTEGER_LITERAL - 67)) | (1L << (HEXADECIMAL_INTEGER_LITERAL - 67)) | (1L << (FLOAT_LITERAL_WITHOUT_EXPONENT - 67)) | (1L << (FLOAT_LITERAL_WITH_EXPONENT - 67)) | (1L << (SYMBOL_LITERAL - 67)) | (1L << (LOCAL_VARIABLE_IDENTIFIER - 67)) | (1L << (LINE__ - 67)) | (1L << (ENCODING__ - 67)) | (1L << (FILE__ - 67)) | (1L << (BEGIN - 67)) | (1L << (BREAK - 67)) | (1L << (CASE - 67)) | (1L << (CLASS - 67)) | (1L << (DEF - 67)) | (1L << (IS_DEFINED - 67)) | (1L << (FOR - 67)) | (1L << (FALSE - 67)) | (1L << (IF - 67)) | (1L << (MODULE - 67)) | (1L << (NEXT - 67)) | (1L << (NIL - 67)) | (1L << (REDO - 67)) | (1L << (RETRY - 67)) | (1L << (RETURN - 67)) | (1L << (SELF - 67)) | (1L << (SUPER - 67)) | (1L << (TRUE - 67)) | (1L << (UNLESS - 67)) | (1L << (UNTIL - 67)) | (1L << (WHILE - 67)) | (1L << (YIELD - 67)) | (1L << (GLOBAL_VARIABLE_IDENTIFIER - 67)) | (1L << (INSTANCE_VARIABLE_IDENTIFIER - 67)) | (1L << (CLASS_VARIABLE_IDENTIFIER - 67)) | (1L << (CONSTANT_IDENTIFIER - 67)))) != 0)) {
				{
				setState(501);
				leftHandSide();
				}
			}

			setState(508);
			_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(504);
					match(COMMA);
					setState(505);
					multipleLeftHandSideItem();
					}
					} 
				}
				setState(510);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,44,_ctx);
			}
			}
		}
		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(511);
			match(LPAREN);
			setState(512);
			multipleLeftHandSide();
			setState(513);
			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(517);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,45,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(515);
				leftHandSide();
				}
				break;
			case 2:
				enterOuterAlt(_localctx, 2);
				{
				setState(516);
				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 List operatorExpressionList() {
			return getRuleContexts(OperatorExpressionListContext.class);
		}
		public OperatorExpressionListContext operatorExpressionList(int i) {
			return getRuleContext(OperatorExpressionListContext.class,i);
		}
		public List splattingRightHandSide() {
			return getRuleContexts(SplattingRightHandSideContext.class);
		}
		public SplattingRightHandSideContext splattingRightHandSide(int i) {
			return getRuleContext(SplattingRightHandSideContext.class,i);
		}
		public List COMMA() { return getTokens(RubyParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(RubyParser.COMMA, i);
		}
		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 {
			int _alt;
			enterOuterAlt(_localctx, 1);
			{
			setState(521);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case REGULAR_EXPRESSION_START:
			case LBRACK:
			case LPAREN:
			case LCURLY:
			case COLON:
			case COLON2:
			case DOT2:
			case DOT3:
			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 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 GLOBAL_VARIABLE_IDENTIFIER:
			case INSTANCE_VARIABLE_IDENTIFIER:
			case CLASS_VARIABLE_IDENTIFIER:
			case CONSTANT_IDENTIFIER:
				{
				setState(519);
				operatorExpressionList();
				}
				break;
			case STAR:
			case STAR2:
				{
				setState(520);
				splattingRightHandSide();
				}
				break;
			default:
				throw new NoViableAltException(this);
			}
			setState(530);
			_errHandler.sync(this);
			_alt = getInterpreter().adaptivePredict(_input,48,_ctx);
			while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) {
				if ( _alt==1 ) {
					{
					{
					setState(523);
					match(COMMA);
					setState(526);
					_errHandler.sync(this);
					switch (_input.LA(1)) {
					case REGULAR_EXPRESSION_START:
					case LBRACK:
					case LPAREN:
					case LCURLY:
					case COLON:
					case COLON2:
					case DOT2:
					case DOT3:
					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 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 GLOBAL_VARIABLE_IDENTIFIER:
					case INSTANCE_VARIABLE_IDENTIFIER:
					case CLASS_VARIABLE_IDENTIFIER:
					case CONSTANT_IDENTIFIER:
						{
						setState(524);
						operatorExpressionList();
						}
						break;
					case STAR:
					case STAR2:
						{
						setState(525);
						splattingRightHandSide();
						}
						break;
					default:
						throw new NoViableAltException(this);
					}
					}
					} 
				}
				setState(532);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,48,_ctx);
			}
			}
		}
		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(533);
			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(538);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,49,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(535);
				match(LOCAL_VARIABLE_IDENTIFIER);
				}
				break;
			case 2:
				enterOuterAlt(_localctx, 2);
				{
				setState(536);
				match(CONSTANT_IDENTIFIER);
				}
				break;
			case 3:
				enterOuterAlt(_localctx, 3);
				{
				setState(537);
				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(543);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,50,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(540);
				methodIdentifier();
				}
				break;
			case 2:
				enterOuterAlt(_localctx, 2);
				{
				setState(541);
				keyword();
				}
				break;
			case 3:
				enterOuterAlt(_localctx, 3);
				{
				setState(542);
				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(548);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case CONSTANT_IDENTIFIER:
				{
				setState(545);
				match(CONSTANT_IDENTIFIER);
				}
				break;
			case LOCAL_VARIABLE_IDENTIFIER:
				{
				setState(546);
				match(LOCAL_VARIABLE_IDENTIFIER);
				}
				break;
			case LINE__:
			case ENCODING__:
			case FILE__:
			case FALSE:
			case NIL:
			case SELF:
			case TRUE:
				{
				setState(547);
				pseudoVariable();
				}
				break;
			default:
				throw new NoViableAltException(this);
			}
			setState(550);
			_la = _input.LA(1);
			if ( !((((_la) & ~0x3f) == 0 && ((1L << _la) & ((1L << QMARK) | (1L << EMARK) | (1L << EQ))) != 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 PrimaryValueListWithAssociationContext primaryValueListWithAssociation() {
			return getRuleContext(PrimaryValueListWithAssociationContext.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 PrimaryValueListWithAssociationContext primaryValueListWithAssociation() {
			return getRuleContext(PrimaryValueListWithAssociationContext.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(568);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,53,_ctx) ) {
			case 1:
				_localctx = new CommandMethodInvocationWithoutParenthesesContext(_localctx);
				enterOuterAlt(_localctx, 1);
				{
				setState(552);
				command();
				}
				break;
			case 2:
				_localctx = new ChainedMethodInvocationWithoutParenthesesContext(_localctx);
				enterOuterAlt(_localctx, 2);
				{
				setState(553);
				chainedCommandWithDoBlock();
				setState(558);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,52,_ctx) ) {
				case 1:
					{
					setState(554);
					_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(555);
					methodName();
					setState(556);
					commandArgumentList();
					}
					break;
				}
				}
				break;
			case 3:
				_localctx = new ReturnMethodInvocationWithoutParenthesesContext(_localctx);
				enterOuterAlt(_localctx, 3);
				{
				setState(560);
				match(RETURN);
				setState(561);
				primaryValueListWithAssociation();
				}
				break;
			case 4:
				_localctx = new BreakMethodInvocationWithoutParenthesesContext(_localctx);
				enterOuterAlt(_localctx, 4);
				{
				setState(562);
				match(BREAK);
				setState(563);
				primaryValueList();
				}
				break;
			case 5:
				_localctx = new NextMethodInvocationWithoutParenthesesContext(_localctx);
				enterOuterAlt(_localctx, 5);
				{
				setState(564);
				match(NEXT);
				setState(565);
				primaryValueList();
				}
				break;
			case 6:
				_localctx = new YieldMethodInvocationWithoutParenthesesContext(_localctx);
				enterOuterAlt(_localctx, 6);
				{
				setState(566);
				match(YIELD);
				setState(567);
				primaryValueListWithAssociation();
				}
				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 CommandTernaryOperatorExpressionContext extends CommandContext {
		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 CommandTernaryOperatorExpressionContext(CommandContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterCommandTernaryOperatorExpression(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitCommandTernaryOperatorExpression(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitCommandTernaryOperatorExpression(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(605);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,58,_ctx) ) {
			case 1:
				_localctx = new CommandTernaryOperatorExpressionContext(_localctx);
				enterOuterAlt(_localctx, 1);
				{
				setState(570);
				operatorExpression(0);
				setState(571);
				match(QMARK);
				setState(575);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==NL) {
					{
					{
					setState(572);
					match(NL);
					}
					}
					setState(577);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(578);
				operatorExpression(0);
				setState(582);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==NL) {
					{
					{
					setState(579);
					match(NL);
					}
					}
					setState(584);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(585);
				match(COLON);
				setState(589);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==NL) {
					{
					{
					setState(586);
					match(NL);
					}
					}
					setState(591);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(592);
				operatorExpression(0);
				}
				break;
			case 2:
				_localctx = new MemberAccessCommandContext(_localctx);
				enterOuterAlt(_localctx, 2);
				{
				setState(594);
				primary();
				setState(596);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==NL) {
					{
					setState(595);
					match(NL);
					}
				}

				setState(598);
				_la = _input.LA(1);
				if ( !((((_la) & ~0x3f) == 0 && ((1L << _la) & ((1L << COLON2) | (1L << DOT) | (1L << AMPDOT))) != 0)) ) {
				_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				setState(599);
				methodName();
				setState(600);
				commandArgument();
				}
				break;
			case 3:
				_localctx = new SimpleCommandContext(_localctx);
				enterOuterAlt(_localctx, 3);
				{
				setState(602);
				methodIdentifier();
				setState(603);
				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(609);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,59,_ctx) ) {
			case 1:
				_localctx = new CommandArgumentCommandArgumentListContext(_localctx);
				enterOuterAlt(_localctx, 1);
				{
				setState(607);
				commandArgumentList();
				}
				break;
			case 2:
				_localctx = new CommandCommandArgumentListContext(_localctx);
				enterOuterAlt(_localctx, 2);
				{
				setState(608);
				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(611);
			commandWithDoBlock();
			setState(615);
			_errHandler.sync(this);
			_alt = getInterpreter().adaptivePredict(_input,60,_ctx);
			while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) {
				if ( _alt==1 ) {
					{
					{
					setState(612);
					chainedMethodInvocation();
					}
					} 
				}
				setState(617);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,60,_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(618);
			_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(619);
			methodName();
			setState(621);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,61,_ctx) ) {
			case 1:
				{
				setState(620);
				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(637);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,62,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(623);
				match(SUPER);
				setState(624);
				argumentList();
				setState(625);
				doBlock();
				}
				break;
			case 2:
				enterOuterAlt(_localctx, 2);
				{
				setState(627);
				methodIdentifier();
				setState(628);
				argumentList();
				setState(629);
				doBlock();
				}
				break;
			case 3:
				enterOuterAlt(_localctx, 3);
				{
				setState(631);
				primary();
				setState(632);
				_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(633);
				methodName();
				setState(634);
				argumentList();
				setState(635);
				doBlock();
				}
				break;
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class BracketedArrayElementListContext extends ParserRuleContext {
		public List bracketedArrayElement() {
			return getRuleContexts(BracketedArrayElementContext.class);
		}
		public BracketedArrayElementContext bracketedArrayElement(int i) {
			return getRuleContext(BracketedArrayElementContext.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 BracketedArrayElementListContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_bracketedArrayElementList; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterBracketedArrayElementList(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitBracketedArrayElementList(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitBracketedArrayElementList(this);
			else return visitor.visitChildren(this);
		}
	}

	public final BracketedArrayElementListContext bracketedArrayElementList() throws RecognitionException {
		BracketedArrayElementListContext _localctx = new BracketedArrayElementListContext(_ctx, getState());
		enterRule(_localctx, 48, RULE_bracketedArrayElementList);
		int _la;
		try {
			int _alt;
			enterOuterAlt(_localctx, 1);
			{
			setState(639);
			bracketedArrayElement();
			setState(652);
			_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(641);
					_errHandler.sync(this);
					_la = _input.LA(1);
					if (_la==COMMA) {
						{
						setState(640);
						match(COMMA);
						}
					}

					setState(646);
					_errHandler.sync(this);
					_la = _input.LA(1);
					while (_la==NL) {
						{
						{
						setState(643);
						match(NL);
						}
						}
						setState(648);
						_errHandler.sync(this);
						_la = _input.LA(1);
					}
					setState(649);
					bracketedArrayElement();
					}
					} 
				}
				setState(654);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,65,_ctx);
			}
			setState(656);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==COMMA) {
				{
				setState(655);
				match(COMMA);
				}
			}

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

	public static class BracketedArrayElementContext extends ParserRuleContext {
		public IndexingArgumentContext indexingArgument() {
			return getRuleContext(IndexingArgumentContext.class,0);
		}
		public CommandContext command() {
			return getRuleContext(CommandContext.class,0);
		}
		public HashLiteralContext hashLiteral() {
			return getRuleContext(HashLiteralContext.class,0);
		}
		public SplattingArgumentContext splattingArgument() {
			return getRuleContext(SplattingArgumentContext.class,0);
		}
		public IndexingArgumentListContext indexingArgumentList() {
			return getRuleContext(IndexingArgumentListContext.class,0);
		}
		public BracketedArrayElementContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_bracketedArrayElement; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterBracketedArrayElement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitBracketedArrayElement(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitBracketedArrayElement(this);
			else return visitor.visitChildren(this);
		}
	}

	public final BracketedArrayElementContext bracketedArrayElement() throws RecognitionException {
		BracketedArrayElementContext _localctx = new BracketedArrayElementContext(_ctx, getState());
		enterRule(_localctx, 50, RULE_bracketedArrayElement);
		try {
			setState(663);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,67,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(658);
				indexingArgument();
				}
				break;
			case 2:
				enterOuterAlt(_localctx, 2);
				{
				setState(659);
				command();
				}
				break;
			case 3:
				enterOuterAlt(_localctx, 3);
				{
				setState(660);
				hashLiteral();
				}
				break;
			case 4:
				enterOuterAlt(_localctx, 4);
				{
				setState(661);
				splattingArgument();
				}
				break;
			case 5:
				enterOuterAlt(_localctx, 5);
				{
				setState(662);
				indexingArgumentList();
				}
				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 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 IndexingArgumentIndexingArgumentListContext extends IndexingArgumentListContext {
		public List indexingArgument() {
			return getRuleContexts(IndexingArgumentContext.class);
		}
		public IndexingArgumentContext indexingArgument(int i) {
			return getRuleContext(IndexingArgumentContext.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 IndexingArgumentIndexingArgumentListContext(IndexingArgumentListContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterIndexingArgumentIndexingArgumentList(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitIndexingArgumentIndexingArgumentList(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitIndexingArgumentIndexingArgumentList(this);
			else return visitor.visitChildren(this);
		}
	}
	public static class SplattingArgumentIndexingArgumentListContext extends IndexingArgumentListContext {
		public List splattingArgument() {
			return getRuleContexts(SplattingArgumentContext.class);
		}
		public SplattingArgumentContext splattingArgument(int i) {
			return getRuleContext(SplattingArgumentContext.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 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, 52, RULE_indexingArgumentList);
		int _la;
		try {
			int _alt;
			setState(707);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,75,_ctx) ) {
			case 1:
				_localctx = new OperatorExpressionListIndexingArgumentListContext(_localctx);
				enterOuterAlt(_localctx, 1);
				{
				setState(665);
				operatorExpressionList();
				setState(667);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,68,_ctx) ) {
				case 1:
					{
					setState(666);
					match(COMMA);
					}
					break;
				}
				}
				break;
			case 2:
				_localctx = new OperatorExpressionListWithSplattingArgumentIndexingArgumentListContext(_localctx);
				enterOuterAlt(_localctx, 2);
				{
				setState(669);
				operatorExpressionList();
				setState(670);
				match(COMMA);
				setState(671);
				splattingArgument();
				}
				break;
			case 3:
				_localctx = new IndexingArgumentIndexingArgumentListContext(_localctx);
				enterOuterAlt(_localctx, 3);
				{
				setState(673);
				indexingArgument();
				setState(686);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,71,_ctx);
				while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) {
					if ( _alt==1 ) {
						{
						{
						setState(675);
						_errHandler.sync(this);
						_la = _input.LA(1);
						if (_la==COMMA) {
							{
							setState(674);
							match(COMMA);
							}
						}

						setState(680);
						_errHandler.sync(this);
						_la = _input.LA(1);
						while (_la==NL) {
							{
							{
							setState(677);
							match(NL);
							}
							}
							setState(682);
							_errHandler.sync(this);
							_la = _input.LA(1);
						}
						setState(683);
						indexingArgument();
						}
						} 
					}
					setState(688);
					_errHandler.sync(this);
					_alt = getInterpreter().adaptivePredict(_input,71,_ctx);
				}
				}
				break;
			case 4:
				_localctx = new AssociationListIndexingArgumentListContext(_localctx);
				enterOuterAlt(_localctx, 4);
				{
				setState(689);
				associationList();
				setState(691);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,72,_ctx) ) {
				case 1:
					{
					setState(690);
					match(COMMA);
					}
					break;
				}
				}
				break;
			case 5:
				_localctx = new SplattingArgumentIndexingArgumentListContext(_localctx);
				enterOuterAlt(_localctx, 5);
				{
				setState(693);
				splattingArgument();
				setState(704);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,74,_ctx);
				while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) {
					if ( _alt==1 ) {
						{
						{
						setState(694);
						match(COMMA);
						setState(698);
						_errHandler.sync(this);
						_la = _input.LA(1);
						while (_la==NL) {
							{
							{
							setState(695);
							match(NL);
							}
							}
							setState(700);
							_errHandler.sync(this);
							_la = _input.LA(1);
						}
						setState(701);
						splattingArgument();
						}
						} 
					}
					setState(706);
					_errHandler.sync(this);
					_alt = getInterpreter().adaptivePredict(_input,74,_ctx);
				}
				}
				break;
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class IndexingArgumentContext extends ParserRuleContext {
		public IndexingArgumentContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_indexingArgument; }
	 
		public IndexingArgumentContext() { }
		public void copyFrom(IndexingArgumentContext ctx) {
			super.copyFrom(ctx);
		}
	}
	public static class SymbolIndexingArgumentContext extends IndexingArgumentContext {
		public SymbolContext symbol() {
			return getRuleContext(SymbolContext.class,0);
		}
		public SymbolIndexingArgumentContext(IndexingArgumentContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterSymbolIndexingArgument(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitSymbolIndexingArgument(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitSymbolIndexingArgument(this);
			else return visitor.visitChildren(this);
		}
	}
	public static class NumericLiteralIndexingArgumentContext extends IndexingArgumentContext {
		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 NumericLiteralIndexingArgumentContext(IndexingArgumentContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterNumericLiteralIndexingArgument(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitNumericLiteralIndexingArgument(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitNumericLiteralIndexingArgument(this);
			else return visitor.visitChildren(this);
		}
	}
	public static class AssociationIndexingArgumentContext extends IndexingArgumentContext {
		public AssociationContext association() {
			return getRuleContext(AssociationContext.class,0);
		}
		public AssociationIndexingArgumentContext(IndexingArgumentContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterAssociationIndexingArgument(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitAssociationIndexingArgument(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitAssociationIndexingArgument(this);
			else return visitor.visitChildren(this);
		}
	}

	public final IndexingArgumentContext indexingArgument() throws RecognitionException {
		IndexingArgumentContext _localctx = new IndexingArgumentContext(_ctx, getState());
		enterRule(_localctx, 54, RULE_indexingArgument);
		int _la;
		try {
			setState(715);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,77,_ctx) ) {
			case 1:
				_localctx = new SymbolIndexingArgumentContext(_localctx);
				enterOuterAlt(_localctx, 1);
				{
				setState(709);
				symbol();
				}
				break;
			case 2:
				_localctx = new AssociationIndexingArgumentContext(_localctx);
				enterOuterAlt(_localctx, 2);
				{
				setState(710);
				association();
				}
				break;
			case 3:
				_localctx = new NumericLiteralIndexingArgumentContext(_localctx);
				enterOuterAlt(_localctx, 3);
				{
				setState(712);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==PLUS || _la==MINUS) {
					{
					setState(711);
					((NumericLiteralIndexingArgumentContext)_localctx).sign = _input.LT(1);
					_la = _input.LA(1);
					if ( !(_la==PLUS || _la==MINUS) ) {
						((NumericLiteralIndexingArgumentContext)_localctx).sign = (Token)_errHandler.recoverInline(this);
					}
					else {
						if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
						_errHandler.reportMatch(this);
						consume();
					}
					}
				}

				setState(714);
				unsignedNumericLiteral();
				}
				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, 56, RULE_splattingArgument);
		try {
			setState(721);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case STAR:
				enterOuterAlt(_localctx, 1);
				{
				setState(717);
				match(STAR);
				setState(718);
				operatorExpression(0);
				}
				break;
			case STAR2:
				enterOuterAlt(_localctx, 2);
				{
				setState(719);
				match(STAR2);
				setState(720);
				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, 58, RULE_operatorExpressionList);
		int _la;
		try {
			int _alt;
			enterOuterAlt(_localctx, 1);
			{
			setState(723);
			operatorExpression(0);
			setState(734);
			_errHandler.sync(this);
			_alt = getInterpreter().adaptivePredict(_input,80,_ctx);
			while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) {
				if ( _alt==1 ) {
					{
					{
					setState(724);
					match(COMMA);
					setState(728);
					_errHandler.sync(this);
					_la = _input.LA(1);
					while (_la==NL) {
						{
						{
						setState(725);
						match(NL);
						}
						}
						setState(730);
						_errHandler.sync(this);
						_la = _input.LA(1);
					}
					setState(731);
					operatorExpression(0);
					}
					} 
				}
				setState(736);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,80,_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, 60, RULE_operatorExpressionList2);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(737);
			operatorExpression(0);
			setState(746); 
			_errHandler.sync(this);
			_la = _input.LA(1);
			do {
				{
				{
				setState(738);
				match(COMMA);
				setState(742);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==NL) {
					{
					{
					setState(739);
					match(NL);
					}
					}
					setState(744);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(745);
				operatorExpression(0);
				}
				}
				setState(748); 
				_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, 62, RULE_argumentWithParentheses);
		int _la;
		try {
			int _alt;
			setState(832);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,96,_ctx) ) {
			case 1:
				_localctx = new EmptyArgumentWithParenthesesContext(_localctx);
				enterOuterAlt(_localctx, 1);
				{
				setState(750);
				match(LPAREN);
				setState(754);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,83,_ctx);
				while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) {
					if ( _alt==1 ) {
						{
						{
						setState(751);
						match(NL);
						}
						} 
					}
					setState(756);
					_errHandler.sync(this);
					_alt = getInterpreter().adaptivePredict(_input,83,_ctx);
				}
				setState(758);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==COMMA) {
					{
					setState(757);
					match(COMMA);
					}
				}

				setState(763);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==NL) {
					{
					{
					setState(760);
					match(NL);
					}
					}
					setState(765);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(766);
				match(RPAREN);
				}
				break;
			case 2:
				_localctx = new ArgumentListArgumentWithParenthesesContext(_localctx);
				enterOuterAlt(_localctx, 2);
				{
				setState(767);
				match(LPAREN);
				setState(771);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==NL) {
					{
					{
					setState(768);
					match(NL);
					}
					}
					setState(773);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(774);
				argumentList();
				setState(776);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==COMMA) {
					{
					setState(775);
					match(COMMA);
					}
				}

				setState(781);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==NL) {
					{
					{
					setState(778);
					match(NL);
					}
					}
					setState(783);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(784);
				match(RPAREN);
				}
				break;
			case 3:
				_localctx = new OperatorExpressionsAndChainedCommandWithBlockArgumentWithParenthesesContext(_localctx);
				enterOuterAlt(_localctx, 3);
				{
				setState(786);
				match(LPAREN);
				setState(790);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==NL) {
					{
					{
					setState(787);
					match(NL);
					}
					}
					setState(792);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(793);
				operatorExpressionList();
				setState(794);
				match(COMMA);
				setState(798);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==NL) {
					{
					{
					setState(795);
					match(NL);
					}
					}
					setState(800);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(801);
				chainedCommandWithDoBlock();
				setState(803);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==COMMA) {
					{
					setState(802);
					match(COMMA);
					}
				}

				setState(808);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==NL) {
					{
					{
					setState(805);
					match(NL);
					}
					}
					setState(810);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(811);
				match(RPAREN);
				}
				break;
			case 4:
				_localctx = new ChainedCommandWithDoBlockArgumentWithParenthesesContext(_localctx);
				enterOuterAlt(_localctx, 4);
				{
				setState(813);
				match(LPAREN);
				setState(817);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==NL) {
					{
					{
					setState(814);
					match(NL);
					}
					}
					setState(819);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(820);
				chainedCommandWithDoBlock();
				setState(822);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==COMMA) {
					{
					setState(821);
					match(COMMA);
					}
				}

				setState(827);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==NL) {
					{
					{
					setState(824);
					match(NL);
					}
					}
					setState(829);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(830);
				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 ArrayArgumentListContext extends ArgumentListContext {
		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 ArrayArgumentListContext(ArgumentListContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterArrayArgumentList(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitArrayArgumentList(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitArrayArgumentList(this);
			else return visitor.visitChildren(this);
		}
	}
	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, 64, RULE_argumentList);
		int _la;
		try {
			setState(914);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,112,_ctx) ) {
			case 1:
				_localctx = new BlockArgumentArgumentListContext(_localctx);
				enterOuterAlt(_localctx, 1);
				{
				setState(834);
				blockArgument();
				}
				break;
			case 2:
				_localctx = new SplattingArgumentArgumentListContext(_localctx);
				enterOuterAlt(_localctx, 2);
				{
				setState(835);
				splattingArgument();
				setState(844);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,98,_ctx) ) {
				case 1:
					{
					setState(836);
					match(COMMA);
					setState(840);
					_errHandler.sync(this);
					_la = _input.LA(1);
					while (_la==NL) {
						{
						{
						setState(837);
						match(NL);
						}
						}
						setState(842);
						_errHandler.sync(this);
						_la = _input.LA(1);
					}
					setState(843);
					blockArgument();
					}
					break;
				}
				setState(854);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,100,_ctx) ) {
				case 1:
					{
					setState(846);
					match(COMMA);
					setState(850);
					_errHandler.sync(this);
					_la = _input.LA(1);
					while (_la==NL) {
						{
						{
						setState(847);
						match(NL);
						}
						}
						setState(852);
						_errHandler.sync(this);
						_la = _input.LA(1);
					}
					setState(853);
					operatorExpressionList();
					}
					break;
				}
				}
				break;
			case 3:
				_localctx = new OperatorsArgumentListContext(_localctx);
				enterOuterAlt(_localctx, 3);
				{
				setState(856);
				operatorExpressionList();
				setState(865);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,102,_ctx) ) {
				case 1:
					{
					setState(857);
					match(COMMA);
					setState(861);
					_errHandler.sync(this);
					_la = _input.LA(1);
					while (_la==NL) {
						{
						{
						setState(858);
						match(NL);
						}
						}
						setState(863);
						_errHandler.sync(this);
						_la = _input.LA(1);
					}
					setState(864);
					associationList();
					}
					break;
				}
				setState(875);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,104,_ctx) ) {
				case 1:
					{
					setState(867);
					match(COMMA);
					setState(871);
					_errHandler.sync(this);
					_la = _input.LA(1);
					while (_la==NL) {
						{
						{
						setState(868);
						match(NL);
						}
						}
						setState(873);
						_errHandler.sync(this);
						_la = _input.LA(1);
					}
					setState(874);
					splattingArgument();
					}
					break;
				}
				setState(885);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,106,_ctx) ) {
				case 1:
					{
					setState(877);
					match(COMMA);
					setState(881);
					_errHandler.sync(this);
					_la = _input.LA(1);
					while (_la==NL) {
						{
						{
						setState(878);
						match(NL);
						}
						}
						setState(883);
						_errHandler.sync(this);
						_la = _input.LA(1);
					}
					setState(884);
					blockArgument();
					}
					break;
				}
				}
				break;
			case 4:
				_localctx = new AssociationsArgumentListContext(_localctx);
				enterOuterAlt(_localctx, 4);
				{
				setState(887);
				associationList();
				setState(896);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,108,_ctx) ) {
				case 1:
					{
					setState(888);
					match(COMMA);
					setState(892);
					_errHandler.sync(this);
					_la = _input.LA(1);
					while (_la==NL) {
						{
						{
						setState(889);
						match(NL);
						}
						}
						setState(894);
						_errHandler.sync(this);
						_la = _input.LA(1);
					}
					setState(895);
					splattingArgument();
					}
					break;
				}
				setState(906);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,110,_ctx) ) {
				case 1:
					{
					setState(898);
					match(COMMA);
					setState(902);
					_errHandler.sync(this);
					_la = _input.LA(1);
					while (_la==NL) {
						{
						{
						setState(899);
						match(NL);
						}
						}
						setState(904);
						_errHandler.sync(this);
						_la = _input.LA(1);
					}
					setState(905);
					blockArgument();
					}
					break;
				}
				}
				break;
			case 5:
				_localctx = new ArrayArgumentListContext(_localctx);
				enterOuterAlt(_localctx, 5);
				{
				setState(908);
				match(LBRACK);
				setState(910);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (((((_la - 3)) & ~0x3f) == 0 && ((1L << (_la - 3)) & ((1L << (REGULAR_EXPRESSION_START - 3)) | (1L << (LBRACK - 3)) | (1L << (LPAREN - 3)) | (1L << (LCURLY - 3)) | (1L << (COLON - 3)) | (1L << (COLON2 - 3)) | (1L << (DOT2 - 3)) | (1L << (DOT3 - 3)) | (1L << (MINUSGT - 3)) | (1L << (EMARK - 3)) | (1L << (PLUS - 3)) | (1L << (MINUS - 3)) | (1L << (STAR - 3)) | (1L << (STAR2 - 3)) | (1L << (TILDE - 3)) | (1L << (SINGLE_QUOTED_STRING_LITERAL - 3)) | (1L << (DOUBLE_QUOTED_STRING_START - 3)) | (1L << (QUOTED_NON_EXPANDED_STRING_LITERAL_START - 3)) | (1L << (QUOTED_EXPANDED_STRING_LITERAL_START - 3)) | (1L << (QUOTED_EXPANDED_REGULAR_EXPRESSION_START - 3)))) != 0) || ((((_la - 67)) & ~0x3f) == 0 && ((1L << (_la - 67)) & ((1L << (QUOTED_EXPANDED_EXTERNAL_COMMAND_LITERAL_START - 67)) | (1L << (QUOTED_NON_EXPANDED_STRING_ARRAY_LITERAL_START - 67)) | (1L << (QUOTED_EXPANDED_STRING_ARRAY_LITERAL_START - 67)) | (1L << (HERE_DOC - 67)) | (1L << (QUOTED_NON_EXPANDED_SYMBOL_ARRAY_LITERAL_START - 67)) | (1L << (QUOTED_EXPANDED_SYMBOL_ARRAY_LITERAL_START - 67)) | (1L << (DECIMAL_INTEGER_LITERAL - 67)) | (1L << (BINARY_INTEGER_LITERAL - 67)) | (1L << (OCTAL_INTEGER_LITERAL - 67)) | (1L << (HEXADECIMAL_INTEGER_LITERAL - 67)) | (1L << (FLOAT_LITERAL_WITHOUT_EXPONENT - 67)) | (1L << (FLOAT_LITERAL_WITH_EXPONENT - 67)) | (1L << (SYMBOL_LITERAL - 67)) | (1L << (LOCAL_VARIABLE_IDENTIFIER - 67)) | (1L << (LINE__ - 67)) | (1L << (ENCODING__ - 67)) | (1L << (FILE__ - 67)) | (1L << (BEGIN_ - 67)) | (1L << (END_ - 67)) | (1L << (ALIAS - 67)) | (1L << (AND - 67)) | (1L << (BEGIN - 67)) | (1L << (BREAK - 67)) | (1L << (CASE - 67)) | (1L << (CLASS - 67)) | (1L << (DEF - 67)) | (1L << (IS_DEFINED - 67)) | (1L << (DO - 67)) | (1L << (ELSE - 67)) | (1L << (ELSIF - 67)) | (1L << (END - 67)) | (1L << (ENSURE - 67)) | (1L << (FOR - 67)) | (1L << (FALSE - 67)) | (1L << (IF - 67)) | (1L << (IN - 67)) | (1L << (MODULE - 67)) | (1L << (NEXT - 67)) | (1L << (NIL - 67)) | (1L << (NOT - 67)) | (1L << (OR - 67)) | (1L << (REDO - 67)) | (1L << (RESCUE - 67)) | (1L << (RETRY - 67)) | (1L << (RETURN - 67)) | (1L << (SELF - 67)) | (1L << (SUPER - 67)) | (1L << (THEN - 67)) | (1L << (TRUE - 67)) | (1L << (UNDEF - 67)) | (1L << (UNLESS - 67)) | (1L << (UNTIL - 67)) | (1L << (WHEN - 67)) | (1L << (WHILE - 67)) | (1L << (YIELD - 67)) | (1L << (GLOBAL_VARIABLE_IDENTIFIER - 67)) | (1L << (INSTANCE_VARIABLE_IDENTIFIER - 67)) | (1L << (CLASS_VARIABLE_IDENTIFIER - 67)) | (1L << (CONSTANT_IDENTIFIER - 67)))) != 0)) {
					{
					setState(909);
					indexingArgumentList();
					}
				}

				setState(912);
				match(RBRACK);
				}
				break;
			case 6:
				_localctx = new SingleCommandArgumentListContext(_localctx);
				enterOuterAlt(_localctx, 6);
				{
				setState(913);
				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, 66, RULE_commandArgumentList);
		int _la;
		try {
			setState(928);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,115,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(916);
				associationList();
				}
				break;
			case 2:
				enterOuterAlt(_localctx, 2);
				{
				setState(917);
				primaryValueList();
				setState(926);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,114,_ctx) ) {
				case 1:
					{
					setState(918);
					match(COMMA);
					setState(922);
					_errHandler.sync(this);
					_la = _input.LA(1);
					while (_la==NL) {
						{
						{
						setState(919);
						match(NL);
						}
						}
						setState(924);
						_errHandler.sync(this);
						_la = _input.LA(1);
					}
					setState(925);
					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, 68, RULE_primaryValueList);
		int _la;
		try {
			int _alt;
			enterOuterAlt(_localctx, 1);
			{
			setState(930);
			primaryValue(0);
			setState(941);
			_errHandler.sync(this);
			_alt = getInterpreter().adaptivePredict(_input,117,_ctx);
			while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) {
				if ( _alt==1 ) {
					{
					{
					setState(931);
					match(COMMA);
					setState(935);
					_errHandler.sync(this);
					_la = _input.LA(1);
					while (_la==NL) {
						{
						{
						setState(932);
						match(NL);
						}
						}
						setState(937);
						_errHandler.sync(this);
						_la = _input.LA(1);
					}
					setState(938);
					primaryValue(0);
					}
					} 
				}
				setState(943);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,117,_ctx);
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class PrimaryValueListWithAssociationContext extends ParserRuleContext {
		public List primaryValue() {
			return getRuleContexts(PrimaryValueContext.class);
		}
		public PrimaryValueContext primaryValue(int i) {
			return getRuleContext(PrimaryValueContext.class,i);
		}
		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 MethodInvocationWithoutParenthesesContext methodInvocationWithoutParentheses() {
			return getRuleContext(MethodInvocationWithoutParenthesesContext.class,0);
		}
		public PrimaryValueListWithAssociationContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_primaryValueListWithAssociation; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterPrimaryValueListWithAssociation(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitPrimaryValueListWithAssociation(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitPrimaryValueListWithAssociation(this);
			else return visitor.visitChildren(this);
		}
	}

	public final PrimaryValueListWithAssociationContext primaryValueListWithAssociation() throws RecognitionException {
		PrimaryValueListWithAssociationContext _localctx = new PrimaryValueListWithAssociationContext(_ctx, getState());
		enterRule(_localctx, 70, RULE_primaryValueListWithAssociation);
		int _la;
		try {
			int _alt;
			setState(965);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,122,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(946);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,118,_ctx) ) {
				case 1:
					{
					setState(944);
					primaryValue(0);
					}
					break;
				case 2:
					{
					setState(945);
					association();
					}
					break;
				}
				setState(961);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,121,_ctx);
				while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) {
					if ( _alt==1 ) {
						{
						{
						setState(948);
						match(COMMA);
						setState(952);
						_errHandler.sync(this);
						_la = _input.LA(1);
						while (_la==NL) {
							{
							{
							setState(949);
							match(NL);
							}
							}
							setState(954);
							_errHandler.sync(this);
							_la = _input.LA(1);
						}
						setState(957);
						_errHandler.sync(this);
						switch ( getInterpreter().adaptivePredict(_input,120,_ctx) ) {
						case 1:
							{
							setState(955);
							primaryValue(0);
							}
							break;
						case 2:
							{
							setState(956);
							association();
							}
							break;
						}
						}
						} 
					}
					setState(963);
					_errHandler.sync(this);
					_alt = getInterpreter().adaptivePredict(_input,121,_ctx);
				}
				}
				break;
			case 2:
				enterOuterAlt(_localctx, 2);
				{
				setState(964);
				methodInvocationWithoutParentheses();
				}
				break;
			}
		}
		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, 72, RULE_blockArgument);
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(967);
			match(AMP);
			setState(969);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,123,_ctx) ) {
			case 1:
				{
				setState(968);
				operatorExpression(0);
				}
				break;
			}
			}
		}
		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 = 74;
		enterRecursionRule(_localctx, 74, RULE_expressionOrCommand, _p);
		int _la;
		try {
			int _alt;
			enterOuterAlt(_localctx, 1);
			{
			setState(985);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,126,_ctx) ) {
			case 1:
				{
				_localctx = new OperatorExpressionOrCommandContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;

				setState(972);
				operatorExpression(0);
				}
				break;
			case 2:
				{
				_localctx = new CommandExpressionOrCommandContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(974);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,124,_ctx) ) {
				case 1:
					{
					setState(973);
					match(EMARK);
					}
					break;
				}
				setState(976);
				methodInvocationWithoutParentheses();
				}
				break;
			case 3:
				{
				_localctx = new NotExpressionOrCommandContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(977);
				match(NOT);
				setState(981);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==NL) {
					{
					{
					setState(978);
					match(NL);
					}
					}
					setState(983);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(984);
				expressionOrCommand(2);
				}
				break;
			}
			_ctx.stop = _input.LT(-1);
			setState(998);
			_errHandler.sync(this);
			_alt = getInterpreter().adaptivePredict(_input,128,_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(987);
					if (!(precpred(_ctx, 1))) throw new FailedPredicateException(this, "precpred(_ctx, 1)");
					setState(988);
					((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(992);
					_errHandler.sync(this);
					_la = _input.LA(1);
					while (_la==NL) {
						{
						{
						setState(989);
						match(NL);
						}
						}
						setState(994);
						_errHandler.sync(this);
						_la = _input.LA(1);
					}
					setState(995);
					((KeywordAndOrExpressionOrCommandContext)_localctx).rhs = expressionOrCommand(2);
					}
					} 
				}
				setState(1000);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,128,_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 = 76;
		enterRecursionRule(_localctx, 76, RULE_operatorExpression, _p);
		int _la;
		try {
			int _alt;
			enterOuterAlt(_localctx, 1);
			{
			{
			_localctx = new PrimaryOperatorExpressionContext(_localctx);
			_ctx = _localctx;
			_prevctx = _localctx;

			setState(1002);
			primary();
			}
			_ctx.stop = _input.LT(-1);
			setState(1030);
			_errHandler.sync(this);
			_alt = getInterpreter().adaptivePredict(_input,132,_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(1004);
					if (!(precpred(_ctx, 1))) throw new FailedPredicateException(this, "precpred(_ctx, 1)");
					setState(1005);
					match(QMARK);
					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);
					operatorExpression(0);
					setState(1016);
					_errHandler.sync(this);
					_la = _input.LA(1);
					while (_la==NL) {
						{
						{
						setState(1013);
						match(NL);
						}
						}
						setState(1018);
						_errHandler.sync(this);
						_la = _input.LA(1);
					}
					setState(1019);
					match(COLON);
					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);
					operatorExpression(2);
					}
					} 
				}
				setState(1032);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,132,_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, 78, RULE_primary);
		try {
			setState(1039);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case RETURN:
				_localctx = new ReturnWithoutArgumentsContext(_localctx);
				enterOuterAlt(_localctx, 1);
				{
				setState(1033);
				match(RETURN);
				}
				break;
			case BREAK:
				_localctx = new BreakWithoutArgumentsContext(_localctx);
				enterOuterAlt(_localctx, 2);
				{
				setState(1034);
				match(BREAK);
				}
				break;
			case NEXT:
				_localctx = new NextWithoutArgumentsContext(_localctx);
				enterOuterAlt(_localctx, 3);
				{
				setState(1035);
				match(NEXT);
				}
				break;
			case REDO:
				_localctx = new RedoWithoutArgumentsContext(_localctx);
				enterOuterAlt(_localctx, 4);
				{
				setState(1036);
				match(REDO);
				}
				break;
			case RETRY:
				_localctx = new RetryWithoutArgumentsContext(_localctx);
				enterOuterAlt(_localctx, 5);
				{
				setState(1037);
				match(RETRY);
				}
				break;
			case REGULAR_EXPRESSION_START:
			case LBRACK:
			case LPAREN:
			case LCURLY:
			case COLON:
			case COLON2:
			case DOT2:
			case DOT3:
			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 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 GLOBAL_VARIABLE_IDENTIFIER:
			case INSTANCE_VARIABLE_IDENTIFIER:
			case CLASS_VARIABLE_IDENTIFIER:
			case CONSTANT_IDENTIFIER:
				_localctx = new PrimaryValuePrimaryContext(_localctx);
				enterOuterAlt(_localctx, 6);
				{
				setState(1038);
				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 HashLiteralContext extends ParserRuleContext {
		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(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_hashLiteral; }
		@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 final HashLiteralContext hashLiteral() throws RecognitionException {
		HashLiteralContext _localctx = new HashLiteralContext(_ctx, getState());
		enterRule(_localctx, 80, RULE_hashLiteral);
		int _la;
		try {
			int _alt;
			enterOuterAlt(_localctx, 1);
			{
			setState(1041);
			match(LCURLY);
			setState(1045);
			_errHandler.sync(this);
			_alt = getInterpreter().adaptivePredict(_input,134,_ctx);
			while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) {
				if ( _alt==1 ) {
					{
					{
					setState(1042);
					match(NL);
					}
					} 
				}
				setState(1047);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,134,_ctx);
			}
			setState(1052);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (((((_la - 3)) & ~0x3f) == 0 && ((1L << (_la - 3)) & ((1L << (REGULAR_EXPRESSION_START - 3)) | (1L << (LBRACK - 3)) | (1L << (LPAREN - 3)) | (1L << (LCURLY - 3)) | (1L << (COLON - 3)) | (1L << (COLON2 - 3)) | (1L << (DOT2 - 3)) | (1L << (DOT3 - 3)) | (1L << (MINUSGT - 3)) | (1L << (EMARK - 3)) | (1L << (PLUS - 3)) | (1L << (MINUS - 3)) | (1L << (STAR2 - 3)) | (1L << (TILDE - 3)) | (1L << (SINGLE_QUOTED_STRING_LITERAL - 3)) | (1L << (DOUBLE_QUOTED_STRING_START - 3)) | (1L << (QUOTED_NON_EXPANDED_STRING_LITERAL_START - 3)) | (1L << (QUOTED_EXPANDED_STRING_LITERAL_START - 3)) | (1L << (QUOTED_EXPANDED_REGULAR_EXPRESSION_START - 3)))) != 0) || ((((_la - 67)) & ~0x3f) == 0 && ((1L << (_la - 67)) & ((1L << (QUOTED_EXPANDED_EXTERNAL_COMMAND_LITERAL_START - 67)) | (1L << (QUOTED_NON_EXPANDED_STRING_ARRAY_LITERAL_START - 67)) | (1L << (QUOTED_EXPANDED_STRING_ARRAY_LITERAL_START - 67)) | (1L << (HERE_DOC - 67)) | (1L << (QUOTED_NON_EXPANDED_SYMBOL_ARRAY_LITERAL_START - 67)) | (1L << (QUOTED_EXPANDED_SYMBOL_ARRAY_LITERAL_START - 67)) | (1L << (DECIMAL_INTEGER_LITERAL - 67)) | (1L << (BINARY_INTEGER_LITERAL - 67)) | (1L << (OCTAL_INTEGER_LITERAL - 67)) | (1L << (HEXADECIMAL_INTEGER_LITERAL - 67)) | (1L << (FLOAT_LITERAL_WITHOUT_EXPONENT - 67)) | (1L << (FLOAT_LITERAL_WITH_EXPONENT - 67)) | (1L << (SYMBOL_LITERAL - 67)) | (1L << (LOCAL_VARIABLE_IDENTIFIER - 67)) | (1L << (LINE__ - 67)) | (1L << (ENCODING__ - 67)) | (1L << (FILE__ - 67)) | (1L << (BEGIN_ - 67)) | (1L << (END_ - 67)) | (1L << (ALIAS - 67)) | (1L << (AND - 67)) | (1L << (BEGIN - 67)) | (1L << (BREAK - 67)) | (1L << (CASE - 67)) | (1L << (CLASS - 67)) | (1L << (DEF - 67)) | (1L << (IS_DEFINED - 67)) | (1L << (DO - 67)) | (1L << (ELSE - 67)) | (1L << (ELSIF - 67)) | (1L << (END - 67)) | (1L << (ENSURE - 67)) | (1L << (FOR - 67)) | (1L << (FALSE - 67)) | (1L << (IF - 67)) | (1L << (IN - 67)) | (1L << (MODULE - 67)) | (1L << (NEXT - 67)) | (1L << (NIL - 67)) | (1L << (NOT - 67)) | (1L << (OR - 67)) | (1L << (REDO - 67)) | (1L << (RESCUE - 67)) | (1L << (RETRY - 67)) | (1L << (RETURN - 67)) | (1L << (SELF - 67)) | (1L << (SUPER - 67)) | (1L << (THEN - 67)) | (1L << (TRUE - 67)) | (1L << (UNDEF - 67)) | (1L << (UNLESS - 67)) | (1L << (UNTIL - 67)) | (1L << (WHEN - 67)) | (1L << (WHILE - 67)) | (1L << (YIELD - 67)) | (1L << (GLOBAL_VARIABLE_IDENTIFIER - 67)) | (1L << (INSTANCE_VARIABLE_IDENTIFIER - 67)) | (1L << (CLASS_VARIABLE_IDENTIFIER - 67)) | (1L << (CONSTANT_IDENTIFIER - 67)))) != 0)) {
				{
				setState(1048);
				associationList();
				setState(1050);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==COMMA) {
					{
					setState(1049);
					match(COMMA);
					}
				}

				}
			}

			setState(1057);
			_errHandler.sync(this);
			_la = _input.LA(1);
			while (_la==NL) {
				{
				{
				setState(1054);
				match(NL);
				}
				}
				setState(1059);
				_errHandler.sync(this);
				_la = _input.LA(1);
			}
			setState(1060);
			match(RCURLY);
			}
		}
		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 BoundedRangeExpressionContext 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 BoundedRangeExpressionContext(PrimaryValueContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterBoundedRangeExpression(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitBoundedRangeExpression(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitBoundedRangeExpression(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 TerminalNode RETURN() { return getToken(RubyParser.RETURN, 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 BracketedArrayElementListContext bracketedArrayElementList() {
			return getRuleContext(BracketedArrayElementListContext.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 LambdaExpressionParameterListContext lambdaExpressionParameterList() {
			return getRuleContext(LambdaExpressionParameterListContext.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 BeginlessRangeExpressionContext extends PrimaryValueContext {
		public RangeOperatorContext rangeOperator() {
			return getRuleContext(RangeOperatorContext.class,0);
		}
		public PrimaryValueContext primaryValue() {
			return getRuleContext(PrimaryValueContext.class,0);
		}
		public BeginlessRangeExpressionContext(PrimaryValueContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterBeginlessRangeExpression(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitBeginlessRangeExpression(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitBeginlessRangeExpression(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 EndlessRangeExpressionContext extends PrimaryValueContext {
		public PrimaryValueContext primaryValue() {
			return getRuleContext(PrimaryValueContext.class,0);
		}
		public RangeOperatorContext rangeOperator() {
			return getRuleContext(RangeOperatorContext.class,0);
		}
		public EndlessRangeExpressionContext(PrimaryValueContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterEndlessRangeExpression(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitEndlessRangeExpression(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitEndlessRangeExpression(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 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 PrimaryValueHashLiteralContext extends PrimaryValueContext {
		public HashLiteralContext hashLiteral() {
			return getRuleContext(HashLiteralContext.class,0);
		}
		public PrimaryValueHashLiteralContext(PrimaryValueContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterPrimaryValueHashLiteral(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitPrimaryValueHashLiteral(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitPrimaryValueHashLiteral(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 TerminalNode RETURN() { return getToken(RubyParser.RETURN, 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 = 82;
		enterRecursionRule(_localctx, 82, RULE_primaryValue, _p);
		int _la;
		try {
			int _alt;
			enterOuterAlt(_localctx, 1);
			{
			setState(1377);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,178,_ctx) ) {
			case 1:
				{
				_localctx = new LocalVariableAssignmentExpressionContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;

				setState(1063);
				((LocalVariableAssignmentExpressionContext)_localctx).lhs = variable();
				setState(1064);
				assignmentOperator();
				setState(1068);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==NL) {
					{
					{
					setState(1065);
					match(NL);
					}
					}
					setState(1070);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(1071);
				((LocalVariableAssignmentExpressionContext)_localctx).rhs = operatorExpression(0);
				}
				break;
			case 2:
				{
				_localctx = new ConstantAssignmentExpressionContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(1073);
				match(COLON2);
				setState(1074);
				match(CONSTANT_IDENTIFIER);
				setState(1075);
				assignmentOperator();
				setState(1079);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==NL) {
					{
					{
					setState(1076);
					match(NL);
					}
					}
					setState(1081);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(1082);
				operatorExpression(0);
				}
				break;
			case 3:
				{
				_localctx = new ClassDefinitionContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(1084);
				match(CLASS);
				setState(1085);
				classPath(0);
				setState(1088);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==LT) {
					{
					setState(1086);
					match(LT);
					setState(1087);
					commandOrPrimaryValueClass();
					}
				}

				setState(1091);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,141,_ctx) ) {
				case 1:
					{
					setState(1090);
					_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(1093);
				bodyStatement();
				setState(1094);
				match(END);
				}
				break;
			case 4:
				{
				_localctx = new SingletonClassDefinitionContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(1096);
				match(CLASS);
				setState(1097);
				match(LT2);
				setState(1098);
				commandOrPrimaryValueClass();
				setState(1099);
				_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(1100);
				bodyStatement();
				setState(1101);
				match(END);
				}
				break;
			case 5:
				{
				_localctx = new ModuleDefinitionContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(1103);
				match(MODULE);
				setState(1104);
				classPath(0);
				setState(1105);
				bodyStatement();
				setState(1106);
				match(END);
				}
				break;
			case 6:
				{
				_localctx = new MethodDefinitionContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(1108);
				match(DEF);
				setState(1109);
				definedMethodName();
				setState(1110);
				methodParameterPart();
				setState(1111);
				bodyStatement();
				setState(1112);
				match(END);
				}
				break;
			case 7:
				{
				_localctx = new SingletonMethodDefinitionContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(1114);
				match(DEF);
				setState(1115);
				singletonObject();
				setState(1116);
				((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(1117);
				definedMethodName();
				setState(1118);
				methodParameterPart();
				setState(1119);
				bodyStatement();
				setState(1120);
				match(END);
				}
				break;
			case 8:
				{
				_localctx = new EndlessMethodDefinitionContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(1122);
				match(DEF);
				setState(1123);
				definedMethodName();
				setState(1129);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==LPAREN) {
					{
					setState(1124);
					match(LPAREN);
					setState(1126);
					_errHandler.sync(this);
					_la = _input.LA(1);
					if (((((_la - 35)) & ~0x3f) == 0 && ((1L << (_la - 35)) & ((1L << (AMP - 35)) | (1L << (STAR - 35)) | (1L << (STAR2 - 35)) | (1L << (LOCAL_VARIABLE_IDENTIFIER - 35)))) != 0)) {
						{
						setState(1125);
						parameterList();
						}
					}

					setState(1128);
					match(RPAREN);
					}
				}

				setState(1131);
				match(EQ);
				setState(1135);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==NL) {
					{
					{
					setState(1132);
					match(NL);
					}
					}
					setState(1137);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(1138);
				statement(0);
				}
				break;
			case 9:
				{
				_localctx = new LambdaExpressionContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(1140);
				match(MINUSGT);
				setState(1142);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if ((((_la) & ~0x3f) == 0 && ((1L << _la) & ((1L << LPAREN) | (1L << AMP) | (1L << STAR) | (1L << STAR2))) != 0) || _la==LOCAL_VARIABLE_IDENTIFIER) {
					{
					setState(1141);
					lambdaExpressionParameterList();
					}
				}

				setState(1144);
				block();
				}
				break;
			case 10:
				{
				_localctx = new IfExpressionContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(1145);
				match(IF);
				setState(1149);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==NL) {
					{
					{
					setState(1146);
					match(NL);
					}
					}
					setState(1151);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(1152);
				expressionOrCommand(0);
				setState(1153);
				thenClause();
				setState(1157);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==ELSIF) {
					{
					{
					setState(1154);
					elsifClause();
					}
					}
					setState(1159);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(1161);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==ELSE) {
					{
					setState(1160);
					elseClause();
					}
				}

				setState(1163);
				match(END);
				}
				break;
			case 11:
				{
				_localctx = new UnlessExpressionContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(1165);
				match(UNLESS);
				setState(1169);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==NL) {
					{
					{
					setState(1166);
					match(NL);
					}
					}
					setState(1171);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(1172);
				expressionOrCommand(0);
				setState(1173);
				thenClause();
				setState(1175);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==ELSE) {
					{
					setState(1174);
					elseClause();
					}
				}

				setState(1177);
				match(END);
				}
				break;
			case 12:
				{
				_localctx = new UntilExpressionContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(1179);
				match(UNTIL);
				setState(1183);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==NL) {
					{
					{
					setState(1180);
					match(NL);
					}
					}
					setState(1185);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(1186);
				expressionOrCommand(0);
				setState(1187);
				doClause();
				setState(1188);
				match(END);
				}
				break;
			case 13:
				{
				_localctx = new YieldExpressionContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(1190);
				match(YIELD);
				setState(1192);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,152,_ctx) ) {
				case 1:
					{
					setState(1191);
					argumentWithParentheses();
					}
					break;
				}
				}
				break;
			case 14:
				{
				_localctx = new BeginEndExpressionContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(1194);
				match(BEGIN);
				setState(1195);
				bodyStatement();
				setState(1196);
				match(END);
				}
				break;
			case 15:
				{
				_localctx = new CaseWithExpressionContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(1198);
				match(CASE);
				setState(1202);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==NL) {
					{
					{
					setState(1199);
					match(NL);
					}
					}
					setState(1204);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(1205);
				expressionOrCommand(0);
				setState(1209);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==SEMI || _la==NL) {
					{
					{
					setState(1206);
					_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(1211);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(1213); 
				_errHandler.sync(this);
				_la = _input.LA(1);
				do {
					{
					{
					setState(1212);
					whenClause();
					}
					}
					setState(1215); 
					_errHandler.sync(this);
					_la = _input.LA(1);
				} while ( _la==WHEN );
				setState(1218);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==ELSE) {
					{
					setState(1217);
					elseClause();
					}
				}

				setState(1220);
				match(END);
				}
				break;
			case 16:
				{
				_localctx = new CaseWithoutExpressionContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(1222);
				match(CASE);
				setState(1226);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==SEMI || _la==NL) {
					{
					{
					setState(1223);
					_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(1228);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(1230); 
				_errHandler.sync(this);
				_la = _input.LA(1);
				do {
					{
					{
					setState(1229);
					whenClause();
					}
					}
					setState(1232); 
					_errHandler.sync(this);
					_la = _input.LA(1);
				} while ( _la==WHEN );
				setState(1235);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==ELSE) {
					{
					setState(1234);
					elseClause();
					}
				}

				setState(1237);
				match(END);
				}
				break;
			case 17:
				{
				_localctx = new WhileExpressionContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(1239);
				match(WHILE);
				setState(1243);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==NL) {
					{
					{
					setState(1240);
					match(NL);
					}
					}
					setState(1245);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(1246);
				expressionOrCommand(0);
				setState(1247);
				doClause();
				setState(1248);
				match(END);
				}
				break;
			case 18:
				{
				_localctx = new ForExpressionContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(1250);
				match(FOR);
				setState(1254);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==NL) {
					{
					{
					setState(1251);
					match(NL);
					}
					}
					setState(1256);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(1257);
				forVariable();
				setState(1258);
				match(IN);
				setState(1262);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==NL) {
					{
					{
					setState(1259);
					match(NL);
					}
					}
					setState(1264);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(1265);
				commandOrPrimaryValue(0);
				setState(1266);
				doClause();
				setState(1267);
				match(END);
				}
				break;
			case 19:
				{
				_localctx = new MethodCallWithParenthesesContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(1269);
				methodCallsWithParentheses();
				}
				break;
			case 20:
				{
				_localctx = new BracketedArrayLiteralContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(1270);
				match(LBRACK);
				setState(1274);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,163,_ctx);
				while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) {
					if ( _alt==1 ) {
						{
						{
						setState(1271);
						match(NL);
						}
						} 
					}
					setState(1276);
					_errHandler.sync(this);
					_alt = getInterpreter().adaptivePredict(_input,163,_ctx);
				}
				setState(1278);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (((((_la - 3)) & ~0x3f) == 0 && ((1L << (_la - 3)) & ((1L << (REGULAR_EXPRESSION_START - 3)) | (1L << (LBRACK - 3)) | (1L << (LPAREN - 3)) | (1L << (LCURLY - 3)) | (1L << (COLON - 3)) | (1L << (COLON2 - 3)) | (1L << (DOT2 - 3)) | (1L << (DOT3 - 3)) | (1L << (MINUSGT - 3)) | (1L << (EMARK - 3)) | (1L << (PLUS - 3)) | (1L << (MINUS - 3)) | (1L << (STAR - 3)) | (1L << (STAR2 - 3)) | (1L << (TILDE - 3)) | (1L << (SINGLE_QUOTED_STRING_LITERAL - 3)) | (1L << (DOUBLE_QUOTED_STRING_START - 3)) | (1L << (QUOTED_NON_EXPANDED_STRING_LITERAL_START - 3)) | (1L << (QUOTED_EXPANDED_STRING_LITERAL_START - 3)) | (1L << (QUOTED_EXPANDED_REGULAR_EXPRESSION_START - 3)))) != 0) || ((((_la - 67)) & ~0x3f) == 0 && ((1L << (_la - 67)) & ((1L << (QUOTED_EXPANDED_EXTERNAL_COMMAND_LITERAL_START - 67)) | (1L << (QUOTED_NON_EXPANDED_STRING_ARRAY_LITERAL_START - 67)) | (1L << (QUOTED_EXPANDED_STRING_ARRAY_LITERAL_START - 67)) | (1L << (HERE_DOC - 67)) | (1L << (QUOTED_NON_EXPANDED_SYMBOL_ARRAY_LITERAL_START - 67)) | (1L << (QUOTED_EXPANDED_SYMBOL_ARRAY_LITERAL_START - 67)) | (1L << (DECIMAL_INTEGER_LITERAL - 67)) | (1L << (BINARY_INTEGER_LITERAL - 67)) | (1L << (OCTAL_INTEGER_LITERAL - 67)) | (1L << (HEXADECIMAL_INTEGER_LITERAL - 67)) | (1L << (FLOAT_LITERAL_WITHOUT_EXPONENT - 67)) | (1L << (FLOAT_LITERAL_WITH_EXPONENT - 67)) | (1L << (SYMBOL_LITERAL - 67)) | (1L << (LOCAL_VARIABLE_IDENTIFIER - 67)) | (1L << (LINE__ - 67)) | (1L << (ENCODING__ - 67)) | (1L << (FILE__ - 67)) | (1L << (BEGIN_ - 67)) | (1L << (END_ - 67)) | (1L << (ALIAS - 67)) | (1L << (AND - 67)) | (1L << (BEGIN - 67)) | (1L << (BREAK - 67)) | (1L << (CASE - 67)) | (1L << (CLASS - 67)) | (1L << (DEF - 67)) | (1L << (IS_DEFINED - 67)) | (1L << (DO - 67)) | (1L << (ELSE - 67)) | (1L << (ELSIF - 67)) | (1L << (END - 67)) | (1L << (ENSURE - 67)) | (1L << (FOR - 67)) | (1L << (FALSE - 67)) | (1L << (IF - 67)) | (1L << (IN - 67)) | (1L << (MODULE - 67)) | (1L << (NEXT - 67)) | (1L << (NIL - 67)) | (1L << (NOT - 67)) | (1L << (OR - 67)) | (1L << (REDO - 67)) | (1L << (RESCUE - 67)) | (1L << (RETRY - 67)) | (1L << (RETURN - 67)) | (1L << (SELF - 67)) | (1L << (SUPER - 67)) | (1L << (THEN - 67)) | (1L << (TRUE - 67)) | (1L << (UNDEF - 67)) | (1L << (UNLESS - 67)) | (1L << (UNTIL - 67)) | (1L << (WHEN - 67)) | (1L << (WHILE - 67)) | (1L << (YIELD - 67)) | (1L << (GLOBAL_VARIABLE_IDENTIFIER - 67)) | (1L << (INSTANCE_VARIABLE_IDENTIFIER - 67)) | (1L << (CLASS_VARIABLE_IDENTIFIER - 67)) | (1L << (CONSTANT_IDENTIFIER - 67)))) != 0)) {
					{
					setState(1277);
					bracketedArrayElementList();
					}
				}

				setState(1283);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==NL) {
					{
					{
					setState(1280);
					match(NL);
					}
					}
					setState(1285);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(1286);
				match(RBRACK);
				}
				break;
			case 21:
				{
				_localctx = new QuotedNonExpandedStringArrayLiteralContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(1287);
				match(QUOTED_NON_EXPANDED_STRING_ARRAY_LITERAL_START);
				setState(1289);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==NON_EXPANDED_ARRAY_ITEM_SEPARATOR || _la==NON_EXPANDED_ARRAY_ITEM_CHARACTER) {
					{
					setState(1288);
					quotedNonExpandedArrayElementList();
					}
				}

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

				setState(1296);
				match(QUOTED_NON_EXPANDED_SYMBOL_ARRAY_LITERAL_END);
				}
				break;
			case 23:
				{
				_localctx = new QuotedExpandedStringArrayLiteralContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(1297);
				match(QUOTED_EXPANDED_STRING_ARRAY_LITERAL_START);
				setState(1299);
				_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(1298);
					quotedExpandedArrayElementList();
					}
				}

				setState(1301);
				match(QUOTED_EXPANDED_STRING_ARRAY_LITERAL_END);
				}
				break;
			case 24:
				{
				_localctx = new QuotedExpandedSymbolArrayLiteralContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(1302);
				match(QUOTED_EXPANDED_SYMBOL_ARRAY_LITERAL_START);
				setState(1304);
				_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(1303);
					quotedExpandedArrayElementList();
					}
				}

				setState(1306);
				match(QUOTED_EXPANDED_SYMBOL_ARRAY_LITERAL_END);
				}
				break;
			case 25:
				{
				_localctx = new PrimaryValueHashLiteralContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(1307);
				hashLiteral();
				}
				break;
			case 26:
				{
				_localctx = new NumericLiteralContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(1309);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==PLUS || _la==MINUS) {
					{
					setState(1308);
					((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(1311);
				unsignedNumericLiteral();
				}
				break;
			case 27:
				{
				_localctx = new SingleQuotedStringExpressionContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(1312);
				singleQuotedString();
				setState(1316);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,171,_ctx);
				while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) {
					if ( _alt==1 ) {
						{
						{
						setState(1313);
						singleOrDoubleQuotedString();
						}
						} 
					}
					setState(1318);
					_errHandler.sync(this);
					_alt = getInterpreter().adaptivePredict(_input,171,_ctx);
				}
				}
				break;
			case 28:
				{
				_localctx = new DoubleQuotedStringExpressionContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(1319);
				doubleQuotedString();
				setState(1323);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,172,_ctx);
				while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) {
					if ( _alt==1 ) {
						{
						{
						setState(1320);
						singleOrDoubleQuotedString();
						}
						} 
					}
					setState(1325);
					_errHandler.sync(this);
					_alt = getInterpreter().adaptivePredict(_input,172,_ctx);
				}
				}
				break;
			case 29:
				{
				_localctx = new QuotedNonExpandedStringLiteralContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(1326);
				match(QUOTED_NON_EXPANDED_STRING_LITERAL_START);
				setState(1328);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==NON_EXPANDED_LITERAL_CHARACTER_SEQUENCE) {
					{
					setState(1327);
					match(NON_EXPANDED_LITERAL_CHARACTER_SEQUENCE);
					}
				}

				setState(1330);
				match(QUOTED_NON_EXPANDED_STRING_LITERAL_END);
				}
				break;
			case 30:
				{
				_localctx = new QuotedExpandedStringLiteralContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(1331);
				match(QUOTED_EXPANDED_STRING_LITERAL_START);
				setState(1335);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==EXPANDED_LITERAL_CHARACTER_SEQUENCE || _la==DELIMITED_STRING_INTERPOLATION_BEGIN) {
					{
					{
					setState(1332);
					quotedExpandedLiteralStringContent();
					}
					}
					setState(1337);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(1338);
				match(QUOTED_EXPANDED_STRING_LITERAL_END);
				}
				break;
			case 31:
				{
				_localctx = new QuotedExpandedExternalCommandLiteralContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(1339);
				match(QUOTED_EXPANDED_EXTERNAL_COMMAND_LITERAL_START);
				setState(1343);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==EXPANDED_LITERAL_CHARACTER_SEQUENCE || _la==DELIMITED_STRING_INTERPOLATION_BEGIN) {
					{
					{
					setState(1340);
					quotedExpandedLiteralStringContent();
					}
					}
					setState(1345);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(1346);
				match(QUOTED_EXPANDED_EXTERNAL_COMMAND_LITERAL_END);
				}
				break;
			case 32:
				{
				_localctx = new SymbolExpressionContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(1347);
				symbol();
				}
				break;
			case 33:
				{
				_localctx = new RegularExpressionLiteralContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(1348);
				match(REGULAR_EXPRESSION_START);
				setState(1352);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==REGULAR_EXPRESSION_BODY || _la==REGULAR_EXPRESSION_INTERPOLATION_BEGIN) {
					{
					{
					setState(1349);
					regexpLiteralContent();
					}
					}
					setState(1354);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(1355);
				match(REGULAR_EXPRESSION_END);
				}
				break;
			case 34:
				{
				_localctx = new QuotedExpandedRegularExpressionLiteralContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(1356);
				match(QUOTED_EXPANDED_REGULAR_EXPRESSION_START);
				setState(1360);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==EXPANDED_LITERAL_CHARACTER_SEQUENCE || _la==DELIMITED_STRING_INTERPOLATION_BEGIN) {
					{
					{
					setState(1357);
					quotedExpandedLiteralStringContent();
					}
					}
					setState(1362);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(1363);
				match(QUOTED_EXPANDED_REGULAR_EXPRESSION_END);
				}
				break;
			case 35:
				{
				_localctx = new GroupingStatementContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(1364);
				match(LPAREN);
				setState(1365);
				compoundStatement();
				setState(1366);
				match(RPAREN);
				}
				break;
			case 36:
				{
				_localctx = new UnaryExpressionContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(1368);
				unaryOperator();
				setState(1369);
				primaryValue(16);
				}
				break;
			case 37:
				{
				_localctx = new UnaryMinusExpressionContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(1371);
				match(MINUS);
				setState(1372);
				primaryValue(14);
				}
				break;
			case 38:
				{
				_localctx = new BeginlessRangeExpressionContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(1373);
				rangeOperator();
				setState(1374);
				primaryValue(2);
				}
				break;
			case 39:
				{
				_localctx = new HereDocsContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(1376);
				hereDoc();
				}
				break;
			}
			_ctx.stop = _input.LT(-1);
			setState(1561);
			_errHandler.sync(this);
			_alt = getInterpreter().adaptivePredict(_input,202,_ctx);
			while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) {
				if ( _alt==1 ) {
					if ( _parseListeners!=null ) triggerExitRuleEvent();
					_prevctx = _localctx;
					{
					setState(1559);
					_errHandler.sync(this);
					switch ( getInterpreter().adaptivePredict(_input,201,_ctx) ) {
					case 1:
						{
						_localctx = new PowerExpressionContext(new PrimaryValueContext(_parentctx, _parentState));
						pushNewRecursionContext(_localctx, _startState, RULE_primaryValue);
						setState(1379);
						if (!(precpred(_ctx, 15))) throw new FailedPredicateException(this, "precpred(_ctx, 15)");
						setState(1380);
						((PowerExpressionContext)_localctx).powerOperator = match(STAR2);
						setState(1384);
						_errHandler.sync(this);
						_la = _input.LA(1);
						while (_la==NL) {
							{
							{
							setState(1381);
							match(NL);
							}
							}
							setState(1386);
							_errHandler.sync(this);
							_la = _input.LA(1);
						}
						setState(1387);
						primaryValue(15);
						}
						break;
					case 2:
						{
						_localctx = new MultiplicativeExpressionContext(new PrimaryValueContext(_parentctx, _parentState));
						pushNewRecursionContext(_localctx, _startState, RULE_primaryValue);
						setState(1388);
						if (!(precpred(_ctx, 13))) throw new FailedPredicateException(this, "precpred(_ctx, 13)");
						setState(1389);
						multiplicativeOperator();
						setState(1393);
						_errHandler.sync(this);
						_la = _input.LA(1);
						while (_la==NL) {
							{
							{
							setState(1390);
							match(NL);
							}
							}
							setState(1395);
							_errHandler.sync(this);
							_la = _input.LA(1);
						}
						setState(1396);
						primaryValue(14);
						}
						break;
					case 3:
						{
						_localctx = new AdditiveExpressionContext(new PrimaryValueContext(_parentctx, _parentState));
						pushNewRecursionContext(_localctx, _startState, RULE_primaryValue);
						setState(1398);
						if (!(precpred(_ctx, 12))) throw new FailedPredicateException(this, "precpred(_ctx, 12)");
						setState(1399);
						additiveOperator();
						setState(1403);
						_errHandler.sync(this);
						_la = _input.LA(1);
						while (_la==NL) {
							{
							{
							setState(1400);
							match(NL);
							}
							}
							setState(1405);
							_errHandler.sync(this);
							_la = _input.LA(1);
						}
						setState(1406);
						primaryValue(13);
						}
						break;
					case 4:
						{
						_localctx = new ShiftExpressionContext(new PrimaryValueContext(_parentctx, _parentState));
						pushNewRecursionContext(_localctx, _startState, RULE_primaryValue);
						setState(1408);
						if (!(precpred(_ctx, 11))) throw new FailedPredicateException(this, "precpred(_ctx, 11)");
						setState(1409);
						bitwiseShiftOperator();
						setState(1413);
						_errHandler.sync(this);
						_la = _input.LA(1);
						while (_la==NL) {
							{
							{
							setState(1410);
							match(NL);
							}
							}
							setState(1415);
							_errHandler.sync(this);
							_la = _input.LA(1);
						}
						setState(1416);
						primaryValue(12);
						}
						break;
					case 5:
						{
						_localctx = new BitwiseAndExpressionContext(new PrimaryValueContext(_parentctx, _parentState));
						pushNewRecursionContext(_localctx, _startState, RULE_primaryValue);
						setState(1418);
						if (!(precpred(_ctx, 10))) throw new FailedPredicateException(this, "precpred(_ctx, 10)");
						setState(1419);
						((BitwiseAndExpressionContext)_localctx).bitwiseAndOperator = match(AMP);
						setState(1423);
						_errHandler.sync(this);
						_la = _input.LA(1);
						while (_la==NL) {
							{
							{
							setState(1420);
							match(NL);
							}
							}
							setState(1425);
							_errHandler.sync(this);
							_la = _input.LA(1);
						}
						setState(1426);
						primaryValue(11);
						}
						break;
					case 6:
						{
						_localctx = new BitwiseOrExpressionContext(new PrimaryValueContext(_parentctx, _parentState));
						pushNewRecursionContext(_localctx, _startState, RULE_primaryValue);
						setState(1427);
						if (!(precpred(_ctx, 9))) throw new FailedPredicateException(this, "precpred(_ctx, 9)");
						setState(1428);
						bitwiseOrOperator();
						setState(1432);
						_errHandler.sync(this);
						_la = _input.LA(1);
						while (_la==NL) {
							{
							{
							setState(1429);
							match(NL);
							}
							}
							setState(1434);
							_errHandler.sync(this);
							_la = _input.LA(1);
						}
						setState(1435);
						primaryValue(10);
						}
						break;
					case 7:
						{
						_localctx = new RelationalExpressionContext(new PrimaryValueContext(_parentctx, _parentState));
						pushNewRecursionContext(_localctx, _startState, RULE_primaryValue);
						setState(1437);
						if (!(precpred(_ctx, 8))) throw new FailedPredicateException(this, "precpred(_ctx, 8)");
						setState(1438);
						relationalOperator();
						setState(1442);
						_errHandler.sync(this);
						_la = _input.LA(1);
						while (_la==NL) {
							{
							{
							setState(1439);
							match(NL);
							}
							}
							setState(1444);
							_errHandler.sync(this);
							_la = _input.LA(1);
						}
						setState(1445);
						primaryValue(9);
						}
						break;
					case 8:
						{
						_localctx = new EqualityExpressionContext(new PrimaryValueContext(_parentctx, _parentState));
						pushNewRecursionContext(_localctx, _startState, RULE_primaryValue);
						setState(1447);
						if (!(precpred(_ctx, 7))) throw new FailedPredicateException(this, "precpred(_ctx, 7)");
						setState(1448);
						equalityOperator();
						setState(1452);
						_errHandler.sync(this);
						_la = _input.LA(1);
						while (_la==NL) {
							{
							{
							setState(1449);
							match(NL);
							}
							}
							setState(1454);
							_errHandler.sync(this);
							_la = _input.LA(1);
						}
						setState(1455);
						primaryValue(8);
						}
						break;
					case 9:
						{
						_localctx = new BoundedRangeExpressionContext(new PrimaryValueContext(_parentctx, _parentState));
						pushNewRecursionContext(_localctx, _startState, RULE_primaryValue);
						setState(1457);
						if (!(precpred(_ctx, 4))) throw new FailedPredicateException(this, "precpred(_ctx, 4)");
						setState(1458);
						rangeOperator();
						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);
						primaryValue(5);
						}
						break;
					case 10:
						{
						_localctx = new AttributeAssignmentExpressionContext(new PrimaryValueContext(_parentctx, _parentState));
						pushNewRecursionContext(_localctx, _startState, RULE_primaryValue);
						setState(1467);
						if (!(precpred(_ctx, 55))) throw new FailedPredicateException(this, "precpred(_ctx, 55)");
						setState(1468);
						((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(1469);
						methodName();
						setState(1470);
						assignmentOperator();
						setState(1474);
						_errHandler.sync(this);
						_la = _input.LA(1);
						while (_la==NL) {
							{
							{
							setState(1471);
							match(NL);
							}
							}
							setState(1476);
							_errHandler.sync(this);
							_la = _input.LA(1);
						}
						setState(1477);
						operatorExpression(0);
						}
						break;
					case 11:
						{
						_localctx = new BracketAssignmentExpressionContext(new PrimaryValueContext(_parentctx, _parentState));
						pushNewRecursionContext(_localctx, _startState, RULE_primaryValue);
						setState(1479);
						if (!(precpred(_ctx, 53))) throw new FailedPredicateException(this, "precpred(_ctx, 53)");
						setState(1480);
						match(LBRACK);
						setState(1482);
						_errHandler.sync(this);
						_la = _input.LA(1);
						if (((((_la - 3)) & ~0x3f) == 0 && ((1L << (_la - 3)) & ((1L << (REGULAR_EXPRESSION_START - 3)) | (1L << (LBRACK - 3)) | (1L << (LPAREN - 3)) | (1L << (LCURLY - 3)) | (1L << (COLON - 3)) | (1L << (COLON2 - 3)) | (1L << (DOT2 - 3)) | (1L << (DOT3 - 3)) | (1L << (MINUSGT - 3)) | (1L << (EMARK - 3)) | (1L << (PLUS - 3)) | (1L << (MINUS - 3)) | (1L << (STAR - 3)) | (1L << (STAR2 - 3)) | (1L << (TILDE - 3)) | (1L << (SINGLE_QUOTED_STRING_LITERAL - 3)) | (1L << (DOUBLE_QUOTED_STRING_START - 3)) | (1L << (QUOTED_NON_EXPANDED_STRING_LITERAL_START - 3)) | (1L << (QUOTED_EXPANDED_STRING_LITERAL_START - 3)) | (1L << (QUOTED_EXPANDED_REGULAR_EXPRESSION_START - 3)))) != 0) || ((((_la - 67)) & ~0x3f) == 0 && ((1L << (_la - 67)) & ((1L << (QUOTED_EXPANDED_EXTERNAL_COMMAND_LITERAL_START - 67)) | (1L << (QUOTED_NON_EXPANDED_STRING_ARRAY_LITERAL_START - 67)) | (1L << (QUOTED_EXPANDED_STRING_ARRAY_LITERAL_START - 67)) | (1L << (HERE_DOC - 67)) | (1L << (QUOTED_NON_EXPANDED_SYMBOL_ARRAY_LITERAL_START - 67)) | (1L << (QUOTED_EXPANDED_SYMBOL_ARRAY_LITERAL_START - 67)) | (1L << (DECIMAL_INTEGER_LITERAL - 67)) | (1L << (BINARY_INTEGER_LITERAL - 67)) | (1L << (OCTAL_INTEGER_LITERAL - 67)) | (1L << (HEXADECIMAL_INTEGER_LITERAL - 67)) | (1L << (FLOAT_LITERAL_WITHOUT_EXPONENT - 67)) | (1L << (FLOAT_LITERAL_WITH_EXPONENT - 67)) | (1L << (SYMBOL_LITERAL - 67)) | (1L << (LOCAL_VARIABLE_IDENTIFIER - 67)) | (1L << (LINE__ - 67)) | (1L << (ENCODING__ - 67)) | (1L << (FILE__ - 67)) | (1L << (BEGIN_ - 67)) | (1L << (END_ - 67)) | (1L << (ALIAS - 67)) | (1L << (AND - 67)) | (1L << (BEGIN - 67)) | (1L << (BREAK - 67)) | (1L << (CASE - 67)) | (1L << (CLASS - 67)) | (1L << (DEF - 67)) | (1L << (IS_DEFINED - 67)) | (1L << (DO - 67)) | (1L << (ELSE - 67)) | (1L << (ELSIF - 67)) | (1L << (END - 67)) | (1L << (ENSURE - 67)) | (1L << (FOR - 67)) | (1L << (FALSE - 67)) | (1L << (IF - 67)) | (1L << (IN - 67)) | (1L << (MODULE - 67)) | (1L << (NEXT - 67)) | (1L << (NIL - 67)) | (1L << (NOT - 67)) | (1L << (OR - 67)) | (1L << (REDO - 67)) | (1L << (RESCUE - 67)) | (1L << (RETRY - 67)) | (1L << (RETURN - 67)) | (1L << (SELF - 67)) | (1L << (SUPER - 67)) | (1L << (THEN - 67)) | (1L << (TRUE - 67)) | (1L << (UNDEF - 67)) | (1L << (UNLESS - 67)) | (1L << (UNTIL - 67)) | (1L << (WHEN - 67)) | (1L << (WHILE - 67)) | (1L << (YIELD - 67)) | (1L << (GLOBAL_VARIABLE_IDENTIFIER - 67)) | (1L << (INSTANCE_VARIABLE_IDENTIFIER - 67)) | (1L << (CLASS_VARIABLE_IDENTIFIER - 67)) | (1L << (CONSTANT_IDENTIFIER - 67)))) != 0)) {
							{
							setState(1481);
							indexingArgumentList();
							}
						}

						setState(1484);
						match(RBRACK);
						setState(1485);
						assignmentOperator();
						setState(1489);
						_errHandler.sync(this);
						_la = _input.LA(1);
						while (_la==NL) {
							{
							{
							setState(1486);
							match(NL);
							}
							}
							setState(1491);
							_errHandler.sync(this);
							_la = _input.LA(1);
						}
						setState(1492);
						operatorExpression(0);
						}
						break;
					case 12:
						{
						_localctx = new AssignmentWithRescueContext(new PrimaryValueContext(_parentctx, _parentState));
						pushNewRecursionContext(_localctx, _startState, RULE_primaryValue);
						setState(1494);
						if (!(precpred(_ctx, 52))) throw new FailedPredicateException(this, "precpred(_ctx, 52)");
						setState(1495);
						assignmentOperator();
						setState(1499);
						_errHandler.sync(this);
						_la = _input.LA(1);
						while (_la==NL) {
							{
							{
							setState(1496);
							match(NL);
							}
							}
							setState(1501);
							_errHandler.sync(this);
							_la = _input.LA(1);
						}
						setState(1502);
						operatorExpression(0);
						setState(1503);
						match(RESCUE);
						setState(1504);
						operatorExpression(0);
						}
						break;
					case 13:
						{
						_localctx = new IndexingAccessExpressionContext(new PrimaryValueContext(_parentctx, _parentState));
						pushNewRecursionContext(_localctx, _startState, RULE_primaryValue);
						setState(1506);
						if (!(precpred(_ctx, 18))) throw new FailedPredicateException(this, "precpred(_ctx, 18)");
						setState(1507);
						match(LBRACK);
						setState(1509);
						_errHandler.sync(this);
						_la = _input.LA(1);
						if (((((_la - 3)) & ~0x3f) == 0 && ((1L << (_la - 3)) & ((1L << (REGULAR_EXPRESSION_START - 3)) | (1L << (LBRACK - 3)) | (1L << (LPAREN - 3)) | (1L << (LCURLY - 3)) | (1L << (COLON - 3)) | (1L << (COLON2 - 3)) | (1L << (DOT2 - 3)) | (1L << (DOT3 - 3)) | (1L << (MINUSGT - 3)) | (1L << (EMARK - 3)) | (1L << (PLUS - 3)) | (1L << (MINUS - 3)) | (1L << (STAR - 3)) | (1L << (STAR2 - 3)) | (1L << (TILDE - 3)) | (1L << (SINGLE_QUOTED_STRING_LITERAL - 3)) | (1L << (DOUBLE_QUOTED_STRING_START - 3)) | (1L << (QUOTED_NON_EXPANDED_STRING_LITERAL_START - 3)) | (1L << (QUOTED_EXPANDED_STRING_LITERAL_START - 3)) | (1L << (QUOTED_EXPANDED_REGULAR_EXPRESSION_START - 3)))) != 0) || ((((_la - 67)) & ~0x3f) == 0 && ((1L << (_la - 67)) & ((1L << (QUOTED_EXPANDED_EXTERNAL_COMMAND_LITERAL_START - 67)) | (1L << (QUOTED_NON_EXPANDED_STRING_ARRAY_LITERAL_START - 67)) | (1L << (QUOTED_EXPANDED_STRING_ARRAY_LITERAL_START - 67)) | (1L << (HERE_DOC - 67)) | (1L << (QUOTED_NON_EXPANDED_SYMBOL_ARRAY_LITERAL_START - 67)) | (1L << (QUOTED_EXPANDED_SYMBOL_ARRAY_LITERAL_START - 67)) | (1L << (DECIMAL_INTEGER_LITERAL - 67)) | (1L << (BINARY_INTEGER_LITERAL - 67)) | (1L << (OCTAL_INTEGER_LITERAL - 67)) | (1L << (HEXADECIMAL_INTEGER_LITERAL - 67)) | (1L << (FLOAT_LITERAL_WITHOUT_EXPONENT - 67)) | (1L << (FLOAT_LITERAL_WITH_EXPONENT - 67)) | (1L << (SYMBOL_LITERAL - 67)) | (1L << (LOCAL_VARIABLE_IDENTIFIER - 67)) | (1L << (LINE__ - 67)) | (1L << (ENCODING__ - 67)) | (1L << (FILE__ - 67)) | (1L << (BEGIN_ - 67)) | (1L << (END_ - 67)) | (1L << (ALIAS - 67)) | (1L << (AND - 67)) | (1L << (BEGIN - 67)) | (1L << (BREAK - 67)) | (1L << (CASE - 67)) | (1L << (CLASS - 67)) | (1L << (DEF - 67)) | (1L << (IS_DEFINED - 67)) | (1L << (DO - 67)) | (1L << (ELSE - 67)) | (1L << (ELSIF - 67)) | (1L << (END - 67)) | (1L << (ENSURE - 67)) | (1L << (FOR - 67)) | (1L << (FALSE - 67)) | (1L << (IF - 67)) | (1L << (IN - 67)) | (1L << (MODULE - 67)) | (1L << (NEXT - 67)) | (1L << (NIL - 67)) | (1L << (NOT - 67)) | (1L << (OR - 67)) | (1L << (REDO - 67)) | (1L << (RESCUE - 67)) | (1L << (RETRY - 67)) | (1L << (RETURN - 67)) | (1L << (SELF - 67)) | (1L << (SUPER - 67)) | (1L << (THEN - 67)) | (1L << (TRUE - 67)) | (1L << (UNDEF - 67)) | (1L << (UNLESS - 67)) | (1L << (UNTIL - 67)) | (1L << (WHEN - 67)) | (1L << (WHILE - 67)) | (1L << (YIELD - 67)) | (1L << (GLOBAL_VARIABLE_IDENTIFIER - 67)) | (1L << (INSTANCE_VARIABLE_IDENTIFIER - 67)) | (1L << (CLASS_VARIABLE_IDENTIFIER - 67)) | (1L << (CONSTANT_IDENTIFIER - 67)))) != 0)) {
							{
							setState(1508);
							indexingArgumentList();
							}
						}

						setState(1511);
						match(RBRACK);
						}
						break;
					case 14:
						{
						_localctx = new MemberAccessExpressionContext(new PrimaryValueContext(_parentctx, _parentState));
						pushNewRecursionContext(_localctx, _startState, RULE_primaryValue);
						setState(1512);
						if (!(precpred(_ctx, 17))) throw new FailedPredicateException(this, "precpred(_ctx, 17)");
						setState(1516);
						_errHandler.sync(this);
						_la = _input.LA(1);
						while (_la==NL) {
							{
							{
							setState(1513);
							match(NL);
							}
							}
							setState(1518);
							_errHandler.sync(this);
							_la = _input.LA(1);
						}
						setState(1519);
						((MemberAccessExpressionContext)_localctx).op = _input.LT(1);
						_la = _input.LA(1);
						if ( !((((_la) & ~0x3f) == 0 && ((1L << _la) & ((1L << COLON2) | (1L << DOT) | (1L << AMPDOT))) != 0)) ) {
							((MemberAccessExpressionContext)_localctx).op = (Token)_errHandler.recoverInline(this);
						}
						else {
							if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
							_errHandler.reportMatch(this);
							consume();
						}
						setState(1523);
						_errHandler.sync(this);
						_la = _input.LA(1);
						while (_la==NL) {
							{
							{
							setState(1520);
							match(NL);
							}
							}
							setState(1525);
							_errHandler.sync(this);
							_la = _input.LA(1);
						}
						setState(1526);
						methodName();
						setState(1528);
						_errHandler.sync(this);
						switch ( getInterpreter().adaptivePredict(_input,195,_ctx) ) {
						case 1:
							{
							setState(1527);
							argumentWithParentheses();
							}
							break;
						}
						setState(1531);
						_errHandler.sync(this);
						switch ( getInterpreter().adaptivePredict(_input,196,_ctx) ) {
						case 1:
							{
							setState(1530);
							block();
							}
							break;
						}
						}
						break;
					case 15:
						{
						_localctx = new LogicalAndExpressionContext(new PrimaryValueContext(_parentctx, _parentState));
						pushNewRecursionContext(_localctx, _startState, RULE_primaryValue);
						setState(1533);
						if (!(precpred(_ctx, 6))) throw new FailedPredicateException(this, "precpred(_ctx, 6)");
						setState(1534);
						((LogicalAndExpressionContext)_localctx).andOperator = match(AMP2);
						setState(1538);
						_errHandler.sync(this);
						_la = _input.LA(1);
						while (_la==NL) {
							{
							{
							setState(1535);
							match(NL);
							}
							}
							setState(1540);
							_errHandler.sync(this);
							_la = _input.LA(1);
						}
						setState(1543);
						_errHandler.sync(this);
						switch (_input.LA(1)) {
						case REGULAR_EXPRESSION_START:
						case LBRACK:
						case LPAREN:
						case LCURLY:
						case COLON:
						case COLON2:
						case DOT2:
						case DOT3:
						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 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 GLOBAL_VARIABLE_IDENTIFIER:
						case INSTANCE_VARIABLE_IDENTIFIER:
						case CLASS_VARIABLE_IDENTIFIER:
						case CONSTANT_IDENTIFIER:
							{
							setState(1541);
							primaryValue(0);
							}
							break;
						case RETURN:
							{
							setState(1542);
							match(RETURN);
							}
							break;
						default:
							throw new NoViableAltException(this);
						}
						}
						break;
					case 16:
						{
						_localctx = new LogicalOrExpressionContext(new PrimaryValueContext(_parentctx, _parentState));
						pushNewRecursionContext(_localctx, _startState, RULE_primaryValue);
						setState(1545);
						if (!(precpred(_ctx, 5))) throw new FailedPredicateException(this, "precpred(_ctx, 5)");
						setState(1546);
						((LogicalOrExpressionContext)_localctx).orOperator = match(BAR2);
						setState(1550);
						_errHandler.sync(this);
						_la = _input.LA(1);
						while (_la==NL) {
							{
							{
							setState(1547);
							match(NL);
							}
							}
							setState(1552);
							_errHandler.sync(this);
							_la = _input.LA(1);
						}
						setState(1555);
						_errHandler.sync(this);
						switch (_input.LA(1)) {
						case REGULAR_EXPRESSION_START:
						case LBRACK:
						case LPAREN:
						case LCURLY:
						case COLON:
						case COLON2:
						case DOT2:
						case DOT3:
						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 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 GLOBAL_VARIABLE_IDENTIFIER:
						case INSTANCE_VARIABLE_IDENTIFIER:
						case CLASS_VARIABLE_IDENTIFIER:
						case CONSTANT_IDENTIFIER:
							{
							setState(1553);
							primaryValue(0);
							}
							break;
						case RETURN:
							{
							setState(1554);
							match(RETURN);
							}
							break;
						default:
							throw new NoViableAltException(this);
						}
						}
						break;
					case 17:
						{
						_localctx = new EndlessRangeExpressionContext(new PrimaryValueContext(_parentctx, _parentState));
						pushNewRecursionContext(_localctx, _startState, RULE_primaryValue);
						setState(1557);
						if (!(precpred(_ctx, 3))) throw new FailedPredicateException(this, "precpred(_ctx, 3)");
						setState(1558);
						rangeOperator();
						}
						break;
					}
					} 
				}
				setState(1563);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,202,_ctx);
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			unrollRecursionContexts(_parentctx);
		}
		return _localctx;
	}

	public static class LambdaExpressionParameterListContext extends ParserRuleContext {
		public TerminalNode LPAREN() { return getToken(RubyParser.LPAREN, 0); }
		public TerminalNode RPAREN() { return getToken(RubyParser.RPAREN, 0); }
		public BlockParameterListContext blockParameterList() {
			return getRuleContext(BlockParameterListContext.class,0);
		}
		public LambdaExpressionParameterListContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_lambdaExpressionParameterList; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterLambdaExpressionParameterList(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitLambdaExpressionParameterList(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitLambdaExpressionParameterList(this);
			else return visitor.visitChildren(this);
		}
	}

	public final LambdaExpressionParameterListContext lambdaExpressionParameterList() throws RecognitionException {
		LambdaExpressionParameterListContext _localctx = new LambdaExpressionParameterListContext(_ctx, getState());
		enterRule(_localctx, 84, RULE_lambdaExpressionParameterList);
		int _la;
		try {
			setState(1570);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,204,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(1564);
				match(LPAREN);
				setState(1566);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if ((((_la) & ~0x3f) == 0 && ((1L << _la) & ((1L << LPAREN) | (1L << AMP) | (1L << STAR) | (1L << STAR2))) != 0) || _la==LOCAL_VARIABLE_IDENTIFIER) {
					{
					setState(1565);
					blockParameterList();
					}
				}

				setState(1568);
				match(RPAREN);
				}
				break;
			case 2:
				enterOuterAlt(_localctx, 2);
				{
				setState(1569);
				blockParameterList();
				}
				break;
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		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, 86, RULE_methodCallsWithParentheses);
		try {
			setState(1604);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,210,_ctx) ) {
			case 1:
				_localctx = new SuperWithParenthesesContext(_localctx);
				enterOuterAlt(_localctx, 1);
				{
				setState(1572);
				match(SUPER);
				setState(1574);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,205,_ctx) ) {
				case 1:
					{
					setState(1573);
					argumentWithParentheses();
					}
					break;
				}
				setState(1577);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,206,_ctx) ) {
				case 1:
					{
					setState(1576);
					block();
					}
					break;
				}
				}
				break;
			case 2:
				_localctx = new SuperWithoutParenthesesContext(_localctx);
				enterOuterAlt(_localctx, 2);
				{
				setState(1579);
				match(SUPER);
				setState(1581);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,207,_ctx) ) {
				case 1:
					{
					setState(1580);
					argumentList();
					}
					break;
				}
				setState(1584);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,208,_ctx) ) {
				case 1:
					{
					setState(1583);
					block();
					}
					break;
				}
				}
				break;
			case 3:
				_localctx = new IsDefinedExpressionContext(_localctx);
				enterOuterAlt(_localctx, 3);
				{
				setState(1586);
				isDefinedKeyword();
				setState(1587);
				match(LPAREN);
				setState(1588);
				expressionOrCommand(0);
				setState(1589);
				match(RPAREN);
				}
				break;
			case 4:
				_localctx = new IsDefinedCommandContext(_localctx);
				enterOuterAlt(_localctx, 4);
				{
				setState(1591);
				isDefinedKeyword();
				setState(1592);
				primaryValue(0);
				}
				break;
			case 5:
				_localctx = new MethodCallExpressionContext(_localctx);
				enterOuterAlt(_localctx, 5);
				{
				setState(1594);
				methodOnlyIdentifier();
				}
				break;
			case 6:
				_localctx = new MethodCallWithBlockExpressionContext(_localctx);
				enterOuterAlt(_localctx, 6);
				{
				setState(1595);
				methodIdentifier();
				setState(1596);
				block();
				}
				break;
			case 7:
				_localctx = new MethodCallWithParenthesesExpressionContext(_localctx);
				enterOuterAlt(_localctx, 7);
				{
				setState(1598);
				methodIdentifier();
				setState(1599);
				argumentWithParentheses();
				setState(1601);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,209,_ctx) ) {
				case 1:
					{
					setState(1600);
					block();
					}
					break;
				}
				}
				break;
			case 8:
				_localctx = new MethodCallOrVariableReferenceContext(_localctx);
				enterOuterAlt(_localctx, 8);
				{
				setState(1603);
				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, 88, RULE_commandOrPrimaryValueClass);
		try {
			setState(1608);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,211,_ctx) ) {
			case 1:
				_localctx = new CommandCommandOrPrimaryValueClassContext(_localctx);
				enterOuterAlt(_localctx, 1);
				{
				setState(1606);
				command();
				}
				break;
			case 2:
				_localctx = new PrimaryValueCommandOrPrimaryValueClassContext(_localctx);
				enterOuterAlt(_localctx, 2);
				{
				setState(1607);
				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 = 90;
		enterRecursionRule(_localctx, 90, RULE_commandOrPrimaryValue, _p);
		int _la;
		try {
			int _alt;
			enterOuterAlt(_localctx, 1);
			{
			setState(1615);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,212,_ctx) ) {
			case 1:
				{
				_localctx = new PrimaryValueCommandOrPrimaryValueContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;

				setState(1611);
				primaryValue(0);
				}
				break;
			case 2:
				{
				_localctx = new CommandCommandOrPrimaryValueContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(1612);
				command();
				}
				break;
			case 3:
				{
				_localctx = new NotCommandOrPrimaryValueContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(1613);
				match(NOT);
				setState(1614);
				commandOrPrimaryValue(2);
				}
				break;
			}
			_ctx.stop = _input.LT(-1);
			setState(1628);
			_errHandler.sync(this);
			_alt = getInterpreter().adaptivePredict(_input,214,_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(1617);
					if (!(precpred(_ctx, 1))) throw new FailedPredicateException(this, "precpred(_ctx, 1)");
					setState(1618);
					_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(1622);
					_errHandler.sync(this);
					_la = _input.LA(1);
					while (_la==NL) {
						{
						{
						setState(1619);
						match(NL);
						}
						}
						setState(1624);
						_errHandler.sync(this);
						_la = _input.LA(1);
					}
					setState(1625);
					commandOrPrimaryValue(2);
					}
					} 
				}
				setState(1630);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,214,_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, 92, RULE_block);
		int _la;
		try {
			int _alt;
			setState(1645);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case LCURLY:
				_localctx = new CurlyBracesBlockContext(_localctx);
				enterOuterAlt(_localctx, 1);
				{
				setState(1631);
				match(LCURLY);
				setState(1635);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,215,_ctx);
				while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) {
					if ( _alt==1 ) {
						{
						{
						setState(1632);
						match(NL);
						}
						} 
					}
					setState(1637);
					_errHandler.sync(this);
					_alt = getInterpreter().adaptivePredict(_input,215,_ctx);
				}
				setState(1639);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==BAR) {
					{
					setState(1638);
					blockParameter();
					}
				}

				setState(1641);
				compoundStatement();
				setState(1642);
				match(RCURLY);
				}
				break;
			case DO:
				_localctx = new DoBlockBlockContext(_localctx);
				enterOuterAlt(_localctx, 2);
				{
				setState(1644);
				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, 94, RULE_doBlock);
		int _la;
		try {
			int _alt;
			enterOuterAlt(_localctx, 1);
			{
			setState(1647);
			match(DO);
			setState(1651);
			_errHandler.sync(this);
			_alt = getInterpreter().adaptivePredict(_input,218,_ctx);
			while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) {
				if ( _alt==1 ) {
					{
					{
					setState(1648);
					match(NL);
					}
					} 
				}
				setState(1653);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,218,_ctx);
			}
			setState(1655);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==BAR) {
				{
				setState(1654);
				blockParameter();
				}
			}

			setState(1657);
			bodyStatement();
			setState(1658);
			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 BlockParameterListContext blockParameterList() {
			return getRuleContext(BlockParameterListContext.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, 96, RULE_blockParameter);
		int _la;
		try {
			setState(1684);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,223,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(1660);
				match(BAR);
				setState(1664);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==NL) {
					{
					{
					setState(1661);
					match(NL);
					}
					}
					setState(1666);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(1667);
				match(BAR);
				}
				break;
			case 2:
				enterOuterAlt(_localctx, 2);
				{
				setState(1668);
				match(BAR);
				setState(1672);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==NL) {
					{
					{
					setState(1669);
					match(NL);
					}
					}
					setState(1674);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(1675);
				blockParameterList();
				setState(1679);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==NL) {
					{
					{
					setState(1676);
					match(NL);
					}
					}
					setState(1681);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(1682);
				match(BAR);
				}
				break;
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class BlockParameterListContext extends ParserRuleContext {
		public MandatoryOrOptionalOrGroupedParameterListContext mandatoryOrOptionalOrGroupedParameterList() {
			return getRuleContext(MandatoryOrOptionalOrGroupedParameterListContext.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 List mandatoryOrGroupedParameterList() {
			return getRuleContexts(MandatoryOrGroupedParameterListContext.class);
		}
		public MandatoryOrGroupedParameterListContext mandatoryOrGroupedParameterList(int i) {
			return getRuleContext(MandatoryOrGroupedParameterListContext.class,i);
		}
		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 BlockParameterListContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_blockParameterList; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterBlockParameterList(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitBlockParameterList(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitBlockParameterList(this);
			else return visitor.visitChildren(this);
		}
	}

	public final BlockParameterListContext blockParameterList() throws RecognitionException {
		BlockParameterListContext _localctx = new BlockParameterListContext(_ctx, getState());
		enterRule(_localctx, 98, RULE_blockParameterList);
		int _la;
		try {
			int _alt;
			setState(1776);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case LPAREN:
			case LOCAL_VARIABLE_IDENTIFIER:
				enterOuterAlt(_localctx, 1);
				{
				setState(1686);
				mandatoryOrOptionalOrGroupedParameterList();
				setState(1695);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,225,_ctx) ) {
				case 1:
					{
					setState(1687);
					match(COMMA);
					setState(1691);
					_errHandler.sync(this);
					_la = _input.LA(1);
					while (_la==NL) {
						{
						{
						setState(1688);
						match(NL);
						}
						}
						setState(1693);
						_errHandler.sync(this);
						_la = _input.LA(1);
					}
					setState(1694);
					arrayParameter();
					}
					break;
				}
				setState(1707);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,227,_ctx);
				while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) {
					if ( _alt==1 ) {
						{
						{
						setState(1697);
						match(COMMA);
						setState(1701);
						_errHandler.sync(this);
						_la = _input.LA(1);
						while (_la==NL) {
							{
							{
							setState(1698);
							match(NL);
							}
							}
							setState(1703);
							_errHandler.sync(this);
							_la = _input.LA(1);
						}
						setState(1704);
						mandatoryOrGroupedParameterList();
						}
						} 
					}
					setState(1709);
					_errHandler.sync(this);
					_alt = getInterpreter().adaptivePredict(_input,227,_ctx);
				}
				setState(1718);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,229,_ctx) ) {
				case 1:
					{
					setState(1710);
					match(COMMA);
					setState(1714);
					_errHandler.sync(this);
					_la = _input.LA(1);
					while (_la==NL) {
						{
						{
						setState(1711);
						match(NL);
						}
						}
						setState(1716);
						_errHandler.sync(this);
						_la = _input.LA(1);
					}
					setState(1717);
					hashParameter();
					}
					break;
				}
				setState(1728);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==COMMA) {
					{
					setState(1720);
					match(COMMA);
					setState(1724);
					_errHandler.sync(this);
					_la = _input.LA(1);
					while (_la==NL) {
						{
						{
						setState(1721);
						match(NL);
						}
						}
						setState(1726);
						_errHandler.sync(this);
						_la = _input.LA(1);
					}
					setState(1727);
					procParameter();
					}
				}

				}
				break;
			case STAR:
				enterOuterAlt(_localctx, 2);
				{
				setState(1730);
				arrayParameter();
				setState(1741);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,233,_ctx);
				while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) {
					if ( _alt==1 ) {
						{
						{
						setState(1731);
						match(COMMA);
						setState(1735);
						_errHandler.sync(this);
						_la = _input.LA(1);
						while (_la==NL) {
							{
							{
							setState(1732);
							match(NL);
							}
							}
							setState(1737);
							_errHandler.sync(this);
							_la = _input.LA(1);
						}
						setState(1738);
						mandatoryOrGroupedParameterList();
						}
						} 
					}
					setState(1743);
					_errHandler.sync(this);
					_alt = getInterpreter().adaptivePredict(_input,233,_ctx);
				}
				setState(1752);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,235,_ctx) ) {
				case 1:
					{
					setState(1744);
					match(COMMA);
					setState(1748);
					_errHandler.sync(this);
					_la = _input.LA(1);
					while (_la==NL) {
						{
						{
						setState(1745);
						match(NL);
						}
						}
						setState(1750);
						_errHandler.sync(this);
						_la = _input.LA(1);
					}
					setState(1751);
					hashParameter();
					}
					break;
				}
				setState(1762);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==COMMA) {
					{
					setState(1754);
					match(COMMA);
					setState(1758);
					_errHandler.sync(this);
					_la = _input.LA(1);
					while (_la==NL) {
						{
						{
						setState(1755);
						match(NL);
						}
						}
						setState(1760);
						_errHandler.sync(this);
						_la = _input.LA(1);
					}
					setState(1761);
					procParameter();
					}
				}

				}
				break;
			case STAR2:
				enterOuterAlt(_localctx, 3);
				{
				setState(1764);
				hashParameter();
				setState(1773);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==COMMA) {
					{
					setState(1765);
					match(COMMA);
					setState(1769);
					_errHandler.sync(this);
					_la = _input.LA(1);
					while (_la==NL) {
						{
						{
						setState(1766);
						match(NL);
						}
						}
						setState(1771);
						_errHandler.sync(this);
						_la = _input.LA(1);
					}
					setState(1772);
					procParameter();
					}
				}

				}
				break;
			case AMP:
				enterOuterAlt(_localctx, 4);
				{
				setState(1775);
				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 MandatoryOrOptionalOrGroupedParameterListContext extends ParserRuleContext {
		public List mandatoryOrOptionalOrGroupedParameter() {
			return getRuleContexts(MandatoryOrOptionalOrGroupedParameterContext.class);
		}
		public MandatoryOrOptionalOrGroupedParameterContext mandatoryOrOptionalOrGroupedParameter(int i) {
			return getRuleContext(MandatoryOrOptionalOrGroupedParameterContext.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 MandatoryOrOptionalOrGroupedParameterListContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_mandatoryOrOptionalOrGroupedParameterList; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterMandatoryOrOptionalOrGroupedParameterList(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitMandatoryOrOptionalOrGroupedParameterList(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitMandatoryOrOptionalOrGroupedParameterList(this);
			else return visitor.visitChildren(this);
		}
	}

	public final MandatoryOrOptionalOrGroupedParameterListContext mandatoryOrOptionalOrGroupedParameterList() throws RecognitionException {
		MandatoryOrOptionalOrGroupedParameterListContext _localctx = new MandatoryOrOptionalOrGroupedParameterListContext(_ctx, getState());
		enterRule(_localctx, 100, RULE_mandatoryOrOptionalOrGroupedParameterList);
		int _la;
		try {
			int _alt;
			enterOuterAlt(_localctx, 1);
			{
			setState(1778);
			mandatoryOrOptionalOrGroupedParameter();
			setState(1789);
			_errHandler.sync(this);
			_alt = getInterpreter().adaptivePredict(_input,242,_ctx);
			while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) {
				if ( _alt==1 ) {
					{
					{
					setState(1779);
					match(COMMA);
					setState(1783);
					_errHandler.sync(this);
					_la = _input.LA(1);
					while (_la==NL) {
						{
						{
						setState(1780);
						match(NL);
						}
						}
						setState(1785);
						_errHandler.sync(this);
						_la = _input.LA(1);
					}
					setState(1786);
					mandatoryOrOptionalOrGroupedParameter();
					}
					} 
				}
				setState(1791);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,242,_ctx);
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class MandatoryOrOptionalOrGroupedParameterContext extends ParserRuleContext {
		public MandatoryParameterContext mandatoryParameter() {
			return getRuleContext(MandatoryParameterContext.class,0);
		}
		public OptionalParameterContext optionalParameter() {
			return getRuleContext(OptionalParameterContext.class,0);
		}
		public GroupedParameterListContext groupedParameterList() {
			return getRuleContext(GroupedParameterListContext.class,0);
		}
		public MandatoryOrOptionalOrGroupedParameterContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_mandatoryOrOptionalOrGroupedParameter; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterMandatoryOrOptionalOrGroupedParameter(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitMandatoryOrOptionalOrGroupedParameter(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitMandatoryOrOptionalOrGroupedParameter(this);
			else return visitor.visitChildren(this);
		}
	}

	public final MandatoryOrOptionalOrGroupedParameterContext mandatoryOrOptionalOrGroupedParameter() throws RecognitionException {
		MandatoryOrOptionalOrGroupedParameterContext _localctx = new MandatoryOrOptionalOrGroupedParameterContext(_ctx, getState());
		enterRule(_localctx, 102, RULE_mandatoryOrOptionalOrGroupedParameter);
		try {
			setState(1795);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,243,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(1792);
				mandatoryParameter();
				}
				break;
			case 2:
				enterOuterAlt(_localctx, 2);
				{
				setState(1793);
				optionalParameter();
				}
				break;
			case 3:
				enterOuterAlt(_localctx, 3);
				{
				setState(1794);
				groupedParameterList();
				}
				break;
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class MandatoryOrGroupedParameterListContext extends ParserRuleContext {
		public List mandatoryOrGroupedParameter() {
			return getRuleContexts(MandatoryOrGroupedParameterContext.class);
		}
		public MandatoryOrGroupedParameterContext mandatoryOrGroupedParameter(int i) {
			return getRuleContext(MandatoryOrGroupedParameterContext.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 MandatoryOrGroupedParameterListContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_mandatoryOrGroupedParameterList; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterMandatoryOrGroupedParameterList(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitMandatoryOrGroupedParameterList(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitMandatoryOrGroupedParameterList(this);
			else return visitor.visitChildren(this);
		}
	}

	public final MandatoryOrGroupedParameterListContext mandatoryOrGroupedParameterList() throws RecognitionException {
		MandatoryOrGroupedParameterListContext _localctx = new MandatoryOrGroupedParameterListContext(_ctx, getState());
		enterRule(_localctx, 104, RULE_mandatoryOrGroupedParameterList);
		int _la;
		try {
			int _alt;
			enterOuterAlt(_localctx, 1);
			{
			setState(1797);
			mandatoryOrGroupedParameter();
			setState(1808);
			_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 ) {
					{
					{
					setState(1798);
					match(COMMA);
					setState(1802);
					_errHandler.sync(this);
					_la = _input.LA(1);
					while (_la==NL) {
						{
						{
						setState(1799);
						match(NL);
						}
						}
						setState(1804);
						_errHandler.sync(this);
						_la = _input.LA(1);
					}
					setState(1805);
					mandatoryOrGroupedParameter();
					}
					} 
				}
				setState(1810);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,245,_ctx);
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class MandatoryOrGroupedParameterContext extends ParserRuleContext {
		public MandatoryParameterContext mandatoryParameter() {
			return getRuleContext(MandatoryParameterContext.class,0);
		}
		public GroupedParameterListContext groupedParameterList() {
			return getRuleContext(GroupedParameterListContext.class,0);
		}
		public MandatoryOrGroupedParameterContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_mandatoryOrGroupedParameter; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterMandatoryOrGroupedParameter(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitMandatoryOrGroupedParameter(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitMandatoryOrGroupedParameter(this);
			else return visitor.visitChildren(this);
		}
	}

	public final MandatoryOrGroupedParameterContext mandatoryOrGroupedParameter() throws RecognitionException {
		MandatoryOrGroupedParameterContext _localctx = new MandatoryOrGroupedParameterContext(_ctx, getState());
		enterRule(_localctx, 106, RULE_mandatoryOrGroupedParameter);
		try {
			setState(1813);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case LOCAL_VARIABLE_IDENTIFIER:
				enterOuterAlt(_localctx, 1);
				{
				setState(1811);
				mandatoryParameter();
				}
				break;
			case LPAREN:
				enterOuterAlt(_localctx, 2);
				{
				setState(1812);
				groupedParameterList();
				}
				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 GroupedParameterListContext extends ParserRuleContext {
		public TerminalNode LPAREN() { return getToken(RubyParser.LPAREN, 0); }
		public List mandatoryParameter() {
			return getRuleContexts(MandatoryParameterContext.class);
		}
		public MandatoryParameterContext mandatoryParameter(int i) {
			return getRuleContext(MandatoryParameterContext.class,i);
		}
		public TerminalNode RPAREN() { return getToken(RubyParser.RPAREN, 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 List NL() { return getTokens(RubyParser.NL); }
		public TerminalNode NL(int i) {
			return getToken(RubyParser.NL, i);
		}
		public GroupedParameterListContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_groupedParameterList; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterGroupedParameterList(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitGroupedParameterList(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitGroupedParameterList(this);
			else return visitor.visitChildren(this);
		}
	}

	public final GroupedParameterListContext groupedParameterList() throws RecognitionException {
		GroupedParameterListContext _localctx = new GroupedParameterListContext(_ctx, getState());
		enterRule(_localctx, 108, RULE_groupedParameterList);
		int _la;
		try {
			setState(1859);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,253,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(1815);
				match(LPAREN);
				setState(1816);
				mandatoryParameter();
				setState(1825);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,248,_ctx) ) {
				case 1:
					{
					setState(1817);
					match(COMMA);
					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);
					arrayParameter();
					}
					break;
				}
				setState(1837);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==COMMA) {
					{
					{
					setState(1827);
					match(COMMA);
					setState(1831);
					_errHandler.sync(this);
					_la = _input.LA(1);
					while (_la==NL) {
						{
						{
						setState(1828);
						match(NL);
						}
						}
						setState(1833);
						_errHandler.sync(this);
						_la = _input.LA(1);
					}
					setState(1834);
					mandatoryParameter();
					}
					}
					setState(1839);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(1840);
				match(RPAREN);
				}
				break;
			case 2:
				enterOuterAlt(_localctx, 2);
				{
				setState(1842);
				match(LPAREN);
				setState(1843);
				arrayParameter();
				setState(1854);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==COMMA) {
					{
					{
					setState(1844);
					match(COMMA);
					setState(1848);
					_errHandler.sync(this);
					_la = _input.LA(1);
					while (_la==NL) {
						{
						{
						setState(1845);
						match(NL);
						}
						}
						setState(1850);
						_errHandler.sync(this);
						_la = _input.LA(1);
					}
					setState(1851);
					mandatoryParameter();
					}
					}
					setState(1856);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(1857);
				match(RPAREN);
				}
				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, 110, RULE_thenClause);
		int _la;
		try {
			int _alt;
			setState(1872);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,256,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(1862); 
				_errHandler.sync(this);
				_alt = 1;
				do {
					switch (_alt) {
					case 1:
						{
						{
						setState(1861);
						_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(1864); 
					_errHandler.sync(this);
					_alt = getInterpreter().adaptivePredict(_input,254,_ctx);
				} while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER );
				setState(1866);
				compoundStatement();
				}
				break;
			case 2:
				enterOuterAlt(_localctx, 2);
				{
				setState(1868);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==SEMI || _la==NL) {
					{
					setState(1867);
					_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(1870);
				match(THEN);
				setState(1871);
				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, 112, RULE_elseClause);
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(1874);
			match(ELSE);
			setState(1875);
			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, 114, RULE_elsifClause);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(1877);
			match(ELSIF);
			setState(1881);
			_errHandler.sync(this);
			_la = _input.LA(1);
			while (_la==NL) {
				{
				{
				setState(1878);
				match(NL);
				}
				}
				setState(1883);
				_errHandler.sync(this);
				_la = _input.LA(1);
			}
			setState(1884);
			expressionOrCommand(0);
			setState(1885);
			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, 116, RULE_whenClause);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(1887);
			match(WHEN);
			setState(1891);
			_errHandler.sync(this);
			_la = _input.LA(1);
			while (_la==NL) {
				{
				{
				setState(1888);
				match(NL);
				}
				}
				setState(1893);
				_errHandler.sync(this);
				_la = _input.LA(1);
			}
			setState(1894);
			whenArgument();
			setState(1895);
			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, 118, RULE_whenArgument);
		int _la;
		try {
			setState(1903);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case REGULAR_EXPRESSION_START:
			case LBRACK:
			case LPAREN:
			case LCURLY:
			case COLON:
			case COLON2:
			case DOT2:
			case DOT3:
			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 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 GLOBAL_VARIABLE_IDENTIFIER:
			case INSTANCE_VARIABLE_IDENTIFIER:
			case CLASS_VARIABLE_IDENTIFIER:
			case CONSTANT_IDENTIFIER:
				enterOuterAlt(_localctx, 1);
				{
				setState(1897);
				operatorExpressionList();
				setState(1900);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==COMMA) {
					{
					setState(1898);
					match(COMMA);
					setState(1899);
					splattingArgument();
					}
				}

				}
				break;
			case STAR:
			case STAR2:
				enterOuterAlt(_localctx, 2);
				{
				setState(1902);
				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, 120, RULE_doClause);
		int _la;
		try {
			int _alt;
			setState(1913);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case SEMI:
			case NL:
				enterOuterAlt(_localctx, 1);
				{
				setState(1906); 
				_errHandler.sync(this);
				_alt = 1;
				do {
					switch (_alt) {
					case 1:
						{
						{
						setState(1905);
						_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(1908); 
					_errHandler.sync(this);
					_alt = getInterpreter().adaptivePredict(_input,261,_ctx);
				} while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER );
				setState(1910);
				compoundStatement();
				}
				break;
			case DO:
				enterOuterAlt(_localctx, 2);
				{
				setState(1911);
				match(DO);
				setState(1912);
				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, 122, RULE_forVariable);
		try {
			setState(1917);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,263,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(1915);
				leftHandSide();
				}
				break;
			case 2:
				enterOuterAlt(_localctx, 2);
				{
				setState(1916);
				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, 124, RULE_bodyStatement);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(1919);
			compoundStatement();
			setState(1923);
			_errHandler.sync(this);
			_la = _input.LA(1);
			while (_la==RESCUE) {
				{
				{
				setState(1920);
				rescueClause();
				}
				}
				setState(1925);
				_errHandler.sync(this);
				_la = _input.LA(1);
			}
			setState(1927);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==ELSE) {
				{
				setState(1926);
				elseClause();
				}
			}

			setState(1930);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==ENSURE) {
				{
				setState(1929);
				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, 126, RULE_rescueClause);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(1932);
			match(RESCUE);
			setState(1934);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (((((_la - 3)) & ~0x3f) == 0 && ((1L << (_la - 3)) & ((1L << (REGULAR_EXPRESSION_START - 3)) | (1L << (LBRACK - 3)) | (1L << (LPAREN - 3)) | (1L << (LCURLY - 3)) | (1L << (COLON - 3)) | (1L << (COLON2 - 3)) | (1L << (DOT2 - 3)) | (1L << (DOT3 - 3)) | (1L << (MINUSGT - 3)) | (1L << (EMARK - 3)) | (1L << (PLUS - 3)) | (1L << (MINUS - 3)) | (1L << (STAR - 3)) | (1L << (STAR2 - 3)) | (1L << (TILDE - 3)) | (1L << (SINGLE_QUOTED_STRING_LITERAL - 3)) | (1L << (DOUBLE_QUOTED_STRING_START - 3)) | (1L << (QUOTED_NON_EXPANDED_STRING_LITERAL_START - 3)) | (1L << (QUOTED_EXPANDED_STRING_LITERAL_START - 3)) | (1L << (QUOTED_EXPANDED_REGULAR_EXPRESSION_START - 3)))) != 0) || ((((_la - 67)) & ~0x3f) == 0 && ((1L << (_la - 67)) & ((1L << (QUOTED_EXPANDED_EXTERNAL_COMMAND_LITERAL_START - 67)) | (1L << (QUOTED_NON_EXPANDED_STRING_ARRAY_LITERAL_START - 67)) | (1L << (QUOTED_EXPANDED_STRING_ARRAY_LITERAL_START - 67)) | (1L << (HERE_DOC - 67)) | (1L << (QUOTED_NON_EXPANDED_SYMBOL_ARRAY_LITERAL_START - 67)) | (1L << (QUOTED_EXPANDED_SYMBOL_ARRAY_LITERAL_START - 67)) | (1L << (DECIMAL_INTEGER_LITERAL - 67)) | (1L << (BINARY_INTEGER_LITERAL - 67)) | (1L << (OCTAL_INTEGER_LITERAL - 67)) | (1L << (HEXADECIMAL_INTEGER_LITERAL - 67)) | (1L << (FLOAT_LITERAL_WITHOUT_EXPONENT - 67)) | (1L << (FLOAT_LITERAL_WITH_EXPONENT - 67)) | (1L << (SYMBOL_LITERAL - 67)) | (1L << (LOCAL_VARIABLE_IDENTIFIER - 67)) | (1L << (LINE__ - 67)) | (1L << (ENCODING__ - 67)) | (1L << (FILE__ - 67)) | (1L << (BEGIN - 67)) | (1L << (BREAK - 67)) | (1L << (CASE - 67)) | (1L << (CLASS - 67)) | (1L << (DEF - 67)) | (1L << (IS_DEFINED - 67)) | (1L << (FOR - 67)) | (1L << (FALSE - 67)) | (1L << (IF - 67)) | (1L << (MODULE - 67)) | (1L << (NEXT - 67)) | (1L << (NIL - 67)) | (1L << (REDO - 67)) | (1L << (RETRY - 67)) | (1L << (RETURN - 67)) | (1L << (SELF - 67)) | (1L << (SUPER - 67)) | (1L << (TRUE - 67)) | (1L << (UNLESS - 67)) | (1L << (UNTIL - 67)) | (1L << (WHILE - 67)) | (1L << (YIELD - 67)) | (1L << (GLOBAL_VARIABLE_IDENTIFIER - 67)) | (1L << (INSTANCE_VARIABLE_IDENTIFIER - 67)) | (1L << (CLASS_VARIABLE_IDENTIFIER - 67)) | (1L << (CONSTANT_IDENTIFIER - 67)))) != 0)) {
				{
				setState(1933);
				exceptionClassList();
				}
			}

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

			setState(1939);
			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, 128, RULE_exceptionClassList);
		try {
			setState(1943);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,269,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(1941);
				operatorExpression(0);
				}
				break;
			case 2:
				enterOuterAlt(_localctx, 2);
				{
				setState(1942);
				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, 130, RULE_exceptionVariableAssignment);
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(1945);
			match(EQGT);
			setState(1946);
			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, 132, RULE_ensureClause);
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(1948);
			match(ENSURE);
			setState(1949);
			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, 134, RULE_definedMethodName);
		try {
			setState(1962);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case LOCAL_VARIABLE_IDENTIFIER:
			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 CONSTANT_IDENTIFIER:
				enterOuterAlt(_localctx, 1);
				{
				setState(1951);
				methodName();
				}
				break;
			case ASSIGNMENT_LIKE_METHOD_IDENTIFIER:
				enterOuterAlt(_localctx, 2);
				{
				setState(1952);
				match(ASSIGNMENT_LIKE_METHOD_IDENTIFIER);
				}
				break;
			case LBRACK:
				enterOuterAlt(_localctx, 3);
				{
				setState(1953);
				match(LBRACK);
				setState(1954);
				match(RBRACK);
				setState(1956);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,270,_ctx) ) {
				case 1:
					{
					setState(1955);
					match(EQ);
					}
					break;
				}
				}
				break;
			case EQ2:
				enterOuterAlt(_localctx, 4);
				{
				setState(1958);
				match(EQ2);
				}
				break;
			case EQ3:
				enterOuterAlt(_localctx, 5);
				{
				setState(1959);
				match(EQ3);
				}
				break;
			case LTEQGT:
				enterOuterAlt(_localctx, 6);
				{
				setState(1960);
				match(LTEQGT);
				}
				break;
			case LT2:
				enterOuterAlt(_localctx, 7);
				{
				setState(1961);
				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, 136, RULE_methodParameterPart);
		int _la;
		try {
			int _alt;
			setState(1985);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case LPAREN:
				enterOuterAlt(_localctx, 1);
				{
				setState(1964);
				match(LPAREN);
				setState(1968);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,272,_ctx);
				while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) {
					if ( _alt==1 ) {
						{
						{
						setState(1965);
						match(NL);
						}
						} 
					}
					setState(1970);
					_errHandler.sync(this);
					_alt = getInterpreter().adaptivePredict(_input,272,_ctx);
				}
				setState(1972);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (((((_la - 35)) & ~0x3f) == 0 && ((1L << (_la - 35)) & ((1L << (AMP - 35)) | (1L << (STAR - 35)) | (1L << (STAR2 - 35)) | (1L << (LOCAL_VARIABLE_IDENTIFIER - 35)))) != 0)) {
					{
					setState(1971);
					parameterList();
					}
				}

				setState(1977);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==NL) {
					{
					{
					setState(1974);
					match(NL);
					}
					}
					setState(1979);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(1980);
				match(RPAREN);
				}
				break;
			case SEMI:
			case AMP:
			case STAR:
			case STAR2:
			case NL:
			case LOCAL_VARIABLE_IDENTIFIER:
				enterOuterAlt(_localctx, 2);
				{
				setState(1982);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (((((_la - 35)) & ~0x3f) == 0 && ((1L << (_la - 35)) & ((1L << (AMP - 35)) | (1L << (STAR - 35)) | (1L << (STAR2 - 35)) | (1L << (LOCAL_VARIABLE_IDENTIFIER - 35)))) != 0)) {
					{
					setState(1981);
					parameterList();
					}
				}

				setState(1984);
				_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 MandatoryParameterListContext mandatoryParameterList() {
			return getRuleContext(MandatoryParameterListContext.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, 138, RULE_parameterList);
		int _la;
		try {
			setState(2071);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case LOCAL_VARIABLE_IDENTIFIER:
				enterOuterAlt(_localctx, 1);
				{
				setState(1987);
				mandatoryOrOptionalParameterList();
				setState(1996);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,278,_ctx) ) {
				case 1:
					{
					setState(1988);
					match(COMMA);
					setState(1992);
					_errHandler.sync(this);
					_la = _input.LA(1);
					while (_la==NL) {
						{
						{
						setState(1989);
						match(NL);
						}
						}
						setState(1994);
						_errHandler.sync(this);
						_la = _input.LA(1);
					}
					setState(1995);
					arrayParameter();
					}
					break;
				}
				setState(2006);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,280,_ctx) ) {
				case 1:
					{
					setState(1998);
					match(COMMA);
					setState(2002);
					_errHandler.sync(this);
					_la = _input.LA(1);
					while (_la==NL) {
						{
						{
						setState(1999);
						match(NL);
						}
						}
						setState(2004);
						_errHandler.sync(this);
						_la = _input.LA(1);
					}
					setState(2005);
					mandatoryParameterList();
					}
					break;
				}
				setState(2016);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,282,_ctx) ) {
				case 1:
					{
					setState(2008);
					match(COMMA);
					setState(2012);
					_errHandler.sync(this);
					_la = _input.LA(1);
					while (_la==NL) {
						{
						{
						setState(2009);
						match(NL);
						}
						}
						setState(2014);
						_errHandler.sync(this);
						_la = _input.LA(1);
					}
					setState(2015);
					hashParameter();
					}
					break;
				}
				setState(2026);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==COMMA) {
					{
					setState(2018);
					match(COMMA);
					setState(2022);
					_errHandler.sync(this);
					_la = _input.LA(1);
					while (_la==NL) {
						{
						{
						setState(2019);
						match(NL);
						}
						}
						setState(2024);
						_errHandler.sync(this);
						_la = _input.LA(1);
					}
					setState(2025);
					procParameter();
					}
				}

				}
				break;
			case STAR:
				enterOuterAlt(_localctx, 2);
				{
				setState(2028);
				arrayParameter();
				setState(2037);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,286,_ctx) ) {
				case 1:
					{
					setState(2029);
					match(COMMA);
					setState(2033);
					_errHandler.sync(this);
					_la = _input.LA(1);
					while (_la==NL) {
						{
						{
						setState(2030);
						match(NL);
						}
						}
						setState(2035);
						_errHandler.sync(this);
						_la = _input.LA(1);
					}
					setState(2036);
					mandatoryParameterList();
					}
					break;
				}
				setState(2047);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,288,_ctx) ) {
				case 1:
					{
					setState(2039);
					match(COMMA);
					setState(2043);
					_errHandler.sync(this);
					_la = _input.LA(1);
					while (_la==NL) {
						{
						{
						setState(2040);
						match(NL);
						}
						}
						setState(2045);
						_errHandler.sync(this);
						_la = _input.LA(1);
					}
					setState(2046);
					hashParameter();
					}
					break;
				}
				setState(2057);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==COMMA) {
					{
					setState(2049);
					match(COMMA);
					setState(2053);
					_errHandler.sync(this);
					_la = _input.LA(1);
					while (_la==NL) {
						{
						{
						setState(2050);
						match(NL);
						}
						}
						setState(2055);
						_errHandler.sync(this);
						_la = _input.LA(1);
					}
					setState(2056);
					procParameter();
					}
				}

				}
				break;
			case STAR2:
				enterOuterAlt(_localctx, 3);
				{
				setState(2059);
				hashParameter();
				setState(2068);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==COMMA) {
					{
					setState(2060);
					match(COMMA);
					setState(2064);
					_errHandler.sync(this);
					_la = _input.LA(1);
					while (_la==NL) {
						{
						{
						setState(2061);
						match(NL);
						}
						}
						setState(2066);
						_errHandler.sync(this);
						_la = _input.LA(1);
					}
					setState(2067);
					procParameter();
					}
				}

				}
				break;
			case AMP:
				enterOuterAlt(_localctx, 4);
				{
				setState(2070);
				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, 140, RULE_mandatoryOrOptionalParameterList);
		int _la;
		try {
			int _alt;
			enterOuterAlt(_localctx, 1);
			{
			setState(2073);
			mandatoryOrOptionalParameter();
			setState(2084);
			_errHandler.sync(this);
			_alt = getInterpreter().adaptivePredict(_input,295,_ctx);
			while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) {
				if ( _alt==1 ) {
					{
					{
					setState(2074);
					match(COMMA);
					setState(2078);
					_errHandler.sync(this);
					_la = _input.LA(1);
					while (_la==NL) {
						{
						{
						setState(2075);
						match(NL);
						}
						}
						setState(2080);
						_errHandler.sync(this);
						_la = _input.LA(1);
					}
					setState(2081);
					mandatoryOrOptionalParameter();
					}
					} 
				}
				setState(2086);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,295,_ctx);
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class MandatoryParameterListContext extends ParserRuleContext {
		public List mandatoryParameter() {
			return getRuleContexts(MandatoryParameterContext.class);
		}
		public MandatoryParameterContext mandatoryParameter(int i) {
			return getRuleContext(MandatoryParameterContext.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 MandatoryParameterListContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_mandatoryParameterList; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterMandatoryParameterList(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitMandatoryParameterList(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitMandatoryParameterList(this);
			else return visitor.visitChildren(this);
		}
	}

	public final MandatoryParameterListContext mandatoryParameterList() throws RecognitionException {
		MandatoryParameterListContext _localctx = new MandatoryParameterListContext(_ctx, getState());
		enterRule(_localctx, 142, RULE_mandatoryParameterList);
		int _la;
		try {
			int _alt;
			enterOuterAlt(_localctx, 1);
			{
			setState(2087);
			mandatoryParameter();
			setState(2098);
			_errHandler.sync(this);
			_alt = getInterpreter().adaptivePredict(_input,297,_ctx);
			while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) {
				if ( _alt==1 ) {
					{
					{
					setState(2088);
					match(COMMA);
					setState(2092);
					_errHandler.sync(this);
					_la = _input.LA(1);
					while (_la==NL) {
						{
						{
						setState(2089);
						match(NL);
						}
						}
						setState(2094);
						_errHandler.sync(this);
						_la = _input.LA(1);
					}
					setState(2095);
					mandatoryParameter();
					}
					} 
				}
				setState(2100);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,297,_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, 144, RULE_mandatoryOrOptionalParameter);
		try {
			setState(2103);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,298,_ctx) ) {
			case 1:
				_localctx = new MandatoryMandatoryOrOptionalParameterContext(_localctx);
				enterOuterAlt(_localctx, 1);
				{
				setState(2101);
				mandatoryParameter();
				}
				break;
			case 2:
				_localctx = new OptionalMandatoryOrOptionalParameterContext(_localctx);
				enterOuterAlt(_localctx, 2);
				{
				setState(2102);
				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, 146, RULE_mandatoryParameter);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(2105);
			match(LOCAL_VARIABLE_IDENTIFIER);
			setState(2107);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==COLON) {
				{
				setState(2106);
				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, 148, RULE_optionalParameter);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(2109);
			optionalParameterName();
			setState(2110);
			_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(2114);
			_errHandler.sync(this);
			_la = _input.LA(1);
			while (_la==NL) {
				{
				{
				setState(2111);
				match(NL);
				}
				}
				setState(2116);
				_errHandler.sync(this);
				_la = _input.LA(1);
			}
			setState(2117);
			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, 150, RULE_optionalParameterName);
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(2119);
			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, 152, RULE_arrayParameter);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(2121);
			match(STAR);
			setState(2123);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==LOCAL_VARIABLE_IDENTIFIER) {
				{
				setState(2122);
				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, 154, RULE_hashParameter);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(2125);
			match(STAR2);
			setState(2127);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==LOCAL_VARIABLE_IDENTIFIER) {
				{
				setState(2126);
				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, 156, RULE_procParameter);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(2129);
			match(AMP);
			setState(2131);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==LOCAL_VARIABLE_IDENTIFIER) {
				{
				setState(2130);
				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, 158, RULE_procParameterName);
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(2133);
			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 = 160;
		enterRecursionRule(_localctx, 160, RULE_classPath, _p);
		try {
			int _alt;
			enterOuterAlt(_localctx, 1);
			{
			setState(2139);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case COLON2:
				{
				_localctx = new TopClassPathContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;

				setState(2136);
				match(COLON2);
				setState(2137);
				match(CONSTANT_IDENTIFIER);
				}
				break;
			case CONSTANT_IDENTIFIER:
				{
				_localctx = new ClassNameContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(2138);
				match(CONSTANT_IDENTIFIER);
				}
				break;
			default:
				throw new NoViableAltException(this);
			}
			_ctx.stop = _input.LT(-1);
			setState(2146);
			_errHandler.sync(this);
			_alt = getInterpreter().adaptivePredict(_input,305,_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(2141);
					if (!(precpred(_ctx, 1))) throw new FailedPredicateException(this, "precpred(_ctx, 1)");
					setState(2142);
					match(COLON2);
					setState(2143);
					match(CONSTANT_IDENTIFIER);
					}
					} 
				}
				setState(2148);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,305,_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, 162, RULE_singletonObject);
		try {
			setState(2154);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case COLON2:
			case LOCAL_VARIABLE_IDENTIFIER:
			case LINE__:
			case ENCODING__:
			case FILE__:
			case FALSE:
			case NIL:
			case SELF:
			case TRUE:
			case GLOBAL_VARIABLE_IDENTIFIER:
			case INSTANCE_VARIABLE_IDENTIFIER:
			case CLASS_VARIABLE_IDENTIFIER:
			case CONSTANT_IDENTIFIER:
				_localctx = new VariableReferenceSingletonObjectContext(_localctx);
				enterOuterAlt(_localctx, 1);
				{
				setState(2149);
				variableReference();
				}
				break;
			case LPAREN:
				_localctx = new ExpressionSingletonObjectContext(_localctx);
				enterOuterAlt(_localctx, 2);
				{
				setState(2150);
				match(LPAREN);
				setState(2151);
				expressionOrCommand(0);
				setState(2152);
				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, 164, RULE_variableReference);
		try {
			setState(2160);
			_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(2156);
				variable();
				}
				break;
			case LINE__:
			case ENCODING__:
			case FILE__:
			case FALSE:
			case NIL:
			case SELF:
			case TRUE:
				_localctx = new PseudoVariableVariableReferenceContext(_localctx);
				enterOuterAlt(_localctx, 2);
				{
				setState(2157);
				pseudoVariable();
				}
				break;
			case COLON2:
				_localctx = new ConstantVariableReferenceContext(_localctx);
				enterOuterAlt(_localctx, 3);
				{
				setState(2158);
				match(COLON2);
				setState(2159);
				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, 166, RULE_associationList);
		int _la;
		try {
			int _alt;
			enterOuterAlt(_localctx, 1);
			{
			setState(2162);
			association();
			setState(2173);
			_errHandler.sync(this);
			_alt = getInterpreter().adaptivePredict(_input,309,_ctx);
			while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) {
				if ( _alt==1 ) {
					{
					{
					setState(2163);
					match(COMMA);
					setState(2167);
					_errHandler.sync(this);
					_la = _input.LA(1);
					while (_la==NL) {
						{
						{
						setState(2164);
						match(NL);
						}
						}
						setState(2169);
						_errHandler.sync(this);
						_la = _input.LA(1);
					}
					setState(2170);
					association();
					}
					} 
				}
				setState(2175);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,309,_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, 168, RULE_association);
		int _la;
		try {
			setState(2187);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case REGULAR_EXPRESSION_START:
			case LBRACK:
			case LPAREN:
			case LCURLY:
			case COLON:
			case COLON2:
			case DOT2:
			case DOT3:
			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 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 GLOBAL_VARIABLE_IDENTIFIER:
			case INSTANCE_VARIABLE_IDENTIFIER:
			case CLASS_VARIABLE_IDENTIFIER:
			case CONSTANT_IDENTIFIER:
				_localctx = new AssociationElementContext(_localctx);
				enterOuterAlt(_localctx, 1);
				{
				setState(2176);
				associationKey();
				setState(2177);
				_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(2181);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==NL) {
					{
					{
					setState(2178);
					match(NL);
					}
					}
					setState(2183);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(2184);
				operatorExpression(0);
				}
				break;
			case STAR2:
				_localctx = new AssociationHashArgContext(_localctx);
				enterOuterAlt(_localctx, 2);
				{
				setState(2186);
				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, 170, RULE_associationKey);
		try {
			setState(2191);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,312,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(2189);
				operatorExpression(0);
				}
				break;
			case 2:
				enterOuterAlt(_localctx, 2);
				{
				setState(2190);
				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, 172, RULE_associationHashArgument);
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(2193);
			match(STAR2);
			setState(2200);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,313,_ctx) ) {
			case 1:
				{
				setState(2194);
				match(LOCAL_VARIABLE_IDENTIFIER);
				}
				break;
			case 2:
				{
				setState(2195);
				methodCallsWithParentheses();
				}
				break;
			case 3:
				{
				{
				setState(2196);
				match(LPAREN);
				setState(2197);
				methodInvocationWithoutParentheses();
				setState(2198);
				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, 174, RULE_regexpLiteralContent);
		try {
			setState(2207);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case REGULAR_EXPRESSION_BODY:
				enterOuterAlt(_localctx, 1);
				{
				setState(2202);
				match(REGULAR_EXPRESSION_BODY);
				}
				break;
			case REGULAR_EXPRESSION_INTERPOLATION_BEGIN:
				enterOuterAlt(_localctx, 2);
				{
				setState(2203);
				match(REGULAR_EXPRESSION_INTERPOLATION_BEGIN);
				setState(2204);
				compoundStatement();
				setState(2205);
				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, 176, RULE_singleQuotedString);
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(2209);
			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, 178, RULE_singleOrDoubleQuotedString);
		try {
			setState(2213);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case SINGLE_QUOTED_STRING_LITERAL:
				enterOuterAlt(_localctx, 1);
				{
				setState(2211);
				singleQuotedString();
				}
				break;
			case DOUBLE_QUOTED_STRING_START:
				enterOuterAlt(_localctx, 2);
				{
				setState(2212);
				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, 180, RULE_doubleQuotedString);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(2215);
			match(DOUBLE_QUOTED_STRING_START);
			setState(2219);
			_errHandler.sync(this);
			_la = _input.LA(1);
			while (_la==DOUBLE_QUOTED_STRING_CHARACTER_SEQUENCE || _la==STRING_INTERPOLATION_BEGIN) {
				{
				{
				setState(2216);
				doubleQuotedStringContent();
				}
				}
				setState(2221);
				_errHandler.sync(this);
				_la = _input.LA(1);
			}
			setState(2222);
			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, 182, RULE_quotedExpandedExternalCommandString);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(2224);
			match(QUOTED_EXPANDED_EXTERNAL_COMMAND_LITERAL_START);
			setState(2228);
			_errHandler.sync(this);
			_la = _input.LA(1);
			while (_la==EXPANDED_LITERAL_CHARACTER_SEQUENCE || _la==DELIMITED_STRING_INTERPOLATION_BEGIN) {
				{
				{
				setState(2225);
				quotedExpandedLiteralStringContent();
				}
				}
				setState(2230);
				_errHandler.sync(this);
				_la = _input.LA(1);
			}
			setState(2231);
			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, 184, RULE_doubleQuotedStringContent);
		try {
			setState(2238);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case DOUBLE_QUOTED_STRING_CHARACTER_SEQUENCE:
				enterOuterAlt(_localctx, 1);
				{
				setState(2233);
				match(DOUBLE_QUOTED_STRING_CHARACTER_SEQUENCE);
				}
				break;
			case STRING_INTERPOLATION_BEGIN:
				enterOuterAlt(_localctx, 2);
				{
				setState(2234);
				match(STRING_INTERPOLATION_BEGIN);
				setState(2235);
				compoundStatement();
				setState(2236);
				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, 186, RULE_quotedNonExpandedLiteralString);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(2240);
			match(QUOTED_NON_EXPANDED_STRING_LITERAL_START);
			setState(2242);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==NON_EXPANDED_LITERAL_CHARACTER_SEQUENCE) {
				{
				setState(2241);
				match(NON_EXPANDED_LITERAL_CHARACTER_SEQUENCE);
				}
			}

			setState(2244);
			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, 188, RULE_quotedExpandedLiteralString);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(2246);
			match(QUOTED_EXPANDED_STRING_LITERAL_START);
			setState(2250);
			_errHandler.sync(this);
			_la = _input.LA(1);
			while (_la==EXPANDED_LITERAL_CHARACTER_SEQUENCE || _la==DELIMITED_STRING_INTERPOLATION_BEGIN) {
				{
				{
				setState(2247);
				quotedExpandedLiteralStringContent();
				}
				}
				setState(2252);
				_errHandler.sync(this);
				_la = _input.LA(1);
			}
			setState(2253);
			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, 190, RULE_quotedExpandedLiteralStringContent);
		try {
			setState(2260);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case EXPANDED_LITERAL_CHARACTER_SEQUENCE:
				enterOuterAlt(_localctx, 1);
				{
				setState(2255);
				match(EXPANDED_LITERAL_CHARACTER_SEQUENCE);
				}
				break;
			case DELIMITED_STRING_INTERPOLATION_BEGIN:
				enterOuterAlt(_localctx, 2);
				{
				setState(2256);
				match(DELIMITED_STRING_INTERPOLATION_BEGIN);
				setState(2257);
				compoundStatement();
				setState(2258);
				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, 192, RULE_quotedNonExpandedArrayElementContent);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(2263); 
			_errHandler.sync(this);
			_la = _input.LA(1);
			do {
				{
				{
				setState(2262);
				match(NON_EXPANDED_ARRAY_ITEM_CHARACTER);
				}
				}
				setState(2265); 
				_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, 194, RULE_quotedExpandedArrayElementContent);
		try {
			setState(2272);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case EXPANDED_ARRAY_ITEM_CHARACTER:
				enterOuterAlt(_localctx, 1);
				{
				setState(2267);
				match(EXPANDED_ARRAY_ITEM_CHARACTER);
				}
				break;
			case DELIMITED_ARRAY_ITEM_INTERPOLATION_BEGIN:
				enterOuterAlt(_localctx, 2);
				{
				setState(2268);
				match(DELIMITED_ARRAY_ITEM_INTERPOLATION_BEGIN);
				setState(2269);
				compoundStatement();
				setState(2270);
				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, 196, RULE_quotedExpandedArrayElement);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(2275); 
			_errHandler.sync(this);
			_la = _input.LA(1);
			do {
				{
				{
				setState(2274);
				quotedExpandedArrayElementContent();
				}
				}
				setState(2277); 
				_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, 198, RULE_quotedNonExpandedArrayElementList);
		int _la;
		try {
			int _alt;
			enterOuterAlt(_localctx, 1);
			{
			setState(2282);
			_errHandler.sync(this);
			_la = _input.LA(1);
			while (_la==NON_EXPANDED_ARRAY_ITEM_SEPARATOR) {
				{
				{
				setState(2279);
				match(NON_EXPANDED_ARRAY_ITEM_SEPARATOR);
				}
				}
				setState(2284);
				_errHandler.sync(this);
				_la = _input.LA(1);
			}
			setState(2285);
			quotedNonExpandedArrayElementContent();
			setState(2294);
			_errHandler.sync(this);
			_alt = getInterpreter().adaptivePredict(_input,327,_ctx);
			while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) {
				if ( _alt==1 ) {
					{
					{
					setState(2287); 
					_errHandler.sync(this);
					_la = _input.LA(1);
					do {
						{
						{
						setState(2286);
						match(NON_EXPANDED_ARRAY_ITEM_SEPARATOR);
						}
						}
						setState(2289); 
						_errHandler.sync(this);
						_la = _input.LA(1);
					} while ( _la==NON_EXPANDED_ARRAY_ITEM_SEPARATOR );
					setState(2291);
					quotedNonExpandedArrayElementContent();
					}
					} 
				}
				setState(2296);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,327,_ctx);
			}
			setState(2300);
			_errHandler.sync(this);
			_la = _input.LA(1);
			while (_la==NON_EXPANDED_ARRAY_ITEM_SEPARATOR) {
				{
				{
				setState(2297);
				match(NON_EXPANDED_ARRAY_ITEM_SEPARATOR);
				}
				}
				setState(2302);
				_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, 200, RULE_quotedExpandedArrayElementList);
		int _la;
		try {
			int _alt;
			enterOuterAlt(_localctx, 1);
			{
			setState(2306);
			_errHandler.sync(this);
			_la = _input.LA(1);
			while (_la==EXPANDED_ARRAY_ITEM_SEPARATOR) {
				{
				{
				setState(2303);
				match(EXPANDED_ARRAY_ITEM_SEPARATOR);
				}
				}
				setState(2308);
				_errHandler.sync(this);
				_la = _input.LA(1);
			}
			setState(2309);
			quotedExpandedArrayElement();
			setState(2318);
			_errHandler.sync(this);
			_alt = getInterpreter().adaptivePredict(_input,331,_ctx);
			while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) {
				if ( _alt==1 ) {
					{
					{
					setState(2311); 
					_errHandler.sync(this);
					_la = _input.LA(1);
					do {
						{
						{
						setState(2310);
						match(EXPANDED_ARRAY_ITEM_SEPARATOR);
						}
						}
						setState(2313); 
						_errHandler.sync(this);
						_la = _input.LA(1);
					} while ( _la==EXPANDED_ARRAY_ITEM_SEPARATOR );
					setState(2315);
					quotedExpandedArrayElement();
					}
					} 
				}
				setState(2320);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,331,_ctx);
			}
			setState(2324);
			_errHandler.sync(this);
			_la = _input.LA(1);
			while (_la==EXPANDED_ARRAY_ITEM_SEPARATOR) {
				{
				{
				setState(2321);
				match(EXPANDED_ARRAY_ITEM_SEPARATOR);
				}
				}
				setState(2326);
				_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, 202, RULE_symbol);
		try {
			setState(2332);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,333,_ctx) ) {
			case 1:
				_localctx = new PureSymbolLiteralContext(_localctx);
				enterOuterAlt(_localctx, 1);
				{
				setState(2327);
				match(SYMBOL_LITERAL);
				}
				break;
			case 2:
				_localctx = new SingleQuotedSymbolLiteralContext(_localctx);
				enterOuterAlt(_localctx, 2);
				{
				setState(2328);
				match(COLON);
				setState(2329);
				singleQuotedString();
				}
				break;
			case 3:
				_localctx = new DoubleQuotedSymbolLiteralContext(_localctx);
				enterOuterAlt(_localctx, 3);
				{
				setState(2330);
				match(COLON);
				setState(2331);
				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, 204, RULE_hereDoc);
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(2334);
			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, 206, RULE_isDefinedKeyword);
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(2336);
			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, 208, RULE_assignmentOperator);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(2338);
			_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, 210, RULE_statementModifier);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(2340);
			_la = _input.LA(1);
			if ( !(((((_la - 105)) & ~0x3f) == 0 && ((1L << (_la - 105)) & ((1L << (IF - 105)) | (1L << (RESCUE - 105)) | (1L << (UNLESS - 105)) | (1L << (UNTIL - 105)) | (1L << (WHILE - 105)))) != 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, 212, RULE_variable);
		try {
			setState(2347);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case CONSTANT_IDENTIFIER:
				_localctx = new ConstantIdentifierVariableContext(_localctx);
				enterOuterAlt(_localctx, 1);
				{
				setState(2342);
				match(CONSTANT_IDENTIFIER);
				}
				break;
			case GLOBAL_VARIABLE_IDENTIFIER:
				_localctx = new GlobalIdentifierVariableContext(_localctx);
				enterOuterAlt(_localctx, 2);
				{
				setState(2343);
				match(GLOBAL_VARIABLE_IDENTIFIER);
				}
				break;
			case CLASS_VARIABLE_IDENTIFIER:
				_localctx = new ClassIdentifierVariableContext(_localctx);
				enterOuterAlt(_localctx, 3);
				{
				setState(2344);
				match(CLASS_VARIABLE_IDENTIFIER);
				}
				break;
			case INSTANCE_VARIABLE_IDENTIFIER:
				_localctx = new InstanceIdentifierVariableContext(_localctx);
				enterOuterAlt(_localctx, 4);
				{
				setState(2345);
				match(INSTANCE_VARIABLE_IDENTIFIER);
				}
				break;
			case LOCAL_VARIABLE_IDENTIFIER:
				_localctx = new LocalIdentifierVariableContext(_localctx);
				enterOuterAlt(_localctx, 5);
				{
				setState(2346);
				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, 214, RULE_pseudoVariable);
		try {
			setState(2356);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case NIL:
				_localctx = new NilPseudoVariableContext(_localctx);
				enterOuterAlt(_localctx, 1);
				{
				setState(2349);
				match(NIL);
				}
				break;
			case TRUE:
				_localctx = new TruePseudoVariableContext(_localctx);
				enterOuterAlt(_localctx, 2);
				{
				setState(2350);
				match(TRUE);
				}
				break;
			case FALSE:
				_localctx = new FalsePseudoVariableContext(_localctx);
				enterOuterAlt(_localctx, 3);
				{
				setState(2351);
				match(FALSE);
				}
				break;
			case SELF:
				_localctx = new SelfPseudoVariableContext(_localctx);
				enterOuterAlt(_localctx, 4);
				{
				setState(2352);
				match(SELF);
				}
				break;
			case LINE__:
				_localctx = new LinePseudoVariableContext(_localctx);
				enterOuterAlt(_localctx, 5);
				{
				setState(2353);
				match(LINE__);
				}
				break;
			case FILE__:
				_localctx = new FilePseudoVariableContext(_localctx);
				enterOuterAlt(_localctx, 6);
				{
				setState(2354);
				match(FILE__);
				}
				break;
			case ENCODING__:
				_localctx = new EncodingPseudoVariableContext(_localctx);
				enterOuterAlt(_localctx, 7);
				{
				setState(2355);
				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, 216, RULE_unsignedNumericLiteral);
		try {
			setState(2364);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case DECIMAL_INTEGER_LITERAL:
				_localctx = new DecimalUnsignedLiteralContext(_localctx);
				enterOuterAlt(_localctx, 1);
				{
				setState(2358);
				match(DECIMAL_INTEGER_LITERAL);
				}
				break;
			case BINARY_INTEGER_LITERAL:
				_localctx = new BinaryUnsignedLiteralContext(_localctx);
				enterOuterAlt(_localctx, 2);
				{
				setState(2359);
				match(BINARY_INTEGER_LITERAL);
				}
				break;
			case OCTAL_INTEGER_LITERAL:
				_localctx = new OctalUnsignedLiteralContext(_localctx);
				enterOuterAlt(_localctx, 3);
				{
				setState(2360);
				match(OCTAL_INTEGER_LITERAL);
				}
				break;
			case HEXADECIMAL_INTEGER_LITERAL:
				_localctx = new HexadecimalUnsignedLiteralContext(_localctx);
				enterOuterAlt(_localctx, 4);
				{
				setState(2361);
				match(HEXADECIMAL_INTEGER_LITERAL);
				}
				break;
			case FLOAT_LITERAL_WITHOUT_EXPONENT:
				_localctx = new FloatWithoutExponentUnsignedLiteralContext(_localctx);
				enterOuterAlt(_localctx, 5);
				{
				setState(2362);
				match(FLOAT_LITERAL_WITHOUT_EXPONENT);
				}
				break;
			case FLOAT_LITERAL_WITH_EXPONENT:
				_localctx = new FloatWithExponentUnsignedLiteralContext(_localctx);
				enterOuterAlt(_localctx, 6);
				{
				setState(2363);
				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, 218, RULE_unaryOperator);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(2366);
			_la = _input.LA(1);
			if ( !((((_la) & ~0x3f) == 0 && ((1L << _la) & ((1L << EMARK) | (1L << PLUS) | (1L << TILDE))) != 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, 220, RULE_multiplicativeOperator);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(2368);
			_la = _input.LA(1);
			if ( !((((_la) & ~0x3f) == 0 && ((1L << _la) & ((1L << STAR) | (1L << SLASH) | (1L << PERCENT))) != 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, 222, RULE_additiveOperator);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(2370);
			_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, 224, RULE_bitwiseShiftOperator);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(2372);
			_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, 226, RULE_bitwiseOrOperator);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(2374);
			_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, 228, RULE_relationalOperator);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(2376);
			_la = _input.LA(1);
			if ( !((((_la) & ~0x3f) == 0 && ((1L << _la) & ((1L << GT) | (1L << GTEQ) | (1L << LT) | (1L << LTEQ))) != 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, 230, RULE_equalityOperator);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(2378);
			_la = _input.LA(1);
			if ( !((((_la) & ~0x3f) == 0 && ((1L << _la) & ((1L << EMARKEQ) | (1L << EMARKTILDE) | (1L << EQ2) | (1L << EQ3) | (1L << LTEQGT) | (1L << EQTILDE))) != 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, 232, RULE_rangeOperator);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(2380);
			_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, 234, RULE_keyword);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(2382);
			_la = _input.LA(1);
			if ( !(((((_la - 88)) & ~0x3f) == 0 && ((1L << (_la - 88)) & ((1L << (BEGIN_ - 88)) | (1L << (END_ - 88)) | (1L << (ALIAS - 88)) | (1L << (AND - 88)) | (1L << (BEGIN - 88)) | (1L << (BREAK - 88)) | (1L << (CASE - 88)) | (1L << (CLASS - 88)) | (1L << (DEF - 88)) | (1L << (IS_DEFINED - 88)) | (1L << (DO - 88)) | (1L << (ELSE - 88)) | (1L << (ELSIF - 88)) | (1L << (END - 88)) | (1L << (ENSURE - 88)) | (1L << (FOR - 88)) | (1L << (IF - 88)) | (1L << (IN - 88)) | (1L << (MODULE - 88)) | (1L << (NEXT - 88)) | (1L << (NOT - 88)) | (1L << (OR - 88)) | (1L << (REDO - 88)) | (1L << (RESCUE - 88)) | (1L << (RETRY - 88)) | (1L << (RETURN - 88)) | (1L << (SUPER - 88)) | (1L << (THEN - 88)) | (1L << (UNDEF - 88)) | (1L << (UNLESS - 88)) | (1L << (UNTIL - 88)) | (1L << (WHEN - 88)) | (1L << (WHILE - 88)) | (1L << (YIELD - 88)))) != 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 37:
			return expressionOrCommand_sempred((ExpressionOrCommandContext)_localctx, predIndex);
		case 38:
			return operatorExpression_sempred((OperatorExpressionContext)_localctx, predIndex);
		case 41:
			return primaryValue_sempred((PrimaryValueContext)_localctx, predIndex);
		case 45:
			return commandOrPrimaryValue_sempred((CommandOrPrimaryValueContext)_localctx, predIndex);
		case 80:
			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, 15);
		case 4:
			return precpred(_ctx, 13);
		case 5:
			return precpred(_ctx, 12);
		case 6:
			return precpred(_ctx, 11);
		case 7:
			return precpred(_ctx, 10);
		case 8:
			return precpred(_ctx, 9);
		case 9:
			return precpred(_ctx, 8);
		case 10:
			return precpred(_ctx, 7);
		case 11:
			return precpred(_ctx, 4);
		case 12:
			return precpred(_ctx, 55);
		case 13:
			return precpred(_ctx, 53);
		case 14:
			return precpred(_ctx, 52);
		case 15:
			return precpred(_ctx, 18);
		case 16:
			return precpred(_ctx, 17);
		case 17:
			return precpred(_ctx, 6);
		case 18:
			return precpred(_ctx, 5);
		case 19:
			return precpred(_ctx, 3);
		}
		return true;
	}
	private boolean commandOrPrimaryValue_sempred(CommandOrPrimaryValueContext _localctx, int predIndex) {
		switch (predIndex) {
		case 20:
			return precpred(_ctx, 1);
		}
		return true;
	}
	private boolean classPath_sempred(ClassPathContext _localctx, int predIndex) {
		switch (predIndex) {
		case 21:
			return precpred(_ctx, 1);
		}
		return true;
	}

	private static final int _serializedATNSegments = 2;
	private static final String _serializedATNSegment0 =
		"\3\u608b\ua72a\u8133\ub9ed\u417c\u3be7\u7786\u5964\3\u0098\u0953\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\4k\t"+
		"k\4l\tl\4m\tm\4n\tn\4o\to\4p\tp\4q\tq\4r\tr\4s\ts\4t\tt\4u\tu\4v\tv\4"+
		"w\tw\3\2\3\2\3\2\3\3\5\3\u00f3\n\3\3\3\7\3\u00f6\n\3\f\3\16\3\u00f9\13"+
		"\3\3\4\7\4\u00fc\n\4\f\4\16\4\u00ff\13\4\3\4\3\4\6\4\u0103\n\4\r\4\16"+
		"\4\u0104\3\4\7\4\u0108\n\4\f\4\16\4\u010b\13\4\3\5\3\5\3\5\3\5\7\5\u0111"+
		"\n\5\f\5\16\5\u0114\13\5\3\5\3\5\3\5\3\5\3\5\7\5\u011b\n\5\f\5\16\5\u011e"+
		"\13\5\3\5\3\5\3\5\7\5\u0123\n\5\f\5\16\5\u0126\13\5\3\5\7\5\u0129\n\5"+
		"\f\5\16\5\u012c\13\5\3\5\3\5\5\5\u0130\n\5\3\5\3\5\3\5\7\5\u0135\n\5\f"+
		"\5\16\5\u0138\13\5\3\5\3\5\7\5\u013c\n\5\f\5\16\5\u013f\13\5\3\6\3\6\5"+
		"\6\u0143\n\6\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\7\7\u0153\n\7\f\7\16\7\u0156\13\7\3\7\3\7\3\7\3\7\3\7\5\7"+
		"\u015d\n\7\3\7\3\7\3\7\7\7\u0162\n\7\f\7\16\7\u0165\13\7\3\7\3\7\3\7\3"+
		"\7\3\7\3\7\3\7\7\7\u016e\n\7\f\7\16\7\u0171\13\7\3\7\3\7\5\7\u0175\n\7"+
		"\3\b\3\b\3\b\7\b\u017a\n\b\f\b\16\b\u017d\13\b\3\b\3\b\3\b\3\b\3\b\7\b"+
		"\u0184\n\b\f\b\16\b\u0187\13\b\3\b\3\b\5\b\u018b\n\b\3\b\3\b\3\b\7\b\u0190"+
		"\n\b\f\b\16\b\u0193\13\b\3\b\3\b\3\b\3\b\3\b\7\b\u019a\n\b\f\b\16\b\u019d"+
		"\13\b\3\b\3\b\5\b\u01a1\n\b\5\b\u01a3\n\b\3\t\3\t\3\t\5\t\u01a8\n\t\3"+
		"\t\3\t\3\t\5\t\u01ad\n\t\3\t\3\t\3\t\3\t\3\t\3\t\3\t\3\t\5\t\u01b7\n\t"+
		"\3\n\3\n\3\n\6\n\u01bc\n\n\r\n\16\n\u01bd\3\n\5\n\u01c1\n\n\3\n\3\n\3"+
		"\n\6\n\u01c6\n\n\r\n\16\n\u01c7\3\n\5\n\u01cb\n\n\3\n\5\n\u01ce\n\n\3"+
		"\n\7\n\u01d1\n\n\f\n\16\n\u01d4\13\n\3\n\5\n\u01d7\n\n\3\n\5\n\u01da\n"+
		"\n\3\n\3\n\5\n\u01de\n\n\3\13\3\13\3\13\6\13\u01e3\n\13\r\13\16\13\u01e4"+
		"\3\13\5\13\u01e8\n\13\3\13\3\13\3\13\6\13\u01ed\n\13\r\13\16\13\u01ee"+
		"\3\13\5\13\u01f2\n\13\3\13\5\13\u01f5\n\13\3\f\3\f\5\f\u01f9\n\f\3\f\3"+
		"\f\7\f\u01fd\n\f\f\f\16\f\u0200\13\f\3\r\3\r\3\r\3\r\3\16\3\16\5\16\u0208"+
		"\n\16\3\17\3\17\5\17\u020c\n\17\3\17\3\17\3\17\5\17\u0211\n\17\7\17\u0213"+
		"\n\17\f\17\16\17\u0216\13\17\3\20\3\20\3\21\3\21\3\21\5\21\u021d\n\21"+
		"\3\22\3\22\3\22\5\22\u0222\n\22\3\23\3\23\3\23\5\23\u0227\n\23\3\23\3"+
		"\23\3\24\3\24\3\24\3\24\3\24\3\24\5\24\u0231\n\24\3\24\3\24\3\24\3\24"+
		"\3\24\3\24\3\24\3\24\5\24\u023b\n\24\3\25\3\25\3\25\7\25\u0240\n\25\f"+
		"\25\16\25\u0243\13\25\3\25\3\25\7\25\u0247\n\25\f\25\16\25\u024a\13\25"+
		"\3\25\3\25\7\25\u024e\n\25\f\25\16\25\u0251\13\25\3\25\3\25\3\25\3\25"+
		"\5\25\u0257\n\25\3\25\3\25\3\25\3\25\3\25\3\25\3\25\5\25\u0260\n\25\3"+
		"\26\3\26\5\26\u0264\n\26\3\27\3\27\7\27\u0268\n\27\f\27\16\27\u026b\13"+
		"\27\3\30\3\30\3\30\5\30\u0270\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\u0280\n\31\3\32\3\32\5\32\u0284"+
		"\n\32\3\32\7\32\u0287\n\32\f\32\16\32\u028a\13\32\3\32\7\32\u028d\n\32"+
		"\f\32\16\32\u0290\13\32\3\32\5\32\u0293\n\32\3\33\3\33\3\33\3\33\3\33"+
		"\5\33\u029a\n\33\3\34\3\34\5\34\u029e\n\34\3\34\3\34\3\34\3\34\3\34\3"+
		"\34\5\34\u02a6\n\34\3\34\7\34\u02a9\n\34\f\34\16\34\u02ac\13\34\3\34\7"+
		"\34\u02af\n\34\f\34\16\34\u02b2\13\34\3\34\3\34\5\34\u02b6\n\34\3\34\3"+
		"\34\3\34\7\34\u02bb\n\34\f\34\16\34\u02be\13\34\3\34\7\34\u02c1\n\34\f"+
		"\34\16\34\u02c4\13\34\5\34\u02c6\n\34\3\35\3\35\3\35\5\35\u02cb\n\35\3"+
		"\35\5\35\u02ce\n\35\3\36\3\36\3\36\3\36\5\36\u02d4\n\36\3\37\3\37\3\37"+
		"\7\37\u02d9\n\37\f\37\16\37\u02dc\13\37\3\37\7\37\u02df\n\37\f\37\16\37"+
		"\u02e2\13\37\3 \3 \3 \7 \u02e7\n \f \16 \u02ea\13 \3 \6 \u02ed\n \r \16"+
		" \u02ee\3!\3!\7!\u02f3\n!\f!\16!\u02f6\13!\3!\5!\u02f9\n!\3!\7!\u02fc"+
		"\n!\f!\16!\u02ff\13!\3!\3!\3!\7!\u0304\n!\f!\16!\u0307\13!\3!\3!\5!\u030b"+
		"\n!\3!\7!\u030e\n!\f!\16!\u0311\13!\3!\3!\3!\3!\7!\u0317\n!\f!\16!\u031a"+
		"\13!\3!\3!\3!\7!\u031f\n!\f!\16!\u0322\13!\3!\3!\5!\u0326\n!\3!\7!\u0329"+
		"\n!\f!\16!\u032c\13!\3!\3!\3!\3!\7!\u0332\n!\f!\16!\u0335\13!\3!\3!\5"+
		"!\u0339\n!\3!\7!\u033c\n!\f!\16!\u033f\13!\3!\3!\5!\u0343\n!\3\"\3\"\3"+
		"\"\3\"\7\"\u0349\n\"\f\"\16\"\u034c\13\"\3\"\5\"\u034f\n\"\3\"\3\"\7\""+
		"\u0353\n\"\f\"\16\"\u0356\13\"\3\"\5\"\u0359\n\"\3\"\3\"\3\"\7\"\u035e"+
		"\n\"\f\"\16\"\u0361\13\"\3\"\5\"\u0364\n\"\3\"\3\"\7\"\u0368\n\"\f\"\16"+
		"\"\u036b\13\"\3\"\5\"\u036e\n\"\3\"\3\"\7\"\u0372\n\"\f\"\16\"\u0375\13"+
		"\"\3\"\5\"\u0378\n\"\3\"\3\"\3\"\7\"\u037d\n\"\f\"\16\"\u0380\13\"\3\""+
		"\5\"\u0383\n\"\3\"\3\"\7\"\u0387\n\"\f\"\16\"\u038a\13\"\3\"\5\"\u038d"+
		"\n\"\3\"\3\"\5\"\u0391\n\"\3\"\3\"\5\"\u0395\n\"\3#\3#\3#\3#\7#\u039b"+
		"\n#\f#\16#\u039e\13#\3#\5#\u03a1\n#\5#\u03a3\n#\3$\3$\3$\7$\u03a8\n$\f"+
		"$\16$\u03ab\13$\3$\7$\u03ae\n$\f$\16$\u03b1\13$\3%\3%\5%\u03b5\n%\3%\3"+
		"%\7%\u03b9\n%\f%\16%\u03bc\13%\3%\3%\5%\u03c0\n%\7%\u03c2\n%\f%\16%\u03c5"+
		"\13%\3%\5%\u03c8\n%\3&\3&\5&\u03cc\n&\3\'\3\'\3\'\5\'\u03d1\n\'\3\'\3"+
		"\'\3\'\7\'\u03d6\n\'\f\'\16\'\u03d9\13\'\3\'\5\'\u03dc\n\'\3\'\3\'\3\'"+
		"\7\'\u03e1\n\'\f\'\16\'\u03e4\13\'\3\'\7\'\u03e7\n\'\f\'\16\'\u03ea\13"+
		"\'\3(\3(\3(\3(\3(\3(\7(\u03f2\n(\f(\16(\u03f5\13(\3(\3(\7(\u03f9\n(\f"+
		"(\16(\u03fc\13(\3(\3(\7(\u0400\n(\f(\16(\u0403\13(\3(\3(\7(\u0407\n(\f"+
		"(\16(\u040a\13(\3)\3)\3)\3)\3)\3)\5)\u0412\n)\3*\3*\7*\u0416\n*\f*\16"+
		"*\u0419\13*\3*\3*\5*\u041d\n*\5*\u041f\n*\3*\7*\u0422\n*\f*\16*\u0425"+
		"\13*\3*\3*\3+\3+\3+\3+\7+\u042d\n+\f+\16+\u0430\13+\3+\3+\3+\3+\3+\3+"+
		"\7+\u0438\n+\f+\16+\u043b\13+\3+\3+\3+\3+\3+\3+\5+\u0443\n+\3+\5+\u0446"+
		"\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+\u0469\n+\3+\5+\u046c\n+\3+\3+\7+"+
		"\u0470\n+\f+\16+\u0473\13+\3+\3+\3+\3+\5+\u0479\n+\3+\3+\3+\7+\u047e\n"+
		"+\f+\16+\u0481\13+\3+\3+\3+\7+\u0486\n+\f+\16+\u0489\13+\3+\5+\u048c\n"+
		"+\3+\3+\3+\3+\7+\u0492\n+\f+\16+\u0495\13+\3+\3+\3+\5+\u049a\n+\3+\3+"+
		"\3+\3+\7+\u04a0\n+\f+\16+\u04a3\13+\3+\3+\3+\3+\3+\3+\5+\u04ab\n+\3+\3"+
		"+\3+\3+\3+\3+\7+\u04b3\n+\f+\16+\u04b6\13+\3+\3+\7+\u04ba\n+\f+\16+\u04bd"+
		"\13+\3+\6+\u04c0\n+\r+\16+\u04c1\3+\5+\u04c5\n+\3+\3+\3+\3+\7+\u04cb\n"+
		"+\f+\16+\u04ce\13+\3+\6+\u04d1\n+\r+\16+\u04d2\3+\5+\u04d6\n+\3+\3+\3"+
		"+\3+\7+\u04dc\n+\f+\16+\u04df\13+\3+\3+\3+\3+\3+\3+\7+\u04e7\n+\f+\16"+
		"+\u04ea\13+\3+\3+\3+\7+\u04ef\n+\f+\16+\u04f2\13+\3+\3+\3+\3+\3+\3+\3"+
		"+\7+\u04fb\n+\f+\16+\u04fe\13+\3+\5+\u0501\n+\3+\7+\u0504\n+\f+\16+\u0507"+
		"\13+\3+\3+\3+\5+\u050c\n+\3+\3+\3+\5+\u0511\n+\3+\3+\3+\5+\u0516\n+\3"+
		"+\3+\3+\5+\u051b\n+\3+\3+\3+\5+\u0520\n+\3+\3+\3+\7+\u0525\n+\f+\16+\u0528"+
		"\13+\3+\3+\7+\u052c\n+\f+\16+\u052f\13+\3+\3+\5+\u0533\n+\3+\3+\3+\7+"+
		"\u0538\n+\f+\16+\u053b\13+\3+\3+\3+\7+\u0540\n+\f+\16+\u0543\13+\3+\3"+
		"+\3+\3+\7+\u0549\n+\f+\16+\u054c\13+\3+\3+\3+\7+\u0551\n+\f+\16+\u0554"+
		"\13+\3+\3+\3+\3+\3+\3+\3+\3+\3+\3+\3+\3+\3+\3+\5+\u0564\n+\3+\3+\3+\7"+
		"+\u0569\n+\f+\16+\u056c\13+\3+\3+\3+\3+\7+\u0572\n+\f+\16+\u0575\13+\3"+
		"+\3+\3+\3+\3+\7+\u057c\n+\f+\16+\u057f\13+\3+\3+\3+\3+\3+\7+\u0586\n+"+
		"\f+\16+\u0589\13+\3+\3+\3+\3+\3+\7+\u0590\n+\f+\16+\u0593\13+\3+\3+\3"+
		"+\3+\7+\u0599\n+\f+\16+\u059c\13+\3+\3+\3+\3+\3+\7+\u05a3\n+\f+\16+\u05a6"+
		"\13+\3+\3+\3+\3+\3+\7+\u05ad\n+\f+\16+\u05b0\13+\3+\3+\3+\3+\3+\7+\u05b7"+
		"\n+\f+\16+\u05ba\13+\3+\3+\3+\3+\3+\3+\3+\7+\u05c3\n+\f+\16+\u05c6\13"+
		"+\3+\3+\3+\3+\3+\5+\u05cd\n+\3+\3+\3+\7+\u05d2\n+\f+\16+\u05d5\13+\3+"+
		"\3+\3+\3+\3+\7+\u05dc\n+\f+\16+\u05df\13+\3+\3+\3+\3+\3+\3+\3+\5+\u05e8"+
		"\n+\3+\3+\3+\7+\u05ed\n+\f+\16+\u05f0\13+\3+\3+\7+\u05f4\n+\f+\16+\u05f7"+
		"\13+\3+\3+\5+\u05fb\n+\3+\5+\u05fe\n+\3+\3+\3+\7+\u0603\n+\f+\16+\u0606"+
		"\13+\3+\3+\5+\u060a\n+\3+\3+\3+\7+\u060f\n+\f+\16+\u0612\13+\3+\3+\5+"+
		"\u0616\n+\3+\3+\7+\u061a\n+\f+\16+\u061d\13+\3,\3,\5,\u0621\n,\3,\3,\5"+
		",\u0625\n,\3-\3-\5-\u0629\n-\3-\5-\u062c\n-\3-\3-\5-\u0630\n-\3-\5-\u0633"+
		"\n-\3-\3-\3-\3-\3-\3-\3-\3-\3-\3-\3-\3-\3-\3-\3-\5-\u0644\n-\3-\5-\u0647"+
		"\n-\3.\3.\5.\u064b\n.\3/\3/\3/\3/\3/\5/\u0652\n/\3/\3/\3/\7/\u0657\n/"+
		"\f/\16/\u065a\13/\3/\7/\u065d\n/\f/\16/\u0660\13/\3\60\3\60\7\60\u0664"+
		"\n\60\f\60\16\60\u0667\13\60\3\60\5\60\u066a\n\60\3\60\3\60\3\60\3\60"+
		"\5\60\u0670\n\60\3\61\3\61\7\61\u0674\n\61\f\61\16\61\u0677\13\61\3\61"+
		"\5\61\u067a\n\61\3\61\3\61\3\61\3\62\3\62\7\62\u0681\n\62\f\62\16\62\u0684"+
		"\13\62\3\62\3\62\3\62\7\62\u0689\n\62\f\62\16\62\u068c\13\62\3\62\3\62"+
		"\7\62\u0690\n\62\f\62\16\62\u0693\13\62\3\62\3\62\5\62\u0697\n\62\3\63"+
		"\3\63\3\63\7\63\u069c\n\63\f\63\16\63\u069f\13\63\3\63\5\63\u06a2\n\63"+
		"\3\63\3\63\7\63\u06a6\n\63\f\63\16\63\u06a9\13\63\3\63\7\63\u06ac\n\63"+
		"\f\63\16\63\u06af\13\63\3\63\3\63\7\63\u06b3\n\63\f\63\16\63\u06b6\13"+
		"\63\3\63\5\63\u06b9\n\63\3\63\3\63\7\63\u06bd\n\63\f\63\16\63\u06c0\13"+
		"\63\3\63\5\63\u06c3\n\63\3\63\3\63\3\63\7\63\u06c8\n\63\f\63\16\63\u06cb"+
		"\13\63\3\63\7\63\u06ce\n\63\f\63\16\63\u06d1\13\63\3\63\3\63\7\63\u06d5"+
		"\n\63\f\63\16\63\u06d8\13\63\3\63\5\63\u06db\n\63\3\63\3\63\7\63\u06df"+
		"\n\63\f\63\16\63\u06e2\13\63\3\63\5\63\u06e5\n\63\3\63\3\63\3\63\7\63"+
		"\u06ea\n\63\f\63\16\63\u06ed\13\63\3\63\5\63\u06f0\n\63\3\63\5\63\u06f3"+
		"\n\63\3\64\3\64\3\64\7\64\u06f8\n\64\f\64\16\64\u06fb\13\64\3\64\7\64"+
		"\u06fe\n\64\f\64\16\64\u0701\13\64\3\65\3\65\3\65\5\65\u0706\n\65\3\66"+
		"\3\66\3\66\7\66\u070b\n\66\f\66\16\66\u070e\13\66\3\66\7\66\u0711\n\66"+
		"\f\66\16\66\u0714\13\66\3\67\3\67\5\67\u0718\n\67\38\38\38\38\78\u071e"+
		"\n8\f8\168\u0721\138\38\58\u0724\n8\38\38\78\u0728\n8\f8\168\u072b\13"+
		"8\38\78\u072e\n8\f8\168\u0731\138\38\38\38\38\38\38\78\u0739\n8\f8\16"+
		"8\u073c\138\38\78\u073f\n8\f8\168\u0742\138\38\38\58\u0746\n8\39\69\u0749"+
		"\n9\r9\169\u074a\39\39\59\u074f\n9\39\39\59\u0753\n9\3:\3:\3:\3;\3;\7"+
		";\u075a\n;\f;\16;\u075d\13;\3;\3;\3;\3<\3<\7<\u0764\n<\f<\16<\u0767\13"+
		"<\3<\3<\3<\3=\3=\3=\5=\u076f\n=\3=\5=\u0772\n=\3>\6>\u0775\n>\r>\16>\u0776"+
		"\3>\3>\3>\5>\u077c\n>\3?\3?\5?\u0780\n?\3@\3@\7@\u0784\n@\f@\16@\u0787"+
		"\13@\3@\5@\u078a\n@\3@\5@\u078d\n@\3A\3A\5A\u0791\nA\3A\5A\u0794\nA\3"+
		"A\3A\3B\3B\5B\u079a\nB\3C\3C\3C\3D\3D\3D\3E\3E\3E\3E\3E\5E\u07a7\nE\3"+
		"E\3E\3E\3E\5E\u07ad\nE\3F\3F\7F\u07b1\nF\fF\16F\u07b4\13F\3F\5F\u07b7"+
		"\nF\3F\7F\u07ba\nF\fF\16F\u07bd\13F\3F\3F\5F\u07c1\nF\3F\5F\u07c4\nF\3"+
		"G\3G\3G\7G\u07c9\nG\fG\16G\u07cc\13G\3G\5G\u07cf\nG\3G\3G\7G\u07d3\nG"+
		"\fG\16G\u07d6\13G\3G\5G\u07d9\nG\3G\3G\7G\u07dd\nG\fG\16G\u07e0\13G\3"+
		"G\5G\u07e3\nG\3G\3G\7G\u07e7\nG\fG\16G\u07ea\13G\3G\5G\u07ed\nG\3G\3G"+
		"\3G\7G\u07f2\nG\fG\16G\u07f5\13G\3G\5G\u07f8\nG\3G\3G\7G\u07fc\nG\fG\16"+
		"G\u07ff\13G\3G\5G\u0802\nG\3G\3G\7G\u0806\nG\fG\16G\u0809\13G\3G\5G\u080c"+
		"\nG\3G\3G\3G\7G\u0811\nG\fG\16G\u0814\13G\3G\5G\u0817\nG\3G\5G\u081a\n"+
		"G\3H\3H\3H\7H\u081f\nH\fH\16H\u0822\13H\3H\7H\u0825\nH\fH\16H\u0828\13"+
		"H\3I\3I\3I\7I\u082d\nI\fI\16I\u0830\13I\3I\7I\u0833\nI\fI\16I\u0836\13"+
		"I\3J\3J\5J\u083a\nJ\3K\3K\5K\u083e\nK\3L\3L\3L\7L\u0843\nL\fL\16L\u0846"+
		"\13L\3L\3L\3M\3M\3N\3N\5N\u084e\nN\3O\3O\5O\u0852\nO\3P\3P\5P\u0856\n"+
		"P\3Q\3Q\3R\3R\3R\3R\5R\u085e\nR\3R\3R\3R\7R\u0863\nR\fR\16R\u0866\13R"+
		"\3S\3S\3S\3S\3S\5S\u086d\nS\3T\3T\3T\3T\5T\u0873\nT\3U\3U\3U\7U\u0878"+
		"\nU\fU\16U\u087b\13U\3U\7U\u087e\nU\fU\16U\u0881\13U\3V\3V\3V\7V\u0886"+
		"\nV\fV\16V\u0889\13V\3V\3V\3V\5V\u088e\nV\3W\3W\5W\u0892\nW\3X\3X\3X\3"+
		"X\3X\3X\3X\5X\u089b\nX\3Y\3Y\3Y\3Y\3Y\5Y\u08a2\nY\3Z\3Z\3[\3[\5[\u08a8"+
		"\n[\3\\\3\\\7\\\u08ac\n\\\f\\\16\\\u08af\13\\\3\\\3\\\3]\3]\7]\u08b5\n"+
		"]\f]\16]\u08b8\13]\3]\3]\3^\3^\3^\3^\3^\5^\u08c1\n^\3_\3_\5_\u08c5\n_"+
		"\3_\3_\3`\3`\7`\u08cb\n`\f`\16`\u08ce\13`\3`\3`\3a\3a\3a\3a\3a\5a\u08d7"+
		"\na\3b\6b\u08da\nb\rb\16b\u08db\3c\3c\3c\3c\3c\5c\u08e3\nc\3d\6d\u08e6"+
		"\nd\rd\16d\u08e7\3e\7e\u08eb\ne\fe\16e\u08ee\13e\3e\3e\6e\u08f2\ne\re"+
		"\16e\u08f3\3e\7e\u08f7\ne\fe\16e\u08fa\13e\3e\7e\u08fd\ne\fe\16e\u0900"+
		"\13e\3f\7f\u0903\nf\ff\16f\u0906\13f\3f\3f\6f\u090a\nf\rf\16f\u090b\3"+
		"f\7f\u090f\nf\ff\16f\u0912\13f\3f\7f\u0915\nf\ff\16f\u0918\13f\3g\3g\3"+
		"g\3g\3g\5g\u091f\ng\3h\3h\3i\3i\3j\3j\3k\3k\3l\3l\3l\3l\3l\5l\u092e\n"+
		"l\3m\3m\3m\3m\3m\3m\3m\5m\u0937\nm\3n\3n\3n\3n\3n\3n\5n\u093f\nn\3o\3"+
		"o\3p\3p\3q\3q\3r\3r\3s\3s\3t\3t\3u\3u\3v\3v\3w\3w\3w\2\b\bLNT\\\u00a2"+
		"x\2\4\6\b\n\f\16\20\22\24\26\30\32\34\36 \"$&(*,.\60\62\64\668:<>@BDF"+
		"HJLNPRTVXZ\\^`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\u00d4"+
		"\u00d6\u00d8\u00da\u00dc\u00de\u00e0\u00e2\u00e4\u00e6\u00e8\u00ea\u00ec"+
		"\2\25\4\2\33\33SS\4\2\31\31\34\34\4\2VV\u0083\u0083\5\2\37\37\"\"**\5"+
		"\2\31\31\34\34\'\'\3\2\66\67\4\2]]qq\4\2\30\30**\4\2\30\30  \4\2**??\6"+
		"\2kkss{|~~\5\2\"\"\66\66<<\4\288:;\3\2\64\65\4\2((--\3\2\60\63\5\2#$+"+
		",./\3\2\35\36\7\2Ziknpuwxz\177\2\u0aaa\2\u00ee\3\2\2\2\4\u00f2\3\2\2\2"+
		"\6\u00fd\3\2\2\2\b\u012f\3\2\2\2\n\u0142\3\2\2\2\f\u0174\3\2\2\2\16\u01a2"+
		"\3\2\2\2\20\u01b6\3\2\2\2\22\u01dd\3\2\2\2\24\u01f4\3\2\2\2\26\u01f6\3"+
		"\2\2\2\30\u0201\3\2\2\2\32\u0207\3\2\2\2\34\u020b\3\2\2\2\36\u0217\3\2"+
		"\2\2 \u021c\3\2\2\2\"\u0221\3\2\2\2$\u0226\3\2\2\2&\u023a\3\2\2\2(\u025f"+
		"\3\2\2\2*\u0263\3\2\2\2,\u0265\3\2\2\2.\u026c\3\2\2\2\60\u027f\3\2\2\2"+
		"\62\u0281\3\2\2\2\64\u0299\3\2\2\2\66\u02c5\3\2\2\28\u02cd\3\2\2\2:\u02d3"+
		"\3\2\2\2<\u02d5\3\2\2\2>\u02e3\3\2\2\2@\u0342\3\2\2\2B\u0394\3\2\2\2D"+
		"\u03a2\3\2\2\2F\u03a4\3\2\2\2H\u03c7\3\2\2\2J\u03c9\3\2\2\2L\u03db\3\2"+
		"\2\2N\u03eb\3\2\2\2P\u0411\3\2\2\2R\u0413\3\2\2\2T\u0563\3\2\2\2V\u0624"+
		"\3\2\2\2X\u0646\3\2\2\2Z\u064a\3\2\2\2\\\u0651\3\2\2\2^\u066f\3\2\2\2"+
		"`\u0671\3\2\2\2b\u0696\3\2\2\2d\u06f2\3\2\2\2f\u06f4\3\2\2\2h\u0705\3"+
		"\2\2\2j\u0707\3\2\2\2l\u0717\3\2\2\2n\u0745\3\2\2\2p\u0752\3\2\2\2r\u0754"+
		"\3\2\2\2t\u0757\3\2\2\2v\u0761\3\2\2\2x\u0771\3\2\2\2z\u077b\3\2\2\2|"+
		"\u077f\3\2\2\2~\u0781\3\2\2\2\u0080\u078e\3\2\2\2\u0082\u0799\3\2\2\2"+
		"\u0084\u079b\3\2\2\2\u0086\u079e\3\2\2\2\u0088\u07ac\3\2\2\2\u008a\u07c3"+
		"\3\2\2\2\u008c\u0819\3\2\2\2\u008e\u081b\3\2\2\2\u0090\u0829\3\2\2\2\u0092"+
		"\u0839\3\2\2\2\u0094\u083b\3\2\2\2\u0096\u083f\3\2\2\2\u0098\u0849\3\2"+
		"\2\2\u009a\u084b\3\2\2\2\u009c\u084f\3\2\2\2\u009e\u0853\3\2\2\2\u00a0"+
		"\u0857\3\2\2\2\u00a2\u085d\3\2\2\2\u00a4\u086c\3\2\2\2\u00a6\u0872\3\2"+
		"\2\2\u00a8\u0874\3\2\2\2\u00aa\u088d\3\2\2\2\u00ac\u0891\3\2\2\2\u00ae"+
		"\u0893\3\2\2\2\u00b0\u08a1\3\2\2\2\u00b2\u08a3\3\2\2\2\u00b4\u08a7\3\2"+
		"\2\2\u00b6\u08a9\3\2\2\2\u00b8\u08b2\3\2\2\2\u00ba\u08c0\3\2\2\2\u00bc"+
		"\u08c2\3\2\2\2\u00be\u08c8\3\2\2\2\u00c0\u08d6\3\2\2\2\u00c2\u08d9\3\2"+
		"\2\2\u00c4\u08e2\3\2\2\2\u00c6\u08e5\3\2\2\2\u00c8\u08ec\3\2\2\2\u00ca"+
		"\u0904\3\2\2\2\u00cc\u091e\3\2\2\2\u00ce\u0920\3\2\2\2\u00d0\u0922\3\2"+
		"\2\2\u00d2\u0924\3\2\2\2\u00d4\u0926\3\2\2\2\u00d6\u092d\3\2\2\2\u00d8"+
		"\u0936\3\2\2\2\u00da\u093e\3\2\2\2\u00dc\u0940\3\2\2\2\u00de\u0942\3\2"+
		"\2\2\u00e0\u0944\3\2\2\2\u00e2\u0946\3\2\2\2\u00e4\u0948\3\2\2\2\u00e6"+
		"\u094a\3\2\2\2\u00e8\u094c\3\2\2\2\u00ea\u094e\3\2\2\2\u00ec\u0950\3\2"+
		"\2\2\u00ee\u00ef\5\4\3\2\u00ef\u00f0\7\2\2\3\u00f0\3\3\2\2\2\u00f1\u00f3"+
		"\5\6\4\2\u00f2\u00f1\3\2\2\2\u00f2\u00f3\3\2\2\2\u00f3\u00f7\3\2\2\2\u00f4"+
		"\u00f6\t\2\2\2\u00f5\u00f4\3\2\2\2\u00f6\u00f9\3\2\2\2\u00f7\u00f5\3\2"+
		"\2\2\u00f7\u00f8\3\2\2\2\u00f8\5\3\2\2\2\u00f9\u00f7\3\2\2\2\u00fa\u00fc"+
		"\t\2\2\2\u00fb\u00fa\3\2\2\2\u00fc\u00ff\3\2\2\2\u00fd\u00fb\3\2\2\2\u00fd"+
		"\u00fe\3\2\2\2\u00fe\u0100\3\2\2\2\u00ff\u00fd\3\2\2\2\u0100\u0109\5\b"+
		"\5\2\u0101\u0103\t\2\2\2\u0102\u0101\3\2\2\2\u0103\u0104\3\2\2\2\u0104"+
		"\u0102\3\2\2\2\u0104\u0105\3\2\2\2\u0105\u0106\3\2\2\2\u0106\u0108\5\b"+
		"\5\2\u0107\u0102\3\2\2\2\u0108\u010b\3\2\2\2\u0109\u0107\3\2\2\2\u0109"+
		"\u010a\3\2\2\2\u010a\7\3\2\2\2\u010b\u0109\3\2\2\2\u010c\u010d\b\5\1\2"+
		"\u010d\u0130\5L\'\2\u010e\u0112\7\\\2\2\u010f\u0111\7S\2\2\u0110\u010f"+
		"\3\2\2\2\u0111\u0114\3\2\2\2\u0112\u0110\3\2\2\2\u0112\u0113\3\2\2\2\u0113"+
		"\u0115\3\2\2\2\u0114\u0112\3\2\2\2\u0115\u0116\5\n\6\2\u0116\u0117\5\n"+
		"\6\2\u0117\u0130\3\2\2\2\u0118\u011c\7z\2\2\u0119\u011b\7S\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\u012a\5\n\6\2\u0120\u0124\7\32"+
		"\2\2\u0121\u0123\7S\2\2\u0122\u0121\3\2\2\2\u0123\u0126\3\2\2\2\u0124"+
		"\u0122\3\2\2\2\u0124\u0125\3\2\2\2\u0125\u0127\3\2\2\2\u0126\u0124\3\2"+
		"\2\2\u0127\u0129\5\n\6\2\u0128\u0120\3\2\2\2\u0129\u012c\3\2\2\2\u012a"+
		"\u0128\3\2\2\2\u012a\u012b\3\2\2\2\u012b\u0130\3\2\2\2\u012c\u012a\3\2"+
		"\2\2\u012d\u0130\5\f\7\2\u012e\u0130\5\16\b\2\u012f\u010c\3\2\2\2\u012f"+
		"\u010e\3\2\2\2\u012f\u0118\3\2\2\2\u012f\u012d\3\2\2\2\u012f\u012e\3\2"+
		"\2\2\u0130\u013d\3\2\2\2\u0131\u0132\f\5\2\2\u0132\u0136\5\u00d4k\2\u0133"+
		"\u0135\7S\2\2\u0134\u0133\3\2\2\2\u0135\u0138\3\2\2\2\u0136\u0134\3\2"+
		"\2\2\u0136\u0137\3\2\2\2\u0137\u0139\3\2\2\2\u0138\u0136\3\2\2\2\u0139"+
		"\u013a\5L\'\2\u013a\u013c\3\2\2\2\u013b\u0131\3\2\2\2\u013c\u013f\3\2"+
		"\2\2\u013d\u013b\3\2\2\2\u013d\u013e\3\2\2\2\u013e\t\3\2\2\2\u013f\u013d"+
		"\3\2\2\2\u0140\u0143\5\u0088E\2\u0141\u0143\5\u00ccg\2\u0142\u0140\3\2"+
		"\2\2\u0142\u0141\3\2\2\2\u0143\13\3\2\2\2\u0144\u0145\5\u00d6l\2\u0145"+
		"\u0149\5\u00d2j\2\u0146\u0148\7S\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\u0175\3\2\2\2\u014e\u014f\7\31"+
		"\2\2\u014f\u0150\7\u0083\2\2\u0150\u0154\5\u00d2j\2\u0151\u0153\7S\2\2"+
		"\u0152\u0151\3\2\2\2\u0153\u0156\3\2\2\2\u0154\u0152\3\2\2\2\u0154\u0155"+
		"\3\2\2\2\u0155\u0157\3\2\2\2\u0156\u0154\3\2\2\2\u0157\u0158\5&\24\2\u0158"+
		"\u0175\3\2\2\2\u0159\u015a\5P)\2\u015a\u015c\7\22\2\2\u015b\u015d\5\66"+
		"\34\2\u015c\u015b\3\2\2\2\u015c\u015d\3\2\2\2\u015d\u015e\3\2\2\2\u015e"+
		"\u015f\7\23\2\2\u015f\u0163\5\u00d2j\2\u0160\u0162\7S\2\2\u0161\u0160"+
		"\3\2\2\2\u0162\u0165\3\2\2\2\u0163\u0161\3\2\2\2\u0163\u0164\3\2\2\2\u0164"+
		"\u0166\3\2\2\2\u0165\u0163\3\2\2\2\u0166\u0167\5&\24\2\u0167\u0175\3\2"+
		"\2\2\u0168\u0169\5P)\2\u0169\u016a\t\3\2\2\u016a\u016b\5\"\22\2\u016b"+
		"\u016f\5\u00d2j\2\u016c\u016e\7S\2\2\u016d\u016c\3\2\2\2\u016e\u0171\3"+
		"\2\2\2\u016f\u016d\3\2\2\2\u016f\u0170\3\2\2\2\u0170\u0172\3\2\2\2\u0171"+
		"\u016f\3\2\2\2\u0172\u0173\5&\24\2\u0173\u0175\3\2\2\2\u0174\u0144\3\2"+
		"\2\2\u0174\u014e\3\2\2\2\u0174\u0159\3\2\2\2\u0174\u0168\3\2\2\2\u0175"+
		"\r\3\2\2\2\u0176\u0177\5\20\t\2\u0177\u017b\7*\2\2\u0178\u017a\7S\2\2"+
		"\u0179\u0178\3\2\2\2\u017a\u017d\3\2\2\2\u017b\u0179\3\2\2\2\u017b\u017c"+
		"\3\2\2\2\u017c\u017e\3\2\2\2\u017d\u017b\3\2\2\2\u017e\u017f\5\34\17\2"+
		"\u017f\u01a3\3\2\2\2\u0180\u0181\5\26\f\2\u0181\u0185\7*\2\2\u0182\u0184"+
		"\7S\2\2\u0183\u0182\3\2\2\2\u0184\u0187\3\2\2\2\u0185\u0183\3\2\2\2\u0185"+
		"\u0186\3\2\2\2\u0186\u018a\3\2\2\2\u0187\u0185\3\2\2\2\u0188\u018b\5&"+
		"\24\2\u0189\u018b\5N(\2\u018a\u0188\3\2\2\2\u018a\u0189\3\2\2\2\u018b"+
		"\u01a3\3\2\2\2\u018c\u018d\5\22\n\2\u018d\u0191\7*\2\2\u018e\u0190\7S"+
		"\2\2\u018f\u018e\3\2\2\2\u0190\u0193\3\2\2\2\u0191\u018f\3\2\2\2\u0191"+
		"\u0192\3\2\2\2\u0192\u0194\3\2\2\2\u0193\u0191\3\2\2\2\u0194\u0195\5\34"+
		"\17\2\u0195\u01a3\3\2\2\2\u0196\u0197\5\24\13\2\u0197\u019b\7*\2\2\u0198"+
		"\u019a\7S\2\2\u0199\u0198\3\2\2\2\u019a\u019d\3\2\2\2\u019b\u0199\3\2"+
		"\2\2\u019b\u019c\3\2\2\2\u019c\u01a0\3\2\2\2\u019d\u019b\3\2\2\2\u019e"+
		"\u01a1\5&\24\2\u019f\u01a1\5N(\2\u01a0\u019e\3\2\2\2\u01a0\u019f\3\2\2"+
		"\2\u01a1\u01a3\3\2\2\2\u01a2\u0176\3\2\2\2\u01a2\u0180\3\2\2\2\u01a2\u018c"+
		"\3\2\2\2\u01a2\u0196\3\2\2\2\u01a3\17\3\2\2\2\u01a4\u01a7\5\u00d6l\2\u01a5"+
		"\u01a6\7*\2\2\u01a6\u01a8\5P)\2\u01a7\u01a5\3\2\2\2\u01a7\u01a8\3\2\2"+
		"\2\u01a8\u01b7\3\2\2\2\u01a9\u01aa\5P)\2\u01aa\u01ac\7\22\2\2\u01ab\u01ad"+
		"\5\66\34\2\u01ac\u01ab\3\2\2\2\u01ac\u01ad\3\2\2\2\u01ad\u01ae\3\2\2\2"+
		"\u01ae\u01af\7\23\2\2\u01af\u01b7\3\2\2\2\u01b0\u01b1\5P)\2\u01b1\u01b2"+
		"\t\3\2\2\u01b2\u01b3\t\4\2\2\u01b3\u01b7\3\2\2\2\u01b4\u01b5\7\31\2\2"+
		"\u01b5\u01b7\7\u0083\2\2\u01b6\u01a4\3\2\2\2\u01b6\u01a9\3\2\2\2\u01b6"+
		"\u01b0\3\2\2\2\u01b6\u01b4\3\2\2\2\u01b7\21\3\2\2\2\u01b8\u01b9\5\32\16"+
		"\2\u01b9\u01ba\7\32\2\2\u01ba\u01bc\3\2\2\2\u01bb\u01b8\3\2\2\2\u01bc"+
		"\u01bd\3\2\2\2\u01bd\u01bb\3\2\2\2\u01bd\u01be\3\2\2\2\u01be\u01c0\3\2"+
		"\2\2\u01bf\u01c1\5\32\16\2\u01c0\u01bf\3\2\2\2\u01c0\u01c1\3\2\2\2\u01c1"+
		"\u01de\3\2\2\2\u01c2\u01c3\5\32\16\2\u01c3\u01c4\7\32\2\2\u01c4\u01c6"+
		"\3\2\2\2\u01c5\u01c2\3\2\2\2\u01c6\u01c7\3\2\2\2\u01c7\u01c5\3\2\2\2\u01c7"+
		"\u01c8\3\2\2\2\u01c8\u01ca\3\2\2\2\u01c9\u01cb\5\26\f\2\u01ca\u01c9\3"+
		"\2\2\2\u01ca\u01cb\3\2\2\2\u01cb\u01d6\3\2\2\2\u01cc\u01ce\7\32\2\2\u01cd"+
		"\u01cc\3\2\2\2\u01cd\u01ce\3\2\2\2\u01ce\u01d2\3\2\2\2\u01cf\u01d1\7S"+
		"\2\2\u01d0\u01cf\3\2\2\2\u01d1\u01d4\3\2\2\2\u01d2\u01d0\3\2\2\2\u01d2"+
		"\u01d3\3\2\2\2\u01d3\u01d5\3\2\2\2\u01d4\u01d2\3\2\2\2\u01d5\u01d7\5\u009e"+
		"P\2\u01d6\u01cd\3\2\2\2\u01d6\u01d7\3\2\2\2\u01d7\u01d9\3\2\2\2\u01d8"+
		"\u01da\7\32\2\2\u01d9\u01d8\3\2\2\2\u01d9\u01da\3\2\2\2\u01da\u01de\3"+
		"\2\2\2\u01db\u01de\5\26\f\2\u01dc\u01de\5\30\r\2\u01dd\u01bb\3\2\2\2\u01dd"+
		"\u01c5\3\2\2\2\u01dd\u01db\3\2\2\2\u01dd\u01dc\3\2\2\2\u01de\23\3\2\2"+
		"\2\u01df\u01e0\5\32\16\2\u01e0\u01e1\7\32\2\2\u01e1\u01e3\3\2\2\2\u01e2"+
		"\u01df\3\2\2\2\u01e3\u01e4\3\2\2\2\u01e4\u01e2\3\2\2\2\u01e4\u01e5\3\2"+
		"\2\2\u01e5\u01e7\3\2\2\2\u01e6\u01e8\5\32\16\2\u01e7\u01e6\3\2\2\2\u01e7"+
		"\u01e8\3\2\2\2\u01e8\u01f5\3\2\2\2\u01e9\u01ea\5\32\16\2\u01ea\u01eb\7"+
		"\32\2\2\u01eb\u01ed\3\2\2\2\u01ec\u01e9\3\2\2\2\u01ed\u01ee\3\2\2\2\u01ee"+
		"\u01ec\3\2\2\2\u01ee\u01ef\3\2\2\2\u01ef\u01f1\3\2\2\2\u01f0\u01f2\5\26"+
		"\f\2\u01f1\u01f0\3\2\2\2\u01f1\u01f2\3\2\2\2\u01f2\u01f5\3\2\2\2\u01f3"+
		"\u01f5\5\30\r\2\u01f4\u01e2\3\2\2\2\u01f4\u01ec\3\2\2\2\u01f4\u01f3\3"+
		"\2\2\2\u01f5\25\3\2\2\2\u01f6\u01f8\78\2\2\u01f7\u01f9\5\20\t\2\u01f8"+
		"\u01f7\3\2\2\2\u01f8\u01f9\3\2\2\2\u01f9\u01fe\3\2\2\2\u01fa\u01fb\7\32"+
		"\2\2\u01fb\u01fd\5\32\16\2\u01fc\u01fa\3\2\2\2\u01fd\u0200\3\2\2\2\u01fe"+
		"\u01fc\3\2\2\2\u01fe\u01ff\3\2\2\2\u01ff\27\3\2\2\2\u0200\u01fe\3\2\2"+
		"\2\u0201\u0202\7\24\2\2\u0202\u0203\5\22\n\2\u0203\u0204\7\25\2\2\u0204"+
		"\31\3\2\2\2\u0205\u0208\5\20\t\2\u0206\u0208\5\30\r\2\u0207\u0205\3\2"+
		"\2\2\u0207\u0206\3\2\2\2\u0208\33\3\2\2\2\u0209\u020c\5<\37\2\u020a\u020c"+
		"\5\36\20\2\u020b\u0209\3\2\2\2\u020b\u020a\3\2\2\2\u020c\u0214\3\2\2\2"+
		"\u020d\u0210\7\32\2\2\u020e\u0211\5<\37\2\u020f\u0211\5\36\20\2\u0210"+
		"\u020e\3\2\2\2\u0210\u020f\3\2\2\2\u0211\u0213\3\2\2\2\u0212\u020d\3\2"+
		"\2\2\u0213\u0216\3\2\2\2\u0214\u0212\3\2\2\2\u0214\u0215\3\2\2\2\u0215"+
		"\35\3\2\2\2\u0216\u0214\3\2\2\2\u0217\u0218\5:\36\2\u0218\37\3\2\2\2\u0219"+
		"\u021d\7V\2\2\u021a\u021d\7\u0083\2\2\u021b\u021d\5$\23\2\u021c\u0219"+
		"\3\2\2\2\u021c\u021a\3\2\2\2\u021c\u021b\3\2\2\2\u021d!\3\2\2\2\u021e"+
		"\u0222\5 \21\2\u021f\u0222\5\u00ecw\2\u0220\u0222\5\u00d8m\2\u0221\u021e"+
		"\3\2\2\2\u0221\u021f\3\2\2\2\u0221\u0220\3\2\2\2\u0222#\3\2\2\2\u0223"+
		"\u0227\7\u0083\2\2\u0224\u0227\7V\2\2\u0225\u0227\5\u00d8m\2\u0226\u0223"+
		"\3\2\2\2\u0226\u0224\3\2\2\2\u0226\u0225\3\2\2\2\u0227\u0228\3\2\2\2\u0228"+
		"\u0229\t\5\2\2\u0229%\3\2\2\2\u022a\u023b\5(\25\2\u022b\u0230\5,\27\2"+
		"\u022c\u022d\t\3\2\2\u022d\u022e\5\"\22\2\u022e\u022f\5D#\2\u022f\u0231"+
		"\3\2\2\2\u0230\u022c\3\2\2\2\u0230\u0231\3\2\2\2\u0231\u023b\3\2\2\2\u0232"+
		"\u0233\7u\2\2\u0233\u023b\5H%\2\u0234\u0235\7_\2\2\u0235\u023b\5F$\2\u0236"+
		"\u0237\7n\2\2\u0237\u023b\5F$\2\u0238\u0239\7\177\2\2\u0239\u023b\5H%"+
		"\2\u023a\u022a\3\2\2\2\u023a\u022b\3\2\2\2\u023a\u0232\3\2\2\2\u023a\u0234"+
		"\3\2\2\2\u023a\u0236\3\2\2\2\u023a\u0238\3\2\2\2\u023b\'\3\2\2\2\u023c"+
		"\u023d\5N(\2\u023d\u0241\7\37\2\2\u023e\u0240\7S\2\2\u023f\u023e\3\2\2"+
		"\2\u0240\u0243\3\2\2\2\u0241\u023f\3\2\2\2\u0241\u0242\3\2\2\2\u0242\u0244"+
		"\3\2\2\2\u0243\u0241\3\2\2\2\u0244\u0248\5N(\2\u0245\u0247\7S\2\2\u0246"+
		"\u0245\3\2\2\2\u0247\u024a\3\2\2\2\u0248\u0246\3\2\2\2\u0248\u0249\3\2"+
		"\2\2\u0249\u024b\3\2\2\2\u024a\u0248\3\2\2\2\u024b\u024f\7\30\2\2\u024c"+
		"\u024e\7S\2\2\u024d\u024c\3\2\2\2\u024e\u0251\3\2\2\2\u024f\u024d\3\2"+
		"\2\2\u024f\u0250\3\2\2\2\u0250\u0252\3\2\2\2\u0251\u024f\3\2\2\2\u0252"+
		"\u0253\5N(\2\u0253\u0260\3\2\2\2\u0254\u0256\5P)\2\u0255\u0257\7S\2\2"+
		"\u0256\u0255\3\2\2\2\u0256\u0257\3\2\2\2\u0257\u0258\3\2\2\2\u0258\u0259"+
		"\t\6\2\2\u0259\u025a\5\"\22\2\u025a\u025b\5*\26\2\u025b\u0260\3\2\2\2"+
		"\u025c\u025d\5 \21\2\u025d\u025e\5*\26\2\u025e\u0260\3\2\2\2\u025f\u023c"+
		"\3\2\2\2\u025f\u0254\3\2\2\2\u025f\u025c\3\2\2\2\u0260)\3\2\2\2\u0261"+
		"\u0264\5D#\2\u0262\u0264\5(\25\2\u0263\u0261\3\2\2\2\u0263\u0262\3\2\2"+
		"\2\u0264+\3\2\2\2\u0265\u0269\5\60\31\2\u0266\u0268\5.\30\2\u0267\u0266"+
		"\3\2\2\2\u0268\u026b\3\2\2\2\u0269\u0267\3\2\2\2\u0269\u026a\3\2\2\2\u026a"+
		"-\3\2\2\2\u026b\u0269\3\2\2\2\u026c\u026d\t\3\2\2\u026d\u026f\5\"\22\2"+
		"\u026e\u0270\5@!\2\u026f\u026e\3\2\2\2\u026f\u0270\3\2\2\2\u0270/\3\2"+
		"\2\2\u0271\u0272\7w\2\2\u0272\u0273\5B\"\2\u0273\u0274\5`\61\2\u0274\u0280"+
		"\3\2\2\2\u0275\u0276\5 \21\2\u0276\u0277\5B\"\2\u0277\u0278\5`\61\2\u0278"+
		"\u0280\3\2\2\2\u0279\u027a\5P)\2\u027a\u027b\t\3\2\2\u027b\u027c\5\"\22"+
		"\2\u027c\u027d\5B\"\2\u027d\u027e\5`\61\2\u027e\u0280\3\2\2\2\u027f\u0271"+
		"\3\2\2\2\u027f\u0275\3\2\2\2\u027f\u0279\3\2\2\2\u0280\61\3\2\2\2\u0281"+
		"\u028e\5\64\33\2\u0282\u0284\7\32\2\2\u0283\u0282\3\2\2\2\u0283\u0284"+
		"\3\2\2\2\u0284\u0288\3\2\2\2\u0285\u0287\7S\2\2\u0286\u0285\3\2\2\2\u0287"+
		"\u028a\3\2\2\2\u0288\u0286\3\2\2\2\u0288\u0289\3\2\2\2\u0289\u028b\3\2"+
		"\2\2\u028a\u0288\3\2\2\2\u028b\u028d\5\64\33\2\u028c\u0283\3\2\2\2\u028d"+
		"\u0290\3\2\2\2\u028e\u028c\3\2\2\2\u028e\u028f\3\2\2\2\u028f\u0292\3\2"+
		"\2\2\u0290\u028e\3\2\2\2\u0291\u0293\7\32\2\2\u0292\u0291\3\2\2\2\u0292"+
		"\u0293\3\2\2\2\u0293\63\3\2\2\2\u0294\u029a\58\35\2\u0295\u029a\5(\25"+
		"\2\u0296\u029a\5R*\2\u0297\u029a\5:\36\2\u0298\u029a\5\66\34\2\u0299\u0294"+
		"\3\2\2\2\u0299\u0295\3\2\2\2\u0299\u0296\3\2\2\2\u0299\u0297\3\2\2\2\u0299"+
		"\u0298\3\2\2\2\u029a\65\3\2\2\2\u029b\u029d\5<\37\2\u029c\u029e\7\32\2"+
		"\2\u029d\u029c\3\2\2\2\u029d\u029e\3\2\2\2\u029e\u02c6\3\2\2\2\u029f\u02a0"+
		"\5<\37\2\u02a0\u02a1\7\32\2\2\u02a1\u02a2\5:\36\2\u02a2\u02c6\3\2\2\2"+
		"\u02a3\u02b0\58\35\2\u02a4\u02a6\7\32\2\2\u02a5\u02a4\3\2\2\2\u02a5\u02a6"+
		"\3\2\2\2\u02a6\u02aa\3\2\2\2\u02a7\u02a9\7S\2\2\u02a8\u02a7\3\2\2\2\u02a9"+
		"\u02ac\3\2\2\2\u02aa\u02a8\3\2\2\2\u02aa\u02ab\3\2\2\2\u02ab\u02ad\3\2"+
		"\2\2\u02ac\u02aa\3\2\2\2\u02ad\u02af\58\35\2\u02ae\u02a5\3\2\2\2\u02af"+
		"\u02b2\3\2\2\2\u02b0\u02ae\3\2\2\2\u02b0\u02b1\3\2\2\2\u02b1\u02c6\3\2"+
		"\2\2\u02b2\u02b0\3\2\2\2\u02b3\u02b5\5\u00a8U\2\u02b4\u02b6\7\32\2\2\u02b5"+
		"\u02b4\3\2\2\2\u02b5\u02b6\3\2\2\2\u02b6\u02c6\3\2\2\2\u02b7\u02c2\5:"+
		"\36\2\u02b8\u02bc\7\32\2\2\u02b9\u02bb\7S\2\2\u02ba\u02b9\3\2\2\2\u02bb"+
		"\u02be\3\2\2\2\u02bc\u02ba\3\2\2\2\u02bc\u02bd\3\2\2\2\u02bd\u02bf\3\2"+
		"\2\2\u02be\u02bc\3\2\2\2\u02bf\u02c1\5:\36\2\u02c0\u02b8\3\2\2\2\u02c1"+
		"\u02c4\3\2\2\2\u02c2\u02c0\3\2\2\2\u02c2\u02c3\3\2\2\2\u02c3\u02c6\3\2"+
		"\2\2\u02c4\u02c2\3\2\2\2\u02c5\u029b\3\2\2\2\u02c5\u029f\3\2\2\2\u02c5"+
		"\u02a3\3\2\2\2\u02c5\u02b3\3\2\2\2\u02c5\u02b7\3\2\2\2\u02c6\67\3\2\2"+
		"\2\u02c7\u02ce\5\u00ccg\2\u02c8\u02ce\5\u00aaV\2\u02c9\u02cb\t\7\2\2\u02ca"+
		"\u02c9\3\2\2\2\u02ca\u02cb\3\2\2\2\u02cb\u02cc\3\2\2\2\u02cc\u02ce\5\u00da"+
		"n\2\u02cd\u02c7\3\2\2\2\u02cd\u02c8\3\2\2\2\u02cd\u02ca\3\2\2\2\u02ce"+
		"9\3\2\2\2\u02cf\u02d0\78\2\2\u02d0\u02d4\5N(\2\u02d1\u02d2\79\2\2\u02d2"+
		"\u02d4\5N(\2\u02d3\u02cf\3\2\2\2\u02d3\u02d1\3\2\2\2\u02d4;\3\2\2\2\u02d5"+
		"\u02e0\5N(\2\u02d6\u02da\7\32\2\2\u02d7\u02d9\7S\2\2\u02d8\u02d7\3\2\2"+
		"\2\u02d9\u02dc\3\2\2\2\u02da\u02d8\3\2\2\2\u02da\u02db\3\2\2\2\u02db\u02dd"+
		"\3\2\2\2\u02dc\u02da\3\2\2\2\u02dd\u02df\5N(\2\u02de\u02d6\3\2\2\2\u02df"+
		"\u02e2\3\2\2\2\u02e0\u02de\3\2\2\2\u02e0\u02e1\3\2\2\2\u02e1=\3\2\2\2"+
		"\u02e2\u02e0\3\2\2\2\u02e3\u02ec\5N(\2\u02e4\u02e8\7\32\2\2\u02e5\u02e7"+
		"\7S\2\2\u02e6\u02e5\3\2\2\2\u02e7\u02ea\3\2\2\2\u02e8\u02e6\3\2\2\2\u02e8"+
		"\u02e9\3\2\2\2\u02e9\u02eb\3\2\2\2\u02ea\u02e8\3\2\2\2\u02eb\u02ed\5N"+
		"(\2\u02ec\u02e4\3\2\2\2\u02ed\u02ee\3\2\2\2\u02ee\u02ec\3\2\2\2\u02ee"+
		"\u02ef\3\2\2\2\u02ef?\3\2\2\2\u02f0\u02f4\7\24\2\2\u02f1\u02f3\7S\2\2"+
		"\u02f2\u02f1\3\2\2\2\u02f3\u02f6\3\2\2\2\u02f4\u02f2\3\2\2\2\u02f4\u02f5"+
		"\3\2\2\2\u02f5\u02f8\3\2\2\2\u02f6\u02f4\3\2\2\2\u02f7\u02f9\7\32\2\2"+
		"\u02f8\u02f7\3\2\2\2\u02f8\u02f9\3\2\2\2\u02f9\u02fd\3\2\2\2\u02fa\u02fc"+
		"\7S\2\2\u02fb\u02fa\3\2\2\2\u02fc\u02ff\3\2\2\2\u02fd\u02fb\3\2\2\2\u02fd"+
		"\u02fe\3\2\2\2\u02fe\u0300\3\2\2\2\u02ff\u02fd\3\2\2\2\u0300\u0343\7\25"+
		"\2\2\u0301\u0305\7\24\2\2\u0302\u0304\7S\2\2\u0303\u0302\3\2\2\2\u0304"+
		"\u0307\3\2\2\2\u0305\u0303\3\2\2\2\u0305\u0306\3\2\2\2\u0306\u0308\3\2"+
		"\2\2\u0307\u0305\3\2\2\2\u0308\u030a\5B\"\2\u0309\u030b\7\32\2\2\u030a"+
		"\u0309\3\2\2\2\u030a\u030b\3\2\2\2\u030b\u030f\3\2\2\2\u030c\u030e\7S"+
		"\2\2\u030d\u030c\3\2\2\2\u030e\u0311\3\2\2\2\u030f\u030d\3\2\2\2\u030f"+
		"\u0310\3\2\2\2\u0310\u0312\3\2\2\2\u0311\u030f\3\2\2\2\u0312\u0313\7\25"+
		"\2\2\u0313\u0343\3\2\2\2\u0314\u0318\7\24\2\2\u0315\u0317\7S\2\2\u0316"+
		"\u0315\3\2\2\2\u0317\u031a\3\2\2\2\u0318\u0316\3\2\2\2\u0318\u0319\3\2"+
		"\2\2\u0319\u031b\3\2\2\2\u031a\u0318\3\2\2\2\u031b\u031c\5<\37\2\u031c"+
		"\u0320\7\32\2\2\u031d\u031f\7S\2\2\u031e\u031d\3\2\2\2\u031f\u0322\3\2"+
		"\2\2\u0320\u031e\3\2\2\2\u0320\u0321\3\2\2\2\u0321\u0323\3\2\2\2\u0322"+
		"\u0320\3\2\2\2\u0323\u0325\5,\27\2\u0324\u0326\7\32\2\2\u0325\u0324\3"+
		"\2\2\2\u0325\u0326\3\2\2\2\u0326\u032a\3\2\2\2\u0327\u0329\7S\2\2\u0328"+
		"\u0327\3\2\2\2\u0329\u032c\3\2\2\2\u032a\u0328\3\2\2\2\u032a\u032b\3\2"+
		"\2\2\u032b\u032d\3\2\2\2\u032c\u032a\3\2\2\2\u032d\u032e\7\25\2\2\u032e"+
		"\u0343\3\2\2\2\u032f\u0333\7\24\2\2\u0330\u0332\7S\2\2\u0331\u0330\3\2"+
		"\2\2\u0332\u0335\3\2\2\2\u0333\u0331\3\2\2\2\u0333\u0334\3\2\2\2\u0334"+
		"\u0336\3\2\2\2\u0335\u0333\3\2\2\2\u0336\u0338\5,\27\2\u0337\u0339\7\32"+
		"\2\2\u0338\u0337\3\2\2\2\u0338\u0339\3\2\2\2\u0339\u033d\3\2\2\2\u033a"+
		"\u033c\7S\2\2\u033b\u033a\3\2\2\2\u033c\u033f\3\2\2\2\u033d\u033b\3\2"+
		"\2\2\u033d\u033e\3\2\2\2\u033e\u0340\3\2\2\2\u033f\u033d\3\2\2\2\u0340"+
		"\u0341\7\25\2\2\u0341\u0343\3\2\2\2\u0342\u02f0\3\2\2\2\u0342\u0301\3"+
		"\2\2\2\u0342\u0314\3\2\2\2\u0342\u032f\3\2\2\2\u0343A\3\2\2\2\u0344\u0395"+
		"\5J&\2\u0345\u034e\5:\36\2\u0346\u034a\7\32\2\2\u0347\u0349\7S\2\2\u0348"+
		"\u0347\3\2\2\2\u0349\u034c\3\2\2\2\u034a\u0348\3\2\2\2\u034a\u034b\3\2"+
		"\2\2\u034b\u034d\3\2\2\2\u034c\u034a\3\2\2\2\u034d\u034f\5J&\2\u034e\u0346"+
		"\3\2\2\2\u034e\u034f\3\2\2\2\u034f\u0358\3\2\2\2\u0350\u0354\7\32\2\2"+
		"\u0351\u0353\7S\2\2\u0352\u0351\3\2\2\2\u0353\u0356\3\2\2\2\u0354\u0352"+
		"\3\2\2\2\u0354\u0355\3\2\2\2\u0355\u0357\3\2\2\2\u0356\u0354\3\2\2\2\u0357"+
		"\u0359\5<\37\2\u0358\u0350\3\2\2\2\u0358\u0359\3\2\2\2\u0359\u0395\3\2"+
		"\2\2\u035a\u0363\5<\37\2\u035b\u035f\7\32\2\2\u035c\u035e\7S\2\2\u035d"+
		"\u035c\3\2\2\2\u035e\u0361\3\2\2\2\u035f\u035d\3\2\2\2\u035f\u0360\3\2"+
		"\2\2\u0360\u0362\3\2\2\2\u0361\u035f\3\2\2\2\u0362\u0364\5\u00a8U\2\u0363"+
		"\u035b\3\2\2\2\u0363\u0364\3\2\2\2\u0364\u036d\3\2\2\2\u0365\u0369\7\32"+
		"\2\2\u0366\u0368\7S\2\2\u0367\u0366\3\2\2\2\u0368\u036b\3\2\2\2\u0369"+
		"\u0367\3\2\2\2\u0369\u036a\3\2\2\2\u036a\u036c\3\2\2\2\u036b\u0369\3\2"+
		"\2\2\u036c\u036e\5:\36\2\u036d\u0365\3\2\2\2\u036d\u036e\3\2\2\2\u036e"+
		"\u0377\3\2\2\2\u036f\u0373\7\32\2\2\u0370\u0372\7S\2\2\u0371\u0370\3\2"+
		"\2\2\u0372\u0375\3\2\2\2\u0373\u0371\3\2\2\2\u0373\u0374\3\2\2\2\u0374"+
		"\u0376\3\2\2\2\u0375\u0373\3\2\2\2\u0376\u0378\5J&\2\u0377\u036f\3\2\2"+
		"\2\u0377\u0378\3\2\2\2\u0378\u0395\3\2\2\2\u0379\u0382\5\u00a8U\2\u037a"+
		"\u037e\7\32\2\2\u037b\u037d\7S\2\2\u037c\u037b\3\2\2\2\u037d\u0380\3\2"+
		"\2\2\u037e\u037c\3\2\2\2\u037e\u037f\3\2\2\2\u037f\u0381\3\2\2\2\u0380"+
		"\u037e\3\2\2\2\u0381\u0383\5:\36\2\u0382\u037a\3\2\2\2\u0382\u0383\3\2"+
		"\2\2\u0383\u038c\3\2\2\2\u0384\u0388\7\32\2\2\u0385\u0387\7S\2\2\u0386"+
		"\u0385\3\2\2\2\u0387\u038a\3\2\2\2\u0388\u0386\3\2\2\2\u0388\u0389\3\2"+
		"\2\2\u0389\u038b\3\2\2\2\u038a\u0388\3\2\2\2\u038b\u038d\5J&\2\u038c\u0384"+
		"\3\2\2\2\u038c\u038d\3\2\2\2\u038d\u0395\3\2\2\2\u038e\u0390\7\22\2\2"+
		"\u038f\u0391\5\66\34\2\u0390\u038f\3\2\2\2\u0390\u0391\3\2\2\2\u0391\u0392"+
		"\3\2\2\2\u0392\u0395\7\23\2\2\u0393\u0395\5(\25\2\u0394\u0344\3\2\2\2"+
		"\u0394\u0345\3\2\2\2\u0394\u035a\3\2\2\2\u0394\u0379\3\2\2\2\u0394\u038e"+
		"\3\2\2\2\u0394\u0393\3\2\2\2\u0395C\3\2\2\2\u0396\u03a3\5\u00a8U\2\u0397"+
		"\u03a0\5F$\2\u0398\u039c\7\32\2\2\u0399\u039b\7S\2\2\u039a\u0399\3\2\2"+
		"\2\u039b\u039e\3\2\2\2\u039c\u039a\3\2\2\2\u039c\u039d\3\2\2\2\u039d\u039f"+
		"\3\2\2\2\u039e\u039c\3\2\2\2\u039f\u03a1\5\u00a8U\2\u03a0\u0398\3\2\2"+
		"\2\u03a0\u03a1\3\2\2\2\u03a1\u03a3\3\2\2\2\u03a2\u0396\3\2\2\2\u03a2\u0397"+
		"\3\2\2\2\u03a3E\3\2\2\2\u03a4\u03af\5T+\2\u03a5\u03a9\7\32\2\2\u03a6\u03a8"+
		"\7S\2\2\u03a7\u03a6\3\2\2\2\u03a8\u03ab\3\2\2\2\u03a9\u03a7\3\2\2\2\u03a9"+
		"\u03aa\3\2\2\2\u03aa\u03ac\3\2\2\2\u03ab\u03a9\3\2\2\2\u03ac\u03ae\5T"+
		"+\2\u03ad\u03a5\3\2\2\2\u03ae\u03b1\3\2\2\2\u03af\u03ad\3\2\2\2\u03af"+
		"\u03b0\3\2\2\2\u03b0G\3\2\2\2\u03b1\u03af\3\2\2\2\u03b2\u03b5\5T+\2\u03b3"+
		"\u03b5\5\u00aaV\2\u03b4\u03b2\3\2\2\2\u03b4\u03b3\3\2\2\2\u03b4\u03b5"+
		"\3\2\2\2\u03b5\u03c3\3\2\2\2\u03b6\u03ba\7\32\2\2\u03b7\u03b9\7S\2\2\u03b8"+
		"\u03b7\3\2\2\2\u03b9\u03bc\3\2\2\2\u03ba\u03b8\3\2\2\2\u03ba\u03bb\3\2"+
		"\2\2\u03bb\u03bf\3\2\2\2\u03bc\u03ba\3\2\2\2\u03bd\u03c0\5T+\2\u03be\u03c0"+
		"\5\u00aaV\2\u03bf\u03bd\3\2\2\2\u03bf\u03be\3\2\2\2\u03c0\u03c2\3\2\2"+
		"\2\u03c1\u03b6\3\2\2\2\u03c2\u03c5\3\2\2\2\u03c3\u03c1\3\2\2\2\u03c3\u03c4"+
		"\3\2\2\2\u03c4\u03c8\3\2\2\2\u03c5\u03c3\3\2\2\2\u03c6\u03c8\5&\24\2\u03c7"+
		"\u03b4\3\2\2\2\u03c7\u03c6\3\2\2\2\u03c8I\3\2\2\2\u03c9\u03cb\7%\2\2\u03ca"+
		"\u03cc\5N(\2\u03cb\u03ca\3\2\2\2\u03cb\u03cc\3\2\2\2\u03ccK\3\2\2\2\u03cd"+
		"\u03ce\b\'\1\2\u03ce\u03dc\5N(\2\u03cf\u03d1\7\"\2\2\u03d0\u03cf\3\2\2"+
		"\2\u03d0\u03d1\3\2\2\2\u03d1\u03d2\3\2\2\2\u03d2\u03dc\5&\24\2\u03d3\u03d7"+
		"\7p\2\2\u03d4\u03d6\7S\2\2\u03d5\u03d4\3\2\2\2\u03d6\u03d9\3\2\2\2\u03d7"+
		"\u03d5\3\2\2\2\u03d7\u03d8\3\2\2\2\u03d8\u03da\3\2\2\2\u03d9\u03d7\3\2"+
		"\2\2\u03da\u03dc\5L\'\4\u03db\u03cd\3\2\2\2\u03db\u03d0\3\2\2\2\u03db"+
		"\u03d3\3\2\2\2\u03dc\u03e8\3\2\2\2\u03dd\u03de\f\3\2\2\u03de\u03e2\t\b"+
		"\2\2\u03df\u03e1\7S\2\2\u03e0\u03df\3\2\2\2\u03e1\u03e4\3\2\2\2\u03e2"+
		"\u03e0\3\2\2\2\u03e2\u03e3\3\2\2\2\u03e3\u03e5\3\2\2\2\u03e4\u03e2\3\2"+
		"\2\2\u03e5\u03e7\5L\'\4\u03e6\u03dd\3\2\2\2\u03e7\u03ea\3\2\2\2\u03e8"+
		"\u03e6\3\2\2\2\u03e8\u03e9\3\2\2\2\u03e9M\3\2\2\2\u03ea\u03e8\3\2\2\2"+
		"\u03eb\u03ec\b(\1\2\u03ec\u03ed\5P)\2\u03ed\u0408\3\2\2\2\u03ee\u03ef"+
		"\f\3\2\2\u03ef\u03f3\7\37\2\2\u03f0\u03f2\7S\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\u03fa\5N(\2\u03f7\u03f9\7S\2\2\u03f8\u03f7"+
		"\3\2\2\2\u03f9\u03fc\3\2\2\2\u03fa\u03f8\3\2\2\2\u03fa\u03fb\3\2\2\2\u03fb"+
		"\u03fd\3\2\2\2\u03fc\u03fa\3\2\2\2\u03fd\u0401\7\30\2\2\u03fe\u0400\7"+
		"S\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\5N"+
		"(\4\u0405\u0407\3\2\2\2\u0406\u03ee\3\2\2\2\u0407\u040a\3\2\2\2\u0408"+
		"\u0406\3\2\2\2\u0408\u0409\3\2\2\2\u0409O\3\2\2\2\u040a\u0408\3\2\2\2"+
		"\u040b\u0412\7u\2\2\u040c\u0412\7_\2\2\u040d\u0412\7n\2\2\u040e\u0412"+
		"\7r\2\2\u040f\u0412\7t\2\2\u0410\u0412\5T+\2\u0411\u040b\3\2\2\2\u0411"+
		"\u040c\3\2\2\2\u0411\u040d\3\2\2\2\u0411\u040e\3\2\2\2\u0411\u040f\3\2"+
		"\2\2\u0411\u0410\3\2\2\2\u0412Q\3\2\2\2\u0413\u0417\7\26\2\2\u0414\u0416"+
		"\7S\2\2\u0415\u0414\3\2\2\2\u0416\u0419\3\2\2\2\u0417\u0415\3\2\2\2\u0417"+
		"\u0418\3\2\2\2\u0418\u041e\3\2\2\2\u0419\u0417\3\2\2\2\u041a\u041c\5\u00a8"+
		"U\2\u041b\u041d\7\32\2\2\u041c\u041b\3\2\2\2\u041c\u041d\3\2\2\2\u041d"+
		"\u041f\3\2\2\2\u041e\u041a\3\2\2\2\u041e\u041f\3\2\2\2\u041f\u0423\3\2"+
		"\2\2\u0420\u0422\7S\2\2\u0421\u0420\3\2\2\2\u0422\u0425\3\2\2\2\u0423"+
		"\u0421\3\2\2\2\u0423\u0424\3\2\2\2\u0424\u0426\3\2\2\2\u0425\u0423\3\2"+
		"\2\2\u0426\u0427\7\27\2\2\u0427S\3\2\2\2\u0428\u0429\b+\1\2\u0429\u042a"+
		"\5\u00d6l\2\u042a\u042e\5\u00d2j\2\u042b\u042d\7S\2\2\u042c\u042b\3\2"+
		"\2\2\u042d\u0430\3\2\2\2\u042e\u042c\3\2\2\2\u042e\u042f\3\2\2\2\u042f"+
		"\u0431\3\2\2\2\u0430\u042e\3\2\2\2\u0431\u0432\5N(\2\u0432\u0564\3\2\2"+
		"\2\u0433\u0434\7\31\2\2\u0434\u0435\7\u0083\2\2\u0435\u0439\5\u00d2j\2"+
		"\u0436\u0438\7S\2\2\u0437\u0436\3\2\2\2\u0438\u043b\3\2\2\2\u0439\u0437"+
		"\3\2\2\2\u0439\u043a\3\2\2\2\u043a\u043c\3\2\2\2\u043b\u0439\3\2\2\2\u043c"+
		"\u043d\5N(\2\u043d\u0564\3\2\2\2\u043e\u043f\7a\2\2\u043f\u0442\5\u00a2"+
		"R\2\u0440\u0441\7\62\2\2\u0441\u0443\5Z.\2\u0442\u0440\3\2\2\2\u0442\u0443"+
		"\3\2\2\2\u0443\u0445\3\2\2\2\u0444\u0446\t\2\2\2\u0445\u0444\3\2\2\2\u0445"+
		"\u0446\3\2\2\2\u0446\u0447\3\2\2\2\u0447\u0448\5~@\2\u0448\u0449\7g\2"+
		"\2\u0449\u0564\3\2\2\2\u044a\u044b\7a\2\2\u044b\u044c\7\64\2\2\u044c\u044d"+
		"\5Z.\2\u044d\u044e\t\2\2\2\u044e\u044f\5~@\2\u044f\u0450\7g\2\2\u0450"+
		"\u0564\3\2\2\2\u0451\u0452\7m\2\2\u0452\u0453\5\u00a2R\2\u0453\u0454\5"+
		"~@\2\u0454\u0455\7g\2\2\u0455\u0564\3\2\2\2\u0456\u0457\7b\2\2\u0457\u0458"+
		"\5\u0088E\2\u0458\u0459\5\u008aF\2\u0459\u045a\5~@\2\u045a\u045b\7g\2"+
		"\2\u045b\u0564\3\2\2\2\u045c\u045d\7b\2\2\u045d\u045e\5\u00a4S\2\u045e"+
		"\u045f\t\3\2\2\u045f\u0460\5\u0088E\2\u0460\u0461\5\u008aF\2\u0461\u0462"+
		"\5~@\2\u0462\u0463\7g\2\2\u0463\u0564\3\2\2\2\u0464\u0465\7b\2\2\u0465"+
		"\u046b\5\u0088E\2\u0466\u0468\7\24\2\2\u0467\u0469\5\u008cG\2\u0468\u0467"+
		"\3\2\2\2\u0468\u0469\3\2\2\2\u0469\u046a\3\2\2\2\u046a\u046c\7\25\2\2"+
		"\u046b\u0466\3\2\2\2\u046b\u046c\3\2\2\2\u046c\u046d\3\2\2\2\u046d\u0471"+
		"\7*\2\2\u046e\u0470\7S\2\2\u046f\u046e\3\2\2\2\u0470\u0473\3\2\2\2\u0471"+
		"\u046f\3\2\2\2\u0471\u0472\3\2\2\2\u0472\u0474\3\2\2\2\u0473\u0471\3\2"+
		"\2\2\u0474\u0475\5\b\5\2\u0475\u0564\3\2\2\2\u0476\u0478\7!\2\2\u0477"+
		"\u0479\5V,\2\u0478\u0477\3\2\2\2\u0478\u0479\3\2\2\2\u0479\u047a\3\2\2"+
		"\2\u047a\u0564\5^\60\2\u047b\u047f\7k\2\2\u047c\u047e\7S\2\2\u047d\u047c"+
		"\3\2\2\2\u047e\u0481\3\2\2\2\u047f\u047d\3\2\2\2\u047f\u0480\3\2\2\2\u0480"+
		"\u0482\3\2\2\2\u0481\u047f\3\2\2\2\u0482\u0483\5L\'\2\u0483\u0487\5p9"+
		"\2\u0484\u0486\5t;\2\u0485\u0484\3\2\2\2\u0486\u0489\3\2\2\2\u0487\u0485"+
		"\3\2\2\2\u0487\u0488\3\2\2\2\u0488\u048b\3\2\2\2\u0489\u0487\3\2\2\2\u048a"+
		"\u048c\5r:\2\u048b\u048a\3\2\2\2\u048b\u048c\3\2\2\2\u048c\u048d\3\2\2"+
		"\2\u048d\u048e\7g\2\2\u048e\u0564\3\2\2\2\u048f\u0493\7{\2\2\u0490\u0492"+
		"\7S\2\2\u0491\u0490\3\2\2\2\u0492\u0495\3\2\2\2\u0493\u0491\3\2\2\2\u0493"+
		"\u0494\3\2\2\2\u0494\u0496\3\2\2\2\u0495\u0493\3\2\2\2\u0496\u0497\5L"+
		"\'\2\u0497\u0499\5p9\2\u0498\u049a\5r:\2\u0499\u0498\3\2\2\2\u0499\u049a"+
		"\3\2\2\2\u049a\u049b\3\2\2\2\u049b\u049c\7g\2\2\u049c\u0564\3\2\2\2\u049d"+
		"\u04a1\7|\2\2\u049e\u04a0\7S\2\2\u049f\u049e\3\2\2\2\u04a0\u04a3\3\2\2"+
		"\2\u04a1\u049f\3\2\2\2\u04a1\u04a2\3\2\2\2\u04a2\u04a4\3\2\2\2\u04a3\u04a1"+
		"\3\2\2\2\u04a4\u04a5\5L\'\2\u04a5\u04a6\5z>\2\u04a6\u04a7\7g\2\2\u04a7"+
		"\u0564\3\2\2\2\u04a8\u04aa\7\177\2\2\u04a9\u04ab\5@!\2\u04aa\u04a9\3\2"+
		"\2\2\u04aa\u04ab\3\2\2\2\u04ab\u0564\3\2\2\2\u04ac\u04ad\7^\2\2\u04ad"+
		"\u04ae\5~@\2\u04ae\u04af\7g\2\2\u04af\u0564\3\2\2\2\u04b0\u04b4\7`\2\2"+
		"\u04b1\u04b3\7S\2\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"+
		"\u04bb\5L\'\2\u04b8\u04ba\t\2\2\2\u04b9\u04b8\3\2\2\2\u04ba\u04bd\3\2"+
		"\2\2\u04bb\u04b9\3\2\2\2\u04bb\u04bc\3\2\2\2\u04bc\u04bf\3\2\2\2\u04bd"+
		"\u04bb\3\2\2\2\u04be\u04c0\5v<\2\u04bf\u04be\3\2\2\2\u04c0\u04c1\3\2\2"+
		"\2\u04c1\u04bf\3\2\2\2\u04c1\u04c2\3\2\2\2\u04c2\u04c4\3\2\2\2\u04c3\u04c5"+
		"\5r:\2\u04c4\u04c3\3\2\2\2\u04c4\u04c5\3\2\2\2\u04c5\u04c6\3\2\2\2\u04c6"+
		"\u04c7\7g\2\2\u04c7\u0564\3\2\2\2\u04c8\u04cc\7`\2\2\u04c9\u04cb\t\2\2"+
		"\2\u04ca\u04c9\3\2\2\2\u04cb\u04ce\3\2\2\2\u04cc\u04ca\3\2\2\2\u04cc\u04cd"+
		"\3\2\2\2\u04cd\u04d0\3\2\2\2\u04ce\u04cc\3\2\2\2\u04cf\u04d1\5v<\2\u04d0"+
		"\u04cf\3\2\2\2\u04d1\u04d2\3\2\2\2\u04d2\u04d0\3\2\2\2\u04d2\u04d3\3\2"+
		"\2\2\u04d3\u04d5\3\2\2\2\u04d4\u04d6\5r:\2\u04d5\u04d4\3\2\2\2\u04d5\u04d6"+
		"\3\2\2\2\u04d6\u04d7\3\2\2\2\u04d7\u04d8\7g\2\2\u04d8\u0564\3\2\2\2\u04d9"+
		"\u04dd\7~\2\2\u04da\u04dc\7S\2\2\u04db\u04da\3\2\2\2\u04dc\u04df\3\2\2"+
		"\2\u04dd\u04db\3\2\2\2\u04dd\u04de\3\2\2\2\u04de\u04e0\3\2\2\2\u04df\u04dd"+
		"\3\2\2\2\u04e0\u04e1\5L\'\2\u04e1\u04e2\5z>\2\u04e2\u04e3\7g\2\2\u04e3"+
		"\u0564\3\2\2\2\u04e4\u04e8\7i\2\2\u04e5\u04e7\7S\2\2\u04e6\u04e5\3\2\2"+
		"\2\u04e7\u04ea\3\2\2\2\u04e8\u04e6\3\2\2\2\u04e8\u04e9\3\2\2\2\u04e9\u04eb"+
		"\3\2\2\2\u04ea\u04e8\3\2\2\2\u04eb\u04ec\5|?\2\u04ec\u04f0\7l\2\2\u04ed"+
		"\u04ef\7S\2\2\u04ee\u04ed\3\2\2\2\u04ef\u04f2\3\2\2\2\u04f0\u04ee\3\2"+
		"\2\2\u04f0\u04f1\3\2\2\2\u04f1\u04f3\3\2\2\2\u04f2\u04f0\3\2\2\2\u04f3"+
		"\u04f4\5\\/\2\u04f4\u04f5\5z>\2\u04f5\u04f6\7g\2\2\u04f6\u0564\3\2\2\2"+
		"\u04f7\u0564\5X-\2\u04f8\u04fc\7\22\2\2\u04f9\u04fb\7S\2\2\u04fa\u04f9"+
		"\3\2\2\2\u04fb\u04fe\3\2\2\2\u04fc\u04fa\3\2\2\2\u04fc\u04fd\3\2\2\2\u04fd"+
		"\u0500\3\2\2\2\u04fe\u04fc\3\2\2\2\u04ff\u0501\5\62\32\2\u0500\u04ff\3"+
		"\2\2\2\u0500\u0501\3\2\2\2\u0501\u0505\3\2\2\2\u0502\u0504\7S\2\2\u0503"+
		"\u0502\3\2\2\2\u0504\u0507\3\2\2\2\u0505\u0503\3\2\2\2\u0505\u0506\3\2"+
		"\2\2\u0506\u0508\3\2\2\2\u0507\u0505\3\2\2\2\u0508\u0564\7\23\2\2\u0509"+
		"\u050b\7F\2\2\u050a\u050c\5\u00c8e\2\u050b\u050a\3\2\2\2\u050b\u050c\3"+
		"\2\2\2\u050c\u050d\3\2\2\2\u050d\u0564\7\7\2\2\u050e\u0510\7J\2\2\u050f"+
		"\u0511\5\u00c8e\2\u0510\u050f\3\2\2\2\u0510\u0511\3\2\2\2\u0511\u0512"+
		"\3\2\2\2\u0512\u0564\7\b\2\2\u0513\u0515\7G\2\2\u0514\u0516\5\u00caf\2"+
		"\u0515\u0514\3\2\2\2\u0515\u0516\3\2\2\2\u0516\u0517\3\2\2\2\u0517\u0564"+
		"\7\f\2\2\u0518\u051a\7K\2\2\u0519\u051b\5\u00caf\2\u051a\u0519\3\2\2\2"+
		"\u051a\u051b\3\2\2\2\u051b\u051c\3\2\2\2\u051c\u0564\7\r\2\2\u051d\u0564"+
		"\5R*\2\u051e\u0520\t\7\2\2\u051f\u051e\3\2\2\2\u051f\u0520\3\2\2\2\u0520"+
		"\u0521\3\2\2\2\u0521\u0564\5\u00dan\2\u0522\u0526\5\u00b2Z\2\u0523\u0525"+
		"\5\u00b4[\2\u0524\u0523\3\2\2\2\u0525\u0528\3\2\2\2\u0526\u0524\3\2\2"+
		"\2\u0526\u0527\3\2\2\2\u0527\u0564\3\2\2\2\u0528\u0526\3\2\2\2\u0529\u052d"+
		"\5\u00b6\\\2\u052a\u052c\5\u00b4[\2\u052b\u052a\3\2\2\2\u052c\u052f\3"+
		"\2\2\2\u052d\u052b\3\2\2\2\u052d\u052e\3\2\2\2\u052e\u0564\3\2\2\2\u052f"+
		"\u052d\3\2\2\2\u0530\u0532\7B\2\2\u0531\u0533\7\20\2\2\u0532\u0531\3\2"+
		"\2\2\u0532\u0533\3\2\2\2\u0533\u0534\3\2\2\2\u0534\u0564\7\6\2\2\u0535"+
		"\u0539\7C\2\2\u0536\u0538\5\u00c0a\2\u0537\u0536\3\2\2\2\u0538\u053b\3"+
		"\2\2\2\u0539\u0537\3\2\2\2\u0539\u053a\3\2\2\2\u053a\u053c\3\2\2\2\u053b"+
		"\u0539\3\2\2\2\u053c\u0564\7\n\2\2\u053d\u0541\7E\2\2\u053e\u0540\5\u00c0"+
		"a\2\u053f\u053e\3\2\2\2\u0540\u0543\3\2\2\2\u0541\u053f\3\2\2\2\u0541"+
		"\u0542\3\2\2\2\u0542\u0544\3\2\2\2\u0543\u0541\3\2\2\2\u0544\u0564\7\13"+
		"\2\2\u0545\u0564\5\u00ccg\2\u0546\u054a\7\5\2\2\u0547\u0549\5\u00b0Y\2"+
		"\u0548\u0547\3\2\2\2\u0549\u054c\3\2\2\2\u054a\u0548\3\2\2\2\u054a\u054b"+
		"\3\2\2\2\u054b\u054d\3\2\2\2\u054c\u054a\3\2\2\2\u054d\u0564\7\u0095\2"+
		"\2\u054e\u0552\7D\2\2\u054f\u0551\5\u00c0a\2\u0550\u054f\3\2\2\2\u0551"+
		"\u0554\3\2\2\2\u0552\u0550\3\2\2\2\u0552\u0553\3\2\2\2\u0553\u0555\3\2"+
		"\2\2\u0554\u0552\3\2\2\2\u0555\u0564\7\t\2\2\u0556\u0557\7\24\2\2\u0557"+
		"\u0558\5\4\3\2\u0558\u0559\7\25\2\2\u0559\u0564\3\2\2\2\u055a\u055b\5"+
		"\u00dco\2\u055b\u055c\5T+\22\u055c\u0564\3\2\2\2\u055d\u055e\7\67\2\2"+
		"\u055e\u0564\5T+\20\u055f\u0560\5\u00eav\2\u0560\u0561\5T+\4\u0561\u0564"+
		"\3\2\2\2\u0562\u0564\5\u00ceh\2\u0563\u0428\3\2\2\2\u0563\u0433\3\2\2"+
		"\2\u0563\u043e\3\2\2\2\u0563\u044a\3\2\2\2\u0563\u0451\3\2\2\2\u0563\u0456"+
		"\3\2\2\2\u0563\u045c\3\2\2\2\u0563\u0464\3\2\2\2\u0563\u0476\3\2\2\2\u0563"+
		"\u047b\3\2\2\2\u0563\u048f\3\2\2\2\u0563\u049d\3\2\2\2\u0563\u04a8\3\2"+
		"\2\2\u0563\u04ac\3\2\2\2\u0563\u04b0\3\2\2\2\u0563\u04c8\3\2\2\2\u0563"+
		"\u04d9\3\2\2\2\u0563\u04e4\3\2\2\2\u0563\u04f7\3\2\2\2\u0563\u04f8\3\2"+
		"\2\2\u0563\u0509\3\2\2\2\u0563\u050e\3\2\2\2\u0563\u0513\3\2\2\2\u0563"+
		"\u0518\3\2\2\2\u0563\u051d\3\2\2\2\u0563\u051f\3\2\2\2\u0563\u0522\3\2"+
		"\2\2\u0563\u0529\3\2\2\2\u0563\u0530\3\2\2\2\u0563\u0535\3\2\2\2\u0563"+
		"\u053d\3\2\2\2\u0563\u0545\3\2\2\2\u0563\u0546\3\2\2\2\u0563\u054e\3\2"+
		"\2\2\u0563\u0556\3\2\2\2\u0563\u055a\3\2\2\2\u0563\u055d\3\2\2\2\u0563"+
		"\u055f\3\2\2\2\u0563\u0562\3\2\2\2\u0564\u061b\3\2\2\2\u0565\u0566\f\21"+
		"\2\2\u0566\u056a\79\2\2\u0567\u0569\7S\2\2\u0568\u0567\3\2\2\2\u0569\u056c"+
		"\3\2\2\2\u056a\u0568\3\2\2\2\u056a\u056b\3\2\2\2\u056b\u056d\3\2\2\2\u056c"+
		"\u056a\3\2\2\2\u056d\u061a\5T+\21\u056e\u056f\f\17\2\2\u056f\u0573\5\u00de"+
		"p\2\u0570\u0572\7S\2\2\u0571\u0570\3\2\2\2\u0572\u0575\3\2\2\2\u0573\u0571"+
		"\3\2\2\2\u0573\u0574\3\2\2\2\u0574\u0576\3\2\2\2\u0575\u0573\3\2\2\2\u0576"+
		"\u0577\5T+\20\u0577\u061a\3\2\2\2\u0578\u0579\f\16\2\2\u0579\u057d\5\u00e0"+
		"q\2\u057a\u057c\7S\2\2\u057b\u057a\3\2\2\2\u057c\u057f\3\2\2\2\u057d\u057b"+
		"\3\2\2\2\u057d\u057e\3\2\2\2\u057e\u0580\3\2\2\2\u057f\u057d\3\2\2\2\u0580"+
		"\u0581\5T+\17\u0581\u061a\3\2\2\2\u0582\u0583\f\r\2\2\u0583\u0587\5\u00e2"+
		"r\2\u0584\u0586\7S\2\2\u0585\u0584\3\2\2\2\u0586\u0589\3\2\2\2\u0587\u0585"+
		"\3\2\2\2\u0587\u0588\3\2\2\2\u0588\u058a\3\2\2\2\u0589\u0587\3\2\2\2\u058a"+
		"\u058b\5T+\16\u058b\u061a\3\2\2\2\u058c\u058d\f\f\2\2\u058d\u0591\7%\2"+
		"\2\u058e\u0590\7S\2\2\u058f\u058e\3\2\2\2\u0590\u0593\3\2\2\2\u0591\u058f"+
		"\3\2\2\2\u0591\u0592\3\2\2\2\u0592\u0594\3\2\2\2\u0593\u0591\3\2\2\2\u0594"+
		"\u061a\5T+\r\u0595\u0596\f\13\2\2\u0596\u059a\5\u00e4s\2\u0597\u0599\7"+
		"S\2\2\u0598\u0597\3\2\2\2\u0599\u059c\3\2\2\2\u059a\u0598\3\2\2\2\u059a"+
		"\u059b\3\2\2\2\u059b\u059d\3\2\2\2\u059c\u059a\3\2\2\2\u059d\u059e\5T"+
		"+\f\u059e\u061a\3\2\2\2\u059f\u05a0\f\n\2\2\u05a0\u05a4\5\u00e6t\2\u05a1"+
		"\u05a3\7S\2\2\u05a2\u05a1\3\2\2\2\u05a3\u05a6\3\2\2\2\u05a4\u05a2\3\2"+
		"\2\2\u05a4\u05a5\3\2\2\2\u05a5\u05a7\3\2\2\2\u05a6\u05a4\3\2\2\2\u05a7"+
		"\u05a8\5T+\13\u05a8\u061a\3\2\2\2\u05a9\u05aa\f\t\2\2\u05aa\u05ae\5\u00e8"+
		"u\2\u05ab\u05ad\7S\2\2\u05ac\u05ab\3\2\2\2\u05ad\u05b0\3\2\2\2\u05ae\u05ac"+
		"\3\2\2\2\u05ae\u05af\3\2\2\2\u05af\u05b1\3\2\2\2\u05b0\u05ae\3\2\2\2\u05b1"+
		"\u05b2\5T+\n\u05b2\u061a\3\2\2\2\u05b3\u05b4\f\6\2\2\u05b4\u05b8\5\u00ea"+
		"v\2\u05b5\u05b7\7S\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"+
		"\u05bc\5T+\7\u05bc\u061a\3\2\2\2\u05bd\u05be\f9\2\2\u05be\u05bf\t\3\2"+
		"\2\u05bf\u05c0\5\"\22\2\u05c0\u05c4\5\u00d2j\2\u05c1\u05c3\7S\2\2\u05c2"+
		"\u05c1\3\2\2\2\u05c3\u05c6\3\2\2\2\u05c4\u05c2\3\2\2\2\u05c4\u05c5\3\2"+
		"\2\2\u05c5\u05c7\3\2\2\2\u05c6\u05c4\3\2\2\2\u05c7\u05c8\5N(\2\u05c8\u061a"+
		"\3\2\2\2\u05c9\u05ca\f\67\2\2\u05ca\u05cc\7\22\2\2\u05cb\u05cd\5\66\34"+
		"\2\u05cc\u05cb\3\2\2\2\u05cc\u05cd\3\2\2\2\u05cd\u05ce\3\2\2\2\u05ce\u05cf"+
		"\7\23\2\2\u05cf\u05d3\5\u00d2j\2\u05d0\u05d2\7S\2\2\u05d1\u05d0\3\2\2"+
		"\2\u05d2\u05d5\3\2\2\2\u05d3\u05d1\3\2\2\2\u05d3\u05d4\3\2\2\2\u05d4\u05d6"+
		"\3\2\2\2\u05d5\u05d3\3\2\2\2\u05d6\u05d7\5N(\2\u05d7\u061a\3\2\2\2\u05d8"+
		"\u05d9\f\66\2\2\u05d9\u05dd\5\u00d2j\2\u05da\u05dc\7S\2\2\u05db\u05da"+
		"\3\2\2\2\u05dc\u05df\3\2\2\2\u05dd\u05db\3\2\2\2\u05dd\u05de\3\2\2\2\u05de"+
		"\u05e0\3\2\2\2\u05df\u05dd\3\2\2\2\u05e0\u05e1\5N(\2\u05e1\u05e2\7s\2"+
		"\2\u05e2\u05e3\5N(\2\u05e3\u061a\3\2\2\2\u05e4\u05e5\f\24\2\2\u05e5\u05e7"+
		"\7\22\2\2\u05e6\u05e8\5\66\34\2\u05e7\u05e6\3\2\2\2\u05e7\u05e8\3\2\2"+
		"\2\u05e8\u05e9\3\2\2\2\u05e9\u061a\7\23\2\2\u05ea\u05ee\f\23\2\2\u05eb"+
		"\u05ed\7S\2\2\u05ec\u05eb\3\2\2\2\u05ed\u05f0\3\2\2\2\u05ee\u05ec\3\2"+
		"\2\2\u05ee\u05ef\3\2\2\2\u05ef\u05f1\3\2\2\2\u05f0\u05ee\3\2\2\2\u05f1"+
		"\u05f5\t\6\2\2\u05f2\u05f4\7S\2\2\u05f3\u05f2\3\2\2\2\u05f4\u05f7\3\2"+
		"\2\2\u05f5\u05f3\3\2\2\2\u05f5\u05f6\3\2\2\2\u05f6\u05f8\3\2\2\2\u05f7"+
		"\u05f5\3\2\2\2\u05f8\u05fa\5\"\22\2\u05f9\u05fb\5@!\2\u05fa\u05f9\3\2"+
		"\2\2\u05fa\u05fb\3\2\2\2\u05fb\u05fd\3\2\2\2\u05fc\u05fe\5^\60\2\u05fd"+
		"\u05fc\3\2\2\2\u05fd\u05fe\3\2\2\2\u05fe\u061a\3\2\2\2\u05ff\u0600\f\b"+
		"\2\2\u0600\u0604\7&\2\2\u0601\u0603\7S\2\2\u0602\u0601\3\2\2\2\u0603\u0606"+
		"\3\2\2\2\u0604\u0602\3\2\2\2\u0604\u0605\3\2\2\2\u0605\u0609\3\2\2\2\u0606"+
		"\u0604\3\2\2\2\u0607\u060a\5T+\2\u0608\u060a\7u\2\2\u0609\u0607\3\2\2"+
		"\2\u0609\u0608\3\2\2\2\u060a\u061a\3\2\2\2\u060b\u060c\f\7\2\2\u060c\u0610"+
		"\7)\2\2\u060d\u060f\7S\2\2\u060e\u060d\3\2\2\2\u060f\u0612\3\2\2\2\u0610"+
		"\u060e\3\2\2\2\u0610\u0611\3\2\2\2\u0611\u0615\3\2\2\2\u0612\u0610\3\2"+
		"\2\2\u0613\u0616\5T+\2\u0614\u0616\7u\2\2\u0615\u0613\3\2\2\2\u0615\u0614"+
		"\3\2\2\2\u0616\u061a\3\2\2\2\u0617\u0618\f\5\2\2\u0618\u061a\5\u00eav"+
		"\2\u0619\u0565\3\2\2\2\u0619\u056e\3\2\2\2\u0619\u0578\3\2\2\2\u0619\u0582"+
		"\3\2\2\2\u0619\u058c\3\2\2\2\u0619\u0595\3\2\2\2\u0619\u059f\3\2\2\2\u0619"+
		"\u05a9\3\2\2\2\u0619\u05b3\3\2\2\2\u0619\u05bd\3\2\2\2\u0619\u05c9\3\2"+
		"\2\2\u0619\u05d8\3\2\2\2\u0619\u05e4\3\2\2\2\u0619\u05ea\3\2\2\2\u0619"+
		"\u05ff\3\2\2\2\u0619\u060b\3\2\2\2\u0619\u0617\3\2\2\2\u061a\u061d\3\2"+
		"\2\2\u061b\u0619\3\2\2\2\u061b\u061c\3\2\2\2\u061cU\3\2\2\2\u061d\u061b"+
		"\3\2\2\2\u061e\u0620\7\24\2\2\u061f\u0621\5d\63\2\u0620\u061f\3\2\2\2"+
		"\u0620\u0621\3\2\2\2\u0621\u0622\3\2\2\2\u0622\u0625\7\25\2\2\u0623\u0625"+
		"\5d\63\2\u0624\u061e\3\2\2\2\u0624\u0623\3\2\2\2\u0625W\3\2\2\2\u0626"+
		"\u0628\7w\2\2\u0627\u0629\5@!\2\u0628\u0627\3\2\2\2\u0628\u0629\3\2\2"+
		"\2\u0629\u062b\3\2\2\2\u062a\u062c\5^\60\2\u062b\u062a\3\2\2\2\u062b\u062c"+
		"\3\2\2\2\u062c\u0647\3\2\2\2\u062d\u062f\7w\2\2\u062e\u0630\5B\"\2\u062f"+
		"\u062e\3\2\2\2\u062f\u0630\3\2\2\2\u0630\u0632\3\2\2\2\u0631\u0633\5^"+
		"\60\2\u0632\u0631\3\2\2\2\u0632\u0633\3\2\2\2\u0633\u0647\3\2\2\2\u0634"+
		"\u0635\5\u00d0i\2\u0635\u0636\7\24\2\2\u0636\u0637\5L\'\2\u0637\u0638"+
		"\7\25\2\2\u0638\u0647\3\2\2\2\u0639\u063a\5\u00d0i\2\u063a\u063b\5T+\2"+
		"\u063b\u0647\3\2\2\2\u063c\u0647\5$\23\2\u063d\u063e\5 \21\2\u063e\u063f"+
		"\5^\60\2\u063f\u0647\3\2\2\2\u0640\u0641\5 \21\2\u0641\u0643\5@!\2\u0642"+
		"\u0644\5^\60\2\u0643\u0642\3\2\2\2\u0643\u0644\3\2\2\2\u0644\u0647\3\2"+
		"\2\2\u0645\u0647\5\u00a6T\2\u0646\u0626\3\2\2\2\u0646\u062d\3\2\2\2\u0646"+
		"\u0634\3\2\2\2\u0646\u0639\3\2\2\2\u0646\u063c\3\2\2\2\u0646\u063d\3\2"+
		"\2\2\u0646\u0640\3\2\2\2\u0646\u0645\3\2\2\2\u0647Y\3\2\2\2\u0648\u064b"+
		"\5(\25\2\u0649\u064b\5T+\2\u064a\u0648\3\2\2\2\u064a\u0649\3\2\2\2\u064b"+
		"[\3\2\2\2\u064c\u064d\b/\1\2\u064d\u0652\5T+\2\u064e\u0652\5(\25\2\u064f"+
		"\u0650\7p\2\2\u0650\u0652\5\\/\4\u0651\u064c\3\2\2\2\u0651\u064e\3\2\2"+
		"\2\u0651\u064f\3\2\2\2\u0652\u065e\3\2\2\2\u0653\u0654\f\3\2\2\u0654\u0658"+
		"\t\b\2\2\u0655\u0657\7S\2\2\u0656\u0655\3\2\2\2\u0657\u065a\3\2\2\2\u0658"+
		"\u0656\3\2\2\2\u0658\u0659\3\2\2\2\u0659\u065b\3\2\2\2\u065a\u0658\3\2"+
		"\2\2\u065b\u065d\5\\/\4\u065c\u0653\3\2\2\2\u065d\u0660\3\2\2\2\u065e"+
		"\u065c\3\2\2\2\u065e\u065f\3\2\2\2\u065f]\3\2\2\2\u0660\u065e\3\2\2\2"+
		"\u0661\u0665\7\26\2\2\u0662\u0664\7S\2\2\u0663\u0662\3\2\2\2\u0664\u0667"+
		"\3\2\2\2\u0665\u0663\3\2\2\2\u0665\u0666\3\2\2\2\u0666\u0669\3\2\2\2\u0667"+
		"\u0665\3\2\2\2\u0668\u066a\5b\62\2\u0669\u0668\3\2\2\2\u0669\u066a\3\2"+
		"\2\2\u066a\u066b\3\2\2\2\u066b\u066c\5\4\3\2\u066c\u066d\7\27\2\2\u066d"+
		"\u0670\3\2\2\2\u066e\u0670\5`\61\2\u066f\u0661\3\2\2\2\u066f\u066e\3\2"+
		"\2\2\u0670_\3\2\2\2\u0671\u0675\7d\2\2\u0672\u0674\7S\2\2\u0673\u0672"+
		"\3\2\2\2\u0674\u0677\3\2\2\2\u0675\u0673\3\2\2\2\u0675\u0676\3\2\2\2\u0676"+
		"\u0679\3\2\2\2\u0677\u0675\3\2\2\2\u0678\u067a\5b\62\2\u0679\u0678\3\2"+
		"\2\2\u0679\u067a\3\2\2\2\u067a\u067b\3\2\2\2\u067b\u067c\5~@\2\u067c\u067d"+
		"\7g\2\2\u067da\3\2\2\2\u067e\u0682\7(\2\2\u067f\u0681\7S\2\2\u0680\u067f"+
		"\3\2\2\2\u0681\u0684\3\2\2\2\u0682\u0680\3\2\2\2\u0682\u0683\3\2\2\2\u0683"+
		"\u0685\3\2\2\2\u0684\u0682\3\2\2\2\u0685\u0697\7(\2\2\u0686\u068a\7(\2"+
		"\2\u0687\u0689\7S\2\2\u0688\u0687\3\2\2\2\u0689\u068c\3\2\2\2\u068a\u0688"+
		"\3\2\2\2\u068a\u068b\3\2\2\2\u068b\u068d\3\2\2\2\u068c\u068a\3\2\2\2\u068d"+
		"\u0691\5d\63\2\u068e\u0690\7S\2\2\u068f\u068e\3\2\2\2\u0690\u0693\3\2"+
		"\2\2\u0691\u068f\3\2\2\2\u0691\u0692\3\2\2\2\u0692\u0694\3\2\2\2\u0693"+
		"\u0691\3\2\2\2\u0694\u0695\7(\2\2\u0695\u0697\3\2\2\2\u0696\u067e\3\2"+
		"\2\2\u0696\u0686\3\2\2\2\u0697c\3\2\2\2\u0698\u06a1\5f\64\2\u0699\u069d"+
		"\7\32\2\2\u069a\u069c\7S\2\2\u069b\u069a\3\2\2\2\u069c\u069f\3\2\2\2\u069d"+
		"\u069b\3\2\2\2\u069d\u069e\3\2\2\2\u069e\u06a0\3\2\2\2\u069f\u069d\3\2"+
		"\2\2\u06a0\u06a2\5\u009aN\2\u06a1\u0699\3\2\2\2\u06a1\u06a2\3\2\2\2\u06a2"+
		"\u06ad\3\2\2\2\u06a3\u06a7\7\32\2\2\u06a4\u06a6\7S\2\2\u06a5\u06a4\3\2"+
		"\2\2\u06a6\u06a9\3\2\2\2\u06a7\u06a5\3\2\2\2\u06a7\u06a8\3\2\2\2\u06a8"+
		"\u06aa\3\2\2\2\u06a9\u06a7\3\2\2\2\u06aa\u06ac\5j\66\2\u06ab\u06a3\3\2"+
		"\2\2\u06ac\u06af\3\2\2\2\u06ad\u06ab\3\2\2\2\u06ad\u06ae\3\2\2\2\u06ae"+
		"\u06b8\3\2\2\2\u06af\u06ad\3\2\2\2\u06b0\u06b4\7\32\2\2\u06b1\u06b3\7"+
		"S\2\2\u06b2\u06b1\3\2\2\2\u06b3\u06b6\3\2\2\2\u06b4\u06b2\3\2\2\2\u06b4"+
		"\u06b5\3\2\2\2\u06b5\u06b7\3\2\2\2\u06b6\u06b4\3\2\2\2\u06b7\u06b9\5\u009c"+
		"O\2\u06b8\u06b0\3\2\2\2\u06b8\u06b9\3\2\2\2\u06b9\u06c2\3\2\2\2\u06ba"+
		"\u06be\7\32\2\2\u06bb\u06bd\7S\2\2\u06bc\u06bb\3\2\2\2\u06bd\u06c0\3\2"+
		"\2\2\u06be\u06bc\3\2\2\2\u06be\u06bf\3\2\2\2\u06bf\u06c1\3\2\2\2\u06c0"+
		"\u06be\3\2\2\2\u06c1\u06c3\5\u009eP\2\u06c2\u06ba\3\2\2\2\u06c2\u06c3"+
		"\3\2\2\2\u06c3\u06f3\3\2\2\2\u06c4\u06cf\5\u009aN\2\u06c5\u06c9\7\32\2"+
		"\2\u06c6\u06c8\7S\2\2\u06c7\u06c6\3\2\2\2\u06c8\u06cb\3\2\2\2\u06c9\u06c7"+
		"\3\2\2\2\u06c9\u06ca\3\2\2\2\u06ca\u06cc\3\2\2\2\u06cb\u06c9\3\2\2\2\u06cc"+
		"\u06ce\5j\66\2\u06cd\u06c5\3\2\2\2\u06ce\u06d1\3\2\2\2\u06cf\u06cd\3\2"+
		"\2\2\u06cf\u06d0\3\2\2\2\u06d0\u06da\3\2\2\2\u06d1\u06cf\3\2\2\2\u06d2"+
		"\u06d6\7\32\2\2\u06d3\u06d5\7S\2\2\u06d4\u06d3\3\2\2\2\u06d5\u06d8\3\2"+
		"\2\2\u06d6\u06d4\3\2\2\2\u06d6\u06d7\3\2\2\2\u06d7\u06d9\3\2\2\2\u06d8"+
		"\u06d6\3\2\2\2\u06d9\u06db\5\u009cO\2\u06da\u06d2\3\2\2\2\u06da\u06db"+
		"\3\2\2\2\u06db\u06e4\3\2\2\2\u06dc\u06e0\7\32\2\2\u06dd\u06df\7S\2\2\u06de"+
		"\u06dd\3\2\2\2\u06df\u06e2\3\2\2\2\u06e0\u06de\3\2\2\2\u06e0\u06e1\3\2"+
		"\2\2\u06e1\u06e3\3\2\2\2\u06e2\u06e0\3\2\2\2\u06e3\u06e5\5\u009eP\2\u06e4"+
		"\u06dc\3\2\2\2\u06e4\u06e5\3\2\2\2\u06e5\u06f3\3\2\2\2\u06e6\u06ef\5\u009c"+
		"O\2\u06e7\u06eb\7\32\2\2\u06e8\u06ea\7S\2\2\u06e9\u06e8\3\2\2\2\u06ea"+
		"\u06ed\3\2\2\2\u06eb\u06e9\3\2\2\2\u06eb\u06ec\3\2\2\2\u06ec\u06ee\3\2"+
		"\2\2\u06ed\u06eb\3\2\2\2\u06ee\u06f0\5\u009eP\2\u06ef\u06e7\3\2\2\2\u06ef"+
		"\u06f0\3\2\2\2\u06f0\u06f3\3\2\2\2\u06f1\u06f3\5\u009eP\2\u06f2\u0698"+
		"\3\2\2\2\u06f2\u06c4\3\2\2\2\u06f2\u06e6\3\2\2\2\u06f2\u06f1\3\2\2\2\u06f3"+
		"e\3\2\2\2\u06f4\u06ff\5h\65\2\u06f5\u06f9\7\32\2\2\u06f6\u06f8\7S\2\2"+
		"\u06f7\u06f6\3\2\2\2\u06f8\u06fb\3\2\2\2\u06f9\u06f7\3\2\2\2\u06f9\u06fa"+
		"\3\2\2\2\u06fa\u06fc\3\2\2\2\u06fb\u06f9\3\2\2\2\u06fc\u06fe\5h\65\2\u06fd"+
		"\u06f5\3\2\2\2\u06fe\u0701\3\2\2\2\u06ff\u06fd\3\2\2\2\u06ff\u0700\3\2"+
		"\2\2\u0700g\3\2\2\2\u0701\u06ff\3\2\2\2\u0702\u0706\5\u0094K\2\u0703\u0706"+
		"\5\u0096L\2\u0704\u0706\5n8\2\u0705\u0702\3\2\2\2\u0705\u0703\3\2\2\2"+
		"\u0705\u0704\3\2\2\2\u0706i\3\2\2\2\u0707\u0712\5l\67\2\u0708\u070c\7"+
		"\32\2\2\u0709\u070b\7S\2\2\u070a\u0709\3\2\2\2\u070b\u070e\3\2\2\2\u070c"+
		"\u070a\3\2\2\2\u070c\u070d\3\2\2\2\u070d\u070f\3\2\2\2\u070e\u070c\3\2"+
		"\2\2\u070f\u0711\5l\67\2\u0710\u0708\3\2\2\2\u0711\u0714\3\2\2\2\u0712"+
		"\u0710\3\2\2\2\u0712\u0713\3\2\2\2\u0713k\3\2\2\2\u0714\u0712\3\2\2\2"+
		"\u0715\u0718\5\u0094K\2\u0716\u0718\5n8\2\u0717\u0715\3\2\2\2\u0717\u0716"+
		"\3\2\2\2\u0718m\3\2\2\2\u0719\u071a\7\24\2\2\u071a\u0723\5\u0094K\2\u071b"+
		"\u071f\7\32\2\2\u071c\u071e\7S\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\u0724\5\u009aN\2\u0723\u071b\3\2\2\2\u0723\u0724"+
		"\3\2\2\2\u0724\u072f\3\2\2\2\u0725\u0729\7\32\2\2\u0726\u0728\7S\2\2\u0727"+
		"\u0726\3\2\2\2\u0728\u072b\3\2\2\2\u0729\u0727\3\2\2\2\u0729\u072a\3\2"+
		"\2\2\u072a\u072c\3\2\2\2\u072b\u0729\3\2\2\2\u072c\u072e\5\u0094K\2\u072d"+
		"\u0725\3\2\2\2\u072e\u0731\3\2\2\2\u072f\u072d\3\2\2\2\u072f\u0730\3\2"+
		"\2\2\u0730\u0732\3\2\2\2\u0731\u072f\3\2\2\2\u0732\u0733\7\25\2\2\u0733"+
		"\u0746\3\2\2\2\u0734\u0735\7\24\2\2\u0735\u0740\5\u009aN\2\u0736\u073a"+
		"\7\32\2\2\u0737\u0739\7S\2\2\u0738\u0737\3\2\2\2\u0739\u073c\3\2\2\2\u073a"+
		"\u0738\3\2\2\2\u073a\u073b\3\2\2\2\u073b\u073d\3\2\2\2\u073c\u073a\3\2"+
		"\2\2\u073d\u073f\5\u0094K\2\u073e\u0736\3\2\2\2\u073f\u0742\3\2\2\2\u0740"+
		"\u073e\3\2\2\2\u0740\u0741\3\2\2\2\u0741\u0743\3\2\2\2\u0742\u0740\3\2"+
		"\2\2\u0743\u0744\7\25\2\2\u0744\u0746\3\2\2\2\u0745\u0719\3\2\2\2\u0745"+
		"\u0734\3\2\2\2\u0746o\3\2\2\2\u0747\u0749\t\2\2\2\u0748\u0747\3\2\2\2"+
		"\u0749\u074a\3\2\2\2\u074a\u0748\3\2\2\2\u074a\u074b\3\2\2\2\u074b\u074c"+
		"\3\2\2\2\u074c\u0753\5\4\3\2\u074d\u074f\t\2\2\2\u074e\u074d\3\2\2\2\u074e"+
		"\u074f\3\2\2\2\u074f\u0750\3\2\2\2\u0750\u0751\7x\2\2\u0751\u0753\5\4"+
		"\3\2\u0752\u0748\3\2\2\2\u0752\u074e\3\2\2\2\u0753q\3\2\2\2\u0754\u0755"+
		"\7e\2\2\u0755\u0756\5\4\3\2\u0756s\3\2\2\2\u0757\u075b\7f\2\2\u0758\u075a"+
		"\7S\2\2\u0759\u0758\3\2\2\2\u075a\u075d\3\2\2\2\u075b\u0759\3\2\2\2\u075b"+
		"\u075c\3\2\2\2\u075c\u075e\3\2\2\2\u075d\u075b\3\2\2\2\u075e\u075f\5L"+
		"\'\2\u075f\u0760\5p9\2\u0760u\3\2\2\2\u0761\u0765\7}\2\2\u0762\u0764\7"+
		"S\2\2\u0763\u0762\3\2\2\2\u0764\u0767\3\2\2\2\u0765\u0763\3\2\2\2\u0765"+
		"\u0766\3\2\2\2\u0766\u0768\3\2\2\2\u0767\u0765\3\2\2\2\u0768\u0769\5x"+
		"=\2\u0769\u076a\5p9\2\u076aw\3\2\2\2\u076b\u076e\5<\37\2\u076c\u076d\7"+
		"\32\2\2\u076d\u076f\5:\36\2\u076e\u076c\3\2\2\2\u076e\u076f\3\2\2\2\u076f"+
		"\u0772\3\2\2\2\u0770\u0772\5:\36\2\u0771\u076b\3\2\2\2\u0771\u0770\3\2"+
		"\2\2\u0772y\3\2\2\2\u0773\u0775\t\2\2\2\u0774\u0773\3\2\2\2\u0775\u0776"+
		"\3\2\2\2\u0776\u0774\3\2\2\2\u0776\u0777\3\2\2\2\u0777\u0778\3\2\2\2\u0778"+
		"\u077c\5\4\3\2\u0779\u077a\7d\2\2\u077a\u077c\5\4\3\2\u077b\u0774\3\2"+
		"\2\2\u077b\u0779\3\2\2\2\u077c{\3\2\2\2\u077d\u0780\5\20\t\2\u077e\u0780"+
		"\5\22\n\2\u077f\u077d\3\2\2\2\u077f\u077e\3\2\2\2\u0780}\3\2\2\2\u0781"+
		"\u0785\5\4\3\2\u0782\u0784\5\u0080A\2\u0783\u0782\3\2\2\2\u0784\u0787"+
		"\3\2\2\2\u0785\u0783\3\2\2\2\u0785\u0786\3\2\2\2\u0786\u0789\3\2\2\2\u0787"+
		"\u0785\3\2\2\2\u0788\u078a\5r:\2\u0789\u0788\3\2\2\2\u0789\u078a\3\2\2"+
		"\2\u078a\u078c\3\2\2\2\u078b\u078d\5\u0086D\2\u078c\u078b\3\2\2\2\u078c"+
		"\u078d\3\2\2\2\u078d\177\3\2\2\2\u078e\u0790\7s\2\2\u078f\u0791\5\u0082"+
		"B\2\u0790\u078f\3\2\2\2\u0790\u0791\3\2\2\2\u0791\u0793\3\2\2\2\u0792"+
		"\u0794\5\u0084C\2\u0793\u0792\3\2\2\2\u0793\u0794\3\2\2\2\u0794\u0795"+
		"\3\2\2\2\u0795\u0796\5p9\2\u0796\u0081\3\2\2\2\u0797\u079a\5N(\2\u0798"+
		"\u079a\5\34\17\2\u0799\u0797\3\2\2\2\u0799\u0798\3\2\2\2\u079a\u0083\3"+
		"\2\2\2\u079b\u079c\7 \2\2\u079c\u079d\5\20\t\2\u079d\u0085\3\2\2\2\u079e"+
		"\u079f\7h\2\2\u079f\u07a0\5\4\3\2\u07a0\u0087\3\2\2\2\u07a1\u07ad\5\""+
		"\22\2\u07a2\u07ad\7\u0084\2\2\u07a3\u07a4\7\22\2\2\u07a4\u07a6\7\23\2"+
		"\2\u07a5\u07a7\7*\2\2\u07a6\u07a5\3\2\2\2\u07a6\u07a7\3\2\2\2\u07a7\u07ad"+
		"\3\2\2\2\u07a8\u07ad\7+\2\2\u07a9\u07ad\7,\2\2\u07aa\u07ad\7.\2\2\u07ab"+
		"\u07ad\7\64\2\2\u07ac\u07a1\3\2\2\2\u07ac\u07a2\3\2\2\2\u07ac\u07a3\3"+
		"\2\2\2\u07ac\u07a8\3\2\2\2\u07ac\u07a9\3\2\2\2\u07ac\u07aa\3\2\2\2\u07ac"+
		"\u07ab\3\2\2\2\u07ad\u0089\3\2\2\2\u07ae\u07b2\7\24\2\2\u07af\u07b1\7"+
		"S\2\2\u07b0\u07af\3\2\2\2\u07b1\u07b4\3\2\2\2\u07b2\u07b0\3\2\2\2\u07b2"+
		"\u07b3\3\2\2\2\u07b3\u07b6\3\2\2\2\u07b4\u07b2\3\2\2\2\u07b5\u07b7\5\u008c"+
		"G\2\u07b6\u07b5\3\2\2\2\u07b6\u07b7\3\2\2\2\u07b7\u07bb\3\2\2\2\u07b8"+
		"\u07ba\7S\2\2\u07b9\u07b8\3\2\2\2\u07ba\u07bd\3\2\2\2\u07bb\u07b9\3\2"+
		"\2\2\u07bb\u07bc\3\2\2\2\u07bc\u07be\3\2\2\2\u07bd\u07bb\3\2\2\2\u07be"+
		"\u07c4\7\25\2\2\u07bf\u07c1\5\u008cG\2\u07c0\u07bf\3\2\2\2\u07c0\u07c1"+
		"\3\2\2\2\u07c1\u07c2\3\2\2\2\u07c2\u07c4\t\2\2\2\u07c3\u07ae\3\2\2\2\u07c3"+
		"\u07c0\3\2\2\2\u07c4\u008b\3\2\2\2\u07c5\u07ce\5\u008eH\2\u07c6\u07ca"+
		"\7\32\2\2\u07c7\u07c9\7S\2\2\u07c8\u07c7\3\2\2\2\u07c9\u07cc\3\2\2\2\u07ca"+
		"\u07c8\3\2\2\2\u07ca\u07cb\3\2\2\2\u07cb\u07cd\3\2\2\2\u07cc\u07ca\3\2"+
		"\2\2\u07cd\u07cf\5\u009aN\2\u07ce\u07c6\3\2\2\2\u07ce\u07cf\3\2\2\2\u07cf"+
		"\u07d8\3\2\2\2\u07d0\u07d4\7\32\2\2\u07d1\u07d3\7S\2\2\u07d2\u07d1\3\2"+
		"\2\2\u07d3\u07d6\3\2\2\2\u07d4\u07d2\3\2\2\2\u07d4\u07d5\3\2\2\2\u07d5"+
		"\u07d7\3\2\2\2\u07d6\u07d4\3\2\2\2\u07d7\u07d9\5\u0090I\2\u07d8\u07d0"+
		"\3\2\2\2\u07d8\u07d9\3\2\2\2\u07d9\u07e2\3\2\2\2\u07da\u07de\7\32\2\2"+
		"\u07db\u07dd\7S\2\2\u07dc\u07db\3\2\2\2\u07dd\u07e0\3\2\2\2\u07de\u07dc"+
		"\3\2\2\2\u07de\u07df\3\2\2\2\u07df\u07e1\3\2\2\2\u07e0\u07de\3\2\2\2\u07e1"+
		"\u07e3\5\u009cO\2\u07e2\u07da\3\2\2\2\u07e2\u07e3\3\2\2\2\u07e3\u07ec"+
		"\3\2\2\2\u07e4\u07e8\7\32\2\2\u07e5\u07e7\7S\2\2\u07e6\u07e5\3\2\2\2\u07e7"+
		"\u07ea\3\2\2\2\u07e8\u07e6\3\2\2\2\u07e8\u07e9\3\2\2\2\u07e9\u07eb\3\2"+
		"\2\2\u07ea\u07e8\3\2\2\2\u07eb\u07ed\5\u009eP\2\u07ec\u07e4\3\2\2\2\u07ec"+
		"\u07ed\3\2\2\2\u07ed\u081a\3\2\2\2\u07ee\u07f7\5\u009aN\2\u07ef\u07f3"+
		"\7\32\2\2\u07f0\u07f2\7S\2\2\u07f1\u07f0\3\2\2\2\u07f2\u07f5\3\2\2\2\u07f3"+
		"\u07f1\3\2\2\2\u07f3\u07f4\3\2\2\2\u07f4\u07f6\3\2\2\2\u07f5\u07f3\3\2"+
		"\2\2\u07f6\u07f8\5\u0090I\2\u07f7\u07ef\3\2\2\2\u07f7\u07f8\3\2\2\2\u07f8"+
		"\u0801\3\2\2\2\u07f9\u07fd\7\32\2\2\u07fa\u07fc\7S\2\2\u07fb\u07fa\3\2"+
		"\2\2\u07fc\u07ff\3\2\2\2\u07fd\u07fb\3\2\2\2\u07fd\u07fe\3\2\2\2\u07fe"+
		"\u0800\3\2\2\2\u07ff\u07fd\3\2\2\2\u0800\u0802\5\u009cO\2\u0801\u07f9"+
		"\3\2\2\2\u0801\u0802\3\2\2\2\u0802\u080b\3\2\2\2\u0803\u0807\7\32\2\2"+
		"\u0804\u0806\7S\2\2\u0805\u0804\3\2\2\2\u0806\u0809\3\2\2\2\u0807\u0805"+
		"\3\2\2\2\u0807\u0808\3\2\2\2\u0808\u080a\3\2\2\2\u0809\u0807\3\2\2\2\u080a"+
		"\u080c\5\u009eP\2\u080b\u0803\3\2\2\2\u080b\u080c\3\2\2\2\u080c\u081a"+
		"\3\2\2\2\u080d\u0816\5\u009cO\2\u080e\u0812\7\32\2\2\u080f\u0811\7S\2"+
		"\2\u0810\u080f\3\2\2\2\u0811\u0814\3\2\2\2\u0812\u0810\3\2\2\2\u0812\u0813"+
		"\3\2\2\2\u0813\u0815\3\2\2\2\u0814\u0812\3\2\2\2\u0815\u0817\5\u009eP"+
		"\2\u0816\u080e\3\2\2\2\u0816\u0817\3\2\2\2\u0817\u081a\3\2\2\2\u0818\u081a"+
		"\5\u009eP\2\u0819\u07c5\3\2\2\2\u0819\u07ee\3\2\2\2\u0819\u080d\3\2\2"+
		"\2\u0819\u0818\3\2\2\2\u081a\u008d\3\2\2\2\u081b\u0826\5\u0092J\2\u081c"+
		"\u0820\7\32\2\2\u081d\u081f\7S\2\2\u081e\u081d\3\2\2\2\u081f\u0822\3\2"+
		"\2\2\u0820\u081e\3\2\2\2\u0820\u0821\3\2\2\2\u0821\u0823\3\2\2\2\u0822"+
		"\u0820\3\2\2\2\u0823\u0825\5\u0092J\2\u0824\u081c\3\2\2\2\u0825\u0828"+
		"\3\2\2\2\u0826\u0824\3\2\2\2\u0826\u0827\3\2\2\2\u0827\u008f\3\2\2\2\u0828"+
		"\u0826\3\2\2\2\u0829\u0834\5\u0094K\2\u082a\u082e\7\32\2\2\u082b\u082d"+
		"\7S\2\2\u082c\u082b\3\2\2\2\u082d\u0830\3\2\2\2\u082e\u082c\3\2\2\2\u082e"+
		"\u082f\3\2\2\2\u082f\u0831\3\2\2\2\u0830\u082e\3\2\2\2\u0831\u0833\5\u0094"+
		"K\2\u0832\u082a\3\2\2\2\u0833\u0836\3\2\2\2\u0834\u0832\3\2\2\2\u0834"+
		"\u0835\3\2\2\2\u0835\u0091\3\2\2\2\u0836\u0834\3\2\2\2\u0837\u083a\5\u0094"+
		"K\2\u0838\u083a\5\u0096L\2\u0839\u0837\3\2\2\2\u0839\u0838\3\2\2\2\u083a"+
		"\u0093\3\2\2\2\u083b\u083d\7V\2\2\u083c\u083e\7\30\2\2\u083d\u083c\3\2"+
		"\2\2\u083d\u083e\3\2\2\2\u083e\u0095\3\2\2\2\u083f\u0840\5\u0098M\2\u0840"+
		"\u0844\t\t\2\2\u0841\u0843\7S\2\2\u0842\u0841\3\2\2\2\u0843\u0846\3\2"+
		"\2\2\u0844\u0842\3\2\2\2\u0844\u0845\3\2\2\2\u0845\u0847\3\2\2\2\u0846"+
		"\u0844\3\2\2\2\u0847\u0848\5N(\2\u0848\u0097\3\2\2\2\u0849\u084a\7V\2"+
		"\2\u084a\u0099\3\2\2\2\u084b\u084d\78\2\2\u084c\u084e\7V\2\2\u084d\u084c"+
		"\3\2\2\2\u084d\u084e\3\2\2\2\u084e\u009b\3\2\2\2\u084f\u0851\79\2\2\u0850"+
		"\u0852\7V\2\2\u0851\u0850\3\2\2\2\u0851\u0852\3\2\2\2\u0852\u009d\3\2"+
		"\2\2\u0853\u0855\7%\2\2\u0854\u0856\5\u00a0Q\2\u0855\u0854\3\2\2\2\u0855"+
		"\u0856\3\2\2\2\u0856\u009f\3\2\2\2\u0857\u0858\7V\2\2\u0858\u00a1\3\2"+
		"\2\2\u0859\u085a\bR\1\2\u085a\u085b\7\31\2\2\u085b\u085e\7\u0083\2\2\u085c"+
		"\u085e\7\u0083\2\2\u085d\u0859\3\2\2\2\u085d\u085c\3\2\2\2\u085e\u0864"+
		"\3\2\2\2\u085f\u0860\f\3\2\2\u0860\u0861\7\31\2\2\u0861\u0863\7\u0083"+
		"\2\2\u0862\u085f\3\2\2\2\u0863\u0866\3\2\2\2\u0864\u0862\3\2\2\2\u0864"+
		"\u0865\3\2\2\2\u0865\u00a3\3\2\2\2\u0866\u0864\3\2\2\2\u0867\u086d\5\u00a6"+
		"T\2\u0868\u0869\7\24\2\2\u0869\u086a\5L\'\2\u086a\u086b\7\25\2\2\u086b"+
		"\u086d\3\2\2\2\u086c\u0867\3\2\2\2\u086c\u0868\3\2\2\2\u086d\u00a5\3\2"+
		"\2\2\u086e\u0873\5\u00d6l\2\u086f\u0873\5\u00d8m\2\u0870\u0871\7\31\2"+
		"\2\u0871\u0873\7\u0083\2\2\u0872\u086e\3\2\2\2\u0872\u086f\3\2\2\2\u0872"+
		"\u0870\3\2\2\2\u0873\u00a7\3\2\2\2\u0874\u087f\5\u00aaV\2\u0875\u0879"+
		"\7\32\2\2\u0876\u0878\7S\2\2\u0877\u0876\3\2\2\2\u0878\u087b\3\2\2\2\u0879"+
		"\u0877\3\2\2\2\u0879\u087a\3\2\2\2\u087a\u087c\3\2\2\2\u087b\u0879\3\2"+
		"\2\2\u087c\u087e\5\u00aaV\2\u087d\u0875\3\2\2\2\u087e\u0881\3\2\2\2\u087f"+
		"\u087d\3\2\2\2\u087f\u0880\3\2\2\2\u0880\u00a9\3\2\2\2\u0881\u087f\3\2"+
		"\2\2\u0882\u0883\5\u00acW\2\u0883\u0887\t\n\2\2\u0884\u0886\7S\2\2\u0885"+
		"\u0884\3\2\2\2\u0886\u0889\3\2\2\2\u0887\u0885\3\2\2\2\u0887\u0888\3\2"+
		"\2\2\u0888\u088a\3\2\2\2\u0889\u0887\3\2\2\2\u088a\u088b\5N(\2\u088b\u088e"+
		"\3\2\2\2\u088c\u088e\5\u00aeX\2\u088d\u0882\3\2\2\2\u088d\u088c\3\2\2"+
		"\2\u088e\u00ab\3\2\2\2\u088f\u0892\5N(\2\u0890\u0892\5\u00ecw\2\u0891"+
		"\u088f\3\2\2\2\u0891\u0890\3\2\2\2\u0892\u00ad\3\2\2\2\u0893\u089a\79"+
		"\2\2\u0894\u089b\7V\2\2\u0895\u089b\5X-\2\u0896\u0897\7\24\2\2\u0897\u0898"+
		"\5&\24\2\u0898\u0899\7\25\2\2\u0899\u089b\3\2\2\2\u089a\u0894\3\2\2\2"+
		"\u089a\u0895\3\2\2\2\u089a\u0896\3\2\2\2\u089a\u089b\3\2\2\2\u089b\u00af"+
		"\3\2\2\2\u089c\u08a2\7\u0096\2\2\u089d\u089e\7\u0097\2\2\u089e\u089f\5"+
		"\4\3\2\u089f\u08a0\7\4\2\2\u08a0\u08a2\3\2\2\2\u08a1\u089c\3\2\2\2\u08a1"+
		"\u089d\3\2\2\2\u08a2\u00b1\3\2\2\2\u08a3\u08a4\7@\2\2\u08a4\u00b3\3\2"+
		"\2\2\u08a5\u08a8\5\u00b2Z\2\u08a6\u08a8\5\u00b6\\\2\u08a7\u08a5\3\2\2"+
		"\2\u08a7\u08a6\3\2\2\2\u08a8\u00b5\3\2\2\2\u08a9\u08ad\7A\2\2\u08aa\u08ac"+
		"\5\u00ba^\2\u08ab\u08aa\3\2\2\2\u08ac\u08af\3\2\2\2\u08ad\u08ab\3\2\2"+
		"\2\u08ad\u08ae\3\2\2\2\u08ae\u08b0\3\2\2\2\u08af\u08ad\3\2\2\2\u08b0\u08b1"+
		"\7\u0088\2\2\u08b1\u00b7\3\2\2\2\u08b2\u08b6\7E\2\2\u08b3\u08b5\5\u00c0"+
		"a\2\u08b4\u08b3\3\2\2\2\u08b5\u08b8\3\2\2\2\u08b6\u08b4\3\2\2\2\u08b6"+
		"\u08b7\3\2\2\2\u08b7\u08b9\3\2\2\2\u08b8\u08b6\3\2\2\2\u08b9\u08ba\7\13"+
		"\2\2\u08ba\u00b9\3\2\2\2\u08bb\u08c1\7\u0089\2\2\u08bc\u08bd\7\u008b\2"+
		"\2\u08bd\u08be\5\4\3\2\u08be\u08bf\7\3\2\2\u08bf\u08c1\3\2\2\2\u08c0\u08bb"+
		"\3\2\2\2\u08c0\u08bc\3\2\2\2\u08c1\u00bb\3\2\2\2\u08c2\u08c4\7B\2\2\u08c3"+
		"\u08c5\7\20\2\2\u08c4\u08c3\3\2\2\2\u08c4\u08c5\3\2\2\2\u08c5\u08c6\3"+
		"\2\2\2\u08c6\u08c7\7\6\2\2\u08c7\u00bd\3\2\2\2\u08c8\u08cc\7C\2\2\u08c9"+
		"\u08cb\5\u00c0a\2\u08ca\u08c9\3\2\2\2\u08cb\u08ce\3\2\2\2\u08cc\u08ca"+
		"\3\2\2\2\u08cc\u08cd\3\2\2\2\u08cd\u08cf\3\2\2\2\u08ce\u08cc\3\2\2\2\u08cf"+
		"\u08d0\7\n\2\2\u08d0\u00bf\3\2\2\2\u08d1\u08d7\7\21\2\2\u08d2\u08d3\7"+
		"\u008c\2\2\u08d3\u08d4\5\4\3\2\u08d4\u08d5\7\16\2\2\u08d5\u08d7\3\2\2"+
		"\2\u08d6\u08d1\3\2\2\2\u08d6\u08d2\3\2\2\2\u08d7\u00c1\3\2\2\2\u08d8\u08da"+
		"\7\u0094\2\2\u08d9\u08d8\3\2\2\2\u08da\u08db\3\2\2\2\u08db\u08d9\3\2\2"+
		"\2\u08db\u08dc\3\2\2\2\u08dc\u00c3\3\2\2\2\u08dd\u08e3\7\u0092\2\2\u08de"+
		"\u08df\7\u0090\2\2\u08df\u08e0\5\4\3\2\u08e0\u08e1\7\17\2\2\u08e1\u08e3"+
		"\3\2\2\2\u08e2\u08dd\3\2\2\2\u08e2\u08de\3\2\2\2\u08e3\u00c5\3\2\2\2\u08e4"+
		"\u08e6\5\u00c4c\2\u08e5\u08e4\3\2\2\2\u08e6\u08e7\3\2\2\2\u08e7\u08e5"+
		"\3\2\2\2\u08e7\u08e8\3\2\2\2\u08e8\u00c7\3\2\2\2\u08e9\u08eb\7\u0093\2"+
		"\2\u08ea\u08e9\3\2\2\2\u08eb\u08ee\3\2\2\2\u08ec\u08ea\3\2\2\2\u08ec\u08ed"+
		"\3\2\2\2\u08ed\u08ef\3\2\2\2\u08ee\u08ec\3\2\2\2\u08ef\u08f8\5\u00c2b"+
		"\2\u08f0\u08f2\7\u0093\2\2\u08f1\u08f0\3\2\2\2\u08f2\u08f3\3\2\2\2\u08f3"+
		"\u08f1\3\2\2\2\u08f3\u08f4\3\2\2\2\u08f4\u08f5\3\2\2\2\u08f5\u08f7\5\u00c2"+
		"b\2\u08f6\u08f1\3\2\2\2\u08f7\u08fa\3\2\2\2\u08f8\u08f6\3\2\2\2\u08f8"+
		"\u08f9\3\2\2\2\u08f9\u08fe\3\2\2\2\u08fa\u08f8\3\2\2\2\u08fb\u08fd\7\u0093"+
		"\2\2\u08fc\u08fb\3\2\2\2\u08fd\u0900\3\2\2\2\u08fe\u08fc\3\2\2\2\u08fe"+
		"\u08ff\3\2\2\2\u08ff\u00c9\3\2\2\2\u0900\u08fe\3\2\2\2\u0901\u0903\7\u0091"+
		"\2\2\u0902\u0901\3\2\2\2\u0903\u0906\3\2\2\2\u0904\u0902\3\2\2\2\u0904"+
		"\u0905\3\2\2\2\u0905\u0907\3\2\2\2\u0906\u0904\3\2\2\2\u0907\u0910\5\u00c6"+
		"d\2\u0908\u090a\7\u0091\2\2\u0909\u0908\3\2\2\2\u090a\u090b\3\2\2\2\u090b"+
		"\u0909\3\2\2\2\u090b\u090c\3\2\2\2\u090c\u090d\3\2\2\2\u090d\u090f\5\u00c6"+
		"d\2\u090e\u0909\3\2\2\2\u090f\u0912\3\2\2\2\u0910\u090e\3\2\2\2\u0910"+
		"\u0911\3\2\2\2\u0911\u0916\3\2\2\2\u0912\u0910\3\2\2\2\u0913\u0915\7\u0091"+
		"\2\2\u0914\u0913\3\2\2\2\u0915\u0918\3\2\2\2\u0916\u0914\3\2\2\2\u0916"+
		"\u0917\3\2\2\2\u0917\u00cb\3\2\2\2\u0918\u0916\3\2\2\2\u0919\u091f\7U"+
		"\2\2\u091a\u091b\7\30\2\2\u091b\u091f\5\u00b2Z\2\u091c\u091d\7\30\2\2"+
		"\u091d\u091f\5\u00b6\\\2\u091e\u0919\3\2\2\2\u091e\u091a\3\2\2\2\u091e"+
		"\u091c\3\2\2\2\u091f\u00cd\3\2\2\2\u0920\u0921\7I\2\2\u0921\u00cf\3\2"+
		"\2\2\u0922\u0923\7c\2\2\u0923\u00d1\3\2\2\2\u0924\u0925\t\13\2\2\u0925"+
		"\u00d3\3\2\2\2\u0926\u0927\t\f\2\2\u0927\u00d5\3\2\2\2\u0928\u092e\7\u0083"+
		"\2\2\u0929\u092e\7\u0080\2\2\u092a\u092e\7\u0082\2\2\u092b\u092e\7\u0081"+
		"\2\2\u092c\u092e\7V\2\2\u092d\u0928\3\2\2\2\u092d\u0929\3\2\2\2\u092d"+
		"\u092a\3\2\2\2\u092d\u092b\3\2\2\2\u092d\u092c\3\2\2\2\u092e\u00d7\3\2"+
		"\2\2\u092f\u0937\7o\2\2\u0930\u0937\7y\2\2\u0931\u0937\7j\2\2\u0932\u0937"+
		"\7v\2\2\u0933\u0937\7W\2\2\u0934\u0937\7Y\2\2\u0935\u0937\7X\2\2\u0936"+
		"\u092f\3\2\2\2\u0936\u0930\3\2\2\2\u0936\u0931\3\2\2\2\u0936\u0932\3\2"+
		"\2\2\u0936\u0933\3\2\2\2\u0936\u0934\3\2\2\2\u0936\u0935\3\2\2\2\u0937"+
		"\u00d9\3\2\2\2\u0938\u093f\7M\2\2\u0939\u093f\7N\2\2\u093a\u093f\7O\2"+
		"\2\u093b\u093f\7P\2\2\u093c\u093f\7Q\2\2\u093d\u093f\7R\2\2\u093e\u0938"+
		"\3\2\2\2\u093e\u0939\3\2\2\2\u093e\u093a\3\2\2\2\u093e\u093b\3\2\2\2\u093e"+
		"\u093c\3\2\2\2\u093e\u093d\3\2\2\2\u093f\u00db\3\2\2\2\u0940\u0941\t\r"+
		"\2\2\u0941\u00dd\3\2\2\2\u0942\u0943\t\16\2\2\u0943\u00df\3\2\2\2\u0944"+
		"\u0945\t\7\2\2\u0945\u00e1\3\2\2\2\u0946\u0947\t\17";
	private static final String _serializedATNSegment1 =
		"\2\2\u0947\u00e3\3\2\2\2\u0948\u0949\t\20\2\2\u0949\u00e5\3\2\2\2\u094a"+
		"\u094b\t\21\2\2\u094b\u00e7\3\2\2\2\u094c\u094d\t\22\2\2\u094d\u00e9\3"+
		"\2\2\2\u094e\u094f\t\23\2\2\u094f\u00eb\3\2\2\2\u0950\u0951\t\24\2\2\u0951"+
		"\u00ed\3\2\2\2\u0153\u00f2\u00f7\u00fd\u0104\u0109\u0112\u011c\u0124\u012a"+
		"\u012f\u0136\u013d\u0142\u0149\u0154\u015c\u0163\u016f\u0174\u017b\u0185"+
		"\u018a\u0191\u019b\u01a0\u01a2\u01a7\u01ac\u01b6\u01bd\u01c0\u01c7\u01ca"+
		"\u01cd\u01d2\u01d6\u01d9\u01dd\u01e4\u01e7\u01ee\u01f1\u01f4\u01f8\u01fe"+
		"\u0207\u020b\u0210\u0214\u021c\u0221\u0226\u0230\u023a\u0241\u0248\u024f"+
		"\u0256\u025f\u0263\u0269\u026f\u027f\u0283\u0288\u028e\u0292\u0299\u029d"+
		"\u02a5\u02aa\u02b0\u02b5\u02bc\u02c2\u02c5\u02ca\u02cd\u02d3\u02da\u02e0"+
		"\u02e8\u02ee\u02f4\u02f8\u02fd\u0305\u030a\u030f\u0318\u0320\u0325\u032a"+
		"\u0333\u0338\u033d\u0342\u034a\u034e\u0354\u0358\u035f\u0363\u0369\u036d"+
		"\u0373\u0377\u037e\u0382\u0388\u038c\u0390\u0394\u039c\u03a0\u03a2\u03a9"+
		"\u03af\u03b4\u03ba\u03bf\u03c3\u03c7\u03cb\u03d0\u03d7\u03db\u03e2\u03e8"+
		"\u03f3\u03fa\u0401\u0408\u0411\u0417\u041c\u041e\u0423\u042e\u0439\u0442"+
		"\u0445\u0468\u046b\u0471\u0478\u047f\u0487\u048b\u0493\u0499\u04a1\u04aa"+
		"\u04b4\u04bb\u04c1\u04c4\u04cc\u04d2\u04d5\u04dd\u04e8\u04f0\u04fc\u0500"+
		"\u0505\u050b\u0510\u0515\u051a\u051f\u0526\u052d\u0532\u0539\u0541\u054a"+
		"\u0552\u0563\u056a\u0573\u057d\u0587\u0591\u059a\u05a4\u05ae\u05b8\u05c4"+
		"\u05cc\u05d3\u05dd\u05e7\u05ee\u05f5\u05fa\u05fd\u0604\u0609\u0610\u0615"+
		"\u0619\u061b\u0620\u0624\u0628\u062b\u062f\u0632\u0643\u0646\u064a\u0651"+
		"\u0658\u065e\u0665\u0669\u066f\u0675\u0679\u0682\u068a\u0691\u0696\u069d"+
		"\u06a1\u06a7\u06ad\u06b4\u06b8\u06be\u06c2\u06c9\u06cf\u06d6\u06da\u06e0"+
		"\u06e4\u06eb\u06ef\u06f2\u06f9\u06ff\u0705\u070c\u0712\u0717\u071f\u0723"+
		"\u0729\u072f\u073a\u0740\u0745\u074a\u074e\u0752\u075b\u0765\u076e\u0771"+
		"\u0776\u077b\u077f\u0785\u0789\u078c\u0790\u0793\u0799\u07a6\u07ac\u07b2"+
		"\u07b6\u07bb\u07c0\u07c3\u07ca\u07ce\u07d4\u07d8\u07de\u07e2\u07e8\u07ec"+
		"\u07f3\u07f7\u07fd\u0801\u0807\u080b\u0812\u0816\u0819\u0820\u0826\u082e"+
		"\u0834\u0839\u083d\u0844\u084d\u0851\u0855\u085d\u0864\u086c\u0872\u0879"+
		"\u087f\u0887\u088d\u0891\u089a\u08a1\u08a7\u08ad\u08b6\u08c0\u08c4\u08cc"+
		"\u08d6\u08db\u08e2\u08e7\u08ec\u08f3\u08f8\u08fe\u0904\u090b\u0910\u0916"+
		"\u091e\u092d\u0936\u093e";
	public static final String _serializedATN = Utils.join(
		new String[] {
			_serializedATNSegment0,
			_serializedATNSegment1
		},
		""
	);
	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