// Generated from CalculatorParser.g4 by ANTLR 4.13.1 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", "CheckReturnValue"}) public class CalculatorParser extends Parser { static { RuntimeMetaData.checkVersion("4.13.1", RuntimeMetaData.VERSION); } protected static final DFA[] _decisionToDFA; protected static final PredictionContextCache _sharedContextCache = new PredictionContextCache(); public static final int PLUS=1, MINUS=2, DIVIDE=3, TIMES=4, LPAREN=5, RPAREN=6, PI=7, REALVAL=8, WS=9; public static final int RULE_expression = 0, RULE_term = 1; private static String[] makeRuleNames() { return new String[] { "expression", "term" }; } public static final String[] ruleNames = makeRuleNames(); private static String[] makeLiteralNames() { return new String[] { null, "'+'", "'-'", "'/'", "'*'", "'('", "')'" }; } private static final String[] _LITERAL_NAMES = makeLiteralNames(); private static String[] makeSymbolicNames() { return new String[] { null, "PLUS", "MINUS", "DIVIDE", "TIMES", "LPAREN", "RPAREN", "PI", "REALVAL", "WS" }; } 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 "CalculatorParser.g4"; } @Override public String[] getRuleNames() { return ruleNames; } @Override public String getSerializedATN() { return _serializedATN; } @Override public ATN getATN() { return _ATN; } public CalculatorParser(TokenStream input) { super(input); _interp = new ParserATNSimulator(this,_ATN,_decisionToDFA,_sharedContextCache); } @SuppressWarnings("CheckReturnValue") 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); } } @SuppressWarnings("CheckReturnValue") public static class TimesdivContext extends ExpressionContext { public Token op; public List expression() { return getRuleContexts(ExpressionContext.class); } public ExpressionContext expression(int i) { return getRuleContext(ExpressionContext.class,i); } public TerminalNode TIMES() { return getToken(CalculatorParser.TIMES, 0); } public TerminalNode DIVIDE() { return getToken(CalculatorParser.DIVIDE, 0); } public TimesdivContext(ExpressionContext ctx) { copyFrom(ctx); } @Override public T accept(ParseTreeVisitor visitor) { if ( visitor instanceof CalculatorParserVisitor ) return ((CalculatorParserVisitor)visitor).visitTimesdiv(this); else return visitor.visitChildren(this); } } @SuppressWarnings("CheckReturnValue") public static class PlusminusContext extends ExpressionContext { public Token op; public List expression() { return getRuleContexts(ExpressionContext.class); } public ExpressionContext expression(int i) { return getRuleContext(ExpressionContext.class,i); } public TerminalNode PLUS() { return getToken(CalculatorParser.PLUS, 0); } public TerminalNode MINUS() { return getToken(CalculatorParser.MINUS, 0); } public PlusminusContext(ExpressionContext ctx) { copyFrom(ctx); } @Override public T accept(ParseTreeVisitor visitor) { if ( visitor instanceof CalculatorParserVisitor ) return ((CalculatorParserVisitor)visitor).visitPlusminus(this); else return visitor.visitChildren(this); } } @SuppressWarnings("CheckReturnValue") public static class JusttermContext extends ExpressionContext { public TermContext term() { return getRuleContext(TermContext.class,0); } public JusttermContext(ExpressionContext ctx) { copyFrom(ctx); } @Override public T accept(ParseTreeVisitor visitor) { if ( visitor instanceof CalculatorParserVisitor ) return ((CalculatorParserVisitor)visitor).visitJustterm(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 = 0; enterRecursionRule(_localctx, 0, RULE_expression, _p); int _la; try { int _alt; enterOuterAlt(_localctx, 1); { { _localctx = new JusttermContext(_localctx); _ctx = _localctx; _prevctx = _localctx; setState(5); term(); } _ctx.stop = _input.LT(-1); setState(15); _errHandler.sync(this); _alt = getInterpreter().adaptivePredict(_input,1,_ctx); while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) { if ( _alt==1 ) { if ( _parseListeners!=null ) triggerExitRuleEvent(); _prevctx = _localctx; { setState(13); _errHandler.sync(this); switch ( getInterpreter().adaptivePredict(_input,0,_ctx) ) { case 1: { _localctx = new TimesdivContext(new ExpressionContext(_parentctx, _parentState)); pushNewRecursionContext(_localctx, _startState, RULE_expression); setState(7); if (!(precpred(_ctx, 3))) throw new FailedPredicateException(this, "precpred(_ctx, 3)"); setState(8); ((TimesdivContext)_localctx).op = _input.LT(1); _la = _input.LA(1); if ( !(_la==DIVIDE || _la==TIMES) ) { ((TimesdivContext)_localctx).op = (Token)_errHandler.recoverInline(this); } else { if ( _input.LA(1)==Token.EOF ) matchedEOF = true; _errHandler.reportMatch(this); consume(); } setState(9); expression(4); } break; case 2: { _localctx = new PlusminusContext(new ExpressionContext(_parentctx, _parentState)); pushNewRecursionContext(_localctx, _startState, RULE_expression); setState(10); if (!(precpred(_ctx, 2))) throw new FailedPredicateException(this, "precpred(_ctx, 2)"); setState(11); ((PlusminusContext)_localctx).op = _input.LT(1); _la = _input.LA(1); if ( !(_la==PLUS || _la==MINUS) ) { ((PlusminusContext)_localctx).op = (Token)_errHandler.recoverInline(this); } else { if ( _input.LA(1)==Token.EOF ) matchedEOF = true; _errHandler.reportMatch(this); consume(); } setState(12); expression(3); } break; } } } setState(17); _errHandler.sync(this); _alt = getInterpreter().adaptivePredict(_input,1,_ctx); } } } catch (RecognitionException re) { _localctx.exception = re; _errHandler.reportError(this, re); _errHandler.recover(this, re); } finally { unrollRecursionContexts(_parentctx); } return _localctx; } @SuppressWarnings("CheckReturnValue") public static class TermContext extends ParserRuleContext { public TermContext(ParserRuleContext parent, int invokingState) { super(parent, invokingState); } @Override public int getRuleIndex() { return RULE_term; } public TermContext() { } public void copyFrom(TermContext ctx) { super.copyFrom(ctx); } } @SuppressWarnings("CheckReturnValue") public static class ParensContext extends TermContext { public TerminalNode LPAREN() { return getToken(CalculatorParser.LPAREN, 0); } public ExpressionContext expression() { return getRuleContext(ExpressionContext.class,0); } public TerminalNode RPAREN() { return getToken(CalculatorParser.RPAREN, 0); } public ParensContext(TermContext ctx) { copyFrom(ctx); } @Override public T accept(ParseTreeVisitor visitor) { if ( visitor instanceof CalculatorParserVisitor ) return ((CalculatorParserVisitor)visitor).visitParens(this); else return visitor.visitChildren(this); } } @SuppressWarnings("CheckReturnValue") public static class PivalContext extends TermContext { public TerminalNode PI() { return getToken(CalculatorParser.PI, 0); } public PivalContext(TermContext ctx) { copyFrom(ctx); } @Override public T accept(ParseTreeVisitor visitor) { if ( visitor instanceof CalculatorParserVisitor ) return ((CalculatorParserVisitor)visitor).visitPival(this); else return visitor.visitChildren(this); } } @SuppressWarnings("CheckReturnValue") public static class RealvalContext extends TermContext { public TerminalNode REALVAL() { return getToken(CalculatorParser.REALVAL, 0); } public RealvalContext(TermContext ctx) { copyFrom(ctx); } @Override public T accept(ParseTreeVisitor visitor) { if ( visitor instanceof CalculatorParserVisitor ) return ((CalculatorParserVisitor)visitor).visitRealval(this); else return visitor.visitChildren(this); } } public final TermContext term() throws RecognitionException { TermContext _localctx = new TermContext(_ctx, getState()); enterRule(_localctx, 2, RULE_term); try { setState(24); _errHandler.sync(this); switch (_input.LA(1)) { case REALVAL: _localctx = new RealvalContext(_localctx); enterOuterAlt(_localctx, 1); { setState(18); match(REALVAL); } break; case PI: _localctx = new PivalContext(_localctx); enterOuterAlt(_localctx, 2); { setState(19); match(PI); } break; case LPAREN: _localctx = new ParensContext(_localctx); enterOuterAlt(_localctx, 3); { setState(20); match(LPAREN); setState(21); expression(0); setState(22); 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 boolean sempred(RuleContext _localctx, int ruleIndex, int predIndex) { switch (ruleIndex) { case 0: return expression_sempred((ExpressionContext)_localctx, predIndex); } return true; } private boolean expression_sempred(ExpressionContext _localctx, int predIndex) { switch (predIndex) { case 0: return precpred(_ctx, 3); case 1: return precpred(_ctx, 2); } return true; } public static final String _serializedATN = "\u0004\u0001\t\u001b\u0002\u0000\u0007\u0000\u0002\u0001\u0007\u0001\u0001"+ "\u0000\u0001\u0000\u0001\u0000\u0001\u0000\u0001\u0000\u0001\u0000\u0001"+ "\u0000\u0001\u0000\u0001\u0000\u0005\u0000\u000e\b\u0000\n\u0000\f\u0000"+ "\u0011\t\u0000\u0001\u0001\u0001\u0001\u0001\u0001\u0001\u0001\u0001\u0001"+ "\u0001\u0001\u0003\u0001\u0019\b\u0001\u0001\u0001\u0000\u0001\u0000\u0002"+ "\u0000\u0002\u0000\u0002\u0001\u0000\u0003\u0004\u0001\u0000\u0001\u0002"+ "\u001c\u0000\u0004\u0001\u0000\u0000\u0000\u0002\u0018\u0001\u0000\u0000"+ "\u0000\u0004\u0005\u0006\u0000\uffff\uffff\u0000\u0005\u0006\u0003\u0002"+ "\u0001\u0000\u0006\u000f\u0001\u0000\u0000\u0000\u0007\b\n\u0003\u0000"+ "\u0000\b\t\u0007\u0000\u0000\u0000\t\u000e\u0003\u0000\u0000\u0004\n\u000b"+ "\n\u0002\u0000\u0000\u000b\f\u0007\u0001\u0000\u0000\f\u000e\u0003\u0000"+ "\u0000\u0003\r\u0007\u0001\u0000\u0000\u0000\r\n\u0001\u0000\u0000\u0000"+ "\u000e\u0011\u0001\u0000\u0000\u0000\u000f\r\u0001\u0000\u0000\u0000\u000f"+ "\u0010\u0001\u0000\u0000\u0000\u0010\u0001\u0001\u0000\u0000\u0000\u0011"+ "\u000f\u0001\u0000\u0000\u0000\u0012\u0019\u0005\b\u0000\u0000\u0013\u0019"+ "\u0005\u0007\u0000\u0000\u0014\u0015\u0005\u0005\u0000\u0000\u0015\u0016"+ "\u0003\u0000\u0000\u0000\u0016\u0017\u0005\u0006\u0000\u0000\u0017\u0019"+ "\u0001\u0000\u0000\u0000\u0018\u0012\u0001\u0000\u0000\u0000\u0018\u0013"+ "\u0001\u0000\u0000\u0000\u0018\u0014\u0001\u0000\u0000\u0000\u0019\u0003"+ "\u0001\u0000\u0000\u0000\u0003\r\u000f\u0018"; 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); } } }