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

src2cpg_3.4.0.87.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_argumentListItem = 33, 
		RULE_splatArgList = 34, RULE_commandArgumentList = 35, RULE_primaryValueList = 36, 
		RULE_primaryValueListWithAssociation = 37, RULE_blockArgument = 38, RULE_expressionOrCommand = 39, 
		RULE_operatorExpression = 40, RULE_primary = 41, RULE_hashLiteral = 42, 
		RULE_primaryValue = 43, RULE_lambdaExpressionParameterList = 44, RULE_methodCallsWithParentheses = 45, 
		RULE_commandOrPrimaryValueClass = 46, RULE_commandOrPrimaryValue = 47, 
		RULE_block = 48, RULE_doBlock = 49, RULE_blockParameter = 50, RULE_blockParameterList = 51, 
		RULE_mandatoryOrOptionalOrGroupedParameterList = 52, RULE_mandatoryOrOptionalOrGroupedParameter = 53, 
		RULE_mandatoryOrGroupedParameterList = 54, RULE_mandatoryOrGroupedParameter = 55, 
		RULE_groupedParameterList = 56, RULE_thenClause = 57, RULE_elseClause = 58, 
		RULE_elsifClause = 59, RULE_whenClause = 60, RULE_whenArgument = 61, RULE_doClause = 62, 
		RULE_forVariable = 63, RULE_bodyStatement = 64, RULE_rescueClause = 65, 
		RULE_exceptionClassList = 66, RULE_exceptionVariableAssignment = 67, RULE_ensureClause = 68, 
		RULE_definedMethodName = 69, RULE_methodParameterPart = 70, RULE_parameterList = 71, 
		RULE_mandatoryOrOptionalParameterList = 72, RULE_mandatoryParameterList = 73, 
		RULE_mandatoryOrOptionalParameter = 74, RULE_mandatoryParameter = 75, 
		RULE_optionalParameter = 76, RULE_optionalParameterName = 77, RULE_arrayParameter = 78, 
		RULE_hashParameter = 79, RULE_procParameter = 80, RULE_procParameterName = 81, 
		RULE_classPath = 82, RULE_singletonObject = 83, RULE_variableReference = 84, 
		RULE_associationList = 85, RULE_association = 86, RULE_associationKey = 87, 
		RULE_associationHashArgument = 88, RULE_regexpLiteralContent = 89, RULE_singleQuotedString = 90, 
		RULE_singleOrDoubleQuotedString = 91, RULE_doubleQuotedString = 92, RULE_quotedExpandedExternalCommandString = 93, 
		RULE_doubleQuotedStringContent = 94, RULE_quotedNonExpandedLiteralString = 95, 
		RULE_quotedExpandedLiteralString = 96, RULE_quotedExpandedLiteralStringContent = 97, 
		RULE_quotedNonExpandedArrayElementContent = 98, RULE_quotedExpandedArrayElementContent = 99, 
		RULE_quotedExpandedArrayElement = 100, RULE_quotedNonExpandedArrayElementList = 101, 
		RULE_quotedExpandedArrayElementList = 102, RULE_symbol = 103, RULE_hereDoc = 104, 
		RULE_isDefinedKeyword = 105, RULE_assignmentOperator = 106, RULE_statementModifier = 107, 
		RULE_variable = 108, RULE_pseudoVariable = 109, RULE_unsignedNumericLiteral = 110, 
		RULE_unaryOperator = 111, RULE_multiplicativeOperator = 112, RULE_additiveOperator = 113, 
		RULE_bitwiseShiftOperator = 114, RULE_bitwiseOrOperator = 115, RULE_relationalOperator = 116, 
		RULE_equalityOperator = 117, RULE_rangeOperator = 118, RULE_keyword = 119;
	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", "argumentListItem", "splatArgList", 
			"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(240);
			compoundStatement();
			setState(241);
			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(244);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,0,_ctx) ) {
			case 1:
				{
				setState(243);
				statements();
				}
				break;
			}
			setState(249);
			_errHandler.sync(this);
			_la = _input.LA(1);
			while (_la==SEMI || _la==NL) {
				{
				{
				setState(246);
				_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(251);
				_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(255);
			_errHandler.sync(this);
			_la = _input.LA(1);
			while (_la==SEMI || _la==NL) {
				{
				{
				setState(252);
				_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(257);
				_errHandler.sync(this);
				_la = _input.LA(1);
			}
			setState(258);
			statement(0);
			setState(267);
			_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(260); 
					_errHandler.sync(this);
					_la = _input.LA(1);
					do {
						{
						{
						setState(259);
						_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(262); 
						_errHandler.sync(this);
						_la = _input.LA(1);
					} while ( _la==SEMI || _la==NL );
					setState(264);
					statement(0);
					}
					} 
				}
				setState(269);
				_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(305);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,9,_ctx) ) {
			case 1:
				{
				_localctx = new ExpressionOrCommandStatementContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;

				setState(271);
				expressionOrCommand(0);
				}
				break;
			case 2:
				{
				_localctx = new AliasStatementContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(272);
				match(ALIAS);
				setState(276);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==NL) {
					{
					{
					setState(273);
					match(NL);
					}
					}
					setState(278);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(279);
				((AliasStatementContext)_localctx).oldName = definedMethodNameOrSymbol();
				setState(280);
				((AliasStatementContext)_localctx).newName = definedMethodNameOrSymbol();
				}
				break;
			case 3:
				{
				_localctx = new UndefStatementContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(282);
				match(UNDEF);
				setState(286);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==NL) {
					{
					{
					setState(283);
					match(NL);
					}
					}
					setState(288);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(289);
				definedMethodNameOrSymbol();
				setState(300);
				_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(290);
						match(COMMA);
						setState(294);
						_errHandler.sync(this);
						_la = _input.LA(1);
						while (_la==NL) {
							{
							{
							setState(291);
							match(NL);
							}
							}
							setState(296);
							_errHandler.sync(this);
							_la = _input.LA(1);
						}
						setState(297);
						definedMethodNameOrSymbol();
						}
						} 
					}
					setState(302);
					_errHandler.sync(this);
					_alt = getInterpreter().adaptivePredict(_input,8,_ctx);
				}
				}
				break;
			case 4:
				{
				_localctx = new SingleAssignmentStatementStatementContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(303);
				singleAssignmentStatement();
				}
				break;
			case 5:
				{
				_localctx = new MultipleAssignmentStatementStatementContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(304);
				multipleAssignmentStatement();
				}
				break;
			}
			_ctx.stop = _input.LT(-1);
			setState(319);
			_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(307);
					if (!(precpred(_ctx, 3))) throw new FailedPredicateException(this, "precpred(_ctx, 3)");
					setState(308);
					statementModifier();
					setState(312);
					_errHandler.sync(this);
					_la = _input.LA(1);
					while (_la==NL) {
						{
						{
						setState(309);
						match(NL);
						}
						}
						setState(314);
						_errHandler.sync(this);
						_la = _input.LA(1);
					}
					setState(315);
					expressionOrCommand(0);
					}
					} 
				}
				setState(321);
				_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(324);
			_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(322);
				definedMethodName();
				}
				break;
			case COLON:
			case SYMBOL_LITERAL:
				enterOuterAlt(_localctx, 2);
				{
				setState(323);
				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(374);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,18,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(326);
				variable();
				setState(327);
				assignmentOperator();
				setState(331);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==NL) {
					{
					{
					setState(328);
					match(NL);
					}
					}
					setState(333);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(334);
				methodInvocationWithoutParentheses();
				}
				break;
			case 2:
				enterOuterAlt(_localctx, 2);
				{
				setState(336);
				match(COLON2);
				setState(337);
				match(CONSTANT_IDENTIFIER);
				setState(338);
				assignmentOperator();
				setState(342);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==NL) {
					{
					{
					setState(339);
					match(NL);
					}
					}
					setState(344);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(345);
				methodInvocationWithoutParentheses();
				}
				break;
			case 3:
				enterOuterAlt(_localctx, 3);
				{
				setState(347);
				primary();
				setState(348);
				match(LBRACK);
				setState(350);
				_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(349);
					indexingArgumentList();
					}
				}

				setState(352);
				match(RBRACK);
				setState(353);
				assignmentOperator();
				setState(357);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==NL) {
					{
					{
					setState(354);
					match(NL);
					}
					}
					setState(359);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(360);
				methodInvocationWithoutParentheses();
				}
				break;
			case 4:
				enterOuterAlt(_localctx, 4);
				{
				setState(362);
				primary();
				setState(363);
				_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(364);
				methodName();
				setState(365);
				assignmentOperator();
				setState(369);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==NL) {
					{
					{
					setState(366);
					match(NL);
					}
					}
					setState(371);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(372);
				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(420);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,25,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(376);
				leftHandSide();
				setState(377);
				match(EQ);
				setState(381);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==NL) {
					{
					{
					setState(378);
					match(NL);
					}
					}
					setState(383);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(384);
				multipleRightHandSide();
				}
				break;
			case 2:
				enterOuterAlt(_localctx, 2);
				{
				setState(386);
				packingLeftHandSide();
				setState(387);
				match(EQ);
				setState(391);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==NL) {
					{
					{
					setState(388);
					match(NL);
					}
					}
					setState(393);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(396);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,21,_ctx) ) {
				case 1:
					{
					setState(394);
					methodInvocationWithoutParentheses();
					}
					break;
				case 2:
					{
					setState(395);
					operatorExpression(0);
					}
					break;
				}
				}
				break;
			case 3:
				enterOuterAlt(_localctx, 3);
				{
				setState(398);
				multipleLeftHandSide();
				setState(399);
				match(EQ);
				setState(403);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==NL) {
					{
					{
					setState(400);
					match(NL);
					}
					}
					setState(405);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(406);
				multipleRightHandSide();
				}
				break;
			case 4:
				enterOuterAlt(_localctx, 4);
				{
				setState(408);
				multipleLeftHandSideExceptPacking();
				setState(409);
				match(EQ);
				setState(413);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==NL) {
					{
					{
					setState(410);
					match(NL);
					}
					}
					setState(415);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(418);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,24,_ctx) ) {
				case 1:
					{
					setState(416);
					methodInvocationWithoutParentheses();
					}
					break;
				case 2:
					{
					setState(417);
					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(440);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,28,_ctx) ) {
			case 1:
				_localctx = new VariableLeftHandSideContext(_localctx);
				enterOuterAlt(_localctx, 1);
				{
				setState(422);
				variable();
				setState(425);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,26,_ctx) ) {
				case 1:
					{
					setState(423);
					match(EQ);
					setState(424);
					primary();
					}
					break;
				}
				}
				break;
			case 2:
				_localctx = new IndexingLeftHandSideContext(_localctx);
				enterOuterAlt(_localctx, 2);
				{
				setState(427);
				primary();
				setState(428);
				match(LBRACK);
				setState(430);
				_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(429);
					indexingArgumentList();
					}
				}

				setState(432);
				match(RBRACK);
				}
				break;
			case 3:
				_localctx = new MemberAccessLeftHandSideContext(_localctx);
				enterOuterAlt(_localctx, 3);
				{
				setState(434);
				primary();
				setState(435);
				_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(436);
				_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(438);
				match(COLON2);
				setState(439);
				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(479);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,37,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(445); 
				_errHandler.sync(this);
				_alt = 1;
				do {
					switch (_alt) {
					case 1:
						{
						{
						setState(442);
						multipleLeftHandSideItem();
						setState(443);
						match(COMMA);
						}
						}
						break;
					default:
						throw new NoViableAltException(this);
					}
					setState(447); 
					_errHandler.sync(this);
					_alt = getInterpreter().adaptivePredict(_input,29,_ctx);
				} while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER );
				setState(450);
				_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(449);
					multipleLeftHandSideItem();
					}
				}

				}
				break;
			case 2:
				enterOuterAlt(_localctx, 2);
				{
				setState(455); 
				_errHandler.sync(this);
				_la = _input.LA(1);
				do {
					{
					{
					setState(452);
					multipleLeftHandSideItem();
					setState(453);
					match(COMMA);
					}
					}
					setState(457); 
					_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(460);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==STAR) {
					{
					setState(459);
					packingLeftHandSide();
					}
				}

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

					setState(468);
					_errHandler.sync(this);
					_la = _input.LA(1);
					while (_la==NL) {
						{
						{
						setState(465);
						match(NL);
						}
						}
						setState(470);
						_errHandler.sync(this);
						_la = _input.LA(1);
					}
					setState(471);
					procParameter();
					}
					break;
				}
				setState(475);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==COMMA) {
					{
					setState(474);
					match(COMMA);
					}
				}

				}
				break;
			case 3:
				enterOuterAlt(_localctx, 3);
				{
				setState(477);
				packingLeftHandSide();
				}
				break;
			case 4:
				enterOuterAlt(_localctx, 4);
				{
				setState(478);
				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(502);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,42,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(484); 
				_errHandler.sync(this);
				_alt = 1;
				do {
					switch (_alt) {
					case 1:
						{
						{
						setState(481);
						multipleLeftHandSideItem();
						setState(482);
						match(COMMA);
						}
						}
						break;
					default:
						throw new NoViableAltException(this);
					}
					setState(486); 
					_errHandler.sync(this);
					_alt = getInterpreter().adaptivePredict(_input,38,_ctx);
				} while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER );
				setState(489);
				_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(488);
					multipleLeftHandSideItem();
					}
				}

				}
				break;
			case 2:
				enterOuterAlt(_localctx, 2);
				{
				setState(494); 
				_errHandler.sync(this);
				_la = _input.LA(1);
				do {
					{
					{
					setState(491);
					multipleLeftHandSideItem();
					setState(492);
					match(COMMA);
					}
					}
					setState(496); 
					_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(499);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==STAR) {
					{
					setState(498);
					packingLeftHandSide();
					}
				}

				}
				break;
			case 3:
				enterOuterAlt(_localctx, 3);
				{
				setState(501);
				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(504);
			match(STAR);
			setState(506);
			_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(505);
				leftHandSide();
				}
			}

			setState(512);
			_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(508);
					match(COMMA);
					setState(509);
					multipleLeftHandSideItem();
					}
					} 
				}
				setState(514);
				_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(515);
			match(LPAREN);
			setState(516);
			multipleLeftHandSide();
			setState(517);
			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(521);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,45,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(519);
				leftHandSide();
				}
				break;
			case 2:
				enterOuterAlt(_localctx, 2);
				{
				setState(520);
				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(525);
			_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(523);
				operatorExpressionList();
				}
				break;
			case STAR:
			case STAR2:
				{
				setState(524);
				splattingRightHandSide();
				}
				break;
			default:
				throw new NoViableAltException(this);
			}
			setState(534);
			_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(527);
					match(COMMA);
					setState(530);
					_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(528);
						operatorExpressionList();
						}
						break;
					case STAR:
					case STAR2:
						{
						setState(529);
						splattingRightHandSide();
						}
						break;
					default:
						throw new NoViableAltException(this);
					}
					}
					} 
				}
				setState(536);
				_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(537);
			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(542);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,49,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(539);
				match(LOCAL_VARIABLE_IDENTIFIER);
				}
				break;
			case 2:
				enterOuterAlt(_localctx, 2);
				{
				setState(540);
				match(CONSTANT_IDENTIFIER);
				}
				break;
			case 3:
				enterOuterAlt(_localctx, 3);
				{
				setState(541);
				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(547);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,50,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(544);
				methodIdentifier();
				}
				break;
			case 2:
				enterOuterAlt(_localctx, 2);
				{
				setState(545);
				keyword();
				}
				break;
			case 3:
				enterOuterAlt(_localctx, 3);
				{
				setState(546);
				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(552);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case CONSTANT_IDENTIFIER:
				{
				setState(549);
				match(CONSTANT_IDENTIFIER);
				}
				break;
			case LOCAL_VARIABLE_IDENTIFIER:
				{
				setState(550);
				match(LOCAL_VARIABLE_IDENTIFIER);
				}
				break;
			case LINE__:
			case ENCODING__:
			case FILE__:
			case FALSE:
			case NIL:
			case SELF:
			case TRUE:
				{
				setState(551);
				pseudoVariable();
				}
				break;
			default:
				throw new NoViableAltException(this);
			}
			setState(554);
			_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(572);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,53,_ctx) ) {
			case 1:
				_localctx = new CommandMethodInvocationWithoutParenthesesContext(_localctx);
				enterOuterAlt(_localctx, 1);
				{
				setState(556);
				command();
				}
				break;
			case 2:
				_localctx = new ChainedMethodInvocationWithoutParenthesesContext(_localctx);
				enterOuterAlt(_localctx, 2);
				{
				setState(557);
				chainedCommandWithDoBlock();
				setState(562);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,52,_ctx) ) {
				case 1:
					{
					setState(558);
					_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(559);
					methodName();
					setState(560);
					commandArgumentList();
					}
					break;
				}
				}
				break;
			case 3:
				_localctx = new ReturnMethodInvocationWithoutParenthesesContext(_localctx);
				enterOuterAlt(_localctx, 3);
				{
				setState(564);
				match(RETURN);
				setState(565);
				primaryValueListWithAssociation();
				}
				break;
			case 4:
				_localctx = new BreakMethodInvocationWithoutParenthesesContext(_localctx);
				enterOuterAlt(_localctx, 4);
				{
				setState(566);
				match(BREAK);
				setState(567);
				primaryValueList();
				}
				break;
			case 5:
				_localctx = new NextMethodInvocationWithoutParenthesesContext(_localctx);
				enterOuterAlt(_localctx, 5);
				{
				setState(568);
				match(NEXT);
				setState(569);
				primaryValueList();
				}
				break;
			case 6:
				_localctx = new YieldMethodInvocationWithoutParenthesesContext(_localctx);
				enterOuterAlt(_localctx, 6);
				{
				setState(570);
				match(YIELD);
				setState(571);
				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(609);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,58,_ctx) ) {
			case 1:
				_localctx = new CommandTernaryOperatorExpressionContext(_localctx);
				enterOuterAlt(_localctx, 1);
				{
				setState(574);
				operatorExpression(0);
				setState(575);
				match(QMARK);
				setState(579);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==NL) {
					{
					{
					setState(576);
					match(NL);
					}
					}
					setState(581);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(582);
				operatorExpression(0);
				setState(586);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==NL) {
					{
					{
					setState(583);
					match(NL);
					}
					}
					setState(588);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(589);
				match(COLON);
				setState(593);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==NL) {
					{
					{
					setState(590);
					match(NL);
					}
					}
					setState(595);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(596);
				operatorExpression(0);
				}
				break;
			case 2:
				_localctx = new MemberAccessCommandContext(_localctx);
				enterOuterAlt(_localctx, 2);
				{
				setState(598);
				primary();
				setState(600);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==NL) {
					{
					setState(599);
					match(NL);
					}
				}

				setState(602);
				_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(603);
				methodName();
				setState(604);
				commandArgument();
				}
				break;
			case 3:
				_localctx = new SimpleCommandContext(_localctx);
				enterOuterAlt(_localctx, 3);
				{
				setState(606);
				methodIdentifier();
				setState(607);
				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(613);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,59,_ctx) ) {
			case 1:
				_localctx = new CommandArgumentCommandArgumentListContext(_localctx);
				enterOuterAlt(_localctx, 1);
				{
				setState(611);
				commandArgumentList();
				}
				break;
			case 2:
				_localctx = new CommandCommandArgumentListContext(_localctx);
				enterOuterAlt(_localctx, 2);
				{
				setState(612);
				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(615);
			commandWithDoBlock();
			setState(619);
			_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(616);
					chainedMethodInvocation();
					}
					} 
				}
				setState(621);
				_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(622);
			_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(623);
			methodName();
			setState(625);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,61,_ctx) ) {
			case 1:
				{
				setState(624);
				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(641);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,62,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(627);
				match(SUPER);
				setState(628);
				argumentList();
				setState(629);
				doBlock();
				}
				break;
			case 2:
				enterOuterAlt(_localctx, 2);
				{
				setState(631);
				methodIdentifier();
				setState(632);
				argumentList();
				setState(633);
				doBlock();
				}
				break;
			case 3:
				enterOuterAlt(_localctx, 3);
				{
				setState(635);
				primary();
				setState(636);
				_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(637);
				methodName();
				setState(638);
				argumentList();
				setState(639);
				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(643);
			bracketedArrayElement();
			setState(656);
			_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(645);
					_errHandler.sync(this);
					_la = _input.LA(1);
					if (_la==COMMA) {
						{
						setState(644);
						match(COMMA);
						}
					}

					setState(650);
					_errHandler.sync(this);
					_la = _input.LA(1);
					while (_la==NL) {
						{
						{
						setState(647);
						match(NL);
						}
						}
						setState(652);
						_errHandler.sync(this);
						_la = _input.LA(1);
					}
					setState(653);
					bracketedArrayElement();
					}
					} 
				}
				setState(658);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,65,_ctx);
			}
			setState(660);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==COMMA) {
				{
				setState(659);
				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(667);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,67,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(662);
				indexingArgument();
				}
				break;
			case 2:
				enterOuterAlt(_localctx, 2);
				{
				setState(663);
				command();
				}
				break;
			case 3:
				enterOuterAlt(_localctx, 3);
				{
				setState(664);
				hashLiteral();
				}
				break;
			case 4:
				enterOuterAlt(_localctx, 4);
				{
				setState(665);
				splattingArgument();
				}
				break;
			case 5:
				enterOuterAlt(_localctx, 5);
				{
				setState(666);
				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(711);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,75,_ctx) ) {
			case 1:
				_localctx = new OperatorExpressionListIndexingArgumentListContext(_localctx);
				enterOuterAlt(_localctx, 1);
				{
				setState(669);
				operatorExpressionList();
				setState(671);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,68,_ctx) ) {
				case 1:
					{
					setState(670);
					match(COMMA);
					}
					break;
				}
				}
				break;
			case 2:
				_localctx = new OperatorExpressionListWithSplattingArgumentIndexingArgumentListContext(_localctx);
				enterOuterAlt(_localctx, 2);
				{
				setState(673);
				operatorExpressionList();
				setState(674);
				match(COMMA);
				setState(675);
				splattingArgument();
				}
				break;
			case 3:
				_localctx = new IndexingArgumentIndexingArgumentListContext(_localctx);
				enterOuterAlt(_localctx, 3);
				{
				setState(677);
				indexingArgument();
				setState(690);
				_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(679);
						_errHandler.sync(this);
						_la = _input.LA(1);
						if (_la==COMMA) {
							{
							setState(678);
							match(COMMA);
							}
						}

						setState(684);
						_errHandler.sync(this);
						_la = _input.LA(1);
						while (_la==NL) {
							{
							{
							setState(681);
							match(NL);
							}
							}
							setState(686);
							_errHandler.sync(this);
							_la = _input.LA(1);
						}
						setState(687);
						indexingArgument();
						}
						} 
					}
					setState(692);
					_errHandler.sync(this);
					_alt = getInterpreter().adaptivePredict(_input,71,_ctx);
				}
				}
				break;
			case 4:
				_localctx = new AssociationListIndexingArgumentListContext(_localctx);
				enterOuterAlt(_localctx, 4);
				{
				setState(693);
				associationList();
				setState(695);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,72,_ctx) ) {
				case 1:
					{
					setState(694);
					match(COMMA);
					}
					break;
				}
				}
				break;
			case 5:
				_localctx = new SplattingArgumentIndexingArgumentListContext(_localctx);
				enterOuterAlt(_localctx, 5);
				{
				setState(697);
				splattingArgument();
				setState(708);
				_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(698);
						match(COMMA);
						setState(702);
						_errHandler.sync(this);
						_la = _input.LA(1);
						while (_la==NL) {
							{
							{
							setState(699);
							match(NL);
							}
							}
							setState(704);
							_errHandler.sync(this);
							_la = _input.LA(1);
						}
						setState(705);
						splattingArgument();
						}
						} 
					}
					setState(710);
					_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(719);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,77,_ctx) ) {
			case 1:
				_localctx = new SymbolIndexingArgumentContext(_localctx);
				enterOuterAlt(_localctx, 1);
				{
				setState(713);
				symbol();
				}
				break;
			case 2:
				_localctx = new AssociationIndexingArgumentContext(_localctx);
				enterOuterAlt(_localctx, 2);
				{
				setState(714);
				association();
				}
				break;
			case 3:
				_localctx = new NumericLiteralIndexingArgumentContext(_localctx);
				enterOuterAlt(_localctx, 3);
				{
				setState(716);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==PLUS || _la==MINUS) {
					{
					setState(715);
					((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(718);
				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(725);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case STAR:
				enterOuterAlt(_localctx, 1);
				{
				setState(721);
				match(STAR);
				setState(722);
				operatorExpression(0);
				}
				break;
			case STAR2:
				enterOuterAlt(_localctx, 2);
				{
				setState(723);
				match(STAR2);
				setState(724);
				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(727);
			operatorExpression(0);
			setState(738);
			_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(728);
					match(COMMA);
					setState(732);
					_errHandler.sync(this);
					_la = _input.LA(1);
					while (_la==NL) {
						{
						{
						setState(729);
						match(NL);
						}
						}
						setState(734);
						_errHandler.sync(this);
						_la = _input.LA(1);
					}
					setState(735);
					operatorExpression(0);
					}
					} 
				}
				setState(740);
				_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(741);
			operatorExpression(0);
			setState(750); 
			_errHandler.sync(this);
			_la = _input.LA(1);
			do {
				{
				{
				setState(742);
				match(COMMA);
				setState(746);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==NL) {
					{
					{
					setState(743);
					match(NL);
					}
					}
					setState(748);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(749);
				operatorExpression(0);
				}
				}
				setState(752); 
				_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(836);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,96,_ctx) ) {
			case 1:
				_localctx = new EmptyArgumentWithParenthesesContext(_localctx);
				enterOuterAlt(_localctx, 1);
				{
				setState(754);
				match(LPAREN);
				setState(758);
				_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(755);
						match(NL);
						}
						} 
					}
					setState(760);
					_errHandler.sync(this);
					_alt = getInterpreter().adaptivePredict(_input,83,_ctx);
				}
				setState(762);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==COMMA) {
					{
					setState(761);
					match(COMMA);
					}
				}

				setState(767);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==NL) {
					{
					{
					setState(764);
					match(NL);
					}
					}
					setState(769);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(770);
				match(RPAREN);
				}
				break;
			case 2:
				_localctx = new ArgumentListArgumentWithParenthesesContext(_localctx);
				enterOuterAlt(_localctx, 2);
				{
				setState(771);
				match(LPAREN);
				setState(775);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==NL) {
					{
					{
					setState(772);
					match(NL);
					}
					}
					setState(777);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(778);
				argumentList();
				setState(780);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==COMMA) {
					{
					setState(779);
					match(COMMA);
					}
				}

				setState(785);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==NL) {
					{
					{
					setState(782);
					match(NL);
					}
					}
					setState(787);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(788);
				match(RPAREN);
				}
				break;
			case 3:
				_localctx = new OperatorExpressionsAndChainedCommandWithBlockArgumentWithParenthesesContext(_localctx);
				enterOuterAlt(_localctx, 3);
				{
				setState(790);
				match(LPAREN);
				setState(794);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==NL) {
					{
					{
					setState(791);
					match(NL);
					}
					}
					setState(796);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(797);
				operatorExpressionList();
				setState(798);
				match(COMMA);
				setState(802);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==NL) {
					{
					{
					setState(799);
					match(NL);
					}
					}
					setState(804);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(805);
				chainedCommandWithDoBlock();
				setState(807);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==COMMA) {
					{
					setState(806);
					match(COMMA);
					}
				}

				setState(812);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==NL) {
					{
					{
					setState(809);
					match(NL);
					}
					}
					setState(814);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(815);
				match(RPAREN);
				}
				break;
			case 4:
				_localctx = new ChainedCommandWithDoBlockArgumentWithParenthesesContext(_localctx);
				enterOuterAlt(_localctx, 4);
				{
				setState(817);
				match(LPAREN);
				setState(821);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==NL) {
					{
					{
					setState(818);
					match(NL);
					}
					}
					setState(823);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(824);
				chainedCommandWithDoBlock();
				setState(826);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==COMMA) {
					{
					setState(825);
					match(COMMA);
					}
				}

				setState(831);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==NL) {
					{
					{
					setState(828);
					match(NL);
					}
					}
					setState(833);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(834);
				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 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 ArgumentListItemArgumentListContext extends ArgumentListContext {
		public List argumentListItem() {
			return getRuleContexts(ArgumentListItemContext.class);
		}
		public ArgumentListItemContext argumentListItem(int i) {
			return getRuleContext(ArgumentListItemContext.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 ArgumentListItemArgumentListContext(ArgumentListContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterArgumentListItemArgumentList(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitArgumentListItemArgumentList(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitArgumentListItemArgumentList(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 {
			int _alt;
			setState(859);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,100,_ctx) ) {
			case 1:
				_localctx = new BlockArgumentArgumentListContext(_localctx);
				enterOuterAlt(_localctx, 1);
				{
				setState(838);
				blockArgument();
				}
				break;
			case 2:
				_localctx = new ArgumentListItemArgumentListContext(_localctx);
				enterOuterAlt(_localctx, 2);
				{
				setState(839);
				argumentListItem();
				setState(850);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,98,_ctx);
				while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) {
					if ( _alt==1 ) {
						{
						{
						setState(840);
						match(COMMA);
						setState(844);
						_errHandler.sync(this);
						_la = _input.LA(1);
						while (_la==NL) {
							{
							{
							setState(841);
							match(NL);
							}
							}
							setState(846);
							_errHandler.sync(this);
							_la = _input.LA(1);
						}
						setState(847);
						argumentListItem();
						}
						} 
					}
					setState(852);
					_errHandler.sync(this);
					_alt = getInterpreter().adaptivePredict(_input,98,_ctx);
				}
				}
				break;
			case 3:
				_localctx = new ArrayArgumentListContext(_localctx);
				enterOuterAlt(_localctx, 3);
				{
				setState(853);
				match(LBRACK);
				setState(855);
				_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(854);
					indexingArgumentList();
					}
				}

				setState(857);
				match(RBRACK);
				}
				break;
			case 4:
				_localctx = new SingleCommandArgumentListContext(_localctx);
				enterOuterAlt(_localctx, 4);
				{
				setState(858);
				command();
				}
				break;
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class ArgumentListItemContext extends ParserRuleContext {
		public SplattingArgumentContext splattingArgument() {
			return getRuleContext(SplattingArgumentContext.class,0);
		}
		public OperatorExpressionListContext operatorExpressionList() {
			return getRuleContext(OperatorExpressionListContext.class,0);
		}
		public AssociationListContext associationList() {
			return getRuleContext(AssociationListContext.class,0);
		}
		public BlockArgumentContext blockArgument() {
			return getRuleContext(BlockArgumentContext.class,0);
		}
		public ArgumentListItemContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_argumentListItem; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterArgumentListItem(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitArgumentListItem(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitArgumentListItem(this);
			else return visitor.visitChildren(this);
		}
	}

	public final ArgumentListItemContext argumentListItem() throws RecognitionException {
		ArgumentListItemContext _localctx = new ArgumentListItemContext(_ctx, getState());
		enterRule(_localctx, 66, RULE_argumentListItem);
		try {
			setState(865);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,101,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(861);
				splattingArgument();
				}
				break;
			case 2:
				enterOuterAlt(_localctx, 2);
				{
				setState(862);
				operatorExpressionList();
				}
				break;
			case 3:
				enterOuterAlt(_localctx, 3);
				{
				setState(863);
				associationList();
				}
				break;
			case 4:
				enterOuterAlt(_localctx, 4);
				{
				setState(864);
				blockArgument();
				}
				break;
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class SplatArgListContext extends ParserRuleContext {
		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 SplatArgListContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_splatArgList; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).enterSplatArgList(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof RubyParserListener ) ((RubyParserListener)listener).exitSplatArgList(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof RubyParserVisitor ) return ((RubyParserVisitor)visitor).visitSplatArgList(this);
			else return visitor.visitChildren(this);
		}
	}

	public final SplatArgListContext splatArgList() throws RecognitionException {
		SplatArgListContext _localctx = new SplatArgListContext(_ctx, getState());
		enterRule(_localctx, 68, RULE_splatArgList);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(867);
			splattingArgument();
			setState(878);
			_errHandler.sync(this);
			_la = _input.LA(1);
			while (_la==COMMA) {
				{
				{
				setState(868);
				match(COMMA);
				setState(872);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==NL) {
					{
					{
					setState(869);
					match(NL);
					}
					}
					setState(874);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(875);
				splattingArgument();
				}
				}
				setState(880);
				_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 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, 70, RULE_commandArgumentList);
		int _la;
		try {
			setState(893);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,106,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(881);
				associationList();
				}
				break;
			case 2:
				enterOuterAlt(_localctx, 2);
				{
				setState(882);
				primaryValueList();
				setState(891);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,105,_ctx) ) {
				case 1:
					{
					setState(883);
					match(COMMA);
					setState(887);
					_errHandler.sync(this);
					_la = _input.LA(1);
					while (_la==NL) {
						{
						{
						setState(884);
						match(NL);
						}
						}
						setState(889);
						_errHandler.sync(this);
						_la = _input.LA(1);
					}
					setState(890);
					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, 72, RULE_primaryValueList);
		int _la;
		try {
			int _alt;
			enterOuterAlt(_localctx, 1);
			{
			setState(895);
			primaryValue(0);
			setState(906);
			_errHandler.sync(this);
			_alt = getInterpreter().adaptivePredict(_input,108,_ctx);
			while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) {
				if ( _alt==1 ) {
					{
					{
					setState(896);
					match(COMMA);
					setState(900);
					_errHandler.sync(this);
					_la = _input.LA(1);
					while (_la==NL) {
						{
						{
						setState(897);
						match(NL);
						}
						}
						setState(902);
						_errHandler.sync(this);
						_la = _input.LA(1);
					}
					setState(903);
					primaryValue(0);
					}
					} 
				}
				setState(908);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,108,_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, 74, RULE_primaryValueListWithAssociation);
		int _la;
		try {
			int _alt;
			setState(930);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,113,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(911);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,109,_ctx) ) {
				case 1:
					{
					setState(909);
					primaryValue(0);
					}
					break;
				case 2:
					{
					setState(910);
					association();
					}
					break;
				}
				setState(926);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,112,_ctx);
				while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) {
					if ( _alt==1 ) {
						{
						{
						setState(913);
						match(COMMA);
						setState(917);
						_errHandler.sync(this);
						_la = _input.LA(1);
						while (_la==NL) {
							{
							{
							setState(914);
							match(NL);
							}
							}
							setState(919);
							_errHandler.sync(this);
							_la = _input.LA(1);
						}
						setState(922);
						_errHandler.sync(this);
						switch ( getInterpreter().adaptivePredict(_input,111,_ctx) ) {
						case 1:
							{
							setState(920);
							primaryValue(0);
							}
							break;
						case 2:
							{
							setState(921);
							association();
							}
							break;
						}
						}
						} 
					}
					setState(928);
					_errHandler.sync(this);
					_alt = getInterpreter().adaptivePredict(_input,112,_ctx);
				}
				}
				break;
			case 2:
				enterOuterAlt(_localctx, 2);
				{
				setState(929);
				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, 76, RULE_blockArgument);
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(932);
			match(AMP);
			setState(934);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,114,_ctx) ) {
			case 1:
				{
				setState(933);
				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 = 78;
		enterRecursionRule(_localctx, 78, RULE_expressionOrCommand, _p);
		int _la;
		try {
			int _alt;
			enterOuterAlt(_localctx, 1);
			{
			setState(950);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,117,_ctx) ) {
			case 1:
				{
				_localctx = new OperatorExpressionOrCommandContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;

				setState(937);
				operatorExpression(0);
				}
				break;
			case 2:
				{
				_localctx = new CommandExpressionOrCommandContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(939);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,115,_ctx) ) {
				case 1:
					{
					setState(938);
					match(EMARK);
					}
					break;
				}
				setState(941);
				methodInvocationWithoutParentheses();
				}
				break;
			case 3:
				{
				_localctx = new NotExpressionOrCommandContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(942);
				match(NOT);
				setState(946);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==NL) {
					{
					{
					setState(943);
					match(NL);
					}
					}
					setState(948);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(949);
				expressionOrCommand(2);
				}
				break;
			}
			_ctx.stop = _input.LT(-1);
			setState(963);
			_errHandler.sync(this);
			_alt = getInterpreter().adaptivePredict(_input,119,_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(952);
					if (!(precpred(_ctx, 1))) throw new FailedPredicateException(this, "precpred(_ctx, 1)");
					setState(953);
					((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(957);
					_errHandler.sync(this);
					_la = _input.LA(1);
					while (_la==NL) {
						{
						{
						setState(954);
						match(NL);
						}
						}
						setState(959);
						_errHandler.sync(this);
						_la = _input.LA(1);
					}
					setState(960);
					((KeywordAndOrExpressionOrCommandContext)_localctx).rhs = expressionOrCommand(2);
					}
					} 
				}
				setState(965);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,119,_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 = 80;
		enterRecursionRule(_localctx, 80, RULE_operatorExpression, _p);
		int _la;
		try {
			int _alt;
			enterOuterAlt(_localctx, 1);
			{
			{
			_localctx = new PrimaryOperatorExpressionContext(_localctx);
			_ctx = _localctx;
			_prevctx = _localctx;

			setState(967);
			primary();
			}
			_ctx.stop = _input.LT(-1);
			setState(995);
			_errHandler.sync(this);
			_alt = getInterpreter().adaptivePredict(_input,123,_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(969);
					if (!(precpred(_ctx, 1))) throw new FailedPredicateException(this, "precpred(_ctx, 1)");
					setState(970);
					match(QMARK);
					setState(974);
					_errHandler.sync(this);
					_la = _input.LA(1);
					while (_la==NL) {
						{
						{
						setState(971);
						match(NL);
						}
						}
						setState(976);
						_errHandler.sync(this);
						_la = _input.LA(1);
					}
					setState(977);
					operatorExpression(0);
					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);
					match(COLON);
					setState(988);
					_errHandler.sync(this);
					_la = _input.LA(1);
					while (_la==NL) {
						{
						{
						setState(985);
						match(NL);
						}
						}
						setState(990);
						_errHandler.sync(this);
						_la = _input.LA(1);
					}
					setState(991);
					operatorExpression(2);
					}
					} 
				}
				setState(997);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,123,_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, 82, RULE_primary);
		try {
			setState(1004);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case RETURN:
				_localctx = new ReturnWithoutArgumentsContext(_localctx);
				enterOuterAlt(_localctx, 1);
				{
				setState(998);
				match(RETURN);
				}
				break;
			case BREAK:
				_localctx = new BreakWithoutArgumentsContext(_localctx);
				enterOuterAlt(_localctx, 2);
				{
				setState(999);
				match(BREAK);
				}
				break;
			case NEXT:
				_localctx = new NextWithoutArgumentsContext(_localctx);
				enterOuterAlt(_localctx, 3);
				{
				setState(1000);
				match(NEXT);
				}
				break;
			case REDO:
				_localctx = new RedoWithoutArgumentsContext(_localctx);
				enterOuterAlt(_localctx, 4);
				{
				setState(1001);
				match(REDO);
				}
				break;
			case RETRY:
				_localctx = new RetryWithoutArgumentsContext(_localctx);
				enterOuterAlt(_localctx, 5);
				{
				setState(1002);
				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(1003);
				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, 84, RULE_hashLiteral);
		int _la;
		try {
			int _alt;
			enterOuterAlt(_localctx, 1);
			{
			setState(1006);
			match(LCURLY);
			setState(1010);
			_errHandler.sync(this);
			_alt = getInterpreter().adaptivePredict(_input,125,_ctx);
			while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) {
				if ( _alt==1 ) {
					{
					{
					setState(1007);
					match(NL);
					}
					} 
				}
				setState(1012);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,125,_ctx);
			}
			setState(1017);
			_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(1013);
				associationList();
				setState(1015);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==COMMA) {
					{
					setState(1014);
					match(COMMA);
					}
				}

				}
			}

			setState(1022);
			_errHandler.sync(this);
			_la = _input.LA(1);
			while (_la==NL) {
				{
				{
				setState(1019);
				match(NL);
				}
				}
				setState(1024);
				_errHandler.sync(this);
				_la = _input.LA(1);
			}
			setState(1025);
			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 = 86;
		enterRecursionRule(_localctx, 86, RULE_primaryValue, _p);
		int _la;
		try {
			int _alt;
			enterOuterAlt(_localctx, 1);
			{
			setState(1342);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,169,_ctx) ) {
			case 1:
				{
				_localctx = new LocalVariableAssignmentExpressionContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;

				setState(1028);
				((LocalVariableAssignmentExpressionContext)_localctx).lhs = variable();
				setState(1029);
				assignmentOperator();
				setState(1033);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==NL) {
					{
					{
					setState(1030);
					match(NL);
					}
					}
					setState(1035);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(1036);
				((LocalVariableAssignmentExpressionContext)_localctx).rhs = operatorExpression(0);
				}
				break;
			case 2:
				{
				_localctx = new ConstantAssignmentExpressionContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(1038);
				match(COLON2);
				setState(1039);
				match(CONSTANT_IDENTIFIER);
				setState(1040);
				assignmentOperator();
				setState(1044);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==NL) {
					{
					{
					setState(1041);
					match(NL);
					}
					}
					setState(1046);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(1047);
				operatorExpression(0);
				}
				break;
			case 3:
				{
				_localctx = new ClassDefinitionContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(1049);
				match(CLASS);
				setState(1050);
				classPath(0);
				setState(1053);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==LT) {
					{
					setState(1051);
					match(LT);
					setState(1052);
					commandOrPrimaryValueClass();
					}
				}

				setState(1056);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,132,_ctx) ) {
				case 1:
					{
					setState(1055);
					_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(1058);
				bodyStatement();
				setState(1059);
				match(END);
				}
				break;
			case 4:
				{
				_localctx = new SingletonClassDefinitionContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(1061);
				match(CLASS);
				setState(1062);
				match(LT2);
				setState(1063);
				commandOrPrimaryValueClass();
				setState(1064);
				_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(1065);
				bodyStatement();
				setState(1066);
				match(END);
				}
				break;
			case 5:
				{
				_localctx = new ModuleDefinitionContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(1068);
				match(MODULE);
				setState(1069);
				classPath(0);
				setState(1070);
				bodyStatement();
				setState(1071);
				match(END);
				}
				break;
			case 6:
				{
				_localctx = new MethodDefinitionContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(1073);
				match(DEF);
				setState(1074);
				definedMethodName();
				setState(1075);
				methodParameterPart();
				setState(1076);
				bodyStatement();
				setState(1077);
				match(END);
				}
				break;
			case 7:
				{
				_localctx = new SingletonMethodDefinitionContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(1079);
				match(DEF);
				setState(1080);
				singletonObject();
				setState(1081);
				((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(1082);
				definedMethodName();
				setState(1083);
				methodParameterPart();
				setState(1084);
				bodyStatement();
				setState(1085);
				match(END);
				}
				break;
			case 8:
				{
				_localctx = new EndlessMethodDefinitionContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(1087);
				match(DEF);
				setState(1088);
				definedMethodName();
				setState(1094);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==LPAREN) {
					{
					setState(1089);
					match(LPAREN);
					setState(1091);
					_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(1090);
						parameterList();
						}
					}

					setState(1093);
					match(RPAREN);
					}
				}

				setState(1096);
				match(EQ);
				setState(1100);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==NL) {
					{
					{
					setState(1097);
					match(NL);
					}
					}
					setState(1102);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(1103);
				statement(0);
				}
				break;
			case 9:
				{
				_localctx = new LambdaExpressionContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(1105);
				match(MINUSGT);
				setState(1107);
				_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(1106);
					lambdaExpressionParameterList();
					}
				}

				setState(1109);
				block();
				}
				break;
			case 10:
				{
				_localctx = new IfExpressionContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(1110);
				match(IF);
				setState(1114);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==NL) {
					{
					{
					setState(1111);
					match(NL);
					}
					}
					setState(1116);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(1117);
				expressionOrCommand(0);
				setState(1118);
				thenClause();
				setState(1122);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==ELSIF) {
					{
					{
					setState(1119);
					elsifClause();
					}
					}
					setState(1124);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(1126);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==ELSE) {
					{
					setState(1125);
					elseClause();
					}
				}

				setState(1128);
				match(END);
				}
				break;
			case 11:
				{
				_localctx = new UnlessExpressionContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(1130);
				match(UNLESS);
				setState(1134);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==NL) {
					{
					{
					setState(1131);
					match(NL);
					}
					}
					setState(1136);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(1137);
				expressionOrCommand(0);
				setState(1138);
				thenClause();
				setState(1140);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==ELSE) {
					{
					setState(1139);
					elseClause();
					}
				}

				setState(1142);
				match(END);
				}
				break;
			case 12:
				{
				_localctx = new UntilExpressionContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(1144);
				match(UNTIL);
				setState(1148);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==NL) {
					{
					{
					setState(1145);
					match(NL);
					}
					}
					setState(1150);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(1151);
				expressionOrCommand(0);
				setState(1152);
				doClause();
				setState(1153);
				match(END);
				}
				break;
			case 13:
				{
				_localctx = new YieldExpressionContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(1155);
				match(YIELD);
				setState(1157);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,143,_ctx) ) {
				case 1:
					{
					setState(1156);
					argumentWithParentheses();
					}
					break;
				}
				}
				break;
			case 14:
				{
				_localctx = new BeginEndExpressionContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(1159);
				match(BEGIN);
				setState(1160);
				bodyStatement();
				setState(1161);
				match(END);
				}
				break;
			case 15:
				{
				_localctx = new CaseWithExpressionContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(1163);
				match(CASE);
				setState(1167);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==NL) {
					{
					{
					setState(1164);
					match(NL);
					}
					}
					setState(1169);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(1170);
				expressionOrCommand(0);
				setState(1174);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==SEMI || _la==NL) {
					{
					{
					setState(1171);
					_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(1176);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(1178); 
				_errHandler.sync(this);
				_la = _input.LA(1);
				do {
					{
					{
					setState(1177);
					whenClause();
					}
					}
					setState(1180); 
					_errHandler.sync(this);
					_la = _input.LA(1);
				} while ( _la==WHEN );
				setState(1183);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==ELSE) {
					{
					setState(1182);
					elseClause();
					}
				}

				setState(1185);
				match(END);
				}
				break;
			case 16:
				{
				_localctx = new CaseWithoutExpressionContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(1187);
				match(CASE);
				setState(1191);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==SEMI || _la==NL) {
					{
					{
					setState(1188);
					_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(1193);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(1195); 
				_errHandler.sync(this);
				_la = _input.LA(1);
				do {
					{
					{
					setState(1194);
					whenClause();
					}
					}
					setState(1197); 
					_errHandler.sync(this);
					_la = _input.LA(1);
				} while ( _la==WHEN );
				setState(1200);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==ELSE) {
					{
					setState(1199);
					elseClause();
					}
				}

				setState(1202);
				match(END);
				}
				break;
			case 17:
				{
				_localctx = new WhileExpressionContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(1204);
				match(WHILE);
				setState(1208);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==NL) {
					{
					{
					setState(1205);
					match(NL);
					}
					}
					setState(1210);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(1211);
				expressionOrCommand(0);
				setState(1212);
				doClause();
				setState(1213);
				match(END);
				}
				break;
			case 18:
				{
				_localctx = new ForExpressionContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(1215);
				match(FOR);
				setState(1219);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==NL) {
					{
					{
					setState(1216);
					match(NL);
					}
					}
					setState(1221);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(1222);
				forVariable();
				setState(1223);
				match(IN);
				setState(1227);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==NL) {
					{
					{
					setState(1224);
					match(NL);
					}
					}
					setState(1229);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(1230);
				commandOrPrimaryValue(0);
				setState(1231);
				doClause();
				setState(1232);
				match(END);
				}
				break;
			case 19:
				{
				_localctx = new MethodCallWithParenthesesContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(1234);
				methodCallsWithParentheses();
				}
				break;
			case 20:
				{
				_localctx = new BracketedArrayLiteralContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(1235);
				match(LBRACK);
				setState(1239);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,154,_ctx);
				while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) {
					if ( _alt==1 ) {
						{
						{
						setState(1236);
						match(NL);
						}
						} 
					}
					setState(1241);
					_errHandler.sync(this);
					_alt = getInterpreter().adaptivePredict(_input,154,_ctx);
				}
				setState(1243);
				_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(1242);
					bracketedArrayElementList();
					}
				}

				setState(1248);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==NL) {
					{
					{
					setState(1245);
					match(NL);
					}
					}
					setState(1250);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(1251);
				match(RBRACK);
				}
				break;
			case 21:
				{
				_localctx = new QuotedNonExpandedStringArrayLiteralContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(1252);
				match(QUOTED_NON_EXPANDED_STRING_ARRAY_LITERAL_START);
				setState(1254);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==NON_EXPANDED_ARRAY_ITEM_SEPARATOR || _la==NON_EXPANDED_ARRAY_ITEM_CHARACTER) {
					{
					setState(1253);
					quotedNonExpandedArrayElementList();
					}
				}

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

				setState(1261);
				match(QUOTED_NON_EXPANDED_SYMBOL_ARRAY_LITERAL_END);
				}
				break;
			case 23:
				{
				_localctx = new QuotedExpandedStringArrayLiteralContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(1262);
				match(QUOTED_EXPANDED_STRING_ARRAY_LITERAL_START);
				setState(1264);
				_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(1263);
					quotedExpandedArrayElementList();
					}
				}

				setState(1266);
				match(QUOTED_EXPANDED_STRING_ARRAY_LITERAL_END);
				}
				break;
			case 24:
				{
				_localctx = new QuotedExpandedSymbolArrayLiteralContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(1267);
				match(QUOTED_EXPANDED_SYMBOL_ARRAY_LITERAL_START);
				setState(1269);
				_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(1268);
					quotedExpandedArrayElementList();
					}
				}

				setState(1271);
				match(QUOTED_EXPANDED_SYMBOL_ARRAY_LITERAL_END);
				}
				break;
			case 25:
				{
				_localctx = new PrimaryValueHashLiteralContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(1272);
				hashLiteral();
				}
				break;
			case 26:
				{
				_localctx = new NumericLiteralContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(1274);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==PLUS || _la==MINUS) {
					{
					setState(1273);
					((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(1276);
				unsignedNumericLiteral();
				}
				break;
			case 27:
				{
				_localctx = new SingleQuotedStringExpressionContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(1277);
				singleQuotedString();
				setState(1281);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,162,_ctx);
				while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) {
					if ( _alt==1 ) {
						{
						{
						setState(1278);
						singleOrDoubleQuotedString();
						}
						} 
					}
					setState(1283);
					_errHandler.sync(this);
					_alt = getInterpreter().adaptivePredict(_input,162,_ctx);
				}
				}
				break;
			case 28:
				{
				_localctx = new DoubleQuotedStringExpressionContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(1284);
				doubleQuotedString();
				setState(1288);
				_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(1285);
						singleOrDoubleQuotedString();
						}
						} 
					}
					setState(1290);
					_errHandler.sync(this);
					_alt = getInterpreter().adaptivePredict(_input,163,_ctx);
				}
				}
				break;
			case 29:
				{
				_localctx = new QuotedNonExpandedStringLiteralContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(1291);
				match(QUOTED_NON_EXPANDED_STRING_LITERAL_START);
				setState(1293);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==NON_EXPANDED_LITERAL_CHARACTER_SEQUENCE) {
					{
					setState(1292);
					match(NON_EXPANDED_LITERAL_CHARACTER_SEQUENCE);
					}
				}

				setState(1295);
				match(QUOTED_NON_EXPANDED_STRING_LITERAL_END);
				}
				break;
			case 30:
				{
				_localctx = new QuotedExpandedStringLiteralContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(1296);
				match(QUOTED_EXPANDED_STRING_LITERAL_START);
				setState(1300);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==EXPANDED_LITERAL_CHARACTER_SEQUENCE || _la==DELIMITED_STRING_INTERPOLATION_BEGIN) {
					{
					{
					setState(1297);
					quotedExpandedLiteralStringContent();
					}
					}
					setState(1302);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(1303);
				match(QUOTED_EXPANDED_STRING_LITERAL_END);
				}
				break;
			case 31:
				{
				_localctx = new QuotedExpandedExternalCommandLiteralContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(1304);
				match(QUOTED_EXPANDED_EXTERNAL_COMMAND_LITERAL_START);
				setState(1308);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==EXPANDED_LITERAL_CHARACTER_SEQUENCE || _la==DELIMITED_STRING_INTERPOLATION_BEGIN) {
					{
					{
					setState(1305);
					quotedExpandedLiteralStringContent();
					}
					}
					setState(1310);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(1311);
				match(QUOTED_EXPANDED_EXTERNAL_COMMAND_LITERAL_END);
				}
				break;
			case 32:
				{
				_localctx = new SymbolExpressionContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(1312);
				symbol();
				}
				break;
			case 33:
				{
				_localctx = new RegularExpressionLiteralContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(1313);
				match(REGULAR_EXPRESSION_START);
				setState(1317);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==REGULAR_EXPRESSION_BODY || _la==REGULAR_EXPRESSION_INTERPOLATION_BEGIN) {
					{
					{
					setState(1314);
					regexpLiteralContent();
					}
					}
					setState(1319);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(1320);
				match(REGULAR_EXPRESSION_END);
				}
				break;
			case 34:
				{
				_localctx = new QuotedExpandedRegularExpressionLiteralContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(1321);
				match(QUOTED_EXPANDED_REGULAR_EXPRESSION_START);
				setState(1325);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==EXPANDED_LITERAL_CHARACTER_SEQUENCE || _la==DELIMITED_STRING_INTERPOLATION_BEGIN) {
					{
					{
					setState(1322);
					quotedExpandedLiteralStringContent();
					}
					}
					setState(1327);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(1328);
				match(QUOTED_EXPANDED_REGULAR_EXPRESSION_END);
				}
				break;
			case 35:
				{
				_localctx = new GroupingStatementContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(1329);
				match(LPAREN);
				setState(1330);
				compoundStatement();
				setState(1331);
				match(RPAREN);
				}
				break;
			case 36:
				{
				_localctx = new UnaryExpressionContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(1333);
				unaryOperator();
				setState(1334);
				primaryValue(16);
				}
				break;
			case 37:
				{
				_localctx = new UnaryMinusExpressionContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(1336);
				match(MINUS);
				setState(1337);
				primaryValue(14);
				}
				break;
			case 38:
				{
				_localctx = new BeginlessRangeExpressionContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(1338);
				rangeOperator();
				setState(1339);
				primaryValue(2);
				}
				break;
			case 39:
				{
				_localctx = new HereDocsContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(1341);
				hereDoc();
				}
				break;
			}
			_ctx.stop = _input.LT(-1);
			setState(1526);
			_errHandler.sync(this);
			_alt = getInterpreter().adaptivePredict(_input,193,_ctx);
			while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) {
				if ( _alt==1 ) {
					if ( _parseListeners!=null ) triggerExitRuleEvent();
					_prevctx = _localctx;
					{
					setState(1524);
					_errHandler.sync(this);
					switch ( getInterpreter().adaptivePredict(_input,192,_ctx) ) {
					case 1:
						{
						_localctx = new PowerExpressionContext(new PrimaryValueContext(_parentctx, _parentState));
						pushNewRecursionContext(_localctx, _startState, RULE_primaryValue);
						setState(1344);
						if (!(precpred(_ctx, 15))) throw new FailedPredicateException(this, "precpred(_ctx, 15)");
						setState(1345);
						((PowerExpressionContext)_localctx).powerOperator = match(STAR2);
						setState(1349);
						_errHandler.sync(this);
						_la = _input.LA(1);
						while (_la==NL) {
							{
							{
							setState(1346);
							match(NL);
							}
							}
							setState(1351);
							_errHandler.sync(this);
							_la = _input.LA(1);
						}
						setState(1352);
						primaryValue(15);
						}
						break;
					case 2:
						{
						_localctx = new MultiplicativeExpressionContext(new PrimaryValueContext(_parentctx, _parentState));
						pushNewRecursionContext(_localctx, _startState, RULE_primaryValue);
						setState(1353);
						if (!(precpred(_ctx, 13))) throw new FailedPredicateException(this, "precpred(_ctx, 13)");
						setState(1354);
						multiplicativeOperator();
						setState(1358);
						_errHandler.sync(this);
						_la = _input.LA(1);
						while (_la==NL) {
							{
							{
							setState(1355);
							match(NL);
							}
							}
							setState(1360);
							_errHandler.sync(this);
							_la = _input.LA(1);
						}
						setState(1361);
						primaryValue(14);
						}
						break;
					case 3:
						{
						_localctx = new AdditiveExpressionContext(new PrimaryValueContext(_parentctx, _parentState));
						pushNewRecursionContext(_localctx, _startState, RULE_primaryValue);
						setState(1363);
						if (!(precpred(_ctx, 12))) throw new FailedPredicateException(this, "precpred(_ctx, 12)");
						setState(1364);
						additiveOperator();
						setState(1368);
						_errHandler.sync(this);
						_la = _input.LA(1);
						while (_la==NL) {
							{
							{
							setState(1365);
							match(NL);
							}
							}
							setState(1370);
							_errHandler.sync(this);
							_la = _input.LA(1);
						}
						setState(1371);
						primaryValue(13);
						}
						break;
					case 4:
						{
						_localctx = new ShiftExpressionContext(new PrimaryValueContext(_parentctx, _parentState));
						pushNewRecursionContext(_localctx, _startState, RULE_primaryValue);
						setState(1373);
						if (!(precpred(_ctx, 11))) throw new FailedPredicateException(this, "precpred(_ctx, 11)");
						setState(1374);
						bitwiseShiftOperator();
						setState(1378);
						_errHandler.sync(this);
						_la = _input.LA(1);
						while (_la==NL) {
							{
							{
							setState(1375);
							match(NL);
							}
							}
							setState(1380);
							_errHandler.sync(this);
							_la = _input.LA(1);
						}
						setState(1381);
						primaryValue(12);
						}
						break;
					case 5:
						{
						_localctx = new BitwiseAndExpressionContext(new PrimaryValueContext(_parentctx, _parentState));
						pushNewRecursionContext(_localctx, _startState, RULE_primaryValue);
						setState(1383);
						if (!(precpred(_ctx, 10))) throw new FailedPredicateException(this, "precpred(_ctx, 10)");
						setState(1384);
						((BitwiseAndExpressionContext)_localctx).bitwiseAndOperator = match(AMP);
						setState(1388);
						_errHandler.sync(this);
						_la = _input.LA(1);
						while (_la==NL) {
							{
							{
							setState(1385);
							match(NL);
							}
							}
							setState(1390);
							_errHandler.sync(this);
							_la = _input.LA(1);
						}
						setState(1391);
						primaryValue(11);
						}
						break;
					case 6:
						{
						_localctx = new BitwiseOrExpressionContext(new PrimaryValueContext(_parentctx, _parentState));
						pushNewRecursionContext(_localctx, _startState, RULE_primaryValue);
						setState(1392);
						if (!(precpred(_ctx, 9))) throw new FailedPredicateException(this, "precpred(_ctx, 9)");
						setState(1393);
						bitwiseOrOperator();
						setState(1397);
						_errHandler.sync(this);
						_la = _input.LA(1);
						while (_la==NL) {
							{
							{
							setState(1394);
							match(NL);
							}
							}
							setState(1399);
							_errHandler.sync(this);
							_la = _input.LA(1);
						}
						setState(1400);
						primaryValue(10);
						}
						break;
					case 7:
						{
						_localctx = new RelationalExpressionContext(new PrimaryValueContext(_parentctx, _parentState));
						pushNewRecursionContext(_localctx, _startState, RULE_primaryValue);
						setState(1402);
						if (!(precpred(_ctx, 8))) throw new FailedPredicateException(this, "precpred(_ctx, 8)");
						setState(1403);
						relationalOperator();
						setState(1407);
						_errHandler.sync(this);
						_la = _input.LA(1);
						while (_la==NL) {
							{
							{
							setState(1404);
							match(NL);
							}
							}
							setState(1409);
							_errHandler.sync(this);
							_la = _input.LA(1);
						}
						setState(1410);
						primaryValue(9);
						}
						break;
					case 8:
						{
						_localctx = new EqualityExpressionContext(new PrimaryValueContext(_parentctx, _parentState));
						pushNewRecursionContext(_localctx, _startState, RULE_primaryValue);
						setState(1412);
						if (!(precpred(_ctx, 7))) throw new FailedPredicateException(this, "precpred(_ctx, 7)");
						setState(1413);
						equalityOperator();
						setState(1417);
						_errHandler.sync(this);
						_la = _input.LA(1);
						while (_la==NL) {
							{
							{
							setState(1414);
							match(NL);
							}
							}
							setState(1419);
							_errHandler.sync(this);
							_la = _input.LA(1);
						}
						setState(1420);
						primaryValue(8);
						}
						break;
					case 9:
						{
						_localctx = new BoundedRangeExpressionContext(new PrimaryValueContext(_parentctx, _parentState));
						pushNewRecursionContext(_localctx, _startState, RULE_primaryValue);
						setState(1422);
						if (!(precpred(_ctx, 4))) throw new FailedPredicateException(this, "precpred(_ctx, 4)");
						setState(1423);
						rangeOperator();
						setState(1427);
						_errHandler.sync(this);
						_la = _input.LA(1);
						while (_la==NL) {
							{
							{
							setState(1424);
							match(NL);
							}
							}
							setState(1429);
							_errHandler.sync(this);
							_la = _input.LA(1);
						}
						setState(1430);
						primaryValue(5);
						}
						break;
					case 10:
						{
						_localctx = new AttributeAssignmentExpressionContext(new PrimaryValueContext(_parentctx, _parentState));
						pushNewRecursionContext(_localctx, _startState, RULE_primaryValue);
						setState(1432);
						if (!(precpred(_ctx, 55))) throw new FailedPredicateException(this, "precpred(_ctx, 55)");
						setState(1433);
						((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(1434);
						methodName();
						setState(1435);
						assignmentOperator();
						setState(1439);
						_errHandler.sync(this);
						_la = _input.LA(1);
						while (_la==NL) {
							{
							{
							setState(1436);
							match(NL);
							}
							}
							setState(1441);
							_errHandler.sync(this);
							_la = _input.LA(1);
						}
						setState(1442);
						operatorExpression(0);
						}
						break;
					case 11:
						{
						_localctx = new BracketAssignmentExpressionContext(new PrimaryValueContext(_parentctx, _parentState));
						pushNewRecursionContext(_localctx, _startState, RULE_primaryValue);
						setState(1444);
						if (!(precpred(_ctx, 53))) throw new FailedPredicateException(this, "precpred(_ctx, 53)");
						setState(1445);
						match(LBRACK);
						setState(1447);
						_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(1446);
							indexingArgumentList();
							}
						}

						setState(1449);
						match(RBRACK);
						setState(1450);
						assignmentOperator();
						setState(1454);
						_errHandler.sync(this);
						_la = _input.LA(1);
						while (_la==NL) {
							{
							{
							setState(1451);
							match(NL);
							}
							}
							setState(1456);
							_errHandler.sync(this);
							_la = _input.LA(1);
						}
						setState(1457);
						operatorExpression(0);
						}
						break;
					case 12:
						{
						_localctx = new AssignmentWithRescueContext(new PrimaryValueContext(_parentctx, _parentState));
						pushNewRecursionContext(_localctx, _startState, RULE_primaryValue);
						setState(1459);
						if (!(precpred(_ctx, 52))) throw new FailedPredicateException(this, "precpred(_ctx, 52)");
						setState(1460);
						assignmentOperator();
						setState(1464);
						_errHandler.sync(this);
						_la = _input.LA(1);
						while (_la==NL) {
							{
							{
							setState(1461);
							match(NL);
							}
							}
							setState(1466);
							_errHandler.sync(this);
							_la = _input.LA(1);
						}
						setState(1467);
						operatorExpression(0);
						setState(1468);
						match(RESCUE);
						setState(1469);
						operatorExpression(0);
						}
						break;
					case 13:
						{
						_localctx = new IndexingAccessExpressionContext(new PrimaryValueContext(_parentctx, _parentState));
						pushNewRecursionContext(_localctx, _startState, RULE_primaryValue);
						setState(1471);
						if (!(precpred(_ctx, 18))) throw new FailedPredicateException(this, "precpred(_ctx, 18)");
						setState(1472);
						match(LBRACK);
						setState(1474);
						_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(1473);
							indexingArgumentList();
							}
						}

						setState(1476);
						match(RBRACK);
						}
						break;
					case 14:
						{
						_localctx = new MemberAccessExpressionContext(new PrimaryValueContext(_parentctx, _parentState));
						pushNewRecursionContext(_localctx, _startState, RULE_primaryValue);
						setState(1477);
						if (!(precpred(_ctx, 17))) throw new FailedPredicateException(this, "precpred(_ctx, 17)");
						setState(1481);
						_errHandler.sync(this);
						_la = _input.LA(1);
						while (_la==NL) {
							{
							{
							setState(1478);
							match(NL);
							}
							}
							setState(1483);
							_errHandler.sync(this);
							_la = _input.LA(1);
						}
						setState(1484);
						((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(1488);
						_errHandler.sync(this);
						_la = _input.LA(1);
						while (_la==NL) {
							{
							{
							setState(1485);
							match(NL);
							}
							}
							setState(1490);
							_errHandler.sync(this);
							_la = _input.LA(1);
						}
						setState(1491);
						methodName();
						setState(1493);
						_errHandler.sync(this);
						switch ( getInterpreter().adaptivePredict(_input,186,_ctx) ) {
						case 1:
							{
							setState(1492);
							argumentWithParentheses();
							}
							break;
						}
						setState(1496);
						_errHandler.sync(this);
						switch ( getInterpreter().adaptivePredict(_input,187,_ctx) ) {
						case 1:
							{
							setState(1495);
							block();
							}
							break;
						}
						}
						break;
					case 15:
						{
						_localctx = new LogicalAndExpressionContext(new PrimaryValueContext(_parentctx, _parentState));
						pushNewRecursionContext(_localctx, _startState, RULE_primaryValue);
						setState(1498);
						if (!(precpred(_ctx, 6))) throw new FailedPredicateException(this, "precpred(_ctx, 6)");
						setState(1499);
						((LogicalAndExpressionContext)_localctx).andOperator = match(AMP2);
						setState(1503);
						_errHandler.sync(this);
						_la = _input.LA(1);
						while (_la==NL) {
							{
							{
							setState(1500);
							match(NL);
							}
							}
							setState(1505);
							_errHandler.sync(this);
							_la = _input.LA(1);
						}
						setState(1508);
						_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(1506);
							primaryValue(0);
							}
							break;
						case RETURN:
							{
							setState(1507);
							match(RETURN);
							}
							break;
						default:
							throw new NoViableAltException(this);
						}
						}
						break;
					case 16:
						{
						_localctx = new LogicalOrExpressionContext(new PrimaryValueContext(_parentctx, _parentState));
						pushNewRecursionContext(_localctx, _startState, RULE_primaryValue);
						setState(1510);
						if (!(precpred(_ctx, 5))) throw new FailedPredicateException(this, "precpred(_ctx, 5)");
						setState(1511);
						((LogicalOrExpressionContext)_localctx).orOperator = match(BAR2);
						setState(1515);
						_errHandler.sync(this);
						_la = _input.LA(1);
						while (_la==NL) {
							{
							{
							setState(1512);
							match(NL);
							}
							}
							setState(1517);
							_errHandler.sync(this);
							_la = _input.LA(1);
						}
						setState(1520);
						_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(1518);
							primaryValue(0);
							}
							break;
						case RETURN:
							{
							setState(1519);
							match(RETURN);
							}
							break;
						default:
							throw new NoViableAltException(this);
						}
						}
						break;
					case 17:
						{
						_localctx = new EndlessRangeExpressionContext(new PrimaryValueContext(_parentctx, _parentState));
						pushNewRecursionContext(_localctx, _startState, RULE_primaryValue);
						setState(1522);
						if (!(precpred(_ctx, 3))) throw new FailedPredicateException(this, "precpred(_ctx, 3)");
						setState(1523);
						rangeOperator();
						}
						break;
					}
					} 
				}
				setState(1528);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,193,_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, 88, RULE_lambdaExpressionParameterList);
		int _la;
		try {
			setState(1535);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,195,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(1529);
				match(LPAREN);
				setState(1531);
				_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(1530);
					blockParameterList();
					}
				}

				setState(1533);
				match(RPAREN);
				}
				break;
			case 2:
				enterOuterAlt(_localctx, 2);
				{
				setState(1534);
				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, 90, RULE_methodCallsWithParentheses);
		try {
			setState(1569);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,201,_ctx) ) {
			case 1:
				_localctx = new SuperWithParenthesesContext(_localctx);
				enterOuterAlt(_localctx, 1);
				{
				setState(1537);
				match(SUPER);
				setState(1539);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,196,_ctx) ) {
				case 1:
					{
					setState(1538);
					argumentWithParentheses();
					}
					break;
				}
				setState(1542);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,197,_ctx) ) {
				case 1:
					{
					setState(1541);
					block();
					}
					break;
				}
				}
				break;
			case 2:
				_localctx = new SuperWithoutParenthesesContext(_localctx);
				enterOuterAlt(_localctx, 2);
				{
				setState(1544);
				match(SUPER);
				setState(1546);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,198,_ctx) ) {
				case 1:
					{
					setState(1545);
					argumentList();
					}
					break;
				}
				setState(1549);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,199,_ctx) ) {
				case 1:
					{
					setState(1548);
					block();
					}
					break;
				}
				}
				break;
			case 3:
				_localctx = new IsDefinedExpressionContext(_localctx);
				enterOuterAlt(_localctx, 3);
				{
				setState(1551);
				isDefinedKeyword();
				setState(1552);
				match(LPAREN);
				setState(1553);
				expressionOrCommand(0);
				setState(1554);
				match(RPAREN);
				}
				break;
			case 4:
				_localctx = new IsDefinedCommandContext(_localctx);
				enterOuterAlt(_localctx, 4);
				{
				setState(1556);
				isDefinedKeyword();
				setState(1557);
				primaryValue(0);
				}
				break;
			case 5:
				_localctx = new MethodCallExpressionContext(_localctx);
				enterOuterAlt(_localctx, 5);
				{
				setState(1559);
				methodOnlyIdentifier();
				}
				break;
			case 6:
				_localctx = new MethodCallWithBlockExpressionContext(_localctx);
				enterOuterAlt(_localctx, 6);
				{
				setState(1560);
				methodIdentifier();
				setState(1561);
				block();
				}
				break;
			case 7:
				_localctx = new MethodCallWithParenthesesExpressionContext(_localctx);
				enterOuterAlt(_localctx, 7);
				{
				setState(1563);
				methodIdentifier();
				setState(1564);
				argumentWithParentheses();
				setState(1566);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,200,_ctx) ) {
				case 1:
					{
					setState(1565);
					block();
					}
					break;
				}
				}
				break;
			case 8:
				_localctx = new MethodCallOrVariableReferenceContext(_localctx);
				enterOuterAlt(_localctx, 8);
				{
				setState(1568);
				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, 92, RULE_commandOrPrimaryValueClass);
		try {
			setState(1573);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,202,_ctx) ) {
			case 1:
				_localctx = new CommandCommandOrPrimaryValueClassContext(_localctx);
				enterOuterAlt(_localctx, 1);
				{
				setState(1571);
				command();
				}
				break;
			case 2:
				_localctx = new PrimaryValueCommandOrPrimaryValueClassContext(_localctx);
				enterOuterAlt(_localctx, 2);
				{
				setState(1572);
				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 = 94;
		enterRecursionRule(_localctx, 94, RULE_commandOrPrimaryValue, _p);
		int _la;
		try {
			int _alt;
			enterOuterAlt(_localctx, 1);
			{
			setState(1580);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,203,_ctx) ) {
			case 1:
				{
				_localctx = new PrimaryValueCommandOrPrimaryValueContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;

				setState(1576);
				primaryValue(0);
				}
				break;
			case 2:
				{
				_localctx = new CommandCommandOrPrimaryValueContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(1577);
				command();
				}
				break;
			case 3:
				{
				_localctx = new NotCommandOrPrimaryValueContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(1578);
				match(NOT);
				setState(1579);
				commandOrPrimaryValue(2);
				}
				break;
			}
			_ctx.stop = _input.LT(-1);
			setState(1593);
			_errHandler.sync(this);
			_alt = getInterpreter().adaptivePredict(_input,205,_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(1582);
					if (!(precpred(_ctx, 1))) throw new FailedPredicateException(this, "precpred(_ctx, 1)");
					setState(1583);
					_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(1587);
					_errHandler.sync(this);
					_la = _input.LA(1);
					while (_la==NL) {
						{
						{
						setState(1584);
						match(NL);
						}
						}
						setState(1589);
						_errHandler.sync(this);
						_la = _input.LA(1);
					}
					setState(1590);
					commandOrPrimaryValue(2);
					}
					} 
				}
				setState(1595);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,205,_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, 96, RULE_block);
		int _la;
		try {
			int _alt;
			setState(1610);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case LCURLY:
				_localctx = new CurlyBracesBlockContext(_localctx);
				enterOuterAlt(_localctx, 1);
				{
				setState(1596);
				match(LCURLY);
				setState(1600);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,206,_ctx);
				while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) {
					if ( _alt==1 ) {
						{
						{
						setState(1597);
						match(NL);
						}
						} 
					}
					setState(1602);
					_errHandler.sync(this);
					_alt = getInterpreter().adaptivePredict(_input,206,_ctx);
				}
				setState(1604);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==BAR) {
					{
					setState(1603);
					blockParameter();
					}
				}

				setState(1606);
				compoundStatement();
				setState(1607);
				match(RCURLY);
				}
				break;
			case DO:
				_localctx = new DoBlockBlockContext(_localctx);
				enterOuterAlt(_localctx, 2);
				{
				setState(1609);
				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, 98, RULE_doBlock);
		int _la;
		try {
			int _alt;
			enterOuterAlt(_localctx, 1);
			{
			setState(1612);
			match(DO);
			setState(1616);
			_errHandler.sync(this);
			_alt = getInterpreter().adaptivePredict(_input,209,_ctx);
			while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) {
				if ( _alt==1 ) {
					{
					{
					setState(1613);
					match(NL);
					}
					} 
				}
				setState(1618);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,209,_ctx);
			}
			setState(1620);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==BAR) {
				{
				setState(1619);
				blockParameter();
				}
			}

			setState(1622);
			bodyStatement();
			setState(1623);
			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, 100, RULE_blockParameter);
		int _la;
		try {
			setState(1649);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,214,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(1625);
				match(BAR);
				setState(1629);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==NL) {
					{
					{
					setState(1626);
					match(NL);
					}
					}
					setState(1631);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(1632);
				match(BAR);
				}
				break;
			case 2:
				enterOuterAlt(_localctx, 2);
				{
				setState(1633);
				match(BAR);
				setState(1637);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==NL) {
					{
					{
					setState(1634);
					match(NL);
					}
					}
					setState(1639);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(1640);
				blockParameterList();
				setState(1644);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==NL) {
					{
					{
					setState(1641);
					match(NL);
					}
					}
					setState(1646);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(1647);
				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, 102, RULE_blockParameterList);
		int _la;
		try {
			int _alt;
			setState(1741);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case LPAREN:
			case LOCAL_VARIABLE_IDENTIFIER:
				enterOuterAlt(_localctx, 1);
				{
				setState(1651);
				mandatoryOrOptionalOrGroupedParameterList();
				setState(1660);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,216,_ctx) ) {
				case 1:
					{
					setState(1652);
					match(COMMA);
					setState(1656);
					_errHandler.sync(this);
					_la = _input.LA(1);
					while (_la==NL) {
						{
						{
						setState(1653);
						match(NL);
						}
						}
						setState(1658);
						_errHandler.sync(this);
						_la = _input.LA(1);
					}
					setState(1659);
					arrayParameter();
					}
					break;
				}
				setState(1672);
				_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(1662);
						match(COMMA);
						setState(1666);
						_errHandler.sync(this);
						_la = _input.LA(1);
						while (_la==NL) {
							{
							{
							setState(1663);
							match(NL);
							}
							}
							setState(1668);
							_errHandler.sync(this);
							_la = _input.LA(1);
						}
						setState(1669);
						mandatoryOrGroupedParameterList();
						}
						} 
					}
					setState(1674);
					_errHandler.sync(this);
					_alt = getInterpreter().adaptivePredict(_input,218,_ctx);
				}
				setState(1683);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,220,_ctx) ) {
				case 1:
					{
					setState(1675);
					match(COMMA);
					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);
					hashParameter();
					}
					break;
				}
				setState(1693);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==COMMA) {
					{
					setState(1685);
					match(COMMA);
					setState(1689);
					_errHandler.sync(this);
					_la = _input.LA(1);
					while (_la==NL) {
						{
						{
						setState(1686);
						match(NL);
						}
						}
						setState(1691);
						_errHandler.sync(this);
						_la = _input.LA(1);
					}
					setState(1692);
					procParameter();
					}
				}

				}
				break;
			case STAR:
				enterOuterAlt(_localctx, 2);
				{
				setState(1695);
				arrayParameter();
				setState(1706);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,224,_ctx);
				while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) {
					if ( _alt==1 ) {
						{
						{
						setState(1696);
						match(COMMA);
						setState(1700);
						_errHandler.sync(this);
						_la = _input.LA(1);
						while (_la==NL) {
							{
							{
							setState(1697);
							match(NL);
							}
							}
							setState(1702);
							_errHandler.sync(this);
							_la = _input.LA(1);
						}
						setState(1703);
						mandatoryOrGroupedParameterList();
						}
						} 
					}
					setState(1708);
					_errHandler.sync(this);
					_alt = getInterpreter().adaptivePredict(_input,224,_ctx);
				}
				setState(1717);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,226,_ctx) ) {
				case 1:
					{
					setState(1709);
					match(COMMA);
					setState(1713);
					_errHandler.sync(this);
					_la = _input.LA(1);
					while (_la==NL) {
						{
						{
						setState(1710);
						match(NL);
						}
						}
						setState(1715);
						_errHandler.sync(this);
						_la = _input.LA(1);
					}
					setState(1716);
					hashParameter();
					}
					break;
				}
				setState(1727);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==COMMA) {
					{
					setState(1719);
					match(COMMA);
					setState(1723);
					_errHandler.sync(this);
					_la = _input.LA(1);
					while (_la==NL) {
						{
						{
						setState(1720);
						match(NL);
						}
						}
						setState(1725);
						_errHandler.sync(this);
						_la = _input.LA(1);
					}
					setState(1726);
					procParameter();
					}
				}

				}
				break;
			case STAR2:
				enterOuterAlt(_localctx, 3);
				{
				setState(1729);
				hashParameter();
				setState(1738);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==COMMA) {
					{
					setState(1730);
					match(COMMA);
					setState(1734);
					_errHandler.sync(this);
					_la = _input.LA(1);
					while (_la==NL) {
						{
						{
						setState(1731);
						match(NL);
						}
						}
						setState(1736);
						_errHandler.sync(this);
						_la = _input.LA(1);
					}
					setState(1737);
					procParameter();
					}
				}

				}
				break;
			case AMP:
				enterOuterAlt(_localctx, 4);
				{
				setState(1740);
				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, 104, RULE_mandatoryOrOptionalOrGroupedParameterList);
		int _la;
		try {
			int _alt;
			enterOuterAlt(_localctx, 1);
			{
			setState(1743);
			mandatoryOrOptionalOrGroupedParameter();
			setState(1754);
			_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(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);
					mandatoryOrOptionalOrGroupedParameter();
					}
					} 
				}
				setState(1756);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,233,_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, 106, RULE_mandatoryOrOptionalOrGroupedParameter);
		try {
			setState(1760);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,234,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(1757);
				mandatoryParameter();
				}
				break;
			case 2:
				enterOuterAlt(_localctx, 2);
				{
				setState(1758);
				optionalParameter();
				}
				break;
			case 3:
				enterOuterAlt(_localctx, 3);
				{
				setState(1759);
				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, 108, RULE_mandatoryOrGroupedParameterList);
		int _la;
		try {
			int _alt;
			enterOuterAlt(_localctx, 1);
			{
			setState(1762);
			mandatoryOrGroupedParameter();
			setState(1773);
			_errHandler.sync(this);
			_alt = getInterpreter().adaptivePredict(_input,236,_ctx);
			while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) {
				if ( _alt==1 ) {
					{
					{
					setState(1763);
					match(COMMA);
					setState(1767);
					_errHandler.sync(this);
					_la = _input.LA(1);
					while (_la==NL) {
						{
						{
						setState(1764);
						match(NL);
						}
						}
						setState(1769);
						_errHandler.sync(this);
						_la = _input.LA(1);
					}
					setState(1770);
					mandatoryOrGroupedParameter();
					}
					} 
				}
				setState(1775);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,236,_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, 110, RULE_mandatoryOrGroupedParameter);
		try {
			setState(1778);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case LOCAL_VARIABLE_IDENTIFIER:
				enterOuterAlt(_localctx, 1);
				{
				setState(1776);
				mandatoryParameter();
				}
				break;
			case LPAREN:
				enterOuterAlt(_localctx, 2);
				{
				setState(1777);
				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, 112, RULE_groupedParameterList);
		int _la;
		try {
			setState(1824);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,244,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(1780);
				match(LPAREN);
				setState(1781);
				mandatoryParameter();
				setState(1790);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,239,_ctx) ) {
				case 1:
					{
					setState(1782);
					match(COMMA);
					setState(1786);
					_errHandler.sync(this);
					_la = _input.LA(1);
					while (_la==NL) {
						{
						{
						setState(1783);
						match(NL);
						}
						}
						setState(1788);
						_errHandler.sync(this);
						_la = _input.LA(1);
					}
					setState(1789);
					arrayParameter();
					}
					break;
				}
				setState(1802);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==COMMA) {
					{
					{
					setState(1792);
					match(COMMA);
					setState(1796);
					_errHandler.sync(this);
					_la = _input.LA(1);
					while (_la==NL) {
						{
						{
						setState(1793);
						match(NL);
						}
						}
						setState(1798);
						_errHandler.sync(this);
						_la = _input.LA(1);
					}
					setState(1799);
					mandatoryParameter();
					}
					}
					setState(1804);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(1805);
				match(RPAREN);
				}
				break;
			case 2:
				enterOuterAlt(_localctx, 2);
				{
				setState(1807);
				match(LPAREN);
				setState(1808);
				arrayParameter();
				setState(1819);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==COMMA) {
					{
					{
					setState(1809);
					match(COMMA);
					setState(1813);
					_errHandler.sync(this);
					_la = _input.LA(1);
					while (_la==NL) {
						{
						{
						setState(1810);
						match(NL);
						}
						}
						setState(1815);
						_errHandler.sync(this);
						_la = _input.LA(1);
					}
					setState(1816);
					mandatoryParameter();
					}
					}
					setState(1821);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(1822);
				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, 114, RULE_thenClause);
		int _la;
		try {
			int _alt;
			setState(1837);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,247,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(1827); 
				_errHandler.sync(this);
				_alt = 1;
				do {
					switch (_alt) {
					case 1:
						{
						{
						setState(1826);
						_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(1829); 
					_errHandler.sync(this);
					_alt = getInterpreter().adaptivePredict(_input,245,_ctx);
				} while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER );
				setState(1831);
				compoundStatement();
				}
				break;
			case 2:
				enterOuterAlt(_localctx, 2);
				{
				setState(1833);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==SEMI || _la==NL) {
					{
					setState(1832);
					_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(1835);
				match(THEN);
				setState(1836);
				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, 116, RULE_elseClause);
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(1839);
			match(ELSE);
			setState(1840);
			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, 118, RULE_elsifClause);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(1842);
			match(ELSIF);
			setState(1846);
			_errHandler.sync(this);
			_la = _input.LA(1);
			while (_la==NL) {
				{
				{
				setState(1843);
				match(NL);
				}
				}
				setState(1848);
				_errHandler.sync(this);
				_la = _input.LA(1);
			}
			setState(1849);
			expressionOrCommand(0);
			setState(1850);
			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, 120, RULE_whenClause);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(1852);
			match(WHEN);
			setState(1856);
			_errHandler.sync(this);
			_la = _input.LA(1);
			while (_la==NL) {
				{
				{
				setState(1853);
				match(NL);
				}
				}
				setState(1858);
				_errHandler.sync(this);
				_la = _input.LA(1);
			}
			setState(1859);
			whenArgument();
			setState(1860);
			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, 122, RULE_whenArgument);
		int _la;
		try {
			setState(1868);
			_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(1862);
				operatorExpressionList();
				setState(1865);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==COMMA) {
					{
					setState(1863);
					match(COMMA);
					setState(1864);
					splattingArgument();
					}
				}

				}
				break;
			case STAR:
			case STAR2:
				enterOuterAlt(_localctx, 2);
				{
				setState(1867);
				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, 124, RULE_doClause);
		int _la;
		try {
			int _alt;
			setState(1878);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case SEMI:
			case NL:
				enterOuterAlt(_localctx, 1);
				{
				setState(1871); 
				_errHandler.sync(this);
				_alt = 1;
				do {
					switch (_alt) {
					case 1:
						{
						{
						setState(1870);
						_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(1873); 
					_errHandler.sync(this);
					_alt = getInterpreter().adaptivePredict(_input,252,_ctx);
				} while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER );
				setState(1875);
				compoundStatement();
				}
				break;
			case DO:
				enterOuterAlt(_localctx, 2);
				{
				setState(1876);
				match(DO);
				setState(1877);
				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, 126, RULE_forVariable);
		try {
			setState(1882);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,254,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(1880);
				leftHandSide();
				}
				break;
			case 2:
				enterOuterAlt(_localctx, 2);
				{
				setState(1881);
				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, 128, RULE_bodyStatement);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(1884);
			compoundStatement();
			setState(1888);
			_errHandler.sync(this);
			_la = _input.LA(1);
			while (_la==RESCUE) {
				{
				{
				setState(1885);
				rescueClause();
				}
				}
				setState(1890);
				_errHandler.sync(this);
				_la = _input.LA(1);
			}
			setState(1892);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==ELSE) {
				{
				setState(1891);
				elseClause();
				}
			}

			setState(1895);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==ENSURE) {
				{
				setState(1894);
				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, 130, RULE_rescueClause);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(1897);
			match(RESCUE);
			setState(1899);
			_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(1898);
				exceptionClassList();
				}
			}

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

			setState(1904);
			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, 132, RULE_exceptionClassList);
		try {
			setState(1908);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,260,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(1906);
				operatorExpression(0);
				}
				break;
			case 2:
				enterOuterAlt(_localctx, 2);
				{
				setState(1907);
				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, 134, RULE_exceptionVariableAssignment);
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(1910);
			match(EQGT);
			setState(1911);
			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, 136, RULE_ensureClause);
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(1913);
			match(ENSURE);
			setState(1914);
			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, 138, RULE_definedMethodName);
		try {
			setState(1927);
			_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(1916);
				methodName();
				}
				break;
			case ASSIGNMENT_LIKE_METHOD_IDENTIFIER:
				enterOuterAlt(_localctx, 2);
				{
				setState(1917);
				match(ASSIGNMENT_LIKE_METHOD_IDENTIFIER);
				}
				break;
			case LBRACK:
				enterOuterAlt(_localctx, 3);
				{
				setState(1918);
				match(LBRACK);
				setState(1919);
				match(RBRACK);
				setState(1921);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,261,_ctx) ) {
				case 1:
					{
					setState(1920);
					match(EQ);
					}
					break;
				}
				}
				break;
			case EQ2:
				enterOuterAlt(_localctx, 4);
				{
				setState(1923);
				match(EQ2);
				}
				break;
			case EQ3:
				enterOuterAlt(_localctx, 5);
				{
				setState(1924);
				match(EQ3);
				}
				break;
			case LTEQGT:
				enterOuterAlt(_localctx, 6);
				{
				setState(1925);
				match(LTEQGT);
				}
				break;
			case LT2:
				enterOuterAlt(_localctx, 7);
				{
				setState(1926);
				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, 140, RULE_methodParameterPart);
		int _la;
		try {
			int _alt;
			setState(1950);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case LPAREN:
				enterOuterAlt(_localctx, 1);
				{
				setState(1929);
				match(LPAREN);
				setState(1933);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,263,_ctx);
				while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) {
					if ( _alt==1 ) {
						{
						{
						setState(1930);
						match(NL);
						}
						} 
					}
					setState(1935);
					_errHandler.sync(this);
					_alt = getInterpreter().adaptivePredict(_input,263,_ctx);
				}
				setState(1937);
				_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(1936);
					parameterList();
					}
				}

				setState(1942);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==NL) {
					{
					{
					setState(1939);
					match(NL);
					}
					}
					setState(1944);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(1945);
				match(RPAREN);
				}
				break;
			case SEMI:
			case AMP:
			case STAR:
			case STAR2:
			case NL:
			case LOCAL_VARIABLE_IDENTIFIER:
				enterOuterAlt(_localctx, 2);
				{
				setState(1947);
				_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(1946);
					parameterList();
					}
				}

				setState(1949);
				_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, 142, RULE_parameterList);
		int _la;
		try {
			setState(2036);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case LOCAL_VARIABLE_IDENTIFIER:
				enterOuterAlt(_localctx, 1);
				{
				setState(1952);
				mandatoryOrOptionalParameterList();
				setState(1961);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,269,_ctx) ) {
				case 1:
					{
					setState(1953);
					match(COMMA);
					setState(1957);
					_errHandler.sync(this);
					_la = _input.LA(1);
					while (_la==NL) {
						{
						{
						setState(1954);
						match(NL);
						}
						}
						setState(1959);
						_errHandler.sync(this);
						_la = _input.LA(1);
					}
					setState(1960);
					arrayParameter();
					}
					break;
				}
				setState(1971);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,271,_ctx) ) {
				case 1:
					{
					setState(1963);
					match(COMMA);
					setState(1967);
					_errHandler.sync(this);
					_la = _input.LA(1);
					while (_la==NL) {
						{
						{
						setState(1964);
						match(NL);
						}
						}
						setState(1969);
						_errHandler.sync(this);
						_la = _input.LA(1);
					}
					setState(1970);
					mandatoryParameterList();
					}
					break;
				}
				setState(1981);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,273,_ctx) ) {
				case 1:
					{
					setState(1973);
					match(COMMA);
					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);
					hashParameter();
					}
					break;
				}
				setState(1991);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==COMMA) {
					{
					setState(1983);
					match(COMMA);
					setState(1987);
					_errHandler.sync(this);
					_la = _input.LA(1);
					while (_la==NL) {
						{
						{
						setState(1984);
						match(NL);
						}
						}
						setState(1989);
						_errHandler.sync(this);
						_la = _input.LA(1);
					}
					setState(1990);
					procParameter();
					}
				}

				}
				break;
			case STAR:
				enterOuterAlt(_localctx, 2);
				{
				setState(1993);
				arrayParameter();
				setState(2002);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,277,_ctx) ) {
				case 1:
					{
					setState(1994);
					match(COMMA);
					setState(1998);
					_errHandler.sync(this);
					_la = _input.LA(1);
					while (_la==NL) {
						{
						{
						setState(1995);
						match(NL);
						}
						}
						setState(2000);
						_errHandler.sync(this);
						_la = _input.LA(1);
					}
					setState(2001);
					mandatoryParameterList();
					}
					break;
				}
				setState(2012);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,279,_ctx) ) {
				case 1:
					{
					setState(2004);
					match(COMMA);
					setState(2008);
					_errHandler.sync(this);
					_la = _input.LA(1);
					while (_la==NL) {
						{
						{
						setState(2005);
						match(NL);
						}
						}
						setState(2010);
						_errHandler.sync(this);
						_la = _input.LA(1);
					}
					setState(2011);
					hashParameter();
					}
					break;
				}
				setState(2022);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==COMMA) {
					{
					setState(2014);
					match(COMMA);
					setState(2018);
					_errHandler.sync(this);
					_la = _input.LA(1);
					while (_la==NL) {
						{
						{
						setState(2015);
						match(NL);
						}
						}
						setState(2020);
						_errHandler.sync(this);
						_la = _input.LA(1);
					}
					setState(2021);
					procParameter();
					}
				}

				}
				break;
			case STAR2:
				enterOuterAlt(_localctx, 3);
				{
				setState(2024);
				hashParameter();
				setState(2033);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==COMMA) {
					{
					setState(2025);
					match(COMMA);
					setState(2029);
					_errHandler.sync(this);
					_la = _input.LA(1);
					while (_la==NL) {
						{
						{
						setState(2026);
						match(NL);
						}
						}
						setState(2031);
						_errHandler.sync(this);
						_la = _input.LA(1);
					}
					setState(2032);
					procParameter();
					}
				}

				}
				break;
			case AMP:
				enterOuterAlt(_localctx, 4);
				{
				setState(2035);
				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, 144, RULE_mandatoryOrOptionalParameterList);
		int _la;
		try {
			int _alt;
			enterOuterAlt(_localctx, 1);
			{
			setState(2038);
			mandatoryOrOptionalParameter();
			setState(2049);
			_errHandler.sync(this);
			_alt = getInterpreter().adaptivePredict(_input,286,_ctx);
			while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) {
				if ( _alt==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);
					mandatoryOrOptionalParameter();
					}
					} 
				}
				setState(2051);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,286,_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, 146, RULE_mandatoryParameterList);
		int _la;
		try {
			int _alt;
			enterOuterAlt(_localctx, 1);
			{
			setState(2052);
			mandatoryParameter();
			setState(2063);
			_errHandler.sync(this);
			_alt = getInterpreter().adaptivePredict(_input,288,_ctx);
			while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) {
				if ( _alt==1 ) {
					{
					{
					setState(2053);
					match(COMMA);
					setState(2057);
					_errHandler.sync(this);
					_la = _input.LA(1);
					while (_la==NL) {
						{
						{
						setState(2054);
						match(NL);
						}
						}
						setState(2059);
						_errHandler.sync(this);
						_la = _input.LA(1);
					}
					setState(2060);
					mandatoryParameter();
					}
					} 
				}
				setState(2065);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,288,_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, 148, RULE_mandatoryOrOptionalParameter);
		try {
			setState(2068);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,289,_ctx) ) {
			case 1:
				_localctx = new MandatoryMandatoryOrOptionalParameterContext(_localctx);
				enterOuterAlt(_localctx, 1);
				{
				setState(2066);
				mandatoryParameter();
				}
				break;
			case 2:
				_localctx = new OptionalMandatoryOrOptionalParameterContext(_localctx);
				enterOuterAlt(_localctx, 2);
				{
				setState(2067);
				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, 150, RULE_mandatoryParameter);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(2070);
			match(LOCAL_VARIABLE_IDENTIFIER);
			setState(2072);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==COLON) {
				{
				setState(2071);
				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, 152, RULE_optionalParameter);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(2074);
			optionalParameterName();
			setState(2075);
			_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(2079);
			_errHandler.sync(this);
			_la = _input.LA(1);
			while (_la==NL) {
				{
				{
				setState(2076);
				match(NL);
				}
				}
				setState(2081);
				_errHandler.sync(this);
				_la = _input.LA(1);
			}
			setState(2082);
			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, 154, RULE_optionalParameterName);
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(2084);
			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, 156, RULE_arrayParameter);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(2086);
			match(STAR);
			setState(2088);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==LOCAL_VARIABLE_IDENTIFIER) {
				{
				setState(2087);
				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, 158, RULE_hashParameter);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(2090);
			match(STAR2);
			setState(2092);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==LOCAL_VARIABLE_IDENTIFIER) {
				{
				setState(2091);
				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, 160, RULE_procParameter);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(2094);
			match(AMP);
			setState(2096);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==LOCAL_VARIABLE_IDENTIFIER) {
				{
				setState(2095);
				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, 162, RULE_procParameterName);
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(2098);
			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 = 164;
		enterRecursionRule(_localctx, 164, RULE_classPath, _p);
		try {
			int _alt;
			enterOuterAlt(_localctx, 1);
			{
			setState(2104);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case COLON2:
				{
				_localctx = new TopClassPathContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;

				setState(2101);
				match(COLON2);
				setState(2102);
				match(CONSTANT_IDENTIFIER);
				}
				break;
			case CONSTANT_IDENTIFIER:
				{
				_localctx = new ClassNameContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(2103);
				match(CONSTANT_IDENTIFIER);
				}
				break;
			default:
				throw new NoViableAltException(this);
			}
			_ctx.stop = _input.LT(-1);
			setState(2111);
			_errHandler.sync(this);
			_alt = getInterpreter().adaptivePredict(_input,296,_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(2106);
					if (!(precpred(_ctx, 1))) throw new FailedPredicateException(this, "precpred(_ctx, 1)");
					setState(2107);
					match(COLON2);
					setState(2108);
					match(CONSTANT_IDENTIFIER);
					}
					} 
				}
				setState(2113);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,296,_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, 166, RULE_singletonObject);
		try {
			setState(2119);
			_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(2114);
				variableReference();
				}
				break;
			case LPAREN:
				_localctx = new ExpressionSingletonObjectContext(_localctx);
				enterOuterAlt(_localctx, 2);
				{
				setState(2115);
				match(LPAREN);
				setState(2116);
				expressionOrCommand(0);
				setState(2117);
				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, 168, RULE_variableReference);
		try {
			setState(2125);
			_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(2121);
				variable();
				}
				break;
			case LINE__:
			case ENCODING__:
			case FILE__:
			case FALSE:
			case NIL:
			case SELF:
			case TRUE:
				_localctx = new PseudoVariableVariableReferenceContext(_localctx);
				enterOuterAlt(_localctx, 2);
				{
				setState(2122);
				pseudoVariable();
				}
				break;
			case COLON2:
				_localctx = new ConstantVariableReferenceContext(_localctx);
				enterOuterAlt(_localctx, 3);
				{
				setState(2123);
				match(COLON2);
				setState(2124);
				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, 170, RULE_associationList);
		int _la;
		try {
			int _alt;
			enterOuterAlt(_localctx, 1);
			{
			setState(2127);
			association();
			setState(2138);
			_errHandler.sync(this);
			_alt = getInterpreter().adaptivePredict(_input,300,_ctx);
			while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) {
				if ( _alt==1 ) {
					{
					{
					setState(2128);
					match(COMMA);
					setState(2132);
					_errHandler.sync(this);
					_la = _input.LA(1);
					while (_la==NL) {
						{
						{
						setState(2129);
						match(NL);
						}
						}
						setState(2134);
						_errHandler.sync(this);
						_la = _input.LA(1);
					}
					setState(2135);
					association();
					}
					} 
				}
				setState(2140);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,300,_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, 172, RULE_association);
		int _la;
		try {
			setState(2152);
			_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(2141);
				associationKey();
				setState(2142);
				_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(2146);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==NL) {
					{
					{
					setState(2143);
					match(NL);
					}
					}
					setState(2148);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(2149);
				operatorExpression(0);
				}
				break;
			case STAR2:
				_localctx = new AssociationHashArgContext(_localctx);
				enterOuterAlt(_localctx, 2);
				{
				setState(2151);
				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, 174, RULE_associationKey);
		try {
			setState(2156);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,303,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(2154);
				operatorExpression(0);
				}
				break;
			case 2:
				enterOuterAlt(_localctx, 2);
				{
				setState(2155);
				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, 176, RULE_associationHashArgument);
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(2158);
			match(STAR2);
			setState(2165);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,304,_ctx) ) {
			case 1:
				{
				setState(2159);
				match(LOCAL_VARIABLE_IDENTIFIER);
				}
				break;
			case 2:
				{
				setState(2160);
				methodCallsWithParentheses();
				}
				break;
			case 3:
				{
				{
				setState(2161);
				match(LPAREN);
				setState(2162);
				methodInvocationWithoutParentheses();
				setState(2163);
				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, 178, RULE_regexpLiteralContent);
		try {
			setState(2172);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case REGULAR_EXPRESSION_BODY:
				enterOuterAlt(_localctx, 1);
				{
				setState(2167);
				match(REGULAR_EXPRESSION_BODY);
				}
				break;
			case REGULAR_EXPRESSION_INTERPOLATION_BEGIN:
				enterOuterAlt(_localctx, 2);
				{
				setState(2168);
				match(REGULAR_EXPRESSION_INTERPOLATION_BEGIN);
				setState(2169);
				compoundStatement();
				setState(2170);
				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, 180, RULE_singleQuotedString);
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(2174);
			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, 182, RULE_singleOrDoubleQuotedString);
		try {
			setState(2178);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case SINGLE_QUOTED_STRING_LITERAL:
				enterOuterAlt(_localctx, 1);
				{
				setState(2176);
				singleQuotedString();
				}
				break;
			case DOUBLE_QUOTED_STRING_START:
				enterOuterAlt(_localctx, 2);
				{
				setState(2177);
				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, 184, RULE_doubleQuotedString);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(2180);
			match(DOUBLE_QUOTED_STRING_START);
			setState(2184);
			_errHandler.sync(this);
			_la = _input.LA(1);
			while (_la==DOUBLE_QUOTED_STRING_CHARACTER_SEQUENCE || _la==STRING_INTERPOLATION_BEGIN) {
				{
				{
				setState(2181);
				doubleQuotedStringContent();
				}
				}
				setState(2186);
				_errHandler.sync(this);
				_la = _input.LA(1);
			}
			setState(2187);
			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, 186, RULE_quotedExpandedExternalCommandString);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(2189);
			match(QUOTED_EXPANDED_EXTERNAL_COMMAND_LITERAL_START);
			setState(2193);
			_errHandler.sync(this);
			_la = _input.LA(1);
			while (_la==EXPANDED_LITERAL_CHARACTER_SEQUENCE || _la==DELIMITED_STRING_INTERPOLATION_BEGIN) {
				{
				{
				setState(2190);
				quotedExpandedLiteralStringContent();
				}
				}
				setState(2195);
				_errHandler.sync(this);
				_la = _input.LA(1);
			}
			setState(2196);
			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, 188, RULE_doubleQuotedStringContent);
		try {
			setState(2203);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case DOUBLE_QUOTED_STRING_CHARACTER_SEQUENCE:
				enterOuterAlt(_localctx, 1);
				{
				setState(2198);
				match(DOUBLE_QUOTED_STRING_CHARACTER_SEQUENCE);
				}
				break;
			case STRING_INTERPOLATION_BEGIN:
				enterOuterAlt(_localctx, 2);
				{
				setState(2199);
				match(STRING_INTERPOLATION_BEGIN);
				setState(2200);
				compoundStatement();
				setState(2201);
				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, 190, RULE_quotedNonExpandedLiteralString);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(2205);
			match(QUOTED_NON_EXPANDED_STRING_LITERAL_START);
			setState(2207);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==NON_EXPANDED_LITERAL_CHARACTER_SEQUENCE) {
				{
				setState(2206);
				match(NON_EXPANDED_LITERAL_CHARACTER_SEQUENCE);
				}
			}

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