// Generated from /Users/Sugar/Documents/Msc/Software-Construction/many-ql/Fugazi/src/org/fugazi/ql/grammar/QL.g4 by ANTLR 4.5 package org.fugazi.ql.parser; import org.antlr.v4.runtime.*; import org.antlr.v4.runtime.atn.ATN; import org.antlr.v4.runtime.atn.ATNDeserializer; import org.antlr.v4.runtime.atn.ParserATNSimulator; import org.antlr.v4.runtime.atn.PredictionContextCache; import org.antlr.v4.runtime.dfa.DFA; import org.antlr.v4.runtime.misc.NotNull; import org.antlr.v4.runtime.tree.ParseTreeVisitor; import org.antlr.v4.runtime.tree.TerminalNode; import java.util.List; @SuppressWarnings({"all", "warnings", "unchecked", "unused", "cast"}) public class QLParser extends Parser { static { RuntimeMetaData.checkVersion("4.5", RuntimeMetaData.VERSION); } protected static final DFA[] _decisionToDFA; protected static final PredictionContextCache _sharedContextCache = new PredictionContextCache(); public static final int T__0=1, T__1=2, T__2=3, T__3=4, T__4=5, T__5=6, T__6=7, T__7=8, T__8=9, T__9=10, T__10=11, T__11=12, T__12=13, T__13=14, T__14=15, T__15=16, T__16=17, T__17=18, T__18=19, T__19=20, T__20=21, T__21=22, T__22=23, T__23=24, BOOL=25, STRING=26, INT=27, ID=28, COMMENT=29, WS=30, LINE_COMMENT=31; public static final int RULE_form = 0, RULE_statement = 1, RULE_ifStatement = 2, RULE_questionDeclaration = 3, RULE_type = 4, RULE_expression = 5; public static final String[] ruleNames = { "form", "statement", "ifStatement", "questionDeclaration", "type", "expression" }; private static final String[] _LITERAL_NAMES = { null, "'form'", "'{'", "'}'", "'if'", "'('", "')'", "';'", "'='", "'bool'", "'int'", "'string'", "'+'", "'-'", "'!'", "'*'", "'/'", "'>'", "'>='", "'<'", "'<='", "'=='", "'!='", "'&&'", "'||'" }; private static final String[] _SYMBOLIC_NAMES = { 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, "BOOL", "STRING", "INT", "ID", "COMMENT", "WS", "LINE_COMMENT" }; 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] = "<INVALID>"; } } } @Override @Deprecated public String[] getTokenNames() { return tokenNames; } @Override @NotNull public Vocabulary getVocabulary() { return VOCABULARY; } @Override public String getGrammarFileName() { return "QL.g4"; } @Override public String[] getRuleNames() { return ruleNames; } @Override public String getSerializedATN() { return _serializedATN; } @Override public ATN getATN() { return _ATN; } public QLParser(TokenStream input) { super(input); _interp = new ParserATNSimulator(this,_ATN,_decisionToDFA,_sharedContextCache); } public static class FormContext extends ParserRuleContext { public TerminalNode ID() { return getToken(QLParser.ID, 0); } public List<StatementContext> statement() { return getRuleContexts(StatementContext.class); } public StatementContext statement(int i) { return getRuleContext(StatementContext.class,i); } public FormContext(ParserRuleContext parent, int invokingState) { super(parent, invokingState); } @Override public int getRuleIndex() { return RULE_form; } @Override public <T> T accept(ParseTreeVisitor<? extends T> visitor) { if ( visitor instanceof QLVisitor ) return ((QLVisitor<? extends T>)visitor).visitForm(this); else return visitor.visitChildren(this); } } public final FormContext form() throws RecognitionException { FormContext _localctx = new FormContext(_ctx, getState()); enterRule(_localctx, 0, RULE_form); int _la; try { enterOuterAlt(_localctx, 1); { setState(12); match(T__0); setState(13); match(ID); setState(14); match(T__1); setState(18); _errHandler.sync(this); _la = _input.LA(1); while ((((_la) & ~0x3f) == 0 && ((1L << _la) & ((1L << T__3) | (1L << T__8) | (1L << T__9) | (1L << T__10))) != 0)) { { { setState(15); statement(); } } setState(20); _errHandler.sync(this); _la = _input.LA(1); } setState(21); match(T__2); } } 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 QuestionDeclarationContext questionDeclaration() { return getRuleContext(QuestionDeclarationContext.class,0); } public IfStatementContext ifStatement() { return getRuleContext(IfStatementContext.class,0); } public StatementContext(ParserRuleContext parent, int invokingState) { super(parent, invokingState); } @Override public int getRuleIndex() { return RULE_statement; } @Override public <T> T accept(ParseTreeVisitor<? extends T> visitor) { if ( visitor instanceof QLVisitor ) return ((QLVisitor<? extends T>)visitor).visitStatement(this); else return visitor.visitChildren(this); } } public final StatementContext statement() throws RecognitionException { StatementContext _localctx = new StatementContext(_ctx, getState()); enterRule(_localctx, 2, RULE_statement); try { setState(25); switch (_input.LA(1)) { case T__8: case T__9: case T__10: enterOuterAlt(_localctx, 1); { setState(23); questionDeclaration(); } break; case T__3: enterOuterAlt(_localctx, 2); { setState(24); ifStatement(); } 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 IfStatementContext extends ParserRuleContext { public ExpressionContext expression() { return getRuleContext(ExpressionContext.class,0); } public List<StatementContext> statement() { return getRuleContexts(StatementContext.class); } public StatementContext statement(int i) { return getRuleContext(StatementContext.class,i); } public IfStatementContext(ParserRuleContext parent, int invokingState) { super(parent, invokingState); } @Override public int getRuleIndex() { return RULE_ifStatement; } @Override public <T> T accept(ParseTreeVisitor<? extends T> visitor) { if ( visitor instanceof QLVisitor ) return ((QLVisitor<? extends T>)visitor).visitIfStatement(this); else return visitor.visitChildren(this); } } public final IfStatementContext ifStatement() throws RecognitionException { IfStatementContext _localctx = new IfStatementContext(_ctx, getState()); enterRule(_localctx, 4, RULE_ifStatement); int _la; try { enterOuterAlt(_localctx, 1); { setState(27); match(T__3); setState(28); match(T__4); setState(29); expression(0); setState(30); match(T__5); setState(31); match(T__1); setState(35); _errHandler.sync(this); _la = _input.LA(1); while ((((_la) & ~0x3f) == 0 && ((1L << _la) & ((1L << T__3) | (1L << T__8) | (1L << T__9) | (1L << T__10))) != 0)) { { { setState(32); statement(); } } setState(37); _errHandler.sync(this); _la = _input.LA(1); } setState(38); match(T__2); } } catch (RecognitionException re) { _localctx.exception = re; _errHandler.reportError(this, re); _errHandler.recover(this, re); } finally { exitRule(); } return _localctx; } public static class QuestionDeclarationContext extends ParserRuleContext { public QuestionDeclarationContext(ParserRuleContext parent, int invokingState) { super(parent, invokingState); } @Override public int getRuleIndex() { return RULE_questionDeclaration; } public QuestionDeclarationContext() { } public void copyFrom(QuestionDeclarationContext ctx) { super.copyFrom(ctx); } } public static class SimpleQuestionContext extends QuestionDeclarationContext { public TypeContext type() { return getRuleContext(TypeContext.class,0); } public TerminalNode ID() { return getToken(QLParser.ID, 0); } public TerminalNode STRING() { return getToken(QLParser.STRING, 0); } public SimpleQuestionContext(QuestionDeclarationContext ctx) { copyFrom(ctx); } @Override public <T> T accept(ParseTreeVisitor<? extends T> visitor) { if ( visitor instanceof QLVisitor ) return ((QLVisitor<? extends T>)visitor).visitSimpleQuestion(this); else return visitor.visitChildren(this); } } public static class ComputedQuestionContext extends QuestionDeclarationContext { public TypeContext type() { return getRuleContext(TypeContext.class,0); } public TerminalNode ID() { return getToken(QLParser.ID, 0); } public TerminalNode STRING() { return getToken(QLParser.STRING, 0); } public ExpressionContext expression() { return getRuleContext(ExpressionContext.class,0); } public ComputedQuestionContext(QuestionDeclarationContext ctx) { copyFrom(ctx); } @Override public <T> T accept(ParseTreeVisitor<? extends T> visitor) { if ( visitor instanceof QLVisitor ) return ((QLVisitor<? extends T>)visitor).visitComputedQuestion(this); else return visitor.visitChildren(this); } } public final QuestionDeclarationContext questionDeclaration() throws RecognitionException { QuestionDeclarationContext _localctx = new QuestionDeclarationContext(_ctx, getState()); enterRule(_localctx, 6, RULE_questionDeclaration); try { setState(56); switch ( getInterpreter().adaptivePredict(_input,3,_ctx) ) { case 1: _localctx = new SimpleQuestionContext(_localctx); enterOuterAlt(_localctx, 1); { setState(40); type(); setState(41); match(ID); setState(42); match(T__4); setState(43); match(STRING); setState(44); match(T__5); setState(45); match(T__6); } break; case 2: _localctx = new ComputedQuestionContext(_localctx); enterOuterAlt(_localctx, 2); { setState(47); type(); setState(48); match(ID); setState(49); match(T__4); setState(50); match(STRING); setState(51); match(T__5); setState(52); match(T__7); setState(53); expression(0); setState(54); match(T__6); } break; } } catch (RecognitionException re) { _localctx.exception = re; _errHandler.reportError(this, re); _errHandler.recover(this, re); } finally { exitRule(); } return _localctx; } public static class TypeContext extends ParserRuleContext { public TypeContext(ParserRuleContext parent, int invokingState) { super(parent, invokingState); } @Override public int getRuleIndex() { return RULE_type; } public TypeContext() { } public void copyFrom(TypeContext ctx) { super.copyFrom(ctx); } } public static class StringTypeContext extends TypeContext { public StringTypeContext(TypeContext ctx) { copyFrom(ctx); } @Override public <T> T accept(ParseTreeVisitor<? extends T> visitor) { if ( visitor instanceof QLVisitor ) return ((QLVisitor<? extends T>)visitor).visitStringType(this); else return visitor.visitChildren(this); } } public static class BoolTypeContext extends TypeContext { public BoolTypeContext(TypeContext ctx) { copyFrom(ctx); } @Override public <T> T accept(ParseTreeVisitor<? extends T> visitor) { if ( visitor instanceof QLVisitor ) return ((QLVisitor<? extends T>)visitor).visitBoolType(this); else return visitor.visitChildren(this); } } public static class IntTypeContext extends TypeContext { public IntTypeContext(TypeContext ctx) { copyFrom(ctx); } @Override public <T> T accept(ParseTreeVisitor<? extends T> visitor) { if ( visitor instanceof QLVisitor ) return ((QLVisitor<? extends T>)visitor).visitIntType(this); else return visitor.visitChildren(this); } } public final TypeContext type() throws RecognitionException { TypeContext _localctx = new TypeContext(_ctx, getState()); enterRule(_localctx, 8, RULE_type); try { setState(61); switch (_input.LA(1)) { case T__8: _localctx = new BoolTypeContext(_localctx); enterOuterAlt(_localctx, 1); { setState(58); match(T__8); } break; case T__9: _localctx = new IntTypeContext(_localctx); enterOuterAlt(_localctx, 2); { setState(59); match(T__9); } break; case T__10: _localctx = new StringTypeContext(_localctx); enterOuterAlt(_localctx, 3); { setState(60); match(T__10); } 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 ExpressionContext extends ParserRuleContext { public ExpressionContext(ParserRuleContext parent, int invokingState) { super(parent, invokingState); } @Override public int getRuleIndex() { return RULE_expression; } public ExpressionContext() { } public void copyFrom(ExpressionContext ctx) { super.copyFrom(ctx); } } public static class StringExpressionContext extends ExpressionContext { public TerminalNode STRING() { return getToken(QLParser.STRING, 0); } public StringExpressionContext(ExpressionContext ctx) { copyFrom(ctx); } @Override public <T> T accept(ParseTreeVisitor<? extends T> visitor) { if ( visitor instanceof QLVisitor ) return ((QLVisitor<? extends T>)visitor).visitStringExpression(this); else return visitor.visitChildren(this); } } public static class LogicalOrExpressionContext extends ExpressionContext { public List<ExpressionContext> expression() { return getRuleContexts(ExpressionContext.class); } public ExpressionContext expression(int i) { return getRuleContext(ExpressionContext.class,i); } public LogicalOrExpressionContext(ExpressionContext ctx) { copyFrom(ctx); } @Override public <T> T accept(ParseTreeVisitor<? extends T> visitor) { if ( visitor instanceof QLVisitor ) return ((QLVisitor<? extends T>)visitor).visitLogicalOrExpression(this); else return visitor.visitChildren(this); } } public static class ParenthesisExpressionContext extends ExpressionContext { public ExpressionContext expression() { return getRuleContext(ExpressionContext.class,0); } public ParenthesisExpressionContext(ExpressionContext ctx) { copyFrom(ctx); } @Override public <T> T accept(ParseTreeVisitor<? extends T> visitor) { if ( visitor instanceof QLVisitor ) return ((QLVisitor<? extends T>)visitor).visitParenthesisExpression(this); else return visitor.visitChildren(this); } } public static class BoolExpressionContext extends ExpressionContext { public TerminalNode BOOL() { return getToken(QLParser.BOOL, 0); } public BoolExpressionContext(ExpressionContext ctx) { copyFrom(ctx); } @Override public <T> T accept(ParseTreeVisitor<? extends T> visitor) { if ( visitor instanceof QLVisitor ) return ((QLVisitor<? extends T>)visitor).visitBoolExpression(this); else return visitor.visitChildren(this); } } public static class UnaryExpressionContext extends ExpressionContext { public Token op; public ExpressionContext expression() { return getRuleContext(ExpressionContext.class,0); } public UnaryExpressionContext(ExpressionContext ctx) { copyFrom(ctx); } @Override public <T> T accept(ParseTreeVisitor<? extends T> visitor) { if ( visitor instanceof QLVisitor ) return ((QLVisitor<? extends T>)visitor).visitUnaryExpression(this); else return visitor.visitChildren(this); } } public static class IdentifierExpressionContext extends ExpressionContext { public TerminalNode ID() { return getToken(QLParser.ID, 0); } public IdentifierExpressionContext(ExpressionContext ctx) { copyFrom(ctx); } @Override public <T> T accept(ParseTreeVisitor<? extends T> visitor) { if ( visitor instanceof QLVisitor ) return ((QLVisitor<? extends T>)visitor).visitIdentifierExpression(this); else return visitor.visitChildren(this); } } public static class LogicalAndExpressionContext extends ExpressionContext { public List<ExpressionContext> expression() { return getRuleContexts(ExpressionContext.class); } public ExpressionContext expression(int i) { return getRuleContext(ExpressionContext.class,i); } public LogicalAndExpressionContext(ExpressionContext ctx) { copyFrom(ctx); } @Override public <T> T accept(ParseTreeVisitor<? extends T> visitor) { if ( visitor instanceof QLVisitor ) return ((QLVisitor<? extends T>)visitor).visitLogicalAndExpression(this); else return visitor.visitChildren(this); } } public static class IntExpressionContext extends ExpressionContext { public TerminalNode INT() { return getToken(QLParser.INT, 0); } public IntExpressionContext(ExpressionContext ctx) { copyFrom(ctx); } @Override public <T> T accept(ParseTreeVisitor<? extends T> visitor) { if ( visitor instanceof QLVisitor ) return ((QLVisitor<? extends T>)visitor).visitIntExpression(this); else return visitor.visitChildren(this); } } public static class ComparisonExpressionContext extends ExpressionContext { public Token op; public List<ExpressionContext> expression() { return getRuleContexts(ExpressionContext.class); } public ExpressionContext expression(int i) { return getRuleContext(ExpressionContext.class,i); } public ComparisonExpressionContext(ExpressionContext ctx) { copyFrom(ctx); } @Override public <T> T accept(ParseTreeVisitor<? extends T> visitor) { if ( visitor instanceof QLVisitor ) return ((QLVisitor<? extends T>)visitor).visitComparisonExpression(this); else return visitor.visitChildren(this); } } public static class AddSubExpressionContext extends ExpressionContext { public Token op; public List<ExpressionContext> expression() { return getRuleContexts(ExpressionContext.class); } public ExpressionContext expression(int i) { return getRuleContext(ExpressionContext.class,i); } public AddSubExpressionContext(ExpressionContext ctx) { copyFrom(ctx); } @Override public <T> T accept(ParseTreeVisitor<? extends T> visitor) { if ( visitor instanceof QLVisitor ) return ((QLVisitor<? extends T>)visitor).visitAddSubExpression(this); else return visitor.visitChildren(this); } } public static class MulDivExpressionContext extends ExpressionContext { public Token op; public List<ExpressionContext> expression() { return getRuleContexts(ExpressionContext.class); } public ExpressionContext expression(int i) { return getRuleContext(ExpressionContext.class,i); } public MulDivExpressionContext(ExpressionContext ctx) { copyFrom(ctx); } @Override public <T> T accept(ParseTreeVisitor<? extends T> visitor) { if ( visitor instanceof QLVisitor ) return ((QLVisitor<? extends T>)visitor).visitMulDivExpression(this); else return visitor.visitChildren(this); } } public final ExpressionContext expression() throws RecognitionException { return expression(0); } private ExpressionContext expression(int _p) throws RecognitionException { ParserRuleContext _parentctx = _ctx; int _parentState = getState(); ExpressionContext _localctx = new ExpressionContext(_ctx, _parentState); ExpressionContext _prevctx = _localctx; int _startState = 10; enterRecursionRule(_localctx, 10, RULE_expression, _p); int _la; try { int _alt; enterOuterAlt(_localctx, 1); { setState(74); switch (_input.LA(1)) { case T__11: case T__12: case T__13: { _localctx = new UnaryExpressionContext(_localctx); _ctx = _localctx; _prevctx = _localctx; setState(64); ((UnaryExpressionContext)_localctx).op = _input.LT(1); _la = _input.LA(1); if ( !((((_la) & ~0x3f) == 0 && ((1L << _la) & ((1L << T__11) | (1L << T__12) | (1L << T__13))) != 0)) ) { ((UnaryExpressionContext)_localctx).op = (Token)_errHandler.recoverInline(this); } consume(); setState(65); expression(10); } break; case T__4: { _localctx = new ParenthesisExpressionContext(_localctx); _ctx = _localctx; _prevctx = _localctx; setState(66); match(T__4); setState(67); expression(0); setState(68); match(T__5); } break; case BOOL: { _localctx = new BoolExpressionContext(_localctx); _ctx = _localctx; _prevctx = _localctx; setState(70); match(BOOL); } break; case INT: { _localctx = new IntExpressionContext(_localctx); _ctx = _localctx; _prevctx = _localctx; setState(71); match(INT); } break; case STRING: { _localctx = new StringExpressionContext(_localctx); _ctx = _localctx; _prevctx = _localctx; setState(72); match(STRING); } break; case ID: { _localctx = new IdentifierExpressionContext(_localctx); _ctx = _localctx; _prevctx = _localctx; setState(73); match(ID); } break; default: throw new NoViableAltException(this); } _ctx.stop = _input.LT(-1); setState(93); _errHandler.sync(this); _alt = getInterpreter().adaptivePredict(_input,7,_ctx); while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) { if ( _alt==1 ) { if ( _parseListeners!=null ) triggerExitRuleEvent(); _prevctx = _localctx; { setState(91); switch ( getInterpreter().adaptivePredict(_input,6,_ctx) ) { case 1: { _localctx = new MulDivExpressionContext(new ExpressionContext(_parentctx, _parentState)); pushNewRecursionContext(_localctx, _startState, RULE_expression); setState(76); if (!(precpred(_ctx, 9))) throw new FailedPredicateException(this, "precpred(_ctx, 9)"); setState(77); ((MulDivExpressionContext)_localctx).op = _input.LT(1); _la = _input.LA(1); if ( !(_la==T__14 || _la==T__15) ) { ((MulDivExpressionContext)_localctx).op = (Token)_errHandler.recoverInline(this); } consume(); setState(78); expression(10); } break; case 2: { _localctx = new AddSubExpressionContext(new ExpressionContext(_parentctx, _parentState)); pushNewRecursionContext(_localctx, _startState, RULE_expression); setState(79); if (!(precpred(_ctx, 8))) throw new FailedPredicateException(this, "precpred(_ctx, 8)"); setState(80); ((AddSubExpressionContext)_localctx).op = _input.LT(1); _la = _input.LA(1); if ( !(_la==T__11 || _la==T__12) ) { ((AddSubExpressionContext)_localctx).op = (Token)_errHandler.recoverInline(this); } consume(); setState(81); expression(9); } break; case 3: { _localctx = new ComparisonExpressionContext(new ExpressionContext(_parentctx, _parentState)); pushNewRecursionContext(_localctx, _startState, RULE_expression); setState(82); if (!(precpred(_ctx, 7))) throw new FailedPredicateException(this, "precpred(_ctx, 7)"); setState(83); ((ComparisonExpressionContext)_localctx).op = _input.LT(1); _la = _input.LA(1); if ( !((((_la) & ~0x3f) == 0 && ((1L << _la) & ((1L << T__16) | (1L << T__17) | (1L << T__18) | (1L << T__19) | (1L << T__20) | (1L << T__21))) != 0)) ) { ((ComparisonExpressionContext)_localctx).op = (Token)_errHandler.recoverInline(this); } consume(); setState(84); expression(8); } break; case 4: { _localctx = new LogicalAndExpressionContext(new ExpressionContext(_parentctx, _parentState)); pushNewRecursionContext(_localctx, _startState, RULE_expression); setState(85); if (!(precpred(_ctx, 6))) throw new FailedPredicateException(this, "precpred(_ctx, 6)"); setState(86); match(T__22); setState(87); expression(7); } break; case 5: { _localctx = new LogicalOrExpressionContext(new ExpressionContext(_parentctx, _parentState)); pushNewRecursionContext(_localctx, _startState, RULE_expression); setState(88); if (!(precpred(_ctx, 5))) throw new FailedPredicateException(this, "precpred(_ctx, 5)"); setState(89); match(T__23); setState(90); expression(6); } break; } } } setState(95); _errHandler.sync(this); _alt = getInterpreter().adaptivePredict(_input,7,_ctx); } } } catch (RecognitionException re) { _localctx.exception = re; _errHandler.reportError(this, re); _errHandler.recover(this, re); } finally { unrollRecursionContexts(_parentctx); } return _localctx; } public boolean sempred(RuleContext _localctx, int ruleIndex, int predIndex) { switch (ruleIndex) { case 5: return expression_sempred((ExpressionContext)_localctx, predIndex); } return true; } private boolean expression_sempred(ExpressionContext _localctx, int predIndex) { switch (predIndex) { case 0: return precpred(_ctx, 9); case 1: return precpred(_ctx, 8); case 2: return precpred(_ctx, 7); case 3: return precpred(_ctx, 6); case 4: return precpred(_ctx, 5); } return true; } public static final String _serializedATN = "\3\u0430\ud6d1\u8206\uad2d\u4417\uaef1\u8d80\uaadd\3!c\4\2\t\2\4\3\t\3"+ "\4\4\t\4\4\5\t\5\4\6\t\6\4\7\t\7\3\2\3\2\3\2\3\2\7\2\23\n\2\f\2\16\2\26"+ "\13\2\3\2\3\2\3\3\3\3\5\3\34\n\3\3\4\3\4\3\4\3\4\3\4\3\4\7\4$\n\4\f\4"+ "\16\4\'\13\4\3\4\3\4\3\5\3\5\3\5\3\5\3\5\3\5\3\5\3\5\3\5\3\5\3\5\3\5\3"+ "\5\3\5\3\5\3\5\5\5;\n\5\3\6\3\6\3\6\5\6@\n\6\3\7\3\7\3\7\3\7\3\7\3\7\3"+ "\7\3\7\3\7\3\7\3\7\5\7M\n\7\3\7\3\7\3\7\3\7\3\7\3\7\3\7\3\7\3\7\3\7\3"+ "\7\3\7\3\7\3\7\3\7\7\7^\n\7\f\7\16\7a\13\7\3\7\2\3\f\b\2\4\6\b\n\f\2\6"+ "\3\2\16\20\3\2\21\22\3\2\16\17\3\2\23\30l\2\16\3\2\2\2\4\33\3\2\2\2\6"+ "\35\3\2\2\2\b:\3\2\2\2\n?\3\2\2\2\fL\3\2\2\2\16\17\7\3\2\2\17\20\7\36"+ "\2\2\20\24\7\4\2\2\21\23\5\4\3\2\22\21\3\2\2\2\23\26\3\2\2\2\24\22\3\2"+ "\2\2\24\25\3\2\2\2\25\27\3\2\2\2\26\24\3\2\2\2\27\30\7\5\2\2\30\3\3\2"+ "\2\2\31\34\5\b\5\2\32\34\5\6\4\2\33\31\3\2\2\2\33\32\3\2\2\2\34\5\3\2"+ "\2\2\35\36\7\6\2\2\36\37\7\7\2\2\37 \5\f\7\2 !\7\b\2\2!%\7\4\2\2\"$\5"+ "\4\3\2#\"\3\2\2\2$\'\3\2\2\2%#\3\2\2\2%&\3\2\2\2&(\3\2\2\2\'%\3\2\2\2"+ "()\7\5\2\2)\7\3\2\2\2*+\5\n\6\2+,\7\36\2\2,-\7\7\2\2-.\7\34\2\2./\7\b"+ "\2\2/\60\7\t\2\2\60;\3\2\2\2\61\62\5\n\6\2\62\63\7\36\2\2\63\64\7\7\2"+ "\2\64\65\7\34\2\2\65\66\7\b\2\2\66\67\7\n\2\2\678\5\f\7\289\7\t\2\29;"+ "\3\2\2\2:*\3\2\2\2:\61\3\2\2\2;\t\3\2\2\2<@\7\13\2\2=@\7\f\2\2>@\7\r\2"+ "\2?<\3\2\2\2?=\3\2\2\2?>\3\2\2\2@\13\3\2\2\2AB\b\7\1\2BC\t\2\2\2CM\5\f"+ "\7\fDE\7\7\2\2EF\5\f\7\2FG\7\b\2\2GM\3\2\2\2HM\7\33\2\2IM\7\35\2\2JM\7"+ "\34\2\2KM\7\36\2\2LA\3\2\2\2LD\3\2\2\2LH\3\2\2\2LI\3\2\2\2LJ\3\2\2\2L"+ "K\3\2\2\2M_\3\2\2\2NO\f\13\2\2OP\t\3\2\2P^\5\f\7\fQR\f\n\2\2RS\t\4\2\2"+ "S^\5\f\7\13TU\f\t\2\2UV\t\5\2\2V^\5\f\7\nWX\f\b\2\2XY\7\31\2\2Y^\5\f\7"+ "\tZ[\f\7\2\2[\\\7\32\2\2\\^\5\f\7\b]N\3\2\2\2]Q\3\2\2\2]T\3\2\2\2]W\3"+ "\2\2\2]Z\3\2\2\2^a\3\2\2\2_]\3\2\2\2_`\3\2\2\2`\r\3\2\2\2a_\3\2\2\2\n"+ "\24\33%:?L]_"; 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); } } }