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

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

				setState(269);
				expressionOrCommand(0);
				}
				break;
			case 2:
				{
				_localctx = new AliasStatementContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(270);
				match(ALIAS);
				setState(274);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==NL) {
					{
					{
					setState(271);
					match(NL);
					}
					}
					setState(276);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(277);
				((AliasStatementContext)_localctx).oldName = definedMethodNameOrSymbol();
				setState(278);
				((AliasStatementContext)_localctx).newName = definedMethodNameOrSymbol();
				}
				break;
			case 3:
				{
				_localctx = new UndefStatementContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(280);
				match(UNDEF);
				setState(284);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==NL) {
					{
					{
					setState(281);
					match(NL);
					}
					}
					setState(286);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(287);
				definedMethodNameOrSymbol();
				setState(298);
				_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(288);
						match(COMMA);
						setState(292);
						_errHandler.sync(this);
						_la = _input.LA(1);
						while (_la==NL) {
							{
							{
							setState(289);
							match(NL);
							}
							}
							setState(294);
							_errHandler.sync(this);
							_la = _input.LA(1);
						}
						setState(295);
						definedMethodNameOrSymbol();
						}
						} 
					}
					setState(300);
					_errHandler.sync(this);
					_alt = getInterpreter().adaptivePredict(_input,8,_ctx);
				}
				}
				break;
			case 4:
				{
				_localctx = new SingleAssignmentStatementStatementContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(301);
				singleAssignmentStatement();
				}
				break;
			case 5:
				{
				_localctx = new MultipleAssignmentStatementStatementContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(302);
				multipleAssignmentStatement();
				}
				break;
			}
			_ctx.stop = _input.LT(-1);
			setState(317);
			_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(305);
					if (!(precpred(_ctx, 3))) throw new FailedPredicateException(this, "precpred(_ctx, 3)");
					setState(306);
					statementModifier();
					setState(310);
					_errHandler.sync(this);
					_la = _input.LA(1);
					while (_la==NL) {
						{
						{
						setState(307);
						match(NL);
						}
						}
						setState(312);
						_errHandler.sync(this);
						_la = _input.LA(1);
					}
					setState(313);
					expressionOrCommand(0);
					}
					} 
				}
				setState(319);
				_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(322);
			_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(320);
				definedMethodName();
				}
				break;
			case COLON:
			case SYMBOL_LITERAL:
				enterOuterAlt(_localctx, 2);
				{
				setState(321);
				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(372);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,18,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(324);
				variable();
				setState(325);
				assignmentOperator();
				setState(329);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==NL) {
					{
					{
					setState(326);
					match(NL);
					}
					}
					setState(331);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(332);
				methodInvocationWithoutParentheses();
				}
				break;
			case 2:
				enterOuterAlt(_localctx, 2);
				{
				setState(334);
				match(COLON2);
				setState(335);
				match(CONSTANT_IDENTIFIER);
				setState(336);
				assignmentOperator();
				setState(340);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==NL) {
					{
					{
					setState(337);
					match(NL);
					}
					}
					setState(342);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(343);
				methodInvocationWithoutParentheses();
				}
				break;
			case 3:
				enterOuterAlt(_localctx, 3);
				{
				setState(345);
				primary();
				setState(346);
				match(LBRACK);
				setState(348);
				_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(347);
					indexingArgumentList();
					}
				}

				setState(350);
				match(RBRACK);
				setState(351);
				assignmentOperator();
				setState(355);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==NL) {
					{
					{
					setState(352);
					match(NL);
					}
					}
					setState(357);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(358);
				methodInvocationWithoutParentheses();
				}
				break;
			case 4:
				enterOuterAlt(_localctx, 4);
				{
				setState(360);
				primary();
				setState(361);
				_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(362);
				methodName();
				setState(363);
				assignmentOperator();
				setState(367);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==NL) {
					{
					{
					setState(364);
					match(NL);
					}
					}
					setState(369);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(370);
				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(418);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,25,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(374);
				leftHandSide();
				setState(375);
				match(EQ);
				setState(379);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==NL) {
					{
					{
					setState(376);
					match(NL);
					}
					}
					setState(381);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(382);
				multipleRightHandSide();
				}
				break;
			case 2:
				enterOuterAlt(_localctx, 2);
				{
				setState(384);
				packingLeftHandSide();
				setState(385);
				match(EQ);
				setState(389);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==NL) {
					{
					{
					setState(386);
					match(NL);
					}
					}
					setState(391);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(394);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,21,_ctx) ) {
				case 1:
					{
					setState(392);
					methodInvocationWithoutParentheses();
					}
					break;
				case 2:
					{
					setState(393);
					operatorExpression(0);
					}
					break;
				}
				}
				break;
			case 3:
				enterOuterAlt(_localctx, 3);
				{
				setState(396);
				multipleLeftHandSide();
				setState(397);
				match(EQ);
				setState(401);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==NL) {
					{
					{
					setState(398);
					match(NL);
					}
					}
					setState(403);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(404);
				multipleRightHandSide();
				}
				break;
			case 4:
				enterOuterAlt(_localctx, 4);
				{
				setState(406);
				multipleLeftHandSideExceptPacking();
				setState(407);
				match(EQ);
				setState(411);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==NL) {
					{
					{
					setState(408);
					match(NL);
					}
					}
					setState(413);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(416);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,24,_ctx) ) {
				case 1:
					{
					setState(414);
					methodInvocationWithoutParentheses();
					}
					break;
				case 2:
					{
					setState(415);
					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(438);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,28,_ctx) ) {
			case 1:
				_localctx = new VariableLeftHandSideContext(_localctx);
				enterOuterAlt(_localctx, 1);
				{
				setState(420);
				variable();
				setState(423);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,26,_ctx) ) {
				case 1:
					{
					setState(421);
					match(EQ);
					setState(422);
					primary();
					}
					break;
				}
				}
				break;
			case 2:
				_localctx = new IndexingLeftHandSideContext(_localctx);
				enterOuterAlt(_localctx, 2);
				{
				setState(425);
				primary();
				setState(426);
				match(LBRACK);
				setState(428);
				_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(427);
					indexingArgumentList();
					}
				}

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

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

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

					setState(466);
					_errHandler.sync(this);
					_la = _input.LA(1);
					while (_la==NL) {
						{
						{
						setState(463);
						match(NL);
						}
						}
						setState(468);
						_errHandler.sync(this);
						_la = _input.LA(1);
					}
					setState(469);
					procParameter();
					}
					break;
				}
				setState(473);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==COMMA) {
					{
					setState(472);
					match(COMMA);
					}
				}

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

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

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

			setState(510);
			_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(506);
					match(COMMA);
					setState(507);
					multipleLeftHandSideItem();
					}
					} 
				}
				setState(512);
				_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(513);
			match(LPAREN);
			setState(514);
			multipleLeftHandSide();
			setState(515);
			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(519);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,45,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(517);
				leftHandSide();
				}
				break;
			case 2:
				enterOuterAlt(_localctx, 2);
				{
				setState(518);
				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(523);
			_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(521);
				operatorExpressionList();
				}
				break;
			case STAR:
			case STAR2:
				{
				setState(522);
				splattingRightHandSide();
				}
				break;
			default:
				throw new NoViableAltException(this);
			}
			setState(532);
			_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(525);
					match(COMMA);
					setState(528);
					_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(526);
						operatorExpressionList();
						}
						break;
					case STAR:
					case STAR2:
						{
						setState(527);
						splattingRightHandSide();
						}
						break;
					default:
						throw new NoViableAltException(this);
					}
					}
					} 
				}
				setState(534);
				_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(535);
			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(540);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,49,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(537);
				match(LOCAL_VARIABLE_IDENTIFIER);
				}
				break;
			case 2:
				enterOuterAlt(_localctx, 2);
				{
				setState(538);
				match(CONSTANT_IDENTIFIER);
				}
				break;
			case 3:
				enterOuterAlt(_localctx, 3);
				{
				setState(539);
				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(545);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,50,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(542);
				methodIdentifier();
				}
				break;
			case 2:
				enterOuterAlt(_localctx, 2);
				{
				setState(543);
				keyword();
				}
				break;
			case 3:
				enterOuterAlt(_localctx, 3);
				{
				setState(544);
				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(550);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case CONSTANT_IDENTIFIER:
				{
				setState(547);
				match(CONSTANT_IDENTIFIER);
				}
				break;
			case LOCAL_VARIABLE_IDENTIFIER:
				{
				setState(548);
				match(LOCAL_VARIABLE_IDENTIFIER);
				}
				break;
			case LINE__:
			case ENCODING__:
			case FILE__:
			case FALSE:
			case NIL:
			case SELF:
			case TRUE:
				{
				setState(549);
				pseudoVariable();
				}
				break;
			default:
				throw new NoViableAltException(this);
			}
			setState(552);
			_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(570);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,53,_ctx) ) {
			case 1:
				_localctx = new CommandMethodInvocationWithoutParenthesesContext(_localctx);
				enterOuterAlt(_localctx, 1);
				{
				setState(554);
				command();
				}
				break;
			case 2:
				_localctx = new ChainedMethodInvocationWithoutParenthesesContext(_localctx);
				enterOuterAlt(_localctx, 2);
				{
				setState(555);
				chainedCommandWithDoBlock();
				setState(560);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,52,_ctx) ) {
				case 1:
					{
					setState(556);
					_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(557);
					methodName();
					setState(558);
					commandArgumentList();
					}
					break;
				}
				}
				break;
			case 3:
				_localctx = new ReturnMethodInvocationWithoutParenthesesContext(_localctx);
				enterOuterAlt(_localctx, 3);
				{
				setState(562);
				match(RETURN);
				setState(563);
				primaryValueListWithAssociation();
				}
				break;
			case 4:
				_localctx = new BreakMethodInvocationWithoutParenthesesContext(_localctx);
				enterOuterAlt(_localctx, 4);
				{
				setState(564);
				match(BREAK);
				setState(565);
				primaryValueList();
				}
				break;
			case 5:
				_localctx = new NextMethodInvocationWithoutParenthesesContext(_localctx);
				enterOuterAlt(_localctx, 5);
				{
				setState(566);
				match(NEXT);
				setState(567);
				primaryValueList();
				}
				break;
			case 6:
				_localctx = new YieldMethodInvocationWithoutParenthesesContext(_localctx);
				enterOuterAlt(_localctx, 6);
				{
				setState(568);
				match(YIELD);
				setState(569);
				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(607);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,58,_ctx) ) {
			case 1:
				_localctx = new CommandTernaryOperatorExpressionContext(_localctx);
				enterOuterAlt(_localctx, 1);
				{
				setState(572);
				operatorExpression(0);
				setState(573);
				match(QMARK);
				setState(577);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==NL) {
					{
					{
					setState(574);
					match(NL);
					}
					}
					setState(579);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(580);
				operatorExpression(0);
				setState(584);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==NL) {
					{
					{
					setState(581);
					match(NL);
					}
					}
					setState(586);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(587);
				match(COLON);
				setState(591);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==NL) {
					{
					{
					setState(588);
					match(NL);
					}
					}
					setState(593);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(594);
				operatorExpression(0);
				}
				break;
			case 2:
				_localctx = new MemberAccessCommandContext(_localctx);
				enterOuterAlt(_localctx, 2);
				{
				setState(596);
				primary();
				setState(598);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==NL) {
					{
					setState(597);
					match(NL);
					}
				}

				setState(600);
				_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(601);
				methodName();
				setState(602);
				commandArgument();
				}
				break;
			case 3:
				_localctx = new SimpleCommandContext(_localctx);
				enterOuterAlt(_localctx, 3);
				{
				setState(604);
				methodIdentifier();
				setState(605);
				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(611);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,59,_ctx) ) {
			case 1:
				_localctx = new CommandArgumentCommandArgumentListContext(_localctx);
				enterOuterAlt(_localctx, 1);
				{
				setState(609);
				commandArgumentList();
				}
				break;
			case 2:
				_localctx = new CommandCommandArgumentListContext(_localctx);
				enterOuterAlt(_localctx, 2);
				{
				setState(610);
				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(613);
			commandWithDoBlock();
			setState(617);
			_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(614);
					chainedMethodInvocation();
					}
					} 
				}
				setState(619);
				_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(620);
			_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(621);
			methodName();
			setState(623);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,61,_ctx) ) {
			case 1:
				{
				setState(622);
				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(639);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,62,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(625);
				match(SUPER);
				setState(626);
				argumentList();
				setState(627);
				doBlock();
				}
				break;
			case 2:
				enterOuterAlt(_localctx, 2);
				{
				setState(629);
				methodIdentifier();
				setState(630);
				argumentList();
				setState(631);
				doBlock();
				}
				break;
			case 3:
				enterOuterAlt(_localctx, 3);
				{
				setState(633);
				primary();
				setState(634);
				_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(635);
				methodName();
				setState(636);
				argumentList();
				setState(637);
				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(641);
			bracketedArrayElement();
			setState(654);
			_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(643);
					_errHandler.sync(this);
					_la = _input.LA(1);
					if (_la==COMMA) {
						{
						setState(642);
						match(COMMA);
						}
					}

					setState(648);
					_errHandler.sync(this);
					_la = _input.LA(1);
					while (_la==NL) {
						{
						{
						setState(645);
						match(NL);
						}
						}
						setState(650);
						_errHandler.sync(this);
						_la = _input.LA(1);
					}
					setState(651);
					bracketedArrayElement();
					}
					} 
				}
				setState(656);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,65,_ctx);
			}
			setState(658);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==COMMA) {
				{
				setState(657);
				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(665);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,67,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(660);
				indexingArgument();
				}
				break;
			case 2:
				enterOuterAlt(_localctx, 2);
				{
				setState(661);
				command();
				}
				break;
			case 3:
				enterOuterAlt(_localctx, 3);
				{
				setState(662);
				hashLiteral();
				}
				break;
			case 4:
				enterOuterAlt(_localctx, 4);
				{
				setState(663);
				splattingArgument();
				}
				break;
			case 5:
				enterOuterAlt(_localctx, 5);
				{
				setState(664);
				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(709);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,75,_ctx) ) {
			case 1:
				_localctx = new OperatorExpressionListIndexingArgumentListContext(_localctx);
				enterOuterAlt(_localctx, 1);
				{
				setState(667);
				operatorExpressionList();
				setState(669);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,68,_ctx) ) {
				case 1:
					{
					setState(668);
					match(COMMA);
					}
					break;
				}
				}
				break;
			case 2:
				_localctx = new OperatorExpressionListWithSplattingArgumentIndexingArgumentListContext(_localctx);
				enterOuterAlt(_localctx, 2);
				{
				setState(671);
				operatorExpressionList();
				setState(672);
				match(COMMA);
				setState(673);
				splattingArgument();
				}
				break;
			case 3:
				_localctx = new IndexingArgumentIndexingArgumentListContext(_localctx);
				enterOuterAlt(_localctx, 3);
				{
				setState(675);
				indexingArgument();
				setState(688);
				_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(677);
						_errHandler.sync(this);
						_la = _input.LA(1);
						if (_la==COMMA) {
							{
							setState(676);
							match(COMMA);
							}
						}

						setState(682);
						_errHandler.sync(this);
						_la = _input.LA(1);
						while (_la==NL) {
							{
							{
							setState(679);
							match(NL);
							}
							}
							setState(684);
							_errHandler.sync(this);
							_la = _input.LA(1);
						}
						setState(685);
						indexingArgument();
						}
						} 
					}
					setState(690);
					_errHandler.sync(this);
					_alt = getInterpreter().adaptivePredict(_input,71,_ctx);
				}
				}
				break;
			case 4:
				_localctx = new AssociationListIndexingArgumentListContext(_localctx);
				enterOuterAlt(_localctx, 4);
				{
				setState(691);
				associationList();
				setState(693);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,72,_ctx) ) {
				case 1:
					{
					setState(692);
					match(COMMA);
					}
					break;
				}
				}
				break;
			case 5:
				_localctx = new SplattingArgumentIndexingArgumentListContext(_localctx);
				enterOuterAlt(_localctx, 5);
				{
				setState(695);
				splattingArgument();
				setState(706);
				_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(696);
						match(COMMA);
						setState(700);
						_errHandler.sync(this);
						_la = _input.LA(1);
						while (_la==NL) {
							{
							{
							setState(697);
							match(NL);
							}
							}
							setState(702);
							_errHandler.sync(this);
							_la = _input.LA(1);
						}
						setState(703);
						splattingArgument();
						}
						} 
					}
					setState(708);
					_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(717);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,77,_ctx) ) {
			case 1:
				_localctx = new SymbolIndexingArgumentContext(_localctx);
				enterOuterAlt(_localctx, 1);
				{
				setState(711);
				symbol();
				}
				break;
			case 2:
				_localctx = new AssociationIndexingArgumentContext(_localctx);
				enterOuterAlt(_localctx, 2);
				{
				setState(712);
				association();
				}
				break;
			case 3:
				_localctx = new NumericLiteralIndexingArgumentContext(_localctx);
				enterOuterAlt(_localctx, 3);
				{
				setState(714);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==PLUS || _la==MINUS) {
					{
					setState(713);
					((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(716);
				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(723);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case STAR:
				enterOuterAlt(_localctx, 1);
				{
				setState(719);
				match(STAR);
				setState(720);
				operatorExpression(0);
				}
				break;
			case STAR2:
				enterOuterAlt(_localctx, 2);
				{
				setState(721);
				match(STAR2);
				setState(722);
				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(725);
			operatorExpression(0);
			setState(736);
			_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(726);
					match(COMMA);
					setState(730);
					_errHandler.sync(this);
					_la = _input.LA(1);
					while (_la==NL) {
						{
						{
						setState(727);
						match(NL);
						}
						}
						setState(732);
						_errHandler.sync(this);
						_la = _input.LA(1);
					}
					setState(733);
					operatorExpression(0);
					}
					} 
				}
				setState(738);
				_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(739);
			operatorExpression(0);
			setState(748); 
			_errHandler.sync(this);
			_la = _input.LA(1);
			do {
				{
				{
				setState(740);
				match(COMMA);
				setState(744);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==NL) {
					{
					{
					setState(741);
					match(NL);
					}
					}
					setState(746);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(747);
				operatorExpression(0);
				}
				}
				setState(750); 
				_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(834);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,96,_ctx) ) {
			case 1:
				_localctx = new EmptyArgumentWithParenthesesContext(_localctx);
				enterOuterAlt(_localctx, 1);
				{
				setState(752);
				match(LPAREN);
				setState(756);
				_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(753);
						match(NL);
						}
						} 
					}
					setState(758);
					_errHandler.sync(this);
					_alt = getInterpreter().adaptivePredict(_input,83,_ctx);
				}
				setState(760);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==COMMA) {
					{
					setState(759);
					match(COMMA);
					}
				}

				setState(765);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==NL) {
					{
					{
					setState(762);
					match(NL);
					}
					}
					setState(767);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(768);
				match(RPAREN);
				}
				break;
			case 2:
				_localctx = new ArgumentListArgumentWithParenthesesContext(_localctx);
				enterOuterAlt(_localctx, 2);
				{
				setState(769);
				match(LPAREN);
				setState(773);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==NL) {
					{
					{
					setState(770);
					match(NL);
					}
					}
					setState(775);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(776);
				argumentList();
				setState(778);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==COMMA) {
					{
					setState(777);
					match(COMMA);
					}
				}

				setState(783);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==NL) {
					{
					{
					setState(780);
					match(NL);
					}
					}
					setState(785);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(786);
				match(RPAREN);
				}
				break;
			case 3:
				_localctx = new OperatorExpressionsAndChainedCommandWithBlockArgumentWithParenthesesContext(_localctx);
				enterOuterAlt(_localctx, 3);
				{
				setState(788);
				match(LPAREN);
				setState(792);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==NL) {
					{
					{
					setState(789);
					match(NL);
					}
					}
					setState(794);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(795);
				operatorExpressionList();
				setState(796);
				match(COMMA);
				setState(800);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==NL) {
					{
					{
					setState(797);
					match(NL);
					}
					}
					setState(802);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(803);
				chainedCommandWithDoBlock();
				setState(805);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==COMMA) {
					{
					setState(804);
					match(COMMA);
					}
				}

				setState(810);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==NL) {
					{
					{
					setState(807);
					match(NL);
					}
					}
					setState(812);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(813);
				match(RPAREN);
				}
				break;
			case 4:
				_localctx = new ChainedCommandWithDoBlockArgumentWithParenthesesContext(_localctx);
				enterOuterAlt(_localctx, 4);
				{
				setState(815);
				match(LPAREN);
				setState(819);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==NL) {
					{
					{
					setState(816);
					match(NL);
					}
					}
					setState(821);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(822);
				chainedCommandWithDoBlock();
				setState(824);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==COMMA) {
					{
					setState(823);
					match(COMMA);
					}
				}

				setState(829);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==NL) {
					{
					{
					setState(826);
					match(NL);
					}
					}
					setState(831);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(832);
				match(RPAREN);
				}
				break;
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

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

	public final ArgumentListContext argumentList() throws RecognitionException {
		ArgumentListContext _localctx = new ArgumentListContext(_ctx, getState());
		enterRule(_localctx, 64, RULE_argumentList);
		int _la;
		try {
			setState(926);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,114,_ctx) ) {
			case 1:
				_localctx = new BlockArgumentArgumentListContext(_localctx);
				enterOuterAlt(_localctx, 1);
				{
				setState(836);
				blockArgument();
				}
				break;
			case 2:
				_localctx = new SplattingArgumentArgumentListContext(_localctx);
				enterOuterAlt(_localctx, 2);
				{
				setState(837);
				splattingArgument();
				setState(846);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,98,_ctx) ) {
				case 1:
					{
					setState(838);
					match(COMMA);
					setState(842);
					_errHandler.sync(this);
					_la = _input.LA(1);
					while (_la==NL) {
						{
						{
						setState(839);
						match(NL);
						}
						}
						setState(844);
						_errHandler.sync(this);
						_la = _input.LA(1);
					}
					setState(845);
					splatArgList();
					}
					break;
				}
				setState(856);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,100,_ctx) ) {
				case 1:
					{
					setState(848);
					match(COMMA);
					setState(852);
					_errHandler.sync(this);
					_la = _input.LA(1);
					while (_la==NL) {
						{
						{
						setState(849);
						match(NL);
						}
						}
						setState(854);
						_errHandler.sync(this);
						_la = _input.LA(1);
					}
					setState(855);
					blockArgument();
					}
					break;
				}
				setState(866);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,102,_ctx) ) {
				case 1:
					{
					setState(858);
					match(COMMA);
					setState(862);
					_errHandler.sync(this);
					_la = _input.LA(1);
					while (_la==NL) {
						{
						{
						setState(859);
						match(NL);
						}
						}
						setState(864);
						_errHandler.sync(this);
						_la = _input.LA(1);
					}
					setState(865);
					operatorExpressionList();
					}
					break;
				}
				}
				break;
			case 3:
				_localctx = new OperatorsArgumentListContext(_localctx);
				enterOuterAlt(_localctx, 3);
				{
				setState(868);
				operatorExpressionList();
				setState(877);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,104,_ctx) ) {
				case 1:
					{
					setState(869);
					match(COMMA);
					setState(873);
					_errHandler.sync(this);
					_la = _input.LA(1);
					while (_la==NL) {
						{
						{
						setState(870);
						match(NL);
						}
						}
						setState(875);
						_errHandler.sync(this);
						_la = _input.LA(1);
					}
					setState(876);
					associationList();
					}
					break;
				}
				setState(887);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,106,_ctx) ) {
				case 1:
					{
					setState(879);
					match(COMMA);
					setState(883);
					_errHandler.sync(this);
					_la = _input.LA(1);
					while (_la==NL) {
						{
						{
						setState(880);
						match(NL);
						}
						}
						setState(885);
						_errHandler.sync(this);
						_la = _input.LA(1);
					}
					setState(886);
					splattingArgument();
					}
					break;
				}
				setState(897);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,108,_ctx) ) {
				case 1:
					{
					setState(889);
					match(COMMA);
					setState(893);
					_errHandler.sync(this);
					_la = _input.LA(1);
					while (_la==NL) {
						{
						{
						setState(890);
						match(NL);
						}
						}
						setState(895);
						_errHandler.sync(this);
						_la = _input.LA(1);
					}
					setState(896);
					blockArgument();
					}
					break;
				}
				}
				break;
			case 4:
				_localctx = new AssociationsArgumentListContext(_localctx);
				enterOuterAlt(_localctx, 4);
				{
				setState(899);
				associationList();
				setState(908);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,110,_ctx) ) {
				case 1:
					{
					setState(900);
					match(COMMA);
					setState(904);
					_errHandler.sync(this);
					_la = _input.LA(1);
					while (_la==NL) {
						{
						{
						setState(901);
						match(NL);
						}
						}
						setState(906);
						_errHandler.sync(this);
						_la = _input.LA(1);
					}
					setState(907);
					splattingArgument();
					}
					break;
				}
				setState(918);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,112,_ctx) ) {
				case 1:
					{
					setState(910);
					match(COMMA);
					setState(914);
					_errHandler.sync(this);
					_la = _input.LA(1);
					while (_la==NL) {
						{
						{
						setState(911);
						match(NL);
						}
						}
						setState(916);
						_errHandler.sync(this);
						_la = _input.LA(1);
					}
					setState(917);
					blockArgument();
					}
					break;
				}
				}
				break;
			case 5:
				_localctx = new ArrayArgumentListContext(_localctx);
				enterOuterAlt(_localctx, 5);
				{
				setState(920);
				match(LBRACK);
				setState(922);
				_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(921);
					indexingArgumentList();
					}
				}

				setState(924);
				match(RBRACK);
				}
				break;
			case 6:
				_localctx = new SingleCommandArgumentListContext(_localctx);
				enterOuterAlt(_localctx, 6);
				{
				setState(925);
				command();
				}
				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, 66, RULE_splatArgList);
		int _la;
		try {
			int _alt;
			enterOuterAlt(_localctx, 1);
			{
			setState(928);
			splattingArgument();
			setState(939);
			_errHandler.sync(this);
			_alt = getInterpreter().adaptivePredict(_input,116,_ctx);
			while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) {
				if ( _alt==1 ) {
					{
					{
					setState(929);
					match(COMMA);
					setState(933);
					_errHandler.sync(this);
					_la = _input.LA(1);
					while (_la==NL) {
						{
						{
						setState(930);
						match(NL);
						}
						}
						setState(935);
						_errHandler.sync(this);
						_la = _input.LA(1);
					}
					setState(936);
					splattingArgument();
					}
					} 
				}
				setState(941);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,116,_ctx);
			}
			}
		}
		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, 68, RULE_commandArgumentList);
		int _la;
		try {
			setState(954);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,119,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(942);
				associationList();
				}
				break;
			case 2:
				enterOuterAlt(_localctx, 2);
				{
				setState(943);
				primaryValueList();
				setState(952);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,118,_ctx) ) {
				case 1:
					{
					setState(944);
					match(COMMA);
					setState(948);
					_errHandler.sync(this);
					_la = _input.LA(1);
					while (_la==NL) {
						{
						{
						setState(945);
						match(NL);
						}
						}
						setState(950);
						_errHandler.sync(this);
						_la = _input.LA(1);
					}
					setState(951);
					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, 70, RULE_primaryValueList);
		int _la;
		try {
			int _alt;
			enterOuterAlt(_localctx, 1);
			{
			setState(956);
			primaryValue(0);
			setState(967);
			_errHandler.sync(this);
			_alt = getInterpreter().adaptivePredict(_input,121,_ctx);
			while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) {
				if ( _alt==1 ) {
					{
					{
					setState(957);
					match(COMMA);
					setState(961);
					_errHandler.sync(this);
					_la = _input.LA(1);
					while (_la==NL) {
						{
						{
						setState(958);
						match(NL);
						}
						}
						setState(963);
						_errHandler.sync(this);
						_la = _input.LA(1);
					}
					setState(964);
					primaryValue(0);
					}
					} 
				}
				setState(969);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,121,_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, 72, RULE_primaryValueListWithAssociation);
		int _la;
		try {
			int _alt;
			setState(991);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,126,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(972);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,122,_ctx) ) {
				case 1:
					{
					setState(970);
					primaryValue(0);
					}
					break;
				case 2:
					{
					setState(971);
					association();
					}
					break;
				}
				setState(987);
				_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(974);
						match(COMMA);
						setState(978);
						_errHandler.sync(this);
						_la = _input.LA(1);
						while (_la==NL) {
							{
							{
							setState(975);
							match(NL);
							}
							}
							setState(980);
							_errHandler.sync(this);
							_la = _input.LA(1);
						}
						setState(983);
						_errHandler.sync(this);
						switch ( getInterpreter().adaptivePredict(_input,124,_ctx) ) {
						case 1:
							{
							setState(981);
							primaryValue(0);
							}
							break;
						case 2:
							{
							setState(982);
							association();
							}
							break;
						}
						}
						} 
					}
					setState(989);
					_errHandler.sync(this);
					_alt = getInterpreter().adaptivePredict(_input,125,_ctx);
				}
				}
				break;
			case 2:
				enterOuterAlt(_localctx, 2);
				{
				setState(990);
				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, 74, RULE_blockArgument);
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(993);
			match(AMP);
			setState(995);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,127,_ctx) ) {
			case 1:
				{
				setState(994);
				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 = 76;
		enterRecursionRule(_localctx, 76, RULE_expressionOrCommand, _p);
		int _la;
		try {
			int _alt;
			enterOuterAlt(_localctx, 1);
			{
			setState(1011);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,130,_ctx) ) {
			case 1:
				{
				_localctx = new OperatorExpressionOrCommandContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;

				setState(998);
				operatorExpression(0);
				}
				break;
			case 2:
				{
				_localctx = new CommandExpressionOrCommandContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(1000);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,128,_ctx) ) {
				case 1:
					{
					setState(999);
					match(EMARK);
					}
					break;
				}
				setState(1002);
				methodInvocationWithoutParentheses();
				}
				break;
			case 3:
				{
				_localctx = new NotExpressionOrCommandContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(1003);
				match(NOT);
				setState(1007);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==NL) {
					{
					{
					setState(1004);
					match(NL);
					}
					}
					setState(1009);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(1010);
				expressionOrCommand(2);
				}
				break;
			}
			_ctx.stop = _input.LT(-1);
			setState(1024);
			_errHandler.sync(this);
			_alt = getInterpreter().adaptivePredict(_input,132,_ctx);
			while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) {
				if ( _alt==1 ) {
					if ( _parseListeners!=null ) triggerExitRuleEvent();
					_prevctx = _localctx;
					{
					{
					_localctx = new KeywordAndOrExpressionOrCommandContext(new ExpressionOrCommandContext(_parentctx, _parentState));
					((KeywordAndOrExpressionOrCommandContext)_localctx).lhs = _prevctx;
					pushNewRecursionContext(_localctx, _startState, RULE_expressionOrCommand);
					setState(1013);
					if (!(precpred(_ctx, 1))) throw new FailedPredicateException(this, "precpred(_ctx, 1)");
					setState(1014);
					((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(1018);
					_errHandler.sync(this);
					_la = _input.LA(1);
					while (_la==NL) {
						{
						{
						setState(1015);
						match(NL);
						}
						}
						setState(1020);
						_errHandler.sync(this);
						_la = _input.LA(1);
					}
					setState(1021);
					((KeywordAndOrExpressionOrCommandContext)_localctx).rhs = expressionOrCommand(2);
					}
					} 
				}
				setState(1026);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,132,_ctx);
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			unrollRecursionContexts(_parentctx);
		}
		return _localctx;
	}

	public static class 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 = 78;
		enterRecursionRule(_localctx, 78, RULE_operatorExpression, _p);
		int _la;
		try {
			int _alt;
			enterOuterAlt(_localctx, 1);
			{
			{
			_localctx = new PrimaryOperatorExpressionContext(_localctx);
			_ctx = _localctx;
			_prevctx = _localctx;

			setState(1028);
			primary();
			}
			_ctx.stop = _input.LT(-1);
			setState(1056);
			_errHandler.sync(this);
			_alt = getInterpreter().adaptivePredict(_input,136,_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(1030);
					if (!(precpred(_ctx, 1))) throw new FailedPredicateException(this, "precpred(_ctx, 1)");
					setState(1031);
					match(QMARK);
					setState(1035);
					_errHandler.sync(this);
					_la = _input.LA(1);
					while (_la==NL) {
						{
						{
						setState(1032);
						match(NL);
						}
						}
						setState(1037);
						_errHandler.sync(this);
						_la = _input.LA(1);
					}
					setState(1038);
					operatorExpression(0);
					setState(1042);
					_errHandler.sync(this);
					_la = _input.LA(1);
					while (_la==NL) {
						{
						{
						setState(1039);
						match(NL);
						}
						}
						setState(1044);
						_errHandler.sync(this);
						_la = _input.LA(1);
					}
					setState(1045);
					match(COLON);
					setState(1049);
					_errHandler.sync(this);
					_la = _input.LA(1);
					while (_la==NL) {
						{
						{
						setState(1046);
						match(NL);
						}
						}
						setState(1051);
						_errHandler.sync(this);
						_la = _input.LA(1);
					}
					setState(1052);
					operatorExpression(2);
					}
					} 
				}
				setState(1058);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,136,_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, 80, RULE_primary);
		try {
			setState(1065);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case RETURN:
				_localctx = new ReturnWithoutArgumentsContext(_localctx);
				enterOuterAlt(_localctx, 1);
				{
				setState(1059);
				match(RETURN);
				}
				break;
			case BREAK:
				_localctx = new BreakWithoutArgumentsContext(_localctx);
				enterOuterAlt(_localctx, 2);
				{
				setState(1060);
				match(BREAK);
				}
				break;
			case NEXT:
				_localctx = new NextWithoutArgumentsContext(_localctx);
				enterOuterAlt(_localctx, 3);
				{
				setState(1061);
				match(NEXT);
				}
				break;
			case REDO:
				_localctx = new RedoWithoutArgumentsContext(_localctx);
				enterOuterAlt(_localctx, 4);
				{
				setState(1062);
				match(REDO);
				}
				break;
			case RETRY:
				_localctx = new RetryWithoutArgumentsContext(_localctx);
				enterOuterAlt(_localctx, 5);
				{
				setState(1063);
				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(1064);
				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, 82, RULE_hashLiteral);
		int _la;
		try {
			int _alt;
			enterOuterAlt(_localctx, 1);
			{
			setState(1067);
			match(LCURLY);
			setState(1071);
			_errHandler.sync(this);
			_alt = getInterpreter().adaptivePredict(_input,138,_ctx);
			while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) {
				if ( _alt==1 ) {
					{
					{
					setState(1068);
					match(NL);
					}
					} 
				}
				setState(1073);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,138,_ctx);
			}
			setState(1078);
			_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(1074);
				associationList();
				setState(1076);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==COMMA) {
					{
					setState(1075);
					match(COMMA);
					}
				}

				}
			}

			setState(1083);
			_errHandler.sync(this);
			_la = _input.LA(1);
			while (_la==NL) {
				{
				{
				setState(1080);
				match(NL);
				}
				}
				setState(1085);
				_errHandler.sync(this);
				_la = _input.LA(1);
			}
			setState(1086);
			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 = 84;
		enterRecursionRule(_localctx, 84, RULE_primaryValue, _p);
		int _la;
		try {
			int _alt;
			enterOuterAlt(_localctx, 1);
			{
			setState(1403);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,182,_ctx) ) {
			case 1:
				{
				_localctx = new LocalVariableAssignmentExpressionContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;

				setState(1089);
				((LocalVariableAssignmentExpressionContext)_localctx).lhs = variable();
				setState(1090);
				assignmentOperator();
				setState(1094);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==NL) {
					{
					{
					setState(1091);
					match(NL);
					}
					}
					setState(1096);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(1097);
				((LocalVariableAssignmentExpressionContext)_localctx).rhs = operatorExpression(0);
				}
				break;
			case 2:
				{
				_localctx = new ConstantAssignmentExpressionContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(1099);
				match(COLON2);
				setState(1100);
				match(CONSTANT_IDENTIFIER);
				setState(1101);
				assignmentOperator();
				setState(1105);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==NL) {
					{
					{
					setState(1102);
					match(NL);
					}
					}
					setState(1107);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(1108);
				operatorExpression(0);
				}
				break;
			case 3:
				{
				_localctx = new ClassDefinitionContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(1110);
				match(CLASS);
				setState(1111);
				classPath(0);
				setState(1114);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==LT) {
					{
					setState(1112);
					match(LT);
					setState(1113);
					commandOrPrimaryValueClass();
					}
				}

				setState(1117);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,145,_ctx) ) {
				case 1:
					{
					setState(1116);
					_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(1119);
				bodyStatement();
				setState(1120);
				match(END);
				}
				break;
			case 4:
				{
				_localctx = new SingletonClassDefinitionContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(1122);
				match(CLASS);
				setState(1123);
				match(LT2);
				setState(1124);
				commandOrPrimaryValueClass();
				setState(1125);
				_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(1126);
				bodyStatement();
				setState(1127);
				match(END);
				}
				break;
			case 5:
				{
				_localctx = new ModuleDefinitionContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(1129);
				match(MODULE);
				setState(1130);
				classPath(0);
				setState(1131);
				bodyStatement();
				setState(1132);
				match(END);
				}
				break;
			case 6:
				{
				_localctx = new MethodDefinitionContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(1134);
				match(DEF);
				setState(1135);
				definedMethodName();
				setState(1136);
				methodParameterPart();
				setState(1137);
				bodyStatement();
				setState(1138);
				match(END);
				}
				break;
			case 7:
				{
				_localctx = new SingletonMethodDefinitionContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(1140);
				match(DEF);
				setState(1141);
				singletonObject();
				setState(1142);
				((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(1143);
				definedMethodName();
				setState(1144);
				methodParameterPart();
				setState(1145);
				bodyStatement();
				setState(1146);
				match(END);
				}
				break;
			case 8:
				{
				_localctx = new EndlessMethodDefinitionContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(1148);
				match(DEF);
				setState(1149);
				definedMethodName();
				setState(1155);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==LPAREN) {
					{
					setState(1150);
					match(LPAREN);
					setState(1152);
					_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(1151);
						parameterList();
						}
					}

					setState(1154);
					match(RPAREN);
					}
				}

				setState(1157);
				match(EQ);
				setState(1161);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==NL) {
					{
					{
					setState(1158);
					match(NL);
					}
					}
					setState(1163);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(1164);
				statement(0);
				}
				break;
			case 9:
				{
				_localctx = new LambdaExpressionContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(1166);
				match(MINUSGT);
				setState(1168);
				_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(1167);
					lambdaExpressionParameterList();
					}
				}

				setState(1170);
				block();
				}
				break;
			case 10:
				{
				_localctx = new IfExpressionContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(1171);
				match(IF);
				setState(1175);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==NL) {
					{
					{
					setState(1172);
					match(NL);
					}
					}
					setState(1177);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(1178);
				expressionOrCommand(0);
				setState(1179);
				thenClause();
				setState(1183);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==ELSIF) {
					{
					{
					setState(1180);
					elsifClause();
					}
					}
					setState(1185);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(1187);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==ELSE) {
					{
					setState(1186);
					elseClause();
					}
				}

				setState(1189);
				match(END);
				}
				break;
			case 11:
				{
				_localctx = new UnlessExpressionContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(1191);
				match(UNLESS);
				setState(1195);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==NL) {
					{
					{
					setState(1192);
					match(NL);
					}
					}
					setState(1197);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(1198);
				expressionOrCommand(0);
				setState(1199);
				thenClause();
				setState(1201);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==ELSE) {
					{
					setState(1200);
					elseClause();
					}
				}

				setState(1203);
				match(END);
				}
				break;
			case 12:
				{
				_localctx = new UntilExpressionContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(1205);
				match(UNTIL);
				setState(1209);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==NL) {
					{
					{
					setState(1206);
					match(NL);
					}
					}
					setState(1211);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(1212);
				expressionOrCommand(0);
				setState(1213);
				doClause();
				setState(1214);
				match(END);
				}
				break;
			case 13:
				{
				_localctx = new YieldExpressionContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(1216);
				match(YIELD);
				setState(1218);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,156,_ctx) ) {
				case 1:
					{
					setState(1217);
					argumentWithParentheses();
					}
					break;
				}
				}
				break;
			case 14:
				{
				_localctx = new BeginEndExpressionContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(1220);
				match(BEGIN);
				setState(1221);
				bodyStatement();
				setState(1222);
				match(END);
				}
				break;
			case 15:
				{
				_localctx = new CaseWithExpressionContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(1224);
				match(CASE);
				setState(1228);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==NL) {
					{
					{
					setState(1225);
					match(NL);
					}
					}
					setState(1230);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(1231);
				expressionOrCommand(0);
				setState(1235);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==SEMI || _la==NL) {
					{
					{
					setState(1232);
					_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(1237);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(1239); 
				_errHandler.sync(this);
				_la = _input.LA(1);
				do {
					{
					{
					setState(1238);
					whenClause();
					}
					}
					setState(1241); 
					_errHandler.sync(this);
					_la = _input.LA(1);
				} while ( _la==WHEN );
				setState(1244);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==ELSE) {
					{
					setState(1243);
					elseClause();
					}
				}

				setState(1246);
				match(END);
				}
				break;
			case 16:
				{
				_localctx = new CaseWithoutExpressionContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(1248);
				match(CASE);
				setState(1252);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==SEMI || _la==NL) {
					{
					{
					setState(1249);
					_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(1254);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(1256); 
				_errHandler.sync(this);
				_la = _input.LA(1);
				do {
					{
					{
					setState(1255);
					whenClause();
					}
					}
					setState(1258); 
					_errHandler.sync(this);
					_la = _input.LA(1);
				} while ( _la==WHEN );
				setState(1261);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==ELSE) {
					{
					setState(1260);
					elseClause();
					}
				}

				setState(1263);
				match(END);
				}
				break;
			case 17:
				{
				_localctx = new WhileExpressionContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(1265);
				match(WHILE);
				setState(1269);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==NL) {
					{
					{
					setState(1266);
					match(NL);
					}
					}
					setState(1271);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(1272);
				expressionOrCommand(0);
				setState(1273);
				doClause();
				setState(1274);
				match(END);
				}
				break;
			case 18:
				{
				_localctx = new ForExpressionContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(1276);
				match(FOR);
				setState(1280);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==NL) {
					{
					{
					setState(1277);
					match(NL);
					}
					}
					setState(1282);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(1283);
				forVariable();
				setState(1284);
				match(IN);
				setState(1288);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==NL) {
					{
					{
					setState(1285);
					match(NL);
					}
					}
					setState(1290);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(1291);
				commandOrPrimaryValue(0);
				setState(1292);
				doClause();
				setState(1293);
				match(END);
				}
				break;
			case 19:
				{
				_localctx = new MethodCallWithParenthesesContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(1295);
				methodCallsWithParentheses();
				}
				break;
			case 20:
				{
				_localctx = new BracketedArrayLiteralContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(1296);
				match(LBRACK);
				setState(1300);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,167,_ctx);
				while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) {
					if ( _alt==1 ) {
						{
						{
						setState(1297);
						match(NL);
						}
						} 
					}
					setState(1302);
					_errHandler.sync(this);
					_alt = getInterpreter().adaptivePredict(_input,167,_ctx);
				}
				setState(1304);
				_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(1303);
					bracketedArrayElementList();
					}
				}

				setState(1309);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==NL) {
					{
					{
					setState(1306);
					match(NL);
					}
					}
					setState(1311);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(1312);
				match(RBRACK);
				}
				break;
			case 21:
				{
				_localctx = new QuotedNonExpandedStringArrayLiteralContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(1313);
				match(QUOTED_NON_EXPANDED_STRING_ARRAY_LITERAL_START);
				setState(1315);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==NON_EXPANDED_ARRAY_ITEM_SEPARATOR || _la==NON_EXPANDED_ARRAY_ITEM_CHARACTER) {
					{
					setState(1314);
					quotedNonExpandedArrayElementList();
					}
				}

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

				setState(1322);
				match(QUOTED_NON_EXPANDED_SYMBOL_ARRAY_LITERAL_END);
				}
				break;
			case 23:
				{
				_localctx = new QuotedExpandedStringArrayLiteralContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(1323);
				match(QUOTED_EXPANDED_STRING_ARRAY_LITERAL_START);
				setState(1325);
				_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(1324);
					quotedExpandedArrayElementList();
					}
				}

				setState(1327);
				match(QUOTED_EXPANDED_STRING_ARRAY_LITERAL_END);
				}
				break;
			case 24:
				{
				_localctx = new QuotedExpandedSymbolArrayLiteralContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(1328);
				match(QUOTED_EXPANDED_SYMBOL_ARRAY_LITERAL_START);
				setState(1330);
				_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(1329);
					quotedExpandedArrayElementList();
					}
				}

				setState(1332);
				match(QUOTED_EXPANDED_SYMBOL_ARRAY_LITERAL_END);
				}
				break;
			case 25:
				{
				_localctx = new PrimaryValueHashLiteralContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(1333);
				hashLiteral();
				}
				break;
			case 26:
				{
				_localctx = new NumericLiteralContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(1335);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==PLUS || _la==MINUS) {
					{
					setState(1334);
					((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(1337);
				unsignedNumericLiteral();
				}
				break;
			case 27:
				{
				_localctx = new SingleQuotedStringExpressionContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(1338);
				singleQuotedString();
				setState(1342);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,175,_ctx);
				while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) {
					if ( _alt==1 ) {
						{
						{
						setState(1339);
						singleOrDoubleQuotedString();
						}
						} 
					}
					setState(1344);
					_errHandler.sync(this);
					_alt = getInterpreter().adaptivePredict(_input,175,_ctx);
				}
				}
				break;
			case 28:
				{
				_localctx = new DoubleQuotedStringExpressionContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(1345);
				doubleQuotedString();
				setState(1349);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,176,_ctx);
				while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) {
					if ( _alt==1 ) {
						{
						{
						setState(1346);
						singleOrDoubleQuotedString();
						}
						} 
					}
					setState(1351);
					_errHandler.sync(this);
					_alt = getInterpreter().adaptivePredict(_input,176,_ctx);
				}
				}
				break;
			case 29:
				{
				_localctx = new QuotedNonExpandedStringLiteralContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(1352);
				match(QUOTED_NON_EXPANDED_STRING_LITERAL_START);
				setState(1354);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==NON_EXPANDED_LITERAL_CHARACTER_SEQUENCE) {
					{
					setState(1353);
					match(NON_EXPANDED_LITERAL_CHARACTER_SEQUENCE);
					}
				}

				setState(1356);
				match(QUOTED_NON_EXPANDED_STRING_LITERAL_END);
				}
				break;
			case 30:
				{
				_localctx = new QuotedExpandedStringLiteralContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(1357);
				match(QUOTED_EXPANDED_STRING_LITERAL_START);
				setState(1361);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==EXPANDED_LITERAL_CHARACTER_SEQUENCE || _la==DELIMITED_STRING_INTERPOLATION_BEGIN) {
					{
					{
					setState(1358);
					quotedExpandedLiteralStringContent();
					}
					}
					setState(1363);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(1364);
				match(QUOTED_EXPANDED_STRING_LITERAL_END);
				}
				break;
			case 31:
				{
				_localctx = new QuotedExpandedExternalCommandLiteralContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(1365);
				match(QUOTED_EXPANDED_EXTERNAL_COMMAND_LITERAL_START);
				setState(1369);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==EXPANDED_LITERAL_CHARACTER_SEQUENCE || _la==DELIMITED_STRING_INTERPOLATION_BEGIN) {
					{
					{
					setState(1366);
					quotedExpandedLiteralStringContent();
					}
					}
					setState(1371);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(1372);
				match(QUOTED_EXPANDED_EXTERNAL_COMMAND_LITERAL_END);
				}
				break;
			case 32:
				{
				_localctx = new SymbolExpressionContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(1373);
				symbol();
				}
				break;
			case 33:
				{
				_localctx = new RegularExpressionLiteralContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(1374);
				match(REGULAR_EXPRESSION_START);
				setState(1378);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==REGULAR_EXPRESSION_BODY || _la==REGULAR_EXPRESSION_INTERPOLATION_BEGIN) {
					{
					{
					setState(1375);
					regexpLiteralContent();
					}
					}
					setState(1380);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(1381);
				match(REGULAR_EXPRESSION_END);
				}
				break;
			case 34:
				{
				_localctx = new QuotedExpandedRegularExpressionLiteralContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(1382);
				match(QUOTED_EXPANDED_REGULAR_EXPRESSION_START);
				setState(1386);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==EXPANDED_LITERAL_CHARACTER_SEQUENCE || _la==DELIMITED_STRING_INTERPOLATION_BEGIN) {
					{
					{
					setState(1383);
					quotedExpandedLiteralStringContent();
					}
					}
					setState(1388);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(1389);
				match(QUOTED_EXPANDED_REGULAR_EXPRESSION_END);
				}
				break;
			case 35:
				{
				_localctx = new GroupingStatementContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(1390);
				match(LPAREN);
				setState(1391);
				compoundStatement();
				setState(1392);
				match(RPAREN);
				}
				break;
			case 36:
				{
				_localctx = new UnaryExpressionContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(1394);
				unaryOperator();
				setState(1395);
				primaryValue(16);
				}
				break;
			case 37:
				{
				_localctx = new UnaryMinusExpressionContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(1397);
				match(MINUS);
				setState(1398);
				primaryValue(14);
				}
				break;
			case 38:
				{
				_localctx = new BeginlessRangeExpressionContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(1399);
				rangeOperator();
				setState(1400);
				primaryValue(2);
				}
				break;
			case 39:
				{
				_localctx = new HereDocsContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(1402);
				hereDoc();
				}
				break;
			}
			_ctx.stop = _input.LT(-1);
			setState(1587);
			_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 ) {
					if ( _parseListeners!=null ) triggerExitRuleEvent();
					_prevctx = _localctx;
					{
					setState(1585);
					_errHandler.sync(this);
					switch ( getInterpreter().adaptivePredict(_input,205,_ctx) ) {
					case 1:
						{
						_localctx = new PowerExpressionContext(new PrimaryValueContext(_parentctx, _parentState));
						pushNewRecursionContext(_localctx, _startState, RULE_primaryValue);
						setState(1405);
						if (!(precpred(_ctx, 15))) throw new FailedPredicateException(this, "precpred(_ctx, 15)");
						setState(1406);
						((PowerExpressionContext)_localctx).powerOperator = match(STAR2);
						setState(1410);
						_errHandler.sync(this);
						_la = _input.LA(1);
						while (_la==NL) {
							{
							{
							setState(1407);
							match(NL);
							}
							}
							setState(1412);
							_errHandler.sync(this);
							_la = _input.LA(1);
						}
						setState(1413);
						primaryValue(15);
						}
						break;
					case 2:
						{
						_localctx = new MultiplicativeExpressionContext(new PrimaryValueContext(_parentctx, _parentState));
						pushNewRecursionContext(_localctx, _startState, RULE_primaryValue);
						setState(1414);
						if (!(precpred(_ctx, 13))) throw new FailedPredicateException(this, "precpred(_ctx, 13)");
						setState(1415);
						multiplicativeOperator();
						setState(1419);
						_errHandler.sync(this);
						_la = _input.LA(1);
						while (_la==NL) {
							{
							{
							setState(1416);
							match(NL);
							}
							}
							setState(1421);
							_errHandler.sync(this);
							_la = _input.LA(1);
						}
						setState(1422);
						primaryValue(14);
						}
						break;
					case 3:
						{
						_localctx = new AdditiveExpressionContext(new PrimaryValueContext(_parentctx, _parentState));
						pushNewRecursionContext(_localctx, _startState, RULE_primaryValue);
						setState(1424);
						if (!(precpred(_ctx, 12))) throw new FailedPredicateException(this, "precpred(_ctx, 12)");
						setState(1425);
						additiveOperator();
						setState(1429);
						_errHandler.sync(this);
						_la = _input.LA(1);
						while (_la==NL) {
							{
							{
							setState(1426);
							match(NL);
							}
							}
							setState(1431);
							_errHandler.sync(this);
							_la = _input.LA(1);
						}
						setState(1432);
						primaryValue(13);
						}
						break;
					case 4:
						{
						_localctx = new ShiftExpressionContext(new PrimaryValueContext(_parentctx, _parentState));
						pushNewRecursionContext(_localctx, _startState, RULE_primaryValue);
						setState(1434);
						if (!(precpred(_ctx, 11))) throw new FailedPredicateException(this, "precpred(_ctx, 11)");
						setState(1435);
						bitwiseShiftOperator();
						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);
						primaryValue(12);
						}
						break;
					case 5:
						{
						_localctx = new BitwiseAndExpressionContext(new PrimaryValueContext(_parentctx, _parentState));
						pushNewRecursionContext(_localctx, _startState, RULE_primaryValue);
						setState(1444);
						if (!(precpred(_ctx, 10))) throw new FailedPredicateException(this, "precpred(_ctx, 10)");
						setState(1445);
						((BitwiseAndExpressionContext)_localctx).bitwiseAndOperator = match(AMP);
						setState(1449);
						_errHandler.sync(this);
						_la = _input.LA(1);
						while (_la==NL) {
							{
							{
							setState(1446);
							match(NL);
							}
							}
							setState(1451);
							_errHandler.sync(this);
							_la = _input.LA(1);
						}
						setState(1452);
						primaryValue(11);
						}
						break;
					case 6:
						{
						_localctx = new BitwiseOrExpressionContext(new PrimaryValueContext(_parentctx, _parentState));
						pushNewRecursionContext(_localctx, _startState, RULE_primaryValue);
						setState(1453);
						if (!(precpred(_ctx, 9))) throw new FailedPredicateException(this, "precpred(_ctx, 9)");
						setState(1454);
						bitwiseOrOperator();
						setState(1458);
						_errHandler.sync(this);
						_la = _input.LA(1);
						while (_la==NL) {
							{
							{
							setState(1455);
							match(NL);
							}
							}
							setState(1460);
							_errHandler.sync(this);
							_la = _input.LA(1);
						}
						setState(1461);
						primaryValue(10);
						}
						break;
					case 7:
						{
						_localctx = new RelationalExpressionContext(new PrimaryValueContext(_parentctx, _parentState));
						pushNewRecursionContext(_localctx, _startState, RULE_primaryValue);
						setState(1463);
						if (!(precpred(_ctx, 8))) throw new FailedPredicateException(this, "precpred(_ctx, 8)");
						setState(1464);
						relationalOperator();
						setState(1468);
						_errHandler.sync(this);
						_la = _input.LA(1);
						while (_la==NL) {
							{
							{
							setState(1465);
							match(NL);
							}
							}
							setState(1470);
							_errHandler.sync(this);
							_la = _input.LA(1);
						}
						setState(1471);
						primaryValue(9);
						}
						break;
					case 8:
						{
						_localctx = new EqualityExpressionContext(new PrimaryValueContext(_parentctx, _parentState));
						pushNewRecursionContext(_localctx, _startState, RULE_primaryValue);
						setState(1473);
						if (!(precpred(_ctx, 7))) throw new FailedPredicateException(this, "precpred(_ctx, 7)");
						setState(1474);
						equalityOperator();
						setState(1478);
						_errHandler.sync(this);
						_la = _input.LA(1);
						while (_la==NL) {
							{
							{
							setState(1475);
							match(NL);
							}
							}
							setState(1480);
							_errHandler.sync(this);
							_la = _input.LA(1);
						}
						setState(1481);
						primaryValue(8);
						}
						break;
					case 9:
						{
						_localctx = new BoundedRangeExpressionContext(new PrimaryValueContext(_parentctx, _parentState));
						pushNewRecursionContext(_localctx, _startState, RULE_primaryValue);
						setState(1483);
						if (!(precpred(_ctx, 4))) throw new FailedPredicateException(this, "precpred(_ctx, 4)");
						setState(1484);
						rangeOperator();
						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);
						primaryValue(5);
						}
						break;
					case 10:
						{
						_localctx = new AttributeAssignmentExpressionContext(new PrimaryValueContext(_parentctx, _parentState));
						pushNewRecursionContext(_localctx, _startState, RULE_primaryValue);
						setState(1493);
						if (!(precpred(_ctx, 55))) throw new FailedPredicateException(this, "precpred(_ctx, 55)");
						setState(1494);
						((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(1495);
						methodName();
						setState(1496);
						assignmentOperator();
						setState(1500);
						_errHandler.sync(this);
						_la = _input.LA(1);
						while (_la==NL) {
							{
							{
							setState(1497);
							match(NL);
							}
							}
							setState(1502);
							_errHandler.sync(this);
							_la = _input.LA(1);
						}
						setState(1503);
						operatorExpression(0);
						}
						break;
					case 11:
						{
						_localctx = new BracketAssignmentExpressionContext(new PrimaryValueContext(_parentctx, _parentState));
						pushNewRecursionContext(_localctx, _startState, RULE_primaryValue);
						setState(1505);
						if (!(precpred(_ctx, 53))) throw new FailedPredicateException(this, "precpred(_ctx, 53)");
						setState(1506);
						match(LBRACK);
						setState(1508);
						_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(1507);
							indexingArgumentList();
							}
						}

						setState(1510);
						match(RBRACK);
						setState(1511);
						assignmentOperator();
						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(1518);
						operatorExpression(0);
						}
						break;
					case 12:
						{
						_localctx = new AssignmentWithRescueContext(new PrimaryValueContext(_parentctx, _parentState));
						pushNewRecursionContext(_localctx, _startState, RULE_primaryValue);
						setState(1520);
						if (!(precpred(_ctx, 52))) throw new FailedPredicateException(this, "precpred(_ctx, 52)");
						setState(1521);
						assignmentOperator();
						setState(1525);
						_errHandler.sync(this);
						_la = _input.LA(1);
						while (_la==NL) {
							{
							{
							setState(1522);
							match(NL);
							}
							}
							setState(1527);
							_errHandler.sync(this);
							_la = _input.LA(1);
						}
						setState(1528);
						operatorExpression(0);
						setState(1529);
						match(RESCUE);
						setState(1530);
						operatorExpression(0);
						}
						break;
					case 13:
						{
						_localctx = new IndexingAccessExpressionContext(new PrimaryValueContext(_parentctx, _parentState));
						pushNewRecursionContext(_localctx, _startState, RULE_primaryValue);
						setState(1532);
						if (!(precpred(_ctx, 18))) throw new FailedPredicateException(this, "precpred(_ctx, 18)");
						setState(1533);
						match(LBRACK);
						setState(1535);
						_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(1534);
							indexingArgumentList();
							}
						}

						setState(1537);
						match(RBRACK);
						}
						break;
					case 14:
						{
						_localctx = new MemberAccessExpressionContext(new PrimaryValueContext(_parentctx, _parentState));
						pushNewRecursionContext(_localctx, _startState, RULE_primaryValue);
						setState(1538);
						if (!(precpred(_ctx, 17))) throw new FailedPredicateException(this, "precpred(_ctx, 17)");
						setState(1542);
						_errHandler.sync(this);
						_la = _input.LA(1);
						while (_la==NL) {
							{
							{
							setState(1539);
							match(NL);
							}
							}
							setState(1544);
							_errHandler.sync(this);
							_la = _input.LA(1);
						}
						setState(1545);
						((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(1549);
						_errHandler.sync(this);
						_la = _input.LA(1);
						while (_la==NL) {
							{
							{
							setState(1546);
							match(NL);
							}
							}
							setState(1551);
							_errHandler.sync(this);
							_la = _input.LA(1);
						}
						setState(1552);
						methodName();
						setState(1554);
						_errHandler.sync(this);
						switch ( getInterpreter().adaptivePredict(_input,199,_ctx) ) {
						case 1:
							{
							setState(1553);
							argumentWithParentheses();
							}
							break;
						}
						setState(1557);
						_errHandler.sync(this);
						switch ( getInterpreter().adaptivePredict(_input,200,_ctx) ) {
						case 1:
							{
							setState(1556);
							block();
							}
							break;
						}
						}
						break;
					case 15:
						{
						_localctx = new LogicalAndExpressionContext(new PrimaryValueContext(_parentctx, _parentState));
						pushNewRecursionContext(_localctx, _startState, RULE_primaryValue);
						setState(1559);
						if (!(precpred(_ctx, 6))) throw new FailedPredicateException(this, "precpred(_ctx, 6)");
						setState(1560);
						((LogicalAndExpressionContext)_localctx).andOperator = match(AMP2);
						setState(1564);
						_errHandler.sync(this);
						_la = _input.LA(1);
						while (_la==NL) {
							{
							{
							setState(1561);
							match(NL);
							}
							}
							setState(1566);
							_errHandler.sync(this);
							_la = _input.LA(1);
						}
						setState(1569);
						_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(1567);
							primaryValue(0);
							}
							break;
						case RETURN:
							{
							setState(1568);
							match(RETURN);
							}
							break;
						default:
							throw new NoViableAltException(this);
						}
						}
						break;
					case 16:
						{
						_localctx = new LogicalOrExpressionContext(new PrimaryValueContext(_parentctx, _parentState));
						pushNewRecursionContext(_localctx, _startState, RULE_primaryValue);
						setState(1571);
						if (!(precpred(_ctx, 5))) throw new FailedPredicateException(this, "precpred(_ctx, 5)");
						setState(1572);
						((LogicalOrExpressionContext)_localctx).orOperator = match(BAR2);
						setState(1576);
						_errHandler.sync(this);
						_la = _input.LA(1);
						while (_la==NL) {
							{
							{
							setState(1573);
							match(NL);
							}
							}
							setState(1578);
							_errHandler.sync(this);
							_la = _input.LA(1);
						}
						setState(1581);
						_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(1579);
							primaryValue(0);
							}
							break;
						case RETURN:
							{
							setState(1580);
							match(RETURN);
							}
							break;
						default:
							throw new NoViableAltException(this);
						}
						}
						break;
					case 17:
						{
						_localctx = new EndlessRangeExpressionContext(new PrimaryValueContext(_parentctx, _parentState));
						pushNewRecursionContext(_localctx, _startState, RULE_primaryValue);
						setState(1583);
						if (!(precpred(_ctx, 3))) throw new FailedPredicateException(this, "precpred(_ctx, 3)");
						setState(1584);
						rangeOperator();
						}
						break;
					}
					} 
				}
				setState(1589);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,206,_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, 86, RULE_lambdaExpressionParameterList);
		int _la;
		try {
			setState(1596);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,208,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(1590);
				match(LPAREN);
				setState(1592);
				_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(1591);
					blockParameterList();
					}
				}

				setState(1594);
				match(RPAREN);
				}
				break;
			case 2:
				enterOuterAlt(_localctx, 2);
				{
				setState(1595);
				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, 88, RULE_methodCallsWithParentheses);
		try {
			setState(1630);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,214,_ctx) ) {
			case 1:
				_localctx = new SuperWithParenthesesContext(_localctx);
				enterOuterAlt(_localctx, 1);
				{
				setState(1598);
				match(SUPER);
				setState(1600);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,209,_ctx) ) {
				case 1:
					{
					setState(1599);
					argumentWithParentheses();
					}
					break;
				}
				setState(1603);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,210,_ctx) ) {
				case 1:
					{
					setState(1602);
					block();
					}
					break;
				}
				}
				break;
			case 2:
				_localctx = new SuperWithoutParenthesesContext(_localctx);
				enterOuterAlt(_localctx, 2);
				{
				setState(1605);
				match(SUPER);
				setState(1607);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,211,_ctx) ) {
				case 1:
					{
					setState(1606);
					argumentList();
					}
					break;
				}
				setState(1610);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,212,_ctx) ) {
				case 1:
					{
					setState(1609);
					block();
					}
					break;
				}
				}
				break;
			case 3:
				_localctx = new IsDefinedExpressionContext(_localctx);
				enterOuterAlt(_localctx, 3);
				{
				setState(1612);
				isDefinedKeyword();
				setState(1613);
				match(LPAREN);
				setState(1614);
				expressionOrCommand(0);
				setState(1615);
				match(RPAREN);
				}
				break;
			case 4:
				_localctx = new IsDefinedCommandContext(_localctx);
				enterOuterAlt(_localctx, 4);
				{
				setState(1617);
				isDefinedKeyword();
				setState(1618);
				primaryValue(0);
				}
				break;
			case 5:
				_localctx = new MethodCallExpressionContext(_localctx);
				enterOuterAlt(_localctx, 5);
				{
				setState(1620);
				methodOnlyIdentifier();
				}
				break;
			case 6:
				_localctx = new MethodCallWithBlockExpressionContext(_localctx);
				enterOuterAlt(_localctx, 6);
				{
				setState(1621);
				methodIdentifier();
				setState(1622);
				block();
				}
				break;
			case 7:
				_localctx = new MethodCallWithParenthesesExpressionContext(_localctx);
				enterOuterAlt(_localctx, 7);
				{
				setState(1624);
				methodIdentifier();
				setState(1625);
				argumentWithParentheses();
				setState(1627);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,213,_ctx) ) {
				case 1:
					{
					setState(1626);
					block();
					}
					break;
				}
				}
				break;
			case 8:
				_localctx = new MethodCallOrVariableReferenceContext(_localctx);
				enterOuterAlt(_localctx, 8);
				{
				setState(1629);
				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, 90, RULE_commandOrPrimaryValueClass);
		try {
			setState(1634);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,215,_ctx) ) {
			case 1:
				_localctx = new CommandCommandOrPrimaryValueClassContext(_localctx);
				enterOuterAlt(_localctx, 1);
				{
				setState(1632);
				command();
				}
				break;
			case 2:
				_localctx = new PrimaryValueCommandOrPrimaryValueClassContext(_localctx);
				enterOuterAlt(_localctx, 2);
				{
				setState(1633);
				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 = 92;
		enterRecursionRule(_localctx, 92, RULE_commandOrPrimaryValue, _p);
		int _la;
		try {
			int _alt;
			enterOuterAlt(_localctx, 1);
			{
			setState(1641);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,216,_ctx) ) {
			case 1:
				{
				_localctx = new PrimaryValueCommandOrPrimaryValueContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;

				setState(1637);
				primaryValue(0);
				}
				break;
			case 2:
				{
				_localctx = new CommandCommandOrPrimaryValueContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(1638);
				command();
				}
				break;
			case 3:
				{
				_localctx = new NotCommandOrPrimaryValueContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(1639);
				match(NOT);
				setState(1640);
				commandOrPrimaryValue(2);
				}
				break;
			}
			_ctx.stop = _input.LT(-1);
			setState(1654);
			_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 ) {
					if ( _parseListeners!=null ) triggerExitRuleEvent();
					_prevctx = _localctx;
					{
					{
					_localctx = new KeywordAndOrCommandOrPrimaryValueContext(new CommandOrPrimaryValueContext(_parentctx, _parentState));
					pushNewRecursionContext(_localctx, _startState, RULE_commandOrPrimaryValue);
					setState(1643);
					if (!(precpred(_ctx, 1))) throw new FailedPredicateException(this, "precpred(_ctx, 1)");
					setState(1644);
					_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(1648);
					_errHandler.sync(this);
					_la = _input.LA(1);
					while (_la==NL) {
						{
						{
						setState(1645);
						match(NL);
						}
						}
						setState(1650);
						_errHandler.sync(this);
						_la = _input.LA(1);
					}
					setState(1651);
					commandOrPrimaryValue(2);
					}
					} 
				}
				setState(1656);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,218,_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, 94, RULE_block);
		int _la;
		try {
			int _alt;
			setState(1671);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case LCURLY:
				_localctx = new CurlyBracesBlockContext(_localctx);
				enterOuterAlt(_localctx, 1);
				{
				setState(1657);
				match(LCURLY);
				setState(1661);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,219,_ctx);
				while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) {
					if ( _alt==1 ) {
						{
						{
						setState(1658);
						match(NL);
						}
						} 
					}
					setState(1663);
					_errHandler.sync(this);
					_alt = getInterpreter().adaptivePredict(_input,219,_ctx);
				}
				setState(1665);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==BAR) {
					{
					setState(1664);
					blockParameter();
					}
				}

				setState(1667);
				compoundStatement();
				setState(1668);
				match(RCURLY);
				}
				break;
			case DO:
				_localctx = new DoBlockBlockContext(_localctx);
				enterOuterAlt(_localctx, 2);
				{
				setState(1670);
				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, 96, RULE_doBlock);
		int _la;
		try {
			int _alt;
			enterOuterAlt(_localctx, 1);
			{
			setState(1673);
			match(DO);
			setState(1677);
			_errHandler.sync(this);
			_alt = getInterpreter().adaptivePredict(_input,222,_ctx);
			while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) {
				if ( _alt==1 ) {
					{
					{
					setState(1674);
					match(NL);
					}
					} 
				}
				setState(1679);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,222,_ctx);
			}
			setState(1681);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==BAR) {
				{
				setState(1680);
				blockParameter();
				}
			}

			setState(1683);
			bodyStatement();
			setState(1684);
			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, 98, RULE_blockParameter);
		int _la;
		try {
			setState(1710);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,227,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(1686);
				match(BAR);
				setState(1690);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==NL) {
					{
					{
					setState(1687);
					match(NL);
					}
					}
					setState(1692);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(1693);
				match(BAR);
				}
				break;
			case 2:
				enterOuterAlt(_localctx, 2);
				{
				setState(1694);
				match(BAR);
				setState(1698);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==NL) {
					{
					{
					setState(1695);
					match(NL);
					}
					}
					setState(1700);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(1701);
				blockParameterList();
				setState(1705);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==NL) {
					{
					{
					setState(1702);
					match(NL);
					}
					}
					setState(1707);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(1708);
				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, 100, RULE_blockParameterList);
		int _la;
		try {
			int _alt;
			setState(1802);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case LPAREN:
			case LOCAL_VARIABLE_IDENTIFIER:
				enterOuterAlt(_localctx, 1);
				{
				setState(1712);
				mandatoryOrOptionalOrGroupedParameterList();
				setState(1721);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,229,_ctx) ) {
				case 1:
					{
					setState(1713);
					match(COMMA);
					setState(1717);
					_errHandler.sync(this);
					_la = _input.LA(1);
					while (_la==NL) {
						{
						{
						setState(1714);
						match(NL);
						}
						}
						setState(1719);
						_errHandler.sync(this);
						_la = _input.LA(1);
					}
					setState(1720);
					arrayParameter();
					}
					break;
				}
				setState(1733);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,231,_ctx);
				while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) {
					if ( _alt==1 ) {
						{
						{
						setState(1723);
						match(COMMA);
						setState(1727);
						_errHandler.sync(this);
						_la = _input.LA(1);
						while (_la==NL) {
							{
							{
							setState(1724);
							match(NL);
							}
							}
							setState(1729);
							_errHandler.sync(this);
							_la = _input.LA(1);
						}
						setState(1730);
						mandatoryOrGroupedParameterList();
						}
						} 
					}
					setState(1735);
					_errHandler.sync(this);
					_alt = getInterpreter().adaptivePredict(_input,231,_ctx);
				}
				setState(1744);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,233,_ctx) ) {
				case 1:
					{
					setState(1736);
					match(COMMA);
					setState(1740);
					_errHandler.sync(this);
					_la = _input.LA(1);
					while (_la==NL) {
						{
						{
						setState(1737);
						match(NL);
						}
						}
						setState(1742);
						_errHandler.sync(this);
						_la = _input.LA(1);
					}
					setState(1743);
					hashParameter();
					}
					break;
				}
				setState(1754);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==COMMA) {
					{
					setState(1746);
					match(COMMA);
					setState(1750);
					_errHandler.sync(this);
					_la = _input.LA(1);
					while (_la==NL) {
						{
						{
						setState(1747);
						match(NL);
						}
						}
						setState(1752);
						_errHandler.sync(this);
						_la = _input.LA(1);
					}
					setState(1753);
					procParameter();
					}
				}

				}
				break;
			case STAR:
				enterOuterAlt(_localctx, 2);
				{
				setState(1756);
				arrayParameter();
				setState(1767);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,237,_ctx);
				while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) {
					if ( _alt==1 ) {
						{
						{
						setState(1757);
						match(COMMA);
						setState(1761);
						_errHandler.sync(this);
						_la = _input.LA(1);
						while (_la==NL) {
							{
							{
							setState(1758);
							match(NL);
							}
							}
							setState(1763);
							_errHandler.sync(this);
							_la = _input.LA(1);
						}
						setState(1764);
						mandatoryOrGroupedParameterList();
						}
						} 
					}
					setState(1769);
					_errHandler.sync(this);
					_alt = getInterpreter().adaptivePredict(_input,237,_ctx);
				}
				setState(1778);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,239,_ctx) ) {
				case 1:
					{
					setState(1770);
					match(COMMA);
					setState(1774);
					_errHandler.sync(this);
					_la = _input.LA(1);
					while (_la==NL) {
						{
						{
						setState(1771);
						match(NL);
						}
						}
						setState(1776);
						_errHandler.sync(this);
						_la = _input.LA(1);
					}
					setState(1777);
					hashParameter();
					}
					break;
				}
				setState(1788);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==COMMA) {
					{
					setState(1780);
					match(COMMA);
					setState(1784);
					_errHandler.sync(this);
					_la = _input.LA(1);
					while (_la==NL) {
						{
						{
						setState(1781);
						match(NL);
						}
						}
						setState(1786);
						_errHandler.sync(this);
						_la = _input.LA(1);
					}
					setState(1787);
					procParameter();
					}
				}

				}
				break;
			case STAR2:
				enterOuterAlt(_localctx, 3);
				{
				setState(1790);
				hashParameter();
				setState(1799);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==COMMA) {
					{
					setState(1791);
					match(COMMA);
					setState(1795);
					_errHandler.sync(this);
					_la = _input.LA(1);
					while (_la==NL) {
						{
						{
						setState(1792);
						match(NL);
						}
						}
						setState(1797);
						_errHandler.sync(this);
						_la = _input.LA(1);
					}
					setState(1798);
					procParameter();
					}
				}

				}
				break;
			case AMP:
				enterOuterAlt(_localctx, 4);
				{
				setState(1801);
				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, 102, RULE_mandatoryOrOptionalOrGroupedParameterList);
		int _la;
		try {
			int _alt;
			enterOuterAlt(_localctx, 1);
			{
			setState(1804);
			mandatoryOrOptionalOrGroupedParameter();
			setState(1815);
			_errHandler.sync(this);
			_alt = getInterpreter().adaptivePredict(_input,246,_ctx);
			while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) {
				if ( _alt==1 ) {
					{
					{
					setState(1805);
					match(COMMA);
					setState(1809);
					_errHandler.sync(this);
					_la = _input.LA(1);
					while (_la==NL) {
						{
						{
						setState(1806);
						match(NL);
						}
						}
						setState(1811);
						_errHandler.sync(this);
						_la = _input.LA(1);
					}
					setState(1812);
					mandatoryOrOptionalOrGroupedParameter();
					}
					} 
				}
				setState(1817);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,246,_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, 104, RULE_mandatoryOrOptionalOrGroupedParameter);
		try {
			setState(1821);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,247,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(1818);
				mandatoryParameter();
				}
				break;
			case 2:
				enterOuterAlt(_localctx, 2);
				{
				setState(1819);
				optionalParameter();
				}
				break;
			case 3:
				enterOuterAlt(_localctx, 3);
				{
				setState(1820);
				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, 106, RULE_mandatoryOrGroupedParameterList);
		int _la;
		try {
			int _alt;
			enterOuterAlt(_localctx, 1);
			{
			setState(1823);
			mandatoryOrGroupedParameter();
			setState(1834);
			_errHandler.sync(this);
			_alt = getInterpreter().adaptivePredict(_input,249,_ctx);
			while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) {
				if ( _alt==1 ) {
					{
					{
					setState(1824);
					match(COMMA);
					setState(1828);
					_errHandler.sync(this);
					_la = _input.LA(1);
					while (_la==NL) {
						{
						{
						setState(1825);
						match(NL);
						}
						}
						setState(1830);
						_errHandler.sync(this);
						_la = _input.LA(1);
					}
					setState(1831);
					mandatoryOrGroupedParameter();
					}
					} 
				}
				setState(1836);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,249,_ctx);
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class 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, 108, RULE_mandatoryOrGroupedParameter);
		try {
			setState(1839);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case LOCAL_VARIABLE_IDENTIFIER:
				enterOuterAlt(_localctx, 1);
				{
				setState(1837);
				mandatoryParameter();
				}
				break;
			case LPAREN:
				enterOuterAlt(_localctx, 2);
				{
				setState(1838);
				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, 110, RULE_groupedParameterList);
		int _la;
		try {
			setState(1885);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,257,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(1841);
				match(LPAREN);
				setState(1842);
				mandatoryParameter();
				setState(1851);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,252,_ctx) ) {
				case 1:
					{
					setState(1843);
					match(COMMA);
					setState(1847);
					_errHandler.sync(this);
					_la = _input.LA(1);
					while (_la==NL) {
						{
						{
						setState(1844);
						match(NL);
						}
						}
						setState(1849);
						_errHandler.sync(this);
						_la = _input.LA(1);
					}
					setState(1850);
					arrayParameter();
					}
					break;
				}
				setState(1863);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==COMMA) {
					{
					{
					setState(1853);
					match(COMMA);
					setState(1857);
					_errHandler.sync(this);
					_la = _input.LA(1);
					while (_la==NL) {
						{
						{
						setState(1854);
						match(NL);
						}
						}
						setState(1859);
						_errHandler.sync(this);
						_la = _input.LA(1);
					}
					setState(1860);
					mandatoryParameter();
					}
					}
					setState(1865);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(1866);
				match(RPAREN);
				}
				break;
			case 2:
				enterOuterAlt(_localctx, 2);
				{
				setState(1868);
				match(LPAREN);
				setState(1869);
				arrayParameter();
				setState(1880);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==COMMA) {
					{
					{
					setState(1870);
					match(COMMA);
					setState(1874);
					_errHandler.sync(this);
					_la = _input.LA(1);
					while (_la==NL) {
						{
						{
						setState(1871);
						match(NL);
						}
						}
						setState(1876);
						_errHandler.sync(this);
						_la = _input.LA(1);
					}
					setState(1877);
					mandatoryParameter();
					}
					}
					setState(1882);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(1883);
				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, 112, RULE_thenClause);
		int _la;
		try {
			int _alt;
			setState(1898);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,260,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(1888); 
				_errHandler.sync(this);
				_alt = 1;
				do {
					switch (_alt) {
					case 1:
						{
						{
						setState(1887);
						_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(1890); 
					_errHandler.sync(this);
					_alt = getInterpreter().adaptivePredict(_input,258,_ctx);
				} while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER );
				setState(1892);
				compoundStatement();
				}
				break;
			case 2:
				enterOuterAlt(_localctx, 2);
				{
				setState(1894);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==SEMI || _la==NL) {
					{
					setState(1893);
					_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(1896);
				match(THEN);
				setState(1897);
				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, 114, RULE_elseClause);
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(1900);
			match(ELSE);
			setState(1901);
			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, 116, RULE_elsifClause);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(1903);
			match(ELSIF);
			setState(1907);
			_errHandler.sync(this);
			_la = _input.LA(1);
			while (_la==NL) {
				{
				{
				setState(1904);
				match(NL);
				}
				}
				setState(1909);
				_errHandler.sync(this);
				_la = _input.LA(1);
			}
			setState(1910);
			expressionOrCommand(0);
			setState(1911);
			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, 118, RULE_whenClause);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(1913);
			match(WHEN);
			setState(1917);
			_errHandler.sync(this);
			_la = _input.LA(1);
			while (_la==NL) {
				{
				{
				setState(1914);
				match(NL);
				}
				}
				setState(1919);
				_errHandler.sync(this);
				_la = _input.LA(1);
			}
			setState(1920);
			whenArgument();
			setState(1921);
			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, 120, RULE_whenArgument);
		int _la;
		try {
			setState(1929);
			_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(1923);
				operatorExpressionList();
				setState(1926);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==COMMA) {
					{
					setState(1924);
					match(COMMA);
					setState(1925);
					splattingArgument();
					}
				}

				}
				break;
			case STAR:
			case STAR2:
				enterOuterAlt(_localctx, 2);
				{
				setState(1928);
				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, 122, RULE_doClause);
		int _la;
		try {
			int _alt;
			setState(1939);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case SEMI:
			case NL:
				enterOuterAlt(_localctx, 1);
				{
				setState(1932); 
				_errHandler.sync(this);
				_alt = 1;
				do {
					switch (_alt) {
					case 1:
						{
						{
						setState(1931);
						_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(1934); 
					_errHandler.sync(this);
					_alt = getInterpreter().adaptivePredict(_input,265,_ctx);
				} while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER );
				setState(1936);
				compoundStatement();
				}
				break;
			case DO:
				enterOuterAlt(_localctx, 2);
				{
				setState(1937);
				match(DO);
				setState(1938);
				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, 124, RULE_forVariable);
		try {
			setState(1943);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,267,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(1941);
				leftHandSide();
				}
				break;
			case 2:
				enterOuterAlt(_localctx, 2);
				{
				setState(1942);
				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, 126, RULE_bodyStatement);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(1945);
			compoundStatement();
			setState(1949);
			_errHandler.sync(this);
			_la = _input.LA(1);
			while (_la==RESCUE) {
				{
				{
				setState(1946);
				rescueClause();
				}
				}
				setState(1951);
				_errHandler.sync(this);
				_la = _input.LA(1);
			}
			setState(1953);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==ELSE) {
				{
				setState(1952);
				elseClause();
				}
			}

			setState(1956);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==ENSURE) {
				{
				setState(1955);
				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, 128, RULE_rescueClause);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(1958);
			match(RESCUE);
			setState(1960);
			_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(1959);
				exceptionClassList();
				}
			}

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

			setState(1965);
			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, 130, RULE_exceptionClassList);
		try {
			setState(1969);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,273,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(1967);
				operatorExpression(0);
				}
				break;
			case 2:
				enterOuterAlt(_localctx, 2);
				{
				setState(1968);
				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, 132, RULE_exceptionVariableAssignment);
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(1971);
			match(EQGT);
			setState(1972);
			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, 134, RULE_ensureClause);
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(1974);
			match(ENSURE);
			setState(1975);
			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, 136, RULE_definedMethodName);
		try {
			setState(1988);
			_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(1977);
				methodName();
				}
				break;
			case ASSIGNMENT_LIKE_METHOD_IDENTIFIER:
				enterOuterAlt(_localctx, 2);
				{
				setState(1978);
				match(ASSIGNMENT_LIKE_METHOD_IDENTIFIER);
				}
				break;
			case LBRACK:
				enterOuterAlt(_localctx, 3);
				{
				setState(1979);
				match(LBRACK);
				setState(1980);
				match(RBRACK);
				setState(1982);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,274,_ctx) ) {
				case 1:
					{
					setState(1981);
					match(EQ);
					}
					break;
				}
				}
				break;
			case EQ2:
				enterOuterAlt(_localctx, 4);
				{
				setState(1984);
				match(EQ2);
				}
				break;
			case EQ3:
				enterOuterAlt(_localctx, 5);
				{
				setState(1985);
				match(EQ3);
				}
				break;
			case LTEQGT:
				enterOuterAlt(_localctx, 6);
				{
				setState(1986);
				match(LTEQGT);
				}
				break;
			case LT2:
				enterOuterAlt(_localctx, 7);
				{
				setState(1987);
				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, 138, RULE_methodParameterPart);
		int _la;
		try {
			int _alt;
			setState(2011);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case LPAREN:
				enterOuterAlt(_localctx, 1);
				{
				setState(1990);
				match(LPAREN);
				setState(1994);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,276,_ctx);
				while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) {
					if ( _alt==1 ) {
						{
						{
						setState(1991);
						match(NL);
						}
						} 
					}
					setState(1996);
					_errHandler.sync(this);
					_alt = getInterpreter().adaptivePredict(_input,276,_ctx);
				}
				setState(1998);
				_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(1997);
					parameterList();
					}
				}

				setState(2003);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==NL) {
					{
					{
					setState(2000);
					match(NL);
					}
					}
					setState(2005);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(2006);
				match(RPAREN);
				}
				break;
			case SEMI:
			case AMP:
			case STAR:
			case STAR2:
			case NL:
			case LOCAL_VARIABLE_IDENTIFIER:
				enterOuterAlt(_localctx, 2);
				{
				setState(2008);
				_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(2007);
					parameterList();
					}
				}

				setState(2010);
				_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, 140, RULE_parameterList);
		int _la;
		try {
			setState(2097);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case LOCAL_VARIABLE_IDENTIFIER:
				enterOuterAlt(_localctx, 1);
				{
				setState(2013);
				mandatoryOrOptionalParameterList();
				setState(2022);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,282,_ctx) ) {
				case 1:
					{
					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);
					arrayParameter();
					}
					break;
				}
				setState(2032);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,284,_ctx) ) {
				case 1:
					{
					setState(2024);
					match(COMMA);
					setState(2028);
					_errHandler.sync(this);
					_la = _input.LA(1);
					while (_la==NL) {
						{
						{
						setState(2025);
						match(NL);
						}
						}
						setState(2030);
						_errHandler.sync(this);
						_la = _input.LA(1);
					}
					setState(2031);
					mandatoryParameterList();
					}
					break;
				}
				setState(2042);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,286,_ctx) ) {
				case 1:
					{
					setState(2034);
					match(COMMA);
					setState(2038);
					_errHandler.sync(this);
					_la = _input.LA(1);
					while (_la==NL) {
						{
						{
						setState(2035);
						match(NL);
						}
						}
						setState(2040);
						_errHandler.sync(this);
						_la = _input.LA(1);
					}
					setState(2041);
					hashParameter();
					}
					break;
				}
				setState(2052);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==COMMA) {
					{
					setState(2044);
					match(COMMA);
					setState(2048);
					_errHandler.sync(this);
					_la = _input.LA(1);
					while (_la==NL) {
						{
						{
						setState(2045);
						match(NL);
						}
						}
						setState(2050);
						_errHandler.sync(this);
						_la = _input.LA(1);
					}
					setState(2051);
					procParameter();
					}
				}

				}
				break;
			case STAR:
				enterOuterAlt(_localctx, 2);
				{
				setState(2054);
				arrayParameter();
				setState(2063);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,290,_ctx) ) {
				case 1:
					{
					setState(2055);
					match(COMMA);
					setState(2059);
					_errHandler.sync(this);
					_la = _input.LA(1);
					while (_la==NL) {
						{
						{
						setState(2056);
						match(NL);
						}
						}
						setState(2061);
						_errHandler.sync(this);
						_la = _input.LA(1);
					}
					setState(2062);
					mandatoryParameterList();
					}
					break;
				}
				setState(2073);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,292,_ctx) ) {
				case 1:
					{
					setState(2065);
					match(COMMA);
					setState(2069);
					_errHandler.sync(this);
					_la = _input.LA(1);
					while (_la==NL) {
						{
						{
						setState(2066);
						match(NL);
						}
						}
						setState(2071);
						_errHandler.sync(this);
						_la = _input.LA(1);
					}
					setState(2072);
					hashParameter();
					}
					break;
				}
				setState(2083);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==COMMA) {
					{
					setState(2075);
					match(COMMA);
					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);
					procParameter();
					}
				}

				}
				break;
			case STAR2:
				enterOuterAlt(_localctx, 3);
				{
				setState(2085);
				hashParameter();
				setState(2094);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==COMMA) {
					{
					setState(2086);
					match(COMMA);
					setState(2090);
					_errHandler.sync(this);
					_la = _input.LA(1);
					while (_la==NL) {
						{
						{
						setState(2087);
						match(NL);
						}
						}
						setState(2092);
						_errHandler.sync(this);
						_la = _input.LA(1);
					}
					setState(2093);
					procParameter();
					}
				}

				}
				break;
			case AMP:
				enterOuterAlt(_localctx, 4);
				{
				setState(2096);
				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, 142, RULE_mandatoryOrOptionalParameterList);
		int _la;
		try {
			int _alt;
			enterOuterAlt(_localctx, 1);
			{
			setState(2099);
			mandatoryOrOptionalParameter();
			setState(2110);
			_errHandler.sync(this);
			_alt = getInterpreter().adaptivePredict(_input,299,_ctx);
			while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) {
				if ( _alt==1 ) {
					{
					{
					setState(2100);
					match(COMMA);
					setState(2104);
					_errHandler.sync(this);
					_la = _input.LA(1);
					while (_la==NL) {
						{
						{
						setState(2101);
						match(NL);
						}
						}
						setState(2106);
						_errHandler.sync(this);
						_la = _input.LA(1);
					}
					setState(2107);
					mandatoryOrOptionalParameter();
					}
					} 
				}
				setState(2112);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,299,_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, 144, RULE_mandatoryParameterList);
		int _la;
		try {
			int _alt;
			enterOuterAlt(_localctx, 1);
			{
			setState(2113);
			mandatoryParameter();
			setState(2124);
			_errHandler.sync(this);
			_alt = getInterpreter().adaptivePredict(_input,301,_ctx);
			while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) {
				if ( _alt==1 ) {
					{
					{
					setState(2114);
					match(COMMA);
					setState(2118);
					_errHandler.sync(this);
					_la = _input.LA(1);
					while (_la==NL) {
						{
						{
						setState(2115);
						match(NL);
						}
						}
						setState(2120);
						_errHandler.sync(this);
						_la = _input.LA(1);
					}
					setState(2121);
					mandatoryParameter();
					}
					} 
				}
				setState(2126);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,301,_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, 146, RULE_mandatoryOrOptionalParameter);
		try {
			setState(2129);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,302,_ctx) ) {
			case 1:
				_localctx = new MandatoryMandatoryOrOptionalParameterContext(_localctx);
				enterOuterAlt(_localctx, 1);
				{
				setState(2127);
				mandatoryParameter();
				}
				break;
			case 2:
				_localctx = new OptionalMandatoryOrOptionalParameterContext(_localctx);
				enterOuterAlt(_localctx, 2);
				{
				setState(2128);
				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, 148, RULE_mandatoryParameter);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(2131);
			match(LOCAL_VARIABLE_IDENTIFIER);
			setState(2133);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==COLON) {
				{
				setState(2132);
				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, 150, RULE_optionalParameter);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(2135);
			optionalParameterName();
			setState(2136);
			_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(2140);
			_errHandler.sync(this);
			_la = _input.LA(1);
			while (_la==NL) {
				{
				{
				setState(2137);
				match(NL);
				}
				}
				setState(2142);
				_errHandler.sync(this);
				_la = _input.LA(1);
			}
			setState(2143);
			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, 152, RULE_optionalParameterName);
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(2145);
			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, 154, RULE_arrayParameter);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(2147);
			match(STAR);
			setState(2149);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==LOCAL_VARIABLE_IDENTIFIER) {
				{
				setState(2148);
				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, 156, RULE_hashParameter);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(2151);
			match(STAR2);
			setState(2153);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==LOCAL_VARIABLE_IDENTIFIER) {
				{
				setState(2152);
				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, 158, RULE_procParameter);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(2155);
			match(AMP);
			setState(2157);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==LOCAL_VARIABLE_IDENTIFIER) {
				{
				setState(2156);
				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, 160, RULE_procParameterName);
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(2159);
			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 = 162;
		enterRecursionRule(_localctx, 162, RULE_classPath, _p);
		try {
			int _alt;
			enterOuterAlt(_localctx, 1);
			{
			setState(2165);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case COLON2:
				{
				_localctx = new TopClassPathContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;

				setState(2162);
				match(COLON2);
				setState(2163);
				match(CONSTANT_IDENTIFIER);
				}
				break;
			case CONSTANT_IDENTIFIER:
				{
				_localctx = new ClassNameContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(2164);
				match(CONSTANT_IDENTIFIER);
				}
				break;
			default:
				throw new NoViableAltException(this);
			}
			_ctx.stop = _input.LT(-1);
			setState(2172);
			_errHandler.sync(this);
			_alt = getInterpreter().adaptivePredict(_input,309,_ctx);
			while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) {
				if ( _alt==1 ) {
					if ( _parseListeners!=null ) triggerExitRuleEvent();
					_prevctx = _localctx;
					{
					{
					_localctx = new NestedClassPathContext(new ClassPathContext(_parentctx, _parentState));
					pushNewRecursionContext(_localctx, _startState, RULE_classPath);
					setState(2167);
					if (!(precpred(_ctx, 1))) throw new FailedPredicateException(this, "precpred(_ctx, 1)");
					setState(2168);
					match(COLON2);
					setState(2169);
					match(CONSTANT_IDENTIFIER);
					}
					} 
				}
				setState(2174);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,309,_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, 164, RULE_singletonObject);
		try {
			setState(2180);
			_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(2175);
				variableReference();
				}
				break;
			case LPAREN:
				_localctx = new ExpressionSingletonObjectContext(_localctx);
				enterOuterAlt(_localctx, 2);
				{
				setState(2176);
				match(LPAREN);
				setState(2177);
				expressionOrCommand(0);
				setState(2178);
				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, 166, RULE_variableReference);
		try {
			setState(2186);
			_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(2182);
				variable();
				}
				break;
			case LINE__:
			case ENCODING__:
			case FILE__:
			case FALSE:
			case NIL:
			case SELF:
			case TRUE:
				_localctx = new PseudoVariableVariableReferenceContext(_localctx);
				enterOuterAlt(_localctx, 2);
				{
				setState(2183);
				pseudoVariable();
				}
				break;
			case COLON2:
				_localctx = new ConstantVariableReferenceContext(_localctx);
				enterOuterAlt(_localctx, 3);
				{
				setState(2184);
				match(COLON2);
				setState(2185);
				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, 168, RULE_associationList);
		int _la;
		try {
			int _alt;
			enterOuterAlt(_localctx, 1);
			{
			setState(2188);
			association();
			setState(2199);
			_errHandler.sync(this);
			_alt = getInterpreter().adaptivePredict(_input,313,_ctx);
			while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) {
				if ( _alt==1 ) {
					{
					{
					setState(2189);
					match(COMMA);
					setState(2193);
					_errHandler.sync(this);
					_la = _input.LA(1);
					while (_la==NL) {
						{
						{
						setState(2190);
						match(NL);
						}
						}
						setState(2195);
						_errHandler.sync(this);
						_la = _input.LA(1);
					}
					setState(2196);
					association();
					}
					} 
				}
				setState(2201);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,313,_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, 170, RULE_association);
		int _la;
		try {
			setState(2213);
			_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(2202);
				associationKey();
				setState(2203);
				_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(2207);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==NL) {
					{
					{
					setState(2204);
					match(NL);
					}
					}
					setState(2209);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(2210);
				operatorExpression(0);
				}
				break;
			case STAR2:
				_localctx = new AssociationHashArgContext(_localctx);
				enterOuterAlt(_localctx, 2);
				{
				setState(2212);
				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, 172, RULE_associationKey);
		try {
			setState(2217);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,316,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(2215);
				operatorExpression(0);
				}
				break;
			case 2:
				enterOuterAlt(_localctx, 2);
				{
				setState(2216);
				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, 174, RULE_associationHashArgument);
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(2219);
			match(STAR2);
			setState(2226);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,317,_ctx) ) {
			case 1:
				{
				setState(2220);
				match(LOCAL_VARIABLE_IDENTIFIER);
				}
				break;
			case 2:
				{
				setState(2221);
				methodCallsWithParentheses();
				}
				break;
			case 3:
				{
				{
				setState(2222);
				match(LPAREN);
				setState(2223);
				methodInvocationWithoutParentheses();
				setState(2224);
				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, 176, RULE_regexpLiteralContent);
		try {
			setState(2233);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case REGULAR_EXPRESSION_BODY:
				enterOuterAlt(_localctx, 1);
				{
				setState(2228);
				match(REGULAR_EXPRESSION_BODY);
				}
				break;
			case REGULAR_EXPRESSION_INTERPOLATION_BEGIN:
				enterOuterAlt(_localctx, 2);
				{
				setState(2229);
				match(REGULAR_EXPRESSION_INTERPOLATION_BEGIN);
				setState(2230);
				compoundStatement();
				setState(2231);
				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, 178, RULE_singleQuotedString);
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(2235);
			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, 180, RULE_singleOrDoubleQuotedString);
		try {
			setState(2239);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case SINGLE_QUOTED_STRING_LITERAL:
				enterOuterAlt(_localctx, 1);
				{
				setState(2237);
				singleQuotedString();
				}
				break;
			case DOUBLE_QUOTED_STRING_START:
				enterOuterAlt(_localctx, 2);
				{
				setState(2238);
				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, 182, RULE_doubleQuotedString);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(2241);
			match(DOUBLE_QUOTED_STRING_START);
			setState(2245);
			_errHandler.sync(this);
			_la = _input.LA(1);
			while (_la==DOUBLE_QUOTED_STRING_CHARACTER_SEQUENCE || _la==STRING_INTERPOLATION_BEGIN) {
				{
				{
				setState(2242);
				doubleQuotedStringContent();
				}
				}
				setState(2247);
				_errHandler.sync(this);
				_la = _input.LA(1);
			}
			setState(2248);
			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, 184, RULE_quotedExpandedExternalCommandString);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(2250);
			match(QUOTED_EXPANDED_EXTERNAL_COMMAND_LITERAL_START);
			setState(2254);
			_errHandler.sync(this);
			_la = _input.LA(1);
			while (_la==EXPANDED_LITERAL_CHARACTER_SEQUENCE || _la==DELIMITED_STRING_INTERPOLATION_BEGIN) {
				{
				{
				setState(2251);
				quotedExpandedLiteralStringContent();
				}
				}
				setState(2256);
				_errHandler.sync(this);
				_la = _input.LA(1);
			}
			setState(2257);
			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, 186, RULE_doubleQuotedStringContent);
		try {
			setState(2264);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case DOUBLE_QUOTED_STRING_CHARACTER_SEQUENCE:
				enterOuterAlt(_localctx, 1);
				{
				setState(2259);
				match(DOUBLE_QUOTED_STRING_CHARACTER_SEQUENCE);
				}
				break;
			case STRING_INTERPOLATION_BEGIN:
				enterOuterAlt(_localctx, 2);
				{
				setState(2260);
				match(STRING_INTERPOLATION_BEGIN);
				setState(2261);
				compoundStatement();
				setState(2262);
				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, 188, RULE_quotedNonExpandedLiteralString);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(2266);
			match(QUOTED_NON_EXPANDED_STRING_LITERAL_START);
			setState(2268);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==NON_EXPANDED_LITERAL_CHARACTER_SEQUENCE) {
				{
				setState(2267);
				match(NON_EXPANDED_LITERAL_CHARACTER_SEQUENCE);
				}
			}

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