# Generated from ./pyfcstm/dsl/grammar/GrammarParser.g4 by ANTLR 4.9.3
# encoding: utf-8
from antlr4 import *
from io import StringIO
import sys
if sys.version_info[1] > 5:
from typing import TextIO
else:
from typing.io import TextIO
[docs]
def serializedATN():
with StringIO() as buf:
buf.write("\3\u608b\ua72a\u8133\ub9ed\u417c\u3be7\u7786\u5964\3]")
buf.write("\u02be\4\2\t\2\4\3\t\3\4\4\t\4\4\5\t\5\4\6\t\6\4\7\t\7")
buf.write("\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")
buf.write("\t\16\4\17\t\17\4\20\t\20\4\21\t\21\4\22\t\22\4\23\t\23")
buf.write("\4\24\t\24\4\25\t\25\4\26\t\26\4\27\t\27\4\30\t\30\4\31")
buf.write("\t\31\4\32\t\32\4\33\t\33\4\34\t\34\4\35\t\35\4\36\t\36")
buf.write('\4\37\t\37\4 \t \4!\t!\4"\t"\4#\t#\4$\t$\4%\t%\4&\t')
buf.write("&\3\2\3\2\3\2\3\3\7\3Q\n\3\f\3\16\3T\13\3\3\3\3\3\3\3")
buf.write("\3\4\3\4\3\4\3\4\3\4\3\4\3\4\3\5\5\5a\n\5\3\5\3\5\3\5")
buf.write("\3\5\5\5g\n\5\3\5\3\5\5\5k\n\5\3\5\3\5\3\5\3\5\5\5q\n")
buf.write("\5\3\5\3\5\7\5u\n\5\f\5\16\5x\13\5\3\5\5\5{\n\5\3\6\3")
buf.write("\6\3\6\3\6\3\6\3\6\3\6\3\6\3\6\3\6\3\6\5\6\u0088\n\6\3")
buf.write("\6\3\6\3\6\3\6\3\6\3\6\5\6\u0090\n\6\3\6\3\6\3\6\3\6\3")
buf.write("\6\3\6\3\6\3\6\3\6\3\6\3\6\3\6\3\6\5\6\u009f\n\6\3\6\3")
buf.write("\6\3\6\3\6\3\6\3\6\5\6\u00a7\n\6\3\6\3\6\3\6\3\6\3\6\3")
buf.write("\6\3\6\3\6\3\6\3\6\3\6\3\6\3\6\5\6\u00b6\n\6\3\6\3\6\3")
buf.write("\6\3\6\3\6\3\6\5\6\u00be\n\6\5\6\u00c0\n\6\3\7\3\7\3\7")
buf.write("\3\7\3\7\3\7\3\7\3\7\3\7\3\7\3\7\3\7\3\7\3\7\5\7\u00d0")
buf.write("\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")
buf.write("\7\3\7\3\7\5\7\u00e1\n\7\3\7\3\7\3\7\3\7\3\7\3\7\3\7\3")
buf.write("\7\3\7\3\7\3\7\3\7\3\7\5\7\u00f0\n\7\3\7\3\7\3\7\3\7\3")
buf.write("\7\3\7\3\7\3\7\3\7\3\7\3\7\3\7\3\7\5\7\u00ff\n\7\3\7\5")
buf.write("\7\u0102\n\7\3\b\3\b\5\b\u0106\n\b\3\b\3\b\3\b\3\b\3\b")
buf.write("\3\b\3\b\3\b\3\b\3\b\3\b\5\b\u0113\n\b\3\b\3\b\3\b\5\b")
buf.write("\u0118\n\b\3\b\3\b\3\b\3\b\5\b\u011e\n\b\3\t\3\t\5\t\u0122")
buf.write("\n\t\3\t\3\t\3\t\3\t\3\t\3\t\3\t\3\t\3\t\3\t\3\t\5\t\u012f")
buf.write("\n\t\3\t\3\t\3\t\5\t\u0134\n\t\3\t\3\t\3\t\3\t\5\t\u013a")
buf.write("\n\t\3\n\3\n\5\n\u013e\n\n\3\n\5\n\u0141\n\n\3\n\3\n\3")
buf.write("\n\3\n\3\n\3\n\5\n\u0149\n\n\3\n\3\n\3\n\3\n\3\n\5\n\u0150")
buf.write("\n\n\3\n\3\n\5\n\u0154\n\n\3\n\3\n\3\n\5\n\u0159\n\n\3")
buf.write("\n\5\n\u015c\n\n\3\n\3\n\3\n\3\n\5\n\u0162\n\n\3\13\3")
buf.write("\13\3\13\3\13\5\13\u0168\n\13\3\13\3\13\3\13\3\13\3\13")
buf.write("\3\13\3\13\3\13\3\13\3\13\3\13\3\13\3\13\3\13\3\13\5\13")
buf.write("\u0179\n\13\3\13\3\13\3\13\3\13\3\13\5\13\u0180\n\13\3")
buf.write("\13\3\13\3\13\3\13\5\13\u0186\n\13\3\f\3\f\3\f\3\f\5\f")
buf.write("\u018c\n\f\3\f\3\f\3\r\3\r\3\r\3\r\3\r\3\r\5\r\u0196\n")
buf.write("\r\3\r\3\r\7\r\u019a\n\r\f\r\16\r\u019d\13\r\3\r\3\r\5")
buf.write("\r\u01a1\n\r\3\16\3\16\3\16\5\16\u01a6\n\16\3\17\3\17")
buf.write("\3\17\3\17\3\17\3\17\3\20\3\20\3\20\3\20\3\20\7\20\u01b3")
buf.write("\n\20\f\20\16\20\u01b6\13\20\3\20\3\20\3\20\5\20\u01bb")
buf.write("\n\20\3\21\3\21\3\21\5\21\u01c0\n\21\3\22\3\22\3\22\3")
buf.write("\22\3\22\3\22\5\22\u01c8\n\22\3\22\3\22\3\23\3\23\3\23")
buf.write("\3\23\3\23\3\24\3\24\3\24\3\24\3\25\3\25\3\25\3\25\3\25")
buf.write("\3\25\3\25\3\25\3\25\3\25\3\25\3\25\7\25\u01e1\n\25\f")
buf.write("\25\16\25\u01e4\13\25\3\25\3\25\5\25\u01e8\n\25\3\26\3")
buf.write("\26\3\26\5\26\u01ed\n\26\3\27\7\27\u01f0\n\27\f\27\16")
buf.write("\27\u01f3\13\27\3\30\3\30\3\30\3\30\3\30\3\30\3\30\3\30")
buf.write("\3\30\3\30\5\30\u01ff\n\30\3\31\7\31\u0202\n\31\f\31\16")
buf.write("\31\u0205\13\31\3\31\3\31\3\32\7\32\u020a\n\32\f\32\16")
buf.write("\32\u020d\13\32\3\32\3\32\3\33\3\33\5\33\u0213\n\33\3")
buf.write("\34\3\34\3\34\3\34\3\34\3\35\3\35\3\35\3\35\3\35\3\36")
buf.write("\3\36\3\36\3\36\3\36\3\37\3\37\5\37\u0226\n\37\3 \3 \3")
buf.write(" \3 \3 \3 \3 \3 \3 \3 \3 \3 \3 \3 \5 \u0236\n \3 \3 \3")
buf.write(" \3 \3 \3 \3 \3 \3 \3 \3 \3 \3 \3 \3 \3 \3 \3 \3 \3 \3")
buf.write(" \7 \u024d\n \f \16 \u0250\13 \3!\3!\3!\3!\3!\3!\3!\3")
buf.write("!\3!\3!\3!\3!\3!\3!\3!\3!\3!\3!\3!\3!\3!\3!\3!\5!\u0269")
buf.write("\n!\3!\3!\3!\3!\3!\3!\3!\3!\3!\3!\3!\3!\3!\3!\3!\3!\3")
buf.write('!\3!\3!\3!\3!\7!\u0280\n!\f!\16!\u0283\13!\3"\3"\3"')
buf.write('\3"\3"\3"\3"\3"\3"\3"\3"\3"\3"\3"\3"\3"\3')
buf.write('"\3"\3"\3"\3"\3"\3"\3"\5"\u029d\n"\3"\3"\3')
buf.write('"\3"\3"\3"\3"\3"\3"\7"\u02a8\n"\f"\16"\u02ab')
buf.write('\13"\3#\3#\3$\3$\3%\3%\3&\5&\u02b4\n&\3&\3&\3&\7&\u02b9')
buf.write("\n&\f&\16&\u02bc\13&\3&\2\5>@B'\2\4\6\b\n\f\16\20\22")
buf.write('\24\26\30\32\34\36 "$&(*,.\60\62\64\668:<>@BDFHJ\2\20')
buf.write("\3\2\24\25\4\2''\62\62\3\2\r\16\3\2\678\4\2\64\6599")
buf.write('\3\2\36\37\4\2\33\33\66\66\4\2 !=>\3\2"#\4\2\31\31$$')
buf.write("\4\2\32\32%%\3\2@B\3\2CD\3\2\26\30\2\u0316\2L\3\2\2\2")
buf.write("\4R\3\2\2\2\6X\3\2\2\2\bz\3\2\2\2\n\u00bf\3\2\2\2\f\u0101")
buf.write("\3\2\2\2\16\u011d\3\2\2\2\20\u0139\3\2\2\2\22\u0161\3")
buf.write("\2\2\2\24\u0185\3\2\2\2\26\u0187\3\2\2\2\30\u018f\3\2")
buf.write("\2\2\32\u01a5\3\2\2\2\34\u01a7\3\2\2\2\36\u01ba\3\2\2")
buf.write('\2 \u01bf\3\2\2\2"\u01c1\3\2\2\2$\u01cb\3\2\2\2&\u01d0')
buf.write("\3\2\2\2(\u01d4\3\2\2\2*\u01ec\3\2\2\2,\u01f1\3\2\2\2")
buf.write(".\u01fe\3\2\2\2\60\u0203\3\2\2\2\62\u020b\3\2\2\2\64\u0212")
buf.write("\3\2\2\2\66\u0214\3\2\2\28\u0219\3\2\2\2:\u021e\3\2\2")
buf.write("\2<\u0225\3\2\2\2>\u0235\3\2\2\2@\u0268\3\2\2\2B\u029c")
buf.write("\3\2\2\2D\u02ac\3\2\2\2F\u02ae\3\2\2\2H\u02b0\3\2\2\2")
buf.write('J\u02b3\3\2\2\2LM\5B"\2MN\7\2\2\3N\3\3\2\2\2OQ\5\6\4')
buf.write("\2PO\3\2\2\2QT\3\2\2\2RP\3\2\2\2RS\3\2\2\2SU\3\2\2\2T")
buf.write("R\3\2\2\2UV\5\b\5\2VW\7\2\2\3W\5\3\2\2\2XY\7\4\2\2YZ\t")
buf.write("\2\2\2Z[\7F\2\2[\\\7?\2\2\\]\5> \2]^\7)\2\2^\7\3\2\2\2")
buf.write("_a\7\b\2\2`_\3\2\2\2`a\3\2\2\2ab\3\2\2\2bc\7\t\2\2cf\7")
buf.write("F\2\2de\7\7\2\2eg\7G\2\2fd\3\2\2\2fg\3\2\2\2gh\3\2\2\2")
buf.write("h{\7)\2\2ik\7\b\2\2ji\3\2\2\2jk\3\2\2\2kl\3\2\2\2lm\7")
buf.write("\t\2\2mp\7F\2\2no\7\7\2\2oq\7G\2\2pn\3\2\2\2pq\3\2\2\2")
buf.write("qr\3\2\2\2rv\7+\2\2su\5.\30\2ts\3\2\2\2ux\3\2\2\2vt\3")
buf.write("\2\2\2vw\3\2\2\2wy\3\2\2\2xv\3\2\2\2y{\7,\2\2z`\3\2\2")
buf.write("\2zj\3\2\2\2{\t\3\2\2\2|}\7\34\2\2}~\7(\2\2~\u0087\7F")
buf.write("\2\2\177\u0080\t\3\2\2\u0080\u0088\5J&\2\u0081\u0082\7")
buf.write("\62\2\2\u0082\u0083\7\22\2\2\u0083\u0084\7-\2\2\u0084")
buf.write('\u0085\5B"\2\u0085\u0086\7.\2\2\u0086\u0088\3\2\2\2\u0087')
buf.write("\177\3\2\2\2\u0087\u0081\3\2\2\2\u0087\u0088\3\2\2\2\u0088")
buf.write("\u008f\3\2\2\2\u0089\u0090\7)\2\2\u008a\u008b\7\21\2\2")
buf.write("\u008b\u008c\7+\2\2\u008c\u008d\5,\27\2\u008d\u008e\7")
buf.write(",\2\2\u008e\u0090\3\2\2\2\u008f\u0089\3\2\2\2\u008f\u008a")
buf.write("\3\2\2\2\u0090\u00c0\3\2\2\2\u0091\u0092\7F\2\2\u0092")
buf.write("\u0093\7(\2\2\u0093\u009e\7F\2\2\u0094\u0095\7'\2\2\u0095")
buf.write("\u009f\7F\2\2\u0096\u0097\7\62\2\2\u0097\u009f\5J&\2\u0098")
buf.write("\u0099\7\62\2\2\u0099\u009a\7\22\2\2\u009a\u009b\7-\2")
buf.write('\2\u009b\u009c\5B"\2\u009c\u009d\7.\2\2\u009d\u009f\3')
buf.write("\2\2\2\u009e\u0094\3\2\2\2\u009e\u0096\3\2\2\2\u009e\u0098")
buf.write("\3\2\2\2\u009e\u009f\3\2\2\2\u009f\u00a6\3\2\2\2\u00a0")
buf.write("\u00a7\7)\2\2\u00a1\u00a2\7\21\2\2\u00a2\u00a3\7+\2\2")
buf.write("\u00a3\u00a4\5,\27\2\u00a4\u00a5\7,\2\2\u00a5\u00a7\3")
buf.write("\2\2\2\u00a6\u00a0\3\2\2\2\u00a6\u00a1\3\2\2\2\u00a7\u00c0")
buf.write("\3\2\2\2\u00a8\u00a9\7F\2\2\u00a9\u00aa\7(\2\2\u00aa\u00b5")
buf.write("\7\34\2\2\u00ab\u00ac\7'\2\2\u00ac\u00b6\7F\2\2\u00ad")
buf.write("\u00ae\7\62\2\2\u00ae\u00b6\5J&\2\u00af\u00b0\7\62\2\2")
buf.write("\u00b0\u00b1\7\22\2\2\u00b1\u00b2\7-\2\2\u00b2\u00b3\5")
buf.write('B"\2\u00b3\u00b4\7.\2\2\u00b4\u00b6\3\2\2\2\u00b5\u00ab')
buf.write("\3\2\2\2\u00b5\u00ad\3\2\2\2\u00b5\u00af\3\2\2\2\u00b5")
buf.write("\u00b6\3\2\2\2\u00b6\u00bd\3\2\2\2\u00b7\u00be\7)\2\2")
buf.write("\u00b8\u00b9\7\21\2\2\u00b9\u00ba\7+\2\2\u00ba\u00bb\5")
buf.write(",\27\2\u00bb\u00bc\7,\2\2\u00bc\u00be\3\2\2\2\u00bd\u00b7")
buf.write("\3\2\2\2\u00bd\u00b8\3\2\2\2\u00be\u00c0\3\2\2\2\u00bf")
buf.write("|\3\2\2\2\u00bf\u0091\3\2\2\2\u00bf\u00a8\3\2\2\2\u00c0")
buf.write("\13\3\2\2\2\u00c1\u00c2\7\66\2\2\u00c2\u00c3\7F\2\2\u00c3")
buf.write("\u00c4\7(\2\2\u00c4\u00cf\7F\2\2\u00c5\u00c6\7'\2\2\u00c6")
buf.write("\u00d0\7F\2\2\u00c7\u00c8\7\62\2\2\u00c8\u00d0\5J&\2\u00c9")
buf.write("\u00ca\7\62\2\2\u00ca\u00cb\7\22\2\2\u00cb\u00cc\7-\2")
buf.write('\2\u00cc\u00cd\5B"\2\u00cd\u00ce\7.\2\2\u00ce\u00d0\3')
buf.write("\2\2\2\u00cf\u00c5\3\2\2\2\u00cf\u00c7\3\2\2\2\u00cf\u00c9")
buf.write("\3\2\2\2\u00cf\u00d0\3\2\2\2\u00d0\u00d1\3\2\2\2\u00d1")
buf.write("\u0102\7)\2\2\u00d2\u00d3\7\66\2\2\u00d3\u00d4\7F\2\2")
buf.write("\u00d4\u00d5\7(\2\2\u00d5\u00e0\7\34\2\2\u00d6\u00d7\7")
buf.write("'\2\2\u00d7\u00e1\7F\2\2\u00d8\u00d9\7\62\2\2\u00d9\u00e1")
buf.write("\5J&\2\u00da\u00db\7\62\2\2\u00db\u00dc\7\22\2\2\u00dc")
buf.write('\u00dd\7-\2\2\u00dd\u00de\5B"\2\u00de\u00df\7.\2\2\u00df')
buf.write("\u00e1\3\2\2\2\u00e0\u00d6\3\2\2\2\u00e0\u00d8\3\2\2\2")
buf.write("\u00e0\u00da\3\2\2\2\u00e0\u00e1\3\2\2\2\u00e1\u00e2\3")
buf.write("\2\2\2\u00e2\u0102\7)\2\2\u00e3\u00e4\7\66\2\2\u00e4\u00e5")
buf.write("\7\65\2\2\u00e5\u00e6\7(\2\2\u00e6\u00ef\7F\2\2\u00e7")
buf.write("\u00e8\t\3\2\2\u00e8\u00f0\5J&\2\u00e9\u00ea\7\62\2\2")
buf.write("\u00ea\u00eb\7\22\2\2\u00eb\u00ec\7-\2\2\u00ec\u00ed\5")
buf.write('B"\2\u00ed\u00ee\7.\2\2\u00ee\u00f0\3\2\2\2\u00ef\u00e7')
buf.write("\3\2\2\2\u00ef\u00e9\3\2\2\2\u00ef\u00f0\3\2\2\2\u00f0")
buf.write("\u00f1\3\2\2\2\u00f1\u0102\7)\2\2\u00f2\u00f3\7\66\2\2")
buf.write("\u00f3\u00f4\7\65\2\2\u00f4\u00f5\7(\2\2\u00f5\u00fe\7")
buf.write("\34\2\2\u00f6\u00f7\t\3\2\2\u00f7\u00ff\5J&\2\u00f8\u00f9")
buf.write("\7\62\2\2\u00f9\u00fa\7\22\2\2\u00fa\u00fb\7-\2\2\u00fb")
buf.write('\u00fc\5B"\2\u00fc\u00fd\7.\2\2\u00fd\u00ff\3\2\2\2\u00fe')
buf.write("\u00f6\3\2\2\2\u00fe\u00f8\3\2\2\2\u00fe\u00ff\3\2\2\2")
buf.write("\u00ff\u0100\3\2\2\2\u0100\u0102\7)\2\2\u0101\u00c1\3")
buf.write("\2\2\2\u0101\u00d2\3\2\2\2\u0101\u00e3\3\2\2\2\u0101\u00f2")
buf.write("\3\2\2\2\u0102\r\3\2\2\2\u0103\u0105\7\n\2\2\u0104\u0106")
buf.write("\7F\2\2\u0105\u0104\3\2\2\2\u0105\u0106\3\2\2\2\u0106")
buf.write("\u0107\3\2\2\2\u0107\u0108\7+\2\2\u0108\u0109\5,\27\2")
buf.write("\u0109\u010a\7,\2\2\u010a\u011e\3\2\2\2\u010b\u010c\7")
buf.write("\n\2\2\u010c\u010d\7\17\2\2\u010d\u010e\7F\2\2\u010e\u011e")
buf.write("\7)\2\2\u010f\u0110\7\n\2\2\u0110\u0112\7\17\2\2\u0111")
buf.write("\u0113\7F\2\2\u0112\u0111\3\2\2\2\u0112\u0113\3\2\2\2")
buf.write("\u0113\u0114\3\2\2\2\u0114\u011e\7H\2\2\u0115\u0117\7")
buf.write("\n\2\2\u0116\u0118\7F\2\2\u0117\u0116\3\2\2\2\u0117\u0118")
buf.write("\3\2\2\2\u0118\u0119\3\2\2\2\u0119\u011a\7\20\2\2\u011a")
buf.write("\u011b\5J&\2\u011b\u011c\7)\2\2\u011c\u011e\3\2\2\2\u011d")
buf.write("\u0103\3\2\2\2\u011d\u010b\3\2\2\2\u011d\u010f\3\2\2\2")
buf.write("\u011d\u0115\3\2\2\2\u011e\17\3\2\2\2\u011f\u0121\7\13")
buf.write("\2\2\u0120\u0122\7F\2\2\u0121\u0120\3\2\2\2\u0121\u0122")
buf.write("\3\2\2\2\u0122\u0123\3\2\2\2\u0123\u0124\7+\2\2\u0124")
buf.write("\u0125\5,\27\2\u0125\u0126\7,\2\2\u0126\u013a\3\2\2\2")
buf.write("\u0127\u0128\7\13\2\2\u0128\u0129\7\17\2\2\u0129\u012a")
buf.write("\7F\2\2\u012a\u013a\7)\2\2\u012b\u012c\7\13\2\2\u012c")
buf.write("\u012e\7\17\2\2\u012d\u012f\7F\2\2\u012e\u012d\3\2\2\2")
buf.write("\u012e\u012f\3\2\2\2\u012f\u0130\3\2\2\2\u0130\u013a\7")
buf.write("H\2\2\u0131\u0133\7\13\2\2\u0132\u0134\7F\2\2\u0133\u0132")
buf.write("\3\2\2\2\u0133\u0134\3\2\2\2\u0134\u0135\3\2\2\2\u0135")
buf.write("\u0136\7\20\2\2\u0136\u0137\5J&\2\u0137\u0138\7)\2\2\u0138")
buf.write("\u013a\3\2\2\2\u0139\u011f\3\2\2\2\u0139\u0127\3\2\2\2")
buf.write("\u0139\u012b\3\2\2\2\u0139\u0131\3\2\2\2\u013a\21\3\2")
buf.write("\2\2\u013b\u013d\7\f\2\2\u013c\u013e\t\4\2\2\u013d\u013c")
buf.write("\3\2\2\2\u013d\u013e\3\2\2\2\u013e\u0140\3\2\2\2\u013f")
buf.write("\u0141\7F\2\2\u0140\u013f\3\2\2\2\u0140\u0141\3\2\2\2")
buf.write("\u0141\u0142\3\2\2\2\u0142\u0143\7+\2\2\u0143\u0144\5")
buf.write(",\27\2\u0144\u0145\7,\2\2\u0145\u0162\3\2\2\2\u0146\u0148")
buf.write("\7\f\2\2\u0147\u0149\t\4\2\2\u0148\u0147\3\2\2\2\u0148")
buf.write("\u0149\3\2\2\2\u0149\u014a\3\2\2\2\u014a\u014b\7\17\2")
buf.write("\2\u014b\u014c\7F\2\2\u014c\u0162\7)\2\2\u014d\u014f\7")
buf.write("\f\2\2\u014e\u0150\t\4\2\2\u014f\u014e\3\2\2\2\u014f\u0150")
buf.write("\3\2\2\2\u0150\u0151\3\2\2\2\u0151\u0153\7\17\2\2\u0152")
buf.write("\u0154\7F\2\2\u0153\u0152\3\2\2\2\u0153\u0154\3\2\2\2")
buf.write("\u0154\u0155\3\2\2\2\u0155\u0162\7H\2\2\u0156\u0158\7")
buf.write("\f\2\2\u0157\u0159\t\4\2\2\u0158\u0157\3\2\2\2\u0158\u0159")
buf.write("\3\2\2\2\u0159\u015b\3\2\2\2\u015a\u015c\7F\2\2\u015b")
buf.write("\u015a\3\2\2\2\u015b\u015c\3\2\2\2\u015c\u015d\3\2\2\2")
buf.write("\u015d\u015e\7\20\2\2\u015e\u015f\5J&\2\u015f\u0160\7")
buf.write(")\2\2\u0160\u0162\3\2\2\2\u0161\u013b\3\2\2\2\u0161\u0146")
buf.write("\3\2\2\2\u0161\u014d\3\2\2\2\u0161\u0156\3\2\2\2\u0162")
buf.write("\23\3\2\2\2\u0163\u0164\7\36\2\2\u0164\u0165\7\f\2\2\u0165")
buf.write("\u0167\t\4\2\2\u0166\u0168\7F\2\2\u0167\u0166\3\2\2\2")
buf.write("\u0167\u0168\3\2\2\2\u0168\u0169\3\2\2\2\u0169\u016a\7")
buf.write("+\2\2\u016a\u016b\5,\27\2\u016b\u016c\7,\2\2\u016c\u0186")
buf.write("\3\2\2\2\u016d\u016e\7\36\2\2\u016e\u016f\7\f\2\2\u016f")
buf.write("\u0170\t\4\2\2\u0170\u0171\7\17\2\2\u0171\u0172\7F\2\2")
buf.write("\u0172\u0186\7)\2\2\u0173\u0174\7\36\2\2\u0174\u0175\7")
buf.write("\f\2\2\u0175\u0176\t\4\2\2\u0176\u0178\7\17\2\2\u0177")
buf.write("\u0179\7F\2\2\u0178\u0177\3\2\2\2\u0178\u0179\3\2\2\2")
buf.write("\u0179\u017a\3\2\2\2\u017a\u0186\7H\2\2\u017b\u017c\7")
buf.write("\36\2\2\u017c\u017d\7\f\2\2\u017d\u017f\t\4\2\2\u017e")
buf.write("\u0180\7F\2\2\u017f\u017e\3\2\2\2\u017f\u0180\3\2\2\2")
buf.write("\u0180\u0181\3\2\2\2\u0181\u0182\7\20\2\2\u0182\u0183")
buf.write("\5J&\2\u0183\u0184\7)\2\2\u0184\u0186\3\2\2\2\u0185\u0163")
buf.write("\3\2\2\2\u0185\u016d\3\2\2\2\u0185\u0173\3\2\2\2\u0185")
buf.write("\u017b\3\2\2\2\u0186\25\3\2\2\2\u0187\u0188\7\5\2\2\u0188")
buf.write("\u018b\7F\2\2\u0189\u018a\7\7\2\2\u018a\u018c\7G\2\2\u018b")
buf.write("\u0189\3\2\2\2\u018b\u018c\3\2\2\2\u018c\u018d\3\2\2\2")
buf.write("\u018d\u018e\7)\2\2\u018e\27\3\2\2\2\u018f\u0190\7\3\2")
buf.write("\2\u0190\u0191\7G\2\2\u0191\u0192\7\6\2\2\u0192\u0195")
buf.write("\7F\2\2\u0193\u0194\7\7\2\2\u0194\u0196\7G\2\2\u0195\u0193")
buf.write("\3\2\2\2\u0195\u0196\3\2\2\2\u0196\u01a0\3\2\2\2\u0197")
buf.write("\u019b\7+\2\2\u0198\u019a\5\32\16\2\u0199\u0198\3\2\2")
buf.write("\2\u019a\u019d\3\2\2\2\u019b\u0199\3\2\2\2\u019b\u019c")
buf.write("\3\2\2\2\u019c\u019e\3\2\2\2\u019d\u019b\3\2\2\2\u019e")
buf.write("\u01a1\7,\2\2\u019f\u01a1\7)\2\2\u01a0\u0197\3\2\2\2\u01a0")
buf.write("\u019f\3\2\2\2\u01a1\31\3\2\2\2\u01a2\u01a6\5\34\17\2")
buf.write('\u01a3\u01a6\5"\22\2\u01a4\u01a6\7)\2\2\u01a5\u01a2\3')
buf.write("\2\2\2\u01a5\u01a3\3\2\2\2\u01a5\u01a4\3\2\2\2\u01a6\33")
buf.write("\3\2\2\2\u01a7\u01a8\7\4\2\2\u01a8\u01a9\5\36\20\2\u01a9")
buf.write("\u01aa\7(\2\2\u01aa\u01ab\5 \21\2\u01ab\u01ac\7)\2\2\u01ac")
buf.write("\35\3\2\2\2\u01ad\u01bb\7\65\2\2\u01ae\u01af\7+\2\2\u01af")
buf.write("\u01b4\7F\2\2\u01b0\u01b1\7*\2\2\u01b1\u01b3\7F\2\2\u01b2")
buf.write("\u01b0\3\2\2\2\u01b3\u01b6\3\2\2\2\u01b4\u01b2\3\2\2\2")
buf.write("\u01b4\u01b5\3\2\2\2\u01b5\u01b7\3\2\2\2\u01b6\u01b4\3")
buf.write("\2\2\2\u01b7\u01bb\7,\2\2\u01b8\u01bb\7X\2\2\u01b9\u01bb")
buf.write("\7F\2\2\u01ba\u01ad\3\2\2\2\u01ba\u01ae\3\2\2\2\u01ba")
buf.write("\u01b8\3\2\2\2\u01ba\u01b9\3\2\2\2\u01bb\37\3\2\2\2\u01bc")
buf.write("\u01c0\7F\2\2\u01bd\u01c0\7]\2\2\u01be\u01c0\7\65\2\2")
buf.write("\u01bf\u01bc\3\2\2\2\u01bf\u01bd\3\2\2\2\u01bf\u01be\3")
buf.write("\2\2\2\u01c0!\3\2\2\2\u01c1\u01c2\7\5\2\2\u01c2\u01c3")
buf.write("\5J&\2\u01c3\u01c4\7(\2\2\u01c4\u01c7\5J&\2\u01c5\u01c6")
buf.write("\7\7\2\2\u01c6\u01c8\7G\2\2\u01c7\u01c5\3\2\2\2\u01c7")
buf.write("\u01c8\3\2\2\2\u01c8\u01c9\3\2\2\2\u01c9\u01ca\7)\2\2")
buf.write("\u01ca#\3\2\2\2\u01cb\u01cc\7F\2\2\u01cc\u01cd\7?\2\2")
buf.write("\u01cd\u01ce\5@!\2\u01ce\u01cf\7)\2\2\u01cf%\3\2\2\2\u01d0")
buf.write("\u01d1\7+\2\2\u01d1\u01d2\5,\27\2\u01d2\u01d3\7,\2\2\u01d3")
buf.write("'\3\2\2\2\u01d4\u01d5\7\22\2\2\u01d5\u01d6\7-\2\2\u01d6")
buf.write('\u01d7\5B"\2\u01d7\u01d8\7.\2\2\u01d8\u01e2\5&\24\2\u01d9')
buf.write("\u01da\7\23\2\2\u01da\u01db\7\22\2\2\u01db\u01dc\7-\2")
buf.write('\2\u01dc\u01dd\5B"\2\u01dd\u01de\7.\2\2\u01de\u01df\5')
buf.write("&\24\2\u01df\u01e1\3\2\2\2\u01e0\u01d9\3\2\2\2\u01e1\u01e4")
buf.write("\3\2\2\2\u01e2\u01e0\3\2\2\2\u01e2\u01e3\3\2\2\2\u01e3")
buf.write("\u01e7\3\2\2\2\u01e4\u01e2\3\2\2\2\u01e5\u01e6\7\23\2")
buf.write("\2\u01e6\u01e8\5&\24\2\u01e7\u01e5\3\2\2\2\u01e7\u01e8")
buf.write("\3\2\2\2\u01e8)\3\2\2\2\u01e9\u01ed\5$\23\2\u01ea\u01ed")
buf.write("\5(\25\2\u01eb\u01ed\7)\2\2\u01ec\u01e9\3\2\2\2\u01ec")
buf.write("\u01ea\3\2\2\2\u01ec\u01eb\3\2\2\2\u01ed+\3\2\2\2\u01ee")
buf.write("\u01f0\5*\26\2\u01ef\u01ee\3\2\2\2\u01f0\u01f3\3\2\2\2")
buf.write("\u01f1\u01ef\3\2\2\2\u01f1\u01f2\3\2\2\2\u01f2-\3\2\2")
buf.write("\2\u01f3\u01f1\3\2\2\2\u01f4\u01ff\5\b\5\2\u01f5\u01ff")
buf.write("\5\n\6\2\u01f6\u01ff\5\f\7\2\u01f7\u01ff\5\16\b\2\u01f8")
buf.write("\u01ff\5\22\n\2\u01f9\u01ff\5\20\t\2\u01fa\u01ff\5\24")
buf.write("\13\2\u01fb\u01ff\5\26\f\2\u01fc\u01ff\5\30\r\2\u01fd")
buf.write("\u01ff\7)\2\2\u01fe\u01f4\3\2\2\2\u01fe\u01f5\3\2\2\2")
buf.write("\u01fe\u01f6\3\2\2\2\u01fe\u01f7\3\2\2\2\u01fe\u01f8\3")
buf.write("\2\2\2\u01fe\u01f9\3\2\2\2\u01fe\u01fa\3\2\2\2\u01fe\u01fb")
buf.write("\3\2\2\2\u01fe\u01fc\3\2\2\2\u01fe\u01fd\3\2\2\2\u01ff")
buf.write("/\3\2\2\2\u0200\u0202\5:\36\2\u0201\u0200\3\2\2\2\u0202")
buf.write("\u0205\3\2\2\2\u0203\u0201\3\2\2\2\u0203\u0204\3\2\2\2")
buf.write("\u0204\u0206\3\2\2\2\u0205\u0203\3\2\2\2\u0206\u0207\7")
buf.write("\2\2\3\u0207\61\3\2\2\2\u0208\u020a\5\64\33\2\u0209\u0208")
buf.write("\3\2\2\2\u020a\u020d\3\2\2\2\u020b\u0209\3\2\2\2\u020b")
buf.write("\u020c\3\2\2\2\u020c\u020e\3\2\2\2\u020d\u020b\3\2\2\2")
buf.write("\u020e\u020f\7\2\2\3\u020f\63\3\2\2\2\u0210\u0213\5\66")
buf.write("\34\2\u0211\u0213\58\35\2\u0212\u0210\3\2\2\2\u0212\u0211")
buf.write("\3\2\2\2\u0213\65\3\2\2\2\u0214\u0215\7F\2\2\u0215\u0216")
buf.write("\7&\2\2\u0216\u0217\5> \2\u0217\u0218\7)\2\2\u0218\67")
buf.write("\3\2\2\2\u0219\u021a\7F\2\2\u021a\u021b\7?\2\2\u021b\u021c")
buf.write("\5> \2\u021c\u021d\7)\2\2\u021d9\3\2\2\2\u021e\u021f\7")
buf.write("F\2\2\u021f\u0220\7&\2\2\u0220\u0221\5@!\2\u0221\u0222")
buf.write("\7)\2\2\u0222;\3\2\2\2\u0223\u0226\5@!\2\u0224\u0226\5")
buf.write('B"\2\u0225\u0223\3\2\2\2\u0225\u0224\3\2\2\2\u0226=\3')
buf.write("\2\2\2\u0227\u0228\b \1\2\u0228\u0229\7/\2\2\u0229\u022a")
buf.write("\5> \2\u022a\u022b\7\60\2\2\u022b\u0236\3\2\2\2\u022c")
buf.write("\u0236\5D#\2\u022d\u0236\5H%\2\u022e\u022f\t\5\2\2\u022f")
buf.write("\u0236\5> \13\u0230\u0231\7E\2\2\u0231\u0232\7/\2\2\u0232")
buf.write("\u0233\5> \2\u0233\u0234\7\60\2\2\u0234\u0236\3\2\2\2")
buf.write("\u0235\u0227\3\2\2\2\u0235\u022c\3\2\2\2\u0235\u022d\3")
buf.write("\2\2\2\u0235\u022e\3\2\2\2\u0235\u0230\3\2\2\2\u0236\u024e")
buf.write("\3\2\2\2\u0237\u0238\f\n\2\2\u0238\u0239\7\35\2\2\u0239")
buf.write("\u024d\5> \n\u023a\u023b\f\t\2\2\u023b\u023c\t\6\2\2\u023c")
buf.write("\u024d\5> \n\u023d\u023e\f\b\2\2\u023e\u023f\t\5\2\2\u023f")
buf.write("\u024d\5> \t\u0240\u0241\f\7\2\2\u0241\u0242\t\7\2\2\u0242")
buf.write("\u024d\5> \b\u0243\u0244\f\6\2\2\u0244\u0245\7:\2\2\u0245")
buf.write("\u024d\5> \7\u0246\u0247\f\5\2\2\u0247\u0248\7;\2\2\u0248")
buf.write("\u024d\5> \6\u0249\u024a\f\4\2\2\u024a\u024b\7<\2\2\u024b")
buf.write("\u024d\5> \5\u024c\u0237\3\2\2\2\u024c\u023a\3\2\2\2\u024c")
buf.write("\u023d\3\2\2\2\u024c\u0240\3\2\2\2\u024c\u0243\3\2\2\2")
buf.write("\u024c\u0246\3\2\2\2\u024c\u0249\3\2\2\2\u024d\u0250\3")
buf.write("\2\2\2\u024e\u024c\3\2\2\2\u024e\u024f\3\2\2\2\u024f?")
buf.write("\3\2\2\2\u0250\u024e\3\2\2\2\u0251\u0252\b!\1\2\u0252")
buf.write("\u0253\7/\2\2\u0253\u0254\5@!\2\u0254\u0255\7\60\2\2\u0255")
buf.write("\u0269\3\2\2\2\u0256\u0269\5D#\2\u0257\u0269\7F\2\2\u0258")
buf.write("\u0269\5H%\2\u0259\u025a\t\5\2\2\u025a\u0269\5@!\f\u025b")
buf.write("\u025c\7E\2\2\u025c\u025d\7/\2\2\u025d\u025e\5@!\2\u025e")
buf.write("\u025f\7\60\2\2\u025f\u0269\3\2\2\2\u0260\u0261\7/\2\2")
buf.write('\u0261\u0262\5B"\2\u0262\u0263\7\60\2\2\u0263\u0264\7')
buf.write("\61\2\2\u0264\u0265\5@!\2\u0265\u0266\7\62\2\2\u0266\u0267")
buf.write("\5@!\3\u0267\u0269\3\2\2\2\u0268\u0251\3\2\2\2\u0268\u0256")
buf.write("\3\2\2\2\u0268\u0257\3\2\2\2\u0268\u0258\3\2\2\2\u0268")
buf.write("\u0259\3\2\2\2\u0268\u025b\3\2\2\2\u0268\u0260\3\2\2\2")
buf.write("\u0269\u0281\3\2\2\2\u026a\u026b\f\13\2\2\u026b\u026c")
buf.write("\7\35\2\2\u026c\u0280\5@!\13\u026d\u026e\f\n\2\2\u026e")
buf.write("\u026f\t\6\2\2\u026f\u0280\5@!\13\u0270\u0271\f\t\2\2")
buf.write("\u0271\u0272\t\5\2\2\u0272\u0280\5@!\n\u0273\u0274\f\b")
buf.write("\2\2\u0274\u0275\t\7\2\2\u0275\u0280\5@!\t\u0276\u0277")
buf.write("\f\7\2\2\u0277\u0278\7:\2\2\u0278\u0280\5@!\b\u0279\u027a")
buf.write("\f\6\2\2\u027a\u027b\7;\2\2\u027b\u0280\5@!\7\u027c\u027d")
buf.write("\f\5\2\2\u027d\u027e\7<\2\2\u027e\u0280\5@!\6\u027f\u026a")
buf.write("\3\2\2\2\u027f\u026d\3\2\2\2\u027f\u0270\3\2\2\2\u027f")
buf.write("\u0273\3\2\2\2\u027f\u0276\3\2\2\2\u027f\u0279\3\2\2\2")
buf.write("\u027f\u027c\3\2\2\2\u0280\u0283\3\2\2\2\u0281\u027f\3")
buf.write("\2\2\2\u0281\u0282\3\2\2\2\u0282A\3\2\2\2\u0283\u0281")
buf.write('\3\2\2\2\u0284\u0285\b"\1\2\u0285\u0286\7/\2\2\u0286')
buf.write('\u0287\5B"\2\u0287\u0288\7\60\2\2\u0288\u029d\3\2\2\2')
buf.write("\u0289\u029d\5F$\2\u028a\u028b\t\b\2\2\u028b\u029d\5B")
buf.write('"\t\u028c\u028d\5@!\2\u028d\u028e\t\t\2\2\u028e\u028f')
buf.write("\5@!\2\u028f\u029d\3\2\2\2\u0290\u0291\5@!\2\u0291\u0292")
buf.write("\t\n\2\2\u0292\u0293\5@!\2\u0293\u029d\3\2\2\2\u0294\u0295")
buf.write('\7/\2\2\u0295\u0296\5B"\2\u0296\u0297\7\60\2\2\u0297')
buf.write('\u0298\7\61\2\2\u0298\u0299\5B"\2\u0299\u029a\7\62\2')
buf.write('\2\u029a\u029b\5B"\3\u029b\u029d\3\2\2\2\u029c\u0284')
buf.write("\3\2\2\2\u029c\u0289\3\2\2\2\u029c\u028a\3\2\2\2\u029c")
buf.write("\u028c\3\2\2\2\u029c\u0290\3\2\2\2\u029c\u0294\3\2\2\2")
buf.write("\u029d\u02a9\3\2\2\2\u029e\u029f\f\6\2\2\u029f\u02a0\t")
buf.write('\n\2\2\u02a0\u02a8\5B"\7\u02a1\u02a2\f\5\2\2\u02a2\u02a3')
buf.write('\t\13\2\2\u02a3\u02a8\5B"\6\u02a4\u02a5\f\4\2\2\u02a5')
buf.write('\u02a6\t\f\2\2\u02a6\u02a8\5B"\5\u02a7\u029e\3\2\2\2')
buf.write("\u02a7\u02a1\3\2\2\2\u02a7\u02a4\3\2\2\2\u02a8\u02ab\3")
buf.write("\2\2\2\u02a9\u02a7\3\2\2\2\u02a9\u02aa\3\2\2\2\u02aaC")
buf.write("\3\2\2\2\u02ab\u02a9\3\2\2\2\u02ac\u02ad\t\r\2\2\u02ad")
buf.write("E\3\2\2\2\u02ae\u02af\t\16\2\2\u02afG\3\2\2\2\u02b0\u02b1")
buf.write("\t\17\2\2\u02b1I\3\2\2\2\u02b2\u02b4\7\64\2\2\u02b3\u02b2")
buf.write("\3\2\2\2\u02b3\u02b4\3\2\2\2\u02b4\u02b5\3\2\2\2\u02b5")
buf.write("\u02ba\7F\2\2\u02b6\u02b7\7\63\2\2\u02b7\u02b9\7F\2\2")
buf.write("\u02b8\u02b6\3\2\2\2\u02b9\u02bc\3\2\2\2\u02ba\u02b8\3")
buf.write("\2\2\2\u02ba\u02bb\3\2\2\2\u02bbK\3\2\2\2\u02bc\u02ba")
buf.write("\3\2\2\2FR`fjpvz\u0087\u008f\u009e\u00a6\u00b5\u00bd\u00bf")
buf.write("\u00cf\u00e0\u00ef\u00fe\u0101\u0105\u0112\u0117\u011d")
buf.write("\u0121\u012e\u0133\u0139\u013d\u0140\u0148\u014f\u0153")
buf.write("\u0158\u015b\u0161\u0167\u0178\u017f\u0185\u018b\u0195")
buf.write("\u019b\u01a0\u01a5\u01b4\u01ba\u01bf\u01c7\u01e2\u01e7")
buf.write("\u01ec\u01f1\u01fe\u0203\u020b\u0212\u0225\u0235\u024c")
buf.write("\u024e\u0268\u027f\u0281\u029c\u02a7\u02a9\u02b3\u02ba")
return buf.getvalue()
[docs]
class GrammarParser(Parser):
grammarFileName = "GrammarParser.g4"
atn = ATNDeserializer().deserialize(serializedATN())
decisionsToDFA = [DFA(ds, i) for i, ds in enumerate(atn.decisionToState)]
sharedContextCache = PredictionContextCache()
literalNames = [
"<INVALID>",
"'import'",
"'def'",
"<INVALID>",
"<INVALID>",
"<INVALID>",
"'pseudo'",
"'state'",
"'enter'",
"'exit'",
"'during'",
"'before'",
"'after'",
"'abstract'",
"'ref'",
"'effect'",
"'if'",
"'else'",
"'int'",
"'float'",
"'pi'",
"'E'",
"'tau'",
"'and'",
"'or'",
"'not'",
"'[*]'",
"'**'",
"'>>'",
"'<<'",
"'<='",
"'>='",
"'=='",
"'!='",
"'&&'",
"'||'",
"':='",
"'::'",
"<INVALID>",
"<INVALID>",
"<INVALID>",
"<INVALID>",
"<INVALID>",
"'['",
"']'",
"'('",
"')'",
"'?'",
"':'",
"<INVALID>",
"<INVALID>",
"<INVALID>",
"'!'",
"'+'",
"'-'",
"'%'",
"'&'",
"'^'",
"'|'",
"'<'",
"'>'",
"'='",
]
symbolicNames = [
"<INVALID>",
"IMPORT",
"DEF",
"EVENT",
"AS",
"NAMED",
"PSEUDO",
"STATE",
"ENTER",
"EXIT",
"DURING",
"BEFORE",
"AFTER",
"ABSTRACT",
"REF",
"EFFECT",
"IF",
"ELSE",
"INT_TYPE",
"FLOAT_TYPE",
"PI_CONST",
"E_CONST",
"TAU_CONST",
"AND_KW",
"OR_KW",
"NOT_KW",
"INIT_MARKER",
"POW",
"SHIFT_RIGHT",
"SHIFT_LEFT",
"LE",
"GE",
"EQ",
"NE",
"LOGICAL_AND",
"LOGICAL_OR",
"DECLARE_ASSIGN",
"COLONCOLON",
"ARROW",
"SEMI",
"COMMA",
"LBRACE",
"RBRACE",
"LBRACK",
"RBRACK",
"LPAREN",
"RPAREN",
"QUESTION",
"COLON",
"DOT",
"SLASH",
"STAR",
"BANG",
"PLUS",
"MINUS",
"PERCENT",
"AMP",
"CARET",
"PIPE",
"LT",
"GT",
"ASSIGN",
"FLOAT",
"HEX_INT",
"INT",
"TRUE",
"FALSE",
"UFUNC_NAME",
"ID",
"STRING",
"MULTILINE_COMMENT",
"LINE_COMMENT",
"PYTHON_COMMENT",
"WS",
"IMPORT_HEADER_WS",
"IMPORT_HEADER_MULTILINE_COMMENT",
"IMPORT_HEADER_LINE_COMMENT",
"IMPORT_HEADER_PYTHON_COMMENT",
"IMPORT_BLOCK_WS",
"IMPORT_BLOCK_MULTILINE_COMMENT",
"IMPORT_BLOCK_LINE_COMMENT",
"IMPORT_BLOCK_PYTHON_COMMENT",
"IMPORT_DEF_SELECTOR_WS",
"IMPORT_DEF_SELECTOR_MULTILINE_COMMENT",
"IMPORT_DEF_SELECTOR_LINE_COMMENT",
"IMPORT_DEF_SELECTOR_PYTHON_COMMENT",
"IMPORT_DEF_SELECTOR_PATTERN",
"IMPORT_DEF_TARGET_WS",
"IMPORT_DEF_TARGET_MULTILINE_COMMENT",
"IMPORT_DEF_TARGET_LINE_COMMENT",
"IMPORT_DEF_TARGET_PYTHON_COMMENT",
"IMPORT_DEF_TARGET_TEMPLATE",
]
RULE_condition = 0
RULE_state_machine_dsl = 1
RULE_def_assignment = 2
RULE_state_definition = 3
RULE_transition_definition = 4
RULE_transition_force_definition = 5
RULE_enter_definition = 6
RULE_exit_definition = 7
RULE_during_definition = 8
RULE_during_aspect_definition = 9
RULE_event_definition = 10
RULE_import_statement = 11
RULE_import_mapping_statement = 12
RULE_import_def_mapping = 13
RULE_import_def_selector = 14
RULE_import_def_target_template = 15
RULE_import_event_mapping = 16
RULE_operation_assignment = 17
RULE_operation_block = 18
RULE_if_statement = 19
RULE_operational_statement = 20
RULE_operational_statement_set = 21
RULE_state_inner_statement = 22
RULE_operation_program = 23
RULE_preamble_program = 24
RULE_preamble_statement = 25
RULE_initial_assignment = 26
RULE_constant_definition = 27
RULE_operational_assignment = 28
RULE_generic_expression = 29
RULE_init_expression = 30
RULE_num_expression = 31
RULE_cond_expression = 32
RULE_num_literal = 33
RULE_bool_literal = 34
RULE_math_const = 35
RULE_chain_id = 36
ruleNames = [
"condition",
"state_machine_dsl",
"def_assignment",
"state_definition",
"transition_definition",
"transition_force_definition",
"enter_definition",
"exit_definition",
"during_definition",
"during_aspect_definition",
"event_definition",
"import_statement",
"import_mapping_statement",
"import_def_mapping",
"import_def_selector",
"import_def_target_template",
"import_event_mapping",
"operation_assignment",
"operation_block",
"if_statement",
"operational_statement",
"operational_statement_set",
"state_inner_statement",
"operation_program",
"preamble_program",
"preamble_statement",
"initial_assignment",
"constant_definition",
"operational_assignment",
"generic_expression",
"init_expression",
"num_expression",
"cond_expression",
"num_literal",
"bool_literal",
"math_const",
"chain_id",
]
EOF = Token.EOF
IMPORT = 1
DEF = 2
EVENT = 3
AS = 4
NAMED = 5
PSEUDO = 6
STATE = 7
ENTER = 8
EXIT = 9
DURING = 10
BEFORE = 11
AFTER = 12
ABSTRACT = 13
REF = 14
EFFECT = 15
IF = 16
ELSE = 17
INT_TYPE = 18
FLOAT_TYPE = 19
PI_CONST = 20
E_CONST = 21
TAU_CONST = 22
AND_KW = 23
OR_KW = 24
NOT_KW = 25
INIT_MARKER = 26
POW = 27
SHIFT_RIGHT = 28
SHIFT_LEFT = 29
LE = 30
GE = 31
EQ = 32
NE = 33
LOGICAL_AND = 34
LOGICAL_OR = 35
DECLARE_ASSIGN = 36
COLONCOLON = 37
ARROW = 38
SEMI = 39
COMMA = 40
LBRACE = 41
RBRACE = 42
LBRACK = 43
RBRACK = 44
LPAREN = 45
RPAREN = 46
QUESTION = 47
COLON = 48
DOT = 49
SLASH = 50
STAR = 51
BANG = 52
PLUS = 53
MINUS = 54
PERCENT = 55
AMP = 56
CARET = 57
PIPE = 58
LT = 59
GT = 60
ASSIGN = 61
FLOAT = 62
HEX_INT = 63
INT = 64
TRUE = 65
FALSE = 66
UFUNC_NAME = 67
ID = 68
STRING = 69
MULTILINE_COMMENT = 70
LINE_COMMENT = 71
PYTHON_COMMENT = 72
WS = 73
IMPORT_HEADER_WS = 74
IMPORT_HEADER_MULTILINE_COMMENT = 75
IMPORT_HEADER_LINE_COMMENT = 76
IMPORT_HEADER_PYTHON_COMMENT = 77
IMPORT_BLOCK_WS = 78
IMPORT_BLOCK_MULTILINE_COMMENT = 79
IMPORT_BLOCK_LINE_COMMENT = 80
IMPORT_BLOCK_PYTHON_COMMENT = 81
IMPORT_DEF_SELECTOR_WS = 82
IMPORT_DEF_SELECTOR_MULTILINE_COMMENT = 83
IMPORT_DEF_SELECTOR_LINE_COMMENT = 84
IMPORT_DEF_SELECTOR_PYTHON_COMMENT = 85
IMPORT_DEF_SELECTOR_PATTERN = 86
IMPORT_DEF_TARGET_WS = 87
IMPORT_DEF_TARGET_MULTILINE_COMMENT = 88
IMPORT_DEF_TARGET_LINE_COMMENT = 89
IMPORT_DEF_TARGET_PYTHON_COMMENT = 90
IMPORT_DEF_TARGET_TEMPLATE = 91
[docs]
def __init__(self, input: TokenStream, output: TextIO = sys.stdout):
super().__init__(input, output)
self.checkVersion("4.9.3")
self._interp = ParserATNSimulator(
self, self.atn, self.decisionsToDFA, self.sharedContextCache
)
self._predicates = None
class ConditionContext(ParserRuleContext):
__slots__ = "parser"
def __init__(
self, parser, parent: ParserRuleContext = None, invokingState: int = -1
):
super().__init__(parent, invokingState)
self.parser = parser
def cond_expression(self):
return self.getTypedRuleContext(GrammarParser.Cond_expressionContext, 0)
def EOF(self):
return self.getToken(GrammarParser.EOF, 0)
def getRuleIndex(self):
return GrammarParser.RULE_condition
def enterRule(self, listener: ParseTreeListener):
if hasattr(listener, "enterCondition"):
listener.enterCondition(self)
def exitRule(self, listener: ParseTreeListener):
if hasattr(listener, "exitCondition"):
listener.exitCondition(self)
def condition(self):
localctx = GrammarParser.ConditionContext(self, self._ctx, self.state)
self.enterRule(localctx, 0, self.RULE_condition)
try:
self.enterOuterAlt(localctx, 1)
self.state = 74
self.cond_expression(0)
self.state = 75
self.match(GrammarParser.EOF)
except RecognitionException as re:
localctx.exception = re
self._errHandler.reportError(self, re)
self._errHandler.recover(self, re)
finally:
self.exitRule()
return localctx
class State_machine_dslContext(ParserRuleContext):
__slots__ = "parser"
def __init__(
self, parser, parent: ParserRuleContext = None, invokingState: int = -1
):
super().__init__(parent, invokingState)
self.parser = parser
def state_definition(self):
return self.getTypedRuleContext(GrammarParser.State_definitionContext, 0)
def EOF(self):
return self.getToken(GrammarParser.EOF, 0)
def def_assignment(self, i: int = None):
if i is None:
return self.getTypedRuleContexts(GrammarParser.Def_assignmentContext)
else:
return self.getTypedRuleContext(GrammarParser.Def_assignmentContext, i)
def getRuleIndex(self):
return GrammarParser.RULE_state_machine_dsl
def enterRule(self, listener: ParseTreeListener):
if hasattr(listener, "enterState_machine_dsl"):
listener.enterState_machine_dsl(self)
def exitRule(self, listener: ParseTreeListener):
if hasattr(listener, "exitState_machine_dsl"):
listener.exitState_machine_dsl(self)
def state_machine_dsl(self):
localctx = GrammarParser.State_machine_dslContext(self, self._ctx, self.state)
self.enterRule(localctx, 2, self.RULE_state_machine_dsl)
self._la = 0 # Token type
try:
self.enterOuterAlt(localctx, 1)
self.state = 80
self._errHandler.sync(self)
_la = self._input.LA(1)
while _la == GrammarParser.DEF:
self.state = 77
self.def_assignment()
self.state = 82
self._errHandler.sync(self)
_la = self._input.LA(1)
self.state = 83
self.state_definition()
self.state = 84
self.match(GrammarParser.EOF)
except RecognitionException as re:
localctx.exception = re
self._errHandler.reportError(self, re)
self._errHandler.recover(self, re)
finally:
self.exitRule()
return localctx
class Def_assignmentContext(ParserRuleContext):
__slots__ = "parser"
def __init__(
self, parser, parent: ParserRuleContext = None, invokingState: int = -1
):
super().__init__(parent, invokingState)
self.parser = parser
self.deftype = None # Token
def DEF(self):
return self.getToken(GrammarParser.DEF, 0)
def ID(self):
return self.getToken(GrammarParser.ID, 0)
def ASSIGN(self):
return self.getToken(GrammarParser.ASSIGN, 0)
def init_expression(self):
return self.getTypedRuleContext(GrammarParser.Init_expressionContext, 0)
def SEMI(self):
return self.getToken(GrammarParser.SEMI, 0)
def INT_TYPE(self):
return self.getToken(GrammarParser.INT_TYPE, 0)
def FLOAT_TYPE(self):
return self.getToken(GrammarParser.FLOAT_TYPE, 0)
def getRuleIndex(self):
return GrammarParser.RULE_def_assignment
def enterRule(self, listener: ParseTreeListener):
if hasattr(listener, "enterDef_assignment"):
listener.enterDef_assignment(self)
def exitRule(self, listener: ParseTreeListener):
if hasattr(listener, "exitDef_assignment"):
listener.exitDef_assignment(self)
def def_assignment(self):
localctx = GrammarParser.Def_assignmentContext(self, self._ctx, self.state)
self.enterRule(localctx, 4, self.RULE_def_assignment)
self._la = 0 # Token type
try:
self.enterOuterAlt(localctx, 1)
self.state = 86
self.match(GrammarParser.DEF)
self.state = 87
localctx.deftype = self._input.LT(1)
_la = self._input.LA(1)
if not (_la == GrammarParser.INT_TYPE or _la == GrammarParser.FLOAT_TYPE):
localctx.deftype = self._errHandler.recoverInline(self)
else:
self._errHandler.reportMatch(self)
self.consume()
self.state = 88
self.match(GrammarParser.ID)
self.state = 89
self.match(GrammarParser.ASSIGN)
self.state = 90
self.init_expression(0)
self.state = 91
self.match(GrammarParser.SEMI)
except RecognitionException as re:
localctx.exception = re
self._errHandler.reportError(self, re)
self._errHandler.recover(self, re)
finally:
self.exitRule()
return localctx
class State_definitionContext(ParserRuleContext):
__slots__ = "parser"
def __init__(
self, parser, parent: ParserRuleContext = None, invokingState: int = -1
):
super().__init__(parent, invokingState)
self.parser = parser
def getRuleIndex(self):
return GrammarParser.RULE_state_definition
def copyFrom(self, ctx: ParserRuleContext):
super().copyFrom(ctx)
class LeafStateDefinitionContext(State_definitionContext):
def __init__(
self, parser, ctx: ParserRuleContext
): # actually a GrammarParser.State_definitionContext
super().__init__(parser)
self.pseudo = None # Token
self.state_id = None # Token
self.extra_name = None # Token
self.copyFrom(ctx)
def STATE(self):
return self.getToken(GrammarParser.STATE, 0)
def SEMI(self):
return self.getToken(GrammarParser.SEMI, 0)
def ID(self):
return self.getToken(GrammarParser.ID, 0)
def NAMED(self):
return self.getToken(GrammarParser.NAMED, 0)
def PSEUDO(self):
return self.getToken(GrammarParser.PSEUDO, 0)
def STRING(self):
return self.getToken(GrammarParser.STRING, 0)
def enterRule(self, listener: ParseTreeListener):
if hasattr(listener, "enterLeafStateDefinition"):
listener.enterLeafStateDefinition(self)
def exitRule(self, listener: ParseTreeListener):
if hasattr(listener, "exitLeafStateDefinition"):
listener.exitLeafStateDefinition(self)
class CompositeStateDefinitionContext(State_definitionContext):
def __init__(
self, parser, ctx: ParserRuleContext
): # actually a GrammarParser.State_definitionContext
super().__init__(parser)
self.pseudo = None # Token
self.state_id = None # Token
self.extra_name = None # Token
self.copyFrom(ctx)
def STATE(self):
return self.getToken(GrammarParser.STATE, 0)
def LBRACE(self):
return self.getToken(GrammarParser.LBRACE, 0)
def RBRACE(self):
return self.getToken(GrammarParser.RBRACE, 0)
def ID(self):
return self.getToken(GrammarParser.ID, 0)
def NAMED(self):
return self.getToken(GrammarParser.NAMED, 0)
def state_inner_statement(self, i: int = None):
if i is None:
return self.getTypedRuleContexts(
GrammarParser.State_inner_statementContext
)
else:
return self.getTypedRuleContext(
GrammarParser.State_inner_statementContext, i
)
def PSEUDO(self):
return self.getToken(GrammarParser.PSEUDO, 0)
def STRING(self):
return self.getToken(GrammarParser.STRING, 0)
def enterRule(self, listener: ParseTreeListener):
if hasattr(listener, "enterCompositeStateDefinition"):
listener.enterCompositeStateDefinition(self)
def exitRule(self, listener: ParseTreeListener):
if hasattr(listener, "exitCompositeStateDefinition"):
listener.exitCompositeStateDefinition(self)
def state_definition(self):
localctx = GrammarParser.State_definitionContext(self, self._ctx, self.state)
self.enterRule(localctx, 6, self.RULE_state_definition)
self._la = 0 # Token type
try:
self.state = 120
self._errHandler.sync(self)
la_ = self._interp.adaptivePredict(self._input, 6, self._ctx)
if la_ == 1:
localctx = GrammarParser.LeafStateDefinitionContext(self, localctx)
self.enterOuterAlt(localctx, 1)
self.state = 94
self._errHandler.sync(self)
_la = self._input.LA(1)
if _la == GrammarParser.PSEUDO:
self.state = 93
localctx.pseudo = self.match(GrammarParser.PSEUDO)
self.state = 96
self.match(GrammarParser.STATE)
self.state = 97
localctx.state_id = self.match(GrammarParser.ID)
self.state = 100
self._errHandler.sync(self)
_la = self._input.LA(1)
if _la == GrammarParser.NAMED:
self.state = 98
self.match(GrammarParser.NAMED)
self.state = 99
localctx.extra_name = self.match(GrammarParser.STRING)
self.state = 102
self.match(GrammarParser.SEMI)
pass
elif la_ == 2:
localctx = GrammarParser.CompositeStateDefinitionContext(self, localctx)
self.enterOuterAlt(localctx, 2)
self.state = 104
self._errHandler.sync(self)
_la = self._input.LA(1)
if _la == GrammarParser.PSEUDO:
self.state = 103
localctx.pseudo = self.match(GrammarParser.PSEUDO)
self.state = 106
self.match(GrammarParser.STATE)
self.state = 107
localctx.state_id = self.match(GrammarParser.ID)
self.state = 110
self._errHandler.sync(self)
_la = self._input.LA(1)
if _la == GrammarParser.NAMED:
self.state = 108
self.match(GrammarParser.NAMED)
self.state = 109
localctx.extra_name = self.match(GrammarParser.STRING)
self.state = 112
self.match(GrammarParser.LBRACE)
self.state = 116
self._errHandler.sync(self)
_la = self._input.LA(1)
while (
((_la) & ~0x3F) == 0
and (
(1 << _la)
& (
(1 << GrammarParser.IMPORT)
| (1 << GrammarParser.EVENT)
| (1 << GrammarParser.PSEUDO)
| (1 << GrammarParser.STATE)
| (1 << GrammarParser.ENTER)
| (1 << GrammarParser.EXIT)
| (1 << GrammarParser.DURING)
| (1 << GrammarParser.INIT_MARKER)
| (1 << GrammarParser.SHIFT_RIGHT)
| (1 << GrammarParser.SEMI)
| (1 << GrammarParser.BANG)
)
)
!= 0
) or _la == GrammarParser.ID:
self.state = 113
self.state_inner_statement()
self.state = 118
self._errHandler.sync(self)
_la = self._input.LA(1)
self.state = 119
self.match(GrammarParser.RBRACE)
pass
except RecognitionException as re:
localctx.exception = re
self._errHandler.reportError(self, re)
self._errHandler.recover(self, re)
finally:
self.exitRule()
return localctx
class Transition_definitionContext(ParserRuleContext):
__slots__ = "parser"
def __init__(
self, parser, parent: ParserRuleContext = None, invokingState: int = -1
):
super().__init__(parent, invokingState)
self.parser = parser
def getRuleIndex(self):
return GrammarParser.RULE_transition_definition
def copyFrom(self, ctx: ParserRuleContext):
super().copyFrom(ctx)
class NormalTransitionDefinitionContext(Transition_definitionContext):
def __init__(
self, parser, ctx: ParserRuleContext
): # actually a GrammarParser.Transition_definitionContext
super().__init__(parser)
self.from_state = None # Token
self.to_state = None # Token
self.from_id = None # Token
self.copyFrom(ctx)
def ARROW(self):
return self.getToken(GrammarParser.ARROW, 0)
def ID(self, i: int = None):
if i is None:
return self.getTokens(GrammarParser.ID)
else:
return self.getToken(GrammarParser.ID, i)
def SEMI(self):
return self.getToken(GrammarParser.SEMI, 0)
def EFFECT(self):
return self.getToken(GrammarParser.EFFECT, 0)
def LBRACE(self):
return self.getToken(GrammarParser.LBRACE, 0)
def operational_statement_set(self):
return self.getTypedRuleContext(
GrammarParser.Operational_statement_setContext, 0
)
def RBRACE(self):
return self.getToken(GrammarParser.RBRACE, 0)
def COLONCOLON(self):
return self.getToken(GrammarParser.COLONCOLON, 0)
def COLON(self):
return self.getToken(GrammarParser.COLON, 0)
def chain_id(self):
return self.getTypedRuleContext(GrammarParser.Chain_idContext, 0)
def IF(self):
return self.getToken(GrammarParser.IF, 0)
def LBRACK(self):
return self.getToken(GrammarParser.LBRACK, 0)
def cond_expression(self):
return self.getTypedRuleContext(GrammarParser.Cond_expressionContext, 0)
def RBRACK(self):
return self.getToken(GrammarParser.RBRACK, 0)
def enterRule(self, listener: ParseTreeListener):
if hasattr(listener, "enterNormalTransitionDefinition"):
listener.enterNormalTransitionDefinition(self)
def exitRule(self, listener: ParseTreeListener):
if hasattr(listener, "exitNormalTransitionDefinition"):
listener.exitNormalTransitionDefinition(self)
class EntryTransitionDefinitionContext(Transition_definitionContext):
def __init__(
self, parser, ctx: ParserRuleContext
): # actually a GrammarParser.Transition_definitionContext
super().__init__(parser)
self.to_state = None # Token
self.copyFrom(ctx)
def INIT_MARKER(self):
return self.getToken(GrammarParser.INIT_MARKER, 0)
def ARROW(self):
return self.getToken(GrammarParser.ARROW, 0)
def ID(self):
return self.getToken(GrammarParser.ID, 0)
def SEMI(self):
return self.getToken(GrammarParser.SEMI, 0)
def EFFECT(self):
return self.getToken(GrammarParser.EFFECT, 0)
def LBRACE(self):
return self.getToken(GrammarParser.LBRACE, 0)
def operational_statement_set(self):
return self.getTypedRuleContext(
GrammarParser.Operational_statement_setContext, 0
)
def RBRACE(self):
return self.getToken(GrammarParser.RBRACE, 0)
def chain_id(self):
return self.getTypedRuleContext(GrammarParser.Chain_idContext, 0)
def COLON(self):
return self.getToken(GrammarParser.COLON, 0)
def IF(self):
return self.getToken(GrammarParser.IF, 0)
def LBRACK(self):
return self.getToken(GrammarParser.LBRACK, 0)
def cond_expression(self):
return self.getTypedRuleContext(GrammarParser.Cond_expressionContext, 0)
def RBRACK(self):
return self.getToken(GrammarParser.RBRACK, 0)
def COLONCOLON(self):
return self.getToken(GrammarParser.COLONCOLON, 0)
def enterRule(self, listener: ParseTreeListener):
if hasattr(listener, "enterEntryTransitionDefinition"):
listener.enterEntryTransitionDefinition(self)
def exitRule(self, listener: ParseTreeListener):
if hasattr(listener, "exitEntryTransitionDefinition"):
listener.exitEntryTransitionDefinition(self)
class ExitTransitionDefinitionContext(Transition_definitionContext):
def __init__(
self, parser, ctx: ParserRuleContext
): # actually a GrammarParser.Transition_definitionContext
super().__init__(parser)
self.from_state = None # Token
self.from_id = None # Token
self.copyFrom(ctx)
def ARROW(self):
return self.getToken(GrammarParser.ARROW, 0)
def INIT_MARKER(self):
return self.getToken(GrammarParser.INIT_MARKER, 0)
def ID(self, i: int = None):
if i is None:
return self.getTokens(GrammarParser.ID)
else:
return self.getToken(GrammarParser.ID, i)
def SEMI(self):
return self.getToken(GrammarParser.SEMI, 0)
def EFFECT(self):
return self.getToken(GrammarParser.EFFECT, 0)
def LBRACE(self):
return self.getToken(GrammarParser.LBRACE, 0)
def operational_statement_set(self):
return self.getTypedRuleContext(
GrammarParser.Operational_statement_setContext, 0
)
def RBRACE(self):
return self.getToken(GrammarParser.RBRACE, 0)
def COLONCOLON(self):
return self.getToken(GrammarParser.COLONCOLON, 0)
def COLON(self):
return self.getToken(GrammarParser.COLON, 0)
def chain_id(self):
return self.getTypedRuleContext(GrammarParser.Chain_idContext, 0)
def IF(self):
return self.getToken(GrammarParser.IF, 0)
def LBRACK(self):
return self.getToken(GrammarParser.LBRACK, 0)
def cond_expression(self):
return self.getTypedRuleContext(GrammarParser.Cond_expressionContext, 0)
def RBRACK(self):
return self.getToken(GrammarParser.RBRACK, 0)
def enterRule(self, listener: ParseTreeListener):
if hasattr(listener, "enterExitTransitionDefinition"):
listener.enterExitTransitionDefinition(self)
def exitRule(self, listener: ParseTreeListener):
if hasattr(listener, "exitExitTransitionDefinition"):
listener.exitExitTransitionDefinition(self)
def transition_definition(self):
localctx = GrammarParser.Transition_definitionContext(
self, self._ctx, self.state
)
self.enterRule(localctx, 8, self.RULE_transition_definition)
self._la = 0 # Token type
try:
self.state = 189
self._errHandler.sync(self)
la_ = self._interp.adaptivePredict(self._input, 13, self._ctx)
if la_ == 1:
localctx = GrammarParser.EntryTransitionDefinitionContext(
self, localctx
)
self.enterOuterAlt(localctx, 1)
self.state = 122
self.match(GrammarParser.INIT_MARKER)
self.state = 123
self.match(GrammarParser.ARROW)
self.state = 124
localctx.to_state = self.match(GrammarParser.ID)
self.state = 133
self._errHandler.sync(self)
la_ = self._interp.adaptivePredict(self._input, 7, self._ctx)
if la_ == 1:
self.state = 125
_la = self._input.LA(1)
if not (
_la == GrammarParser.COLONCOLON or _la == GrammarParser.COLON
):
self._errHandler.recoverInline(self)
else:
self._errHandler.reportMatch(self)
self.consume()
self.state = 126
self.chain_id()
elif la_ == 2:
self.state = 127
self.match(GrammarParser.COLON)
self.state = 128
self.match(GrammarParser.IF)
self.state = 129
self.match(GrammarParser.LBRACK)
self.state = 130
self.cond_expression(0)
self.state = 131
self.match(GrammarParser.RBRACK)
self.state = 141
self._errHandler.sync(self)
token = self._input.LA(1)
if token in [GrammarParser.SEMI]:
self.state = 135
self.match(GrammarParser.SEMI)
pass
elif token in [GrammarParser.EFFECT]:
self.state = 136
self.match(GrammarParser.EFFECT)
self.state = 137
self.match(GrammarParser.LBRACE)
self.state = 138
self.operational_statement_set()
self.state = 139
self.match(GrammarParser.RBRACE)
pass
else:
raise NoViableAltException(self)
pass
elif la_ == 2:
localctx = GrammarParser.NormalTransitionDefinitionContext(
self, localctx
)
self.enterOuterAlt(localctx, 2)
self.state = 143
localctx.from_state = self.match(GrammarParser.ID)
self.state = 144
self.match(GrammarParser.ARROW)
self.state = 145
localctx.to_state = self.match(GrammarParser.ID)
self.state = 156
self._errHandler.sync(self)
la_ = self._interp.adaptivePredict(self._input, 9, self._ctx)
if la_ == 1:
self.state = 146
self.match(GrammarParser.COLONCOLON)
self.state = 147
localctx.from_id = self.match(GrammarParser.ID)
elif la_ == 2:
self.state = 148
self.match(GrammarParser.COLON)
self.state = 149
self.chain_id()
elif la_ == 3:
self.state = 150
self.match(GrammarParser.COLON)
self.state = 151
self.match(GrammarParser.IF)
self.state = 152
self.match(GrammarParser.LBRACK)
self.state = 153
self.cond_expression(0)
self.state = 154
self.match(GrammarParser.RBRACK)
self.state = 164
self._errHandler.sync(self)
token = self._input.LA(1)
if token in [GrammarParser.SEMI]:
self.state = 158
self.match(GrammarParser.SEMI)
pass
elif token in [GrammarParser.EFFECT]:
self.state = 159
self.match(GrammarParser.EFFECT)
self.state = 160
self.match(GrammarParser.LBRACE)
self.state = 161
self.operational_statement_set()
self.state = 162
self.match(GrammarParser.RBRACE)
pass
else:
raise NoViableAltException(self)
pass
elif la_ == 3:
localctx = GrammarParser.ExitTransitionDefinitionContext(self, localctx)
self.enterOuterAlt(localctx, 3)
self.state = 166
localctx.from_state = self.match(GrammarParser.ID)
self.state = 167
self.match(GrammarParser.ARROW)
self.state = 168
self.match(GrammarParser.INIT_MARKER)
self.state = 179
self._errHandler.sync(self)
la_ = self._interp.adaptivePredict(self._input, 11, self._ctx)
if la_ == 1:
self.state = 169
self.match(GrammarParser.COLONCOLON)
self.state = 170
localctx.from_id = self.match(GrammarParser.ID)
elif la_ == 2:
self.state = 171
self.match(GrammarParser.COLON)
self.state = 172
self.chain_id()
elif la_ == 3:
self.state = 173
self.match(GrammarParser.COLON)
self.state = 174
self.match(GrammarParser.IF)
self.state = 175
self.match(GrammarParser.LBRACK)
self.state = 176
self.cond_expression(0)
self.state = 177
self.match(GrammarParser.RBRACK)
self.state = 187
self._errHandler.sync(self)
token = self._input.LA(1)
if token in [GrammarParser.SEMI]:
self.state = 181
self.match(GrammarParser.SEMI)
pass
elif token in [GrammarParser.EFFECT]:
self.state = 182
self.match(GrammarParser.EFFECT)
self.state = 183
self.match(GrammarParser.LBRACE)
self.state = 184
self.operational_statement_set()
self.state = 185
self.match(GrammarParser.RBRACE)
pass
else:
raise NoViableAltException(self)
pass
except RecognitionException as re:
localctx.exception = re
self._errHandler.reportError(self, re)
self._errHandler.recover(self, re)
finally:
self.exitRule()
return localctx
class Transition_force_definitionContext(ParserRuleContext):
__slots__ = "parser"
def __init__(
self, parser, parent: ParserRuleContext = None, invokingState: int = -1
):
super().__init__(parent, invokingState)
self.parser = parser
def getRuleIndex(self):
return GrammarParser.RULE_transition_force_definition
def copyFrom(self, ctx: ParserRuleContext):
super().copyFrom(ctx)
class NormalForceTransitionDefinitionContext(Transition_force_definitionContext):
def __init__(
self, parser, ctx: ParserRuleContext
): # actually a GrammarParser.Transition_force_definitionContext
super().__init__(parser)
self.from_state = None # Token
self.to_state = None # Token
self.from_id = None # Token
self.copyFrom(ctx)
def BANG(self):
return self.getToken(GrammarParser.BANG, 0)
def ARROW(self):
return self.getToken(GrammarParser.ARROW, 0)
def SEMI(self):
return self.getToken(GrammarParser.SEMI, 0)
def ID(self, i: int = None):
if i is None:
return self.getTokens(GrammarParser.ID)
else:
return self.getToken(GrammarParser.ID, i)
def COLONCOLON(self):
return self.getToken(GrammarParser.COLONCOLON, 0)
def COLON(self):
return self.getToken(GrammarParser.COLON, 0)
def chain_id(self):
return self.getTypedRuleContext(GrammarParser.Chain_idContext, 0)
def IF(self):
return self.getToken(GrammarParser.IF, 0)
def LBRACK(self):
return self.getToken(GrammarParser.LBRACK, 0)
def cond_expression(self):
return self.getTypedRuleContext(GrammarParser.Cond_expressionContext, 0)
def RBRACK(self):
return self.getToken(GrammarParser.RBRACK, 0)
def enterRule(self, listener: ParseTreeListener):
if hasattr(listener, "enterNormalForceTransitionDefinition"):
listener.enterNormalForceTransitionDefinition(self)
def exitRule(self, listener: ParseTreeListener):
if hasattr(listener, "exitNormalForceTransitionDefinition"):
listener.exitNormalForceTransitionDefinition(self)
class ExitAllForceTransitionDefinitionContext(Transition_force_definitionContext):
def __init__(
self, parser, ctx: ParserRuleContext
): # actually a GrammarParser.Transition_force_definitionContext
super().__init__(parser)
self.copyFrom(ctx)
def BANG(self):
return self.getToken(GrammarParser.BANG, 0)
def STAR(self):
return self.getToken(GrammarParser.STAR, 0)
def ARROW(self):
return self.getToken(GrammarParser.ARROW, 0)
def INIT_MARKER(self):
return self.getToken(GrammarParser.INIT_MARKER, 0)
def SEMI(self):
return self.getToken(GrammarParser.SEMI, 0)
def chain_id(self):
return self.getTypedRuleContext(GrammarParser.Chain_idContext, 0)
def COLON(self):
return self.getToken(GrammarParser.COLON, 0)
def IF(self):
return self.getToken(GrammarParser.IF, 0)
def LBRACK(self):
return self.getToken(GrammarParser.LBRACK, 0)
def cond_expression(self):
return self.getTypedRuleContext(GrammarParser.Cond_expressionContext, 0)
def RBRACK(self):
return self.getToken(GrammarParser.RBRACK, 0)
def COLONCOLON(self):
return self.getToken(GrammarParser.COLONCOLON, 0)
def enterRule(self, listener: ParseTreeListener):
if hasattr(listener, "enterExitAllForceTransitionDefinition"):
listener.enterExitAllForceTransitionDefinition(self)
def exitRule(self, listener: ParseTreeListener):
if hasattr(listener, "exitExitAllForceTransitionDefinition"):
listener.exitExitAllForceTransitionDefinition(self)
class NormalAllForceTransitionDefinitionContext(Transition_force_definitionContext):
def __init__(
self, parser, ctx: ParserRuleContext
): # actually a GrammarParser.Transition_force_definitionContext
super().__init__(parser)
self.to_state = None # Token
self.copyFrom(ctx)
def BANG(self):
return self.getToken(GrammarParser.BANG, 0)
def STAR(self):
return self.getToken(GrammarParser.STAR, 0)
def ARROW(self):
return self.getToken(GrammarParser.ARROW, 0)
def SEMI(self):
return self.getToken(GrammarParser.SEMI, 0)
def ID(self):
return self.getToken(GrammarParser.ID, 0)
def chain_id(self):
return self.getTypedRuleContext(GrammarParser.Chain_idContext, 0)
def COLON(self):
return self.getToken(GrammarParser.COLON, 0)
def IF(self):
return self.getToken(GrammarParser.IF, 0)
def LBRACK(self):
return self.getToken(GrammarParser.LBRACK, 0)
def cond_expression(self):
return self.getTypedRuleContext(GrammarParser.Cond_expressionContext, 0)
def RBRACK(self):
return self.getToken(GrammarParser.RBRACK, 0)
def COLONCOLON(self):
return self.getToken(GrammarParser.COLONCOLON, 0)
def enterRule(self, listener: ParseTreeListener):
if hasattr(listener, "enterNormalAllForceTransitionDefinition"):
listener.enterNormalAllForceTransitionDefinition(self)
def exitRule(self, listener: ParseTreeListener):
if hasattr(listener, "exitNormalAllForceTransitionDefinition"):
listener.exitNormalAllForceTransitionDefinition(self)
class ExitForceTransitionDefinitionContext(Transition_force_definitionContext):
def __init__(
self, parser, ctx: ParserRuleContext
): # actually a GrammarParser.Transition_force_definitionContext
super().__init__(parser)
self.from_state = None # Token
self.from_id = None # Token
self.copyFrom(ctx)
def BANG(self):
return self.getToken(GrammarParser.BANG, 0)
def ARROW(self):
return self.getToken(GrammarParser.ARROW, 0)
def INIT_MARKER(self):
return self.getToken(GrammarParser.INIT_MARKER, 0)
def SEMI(self):
return self.getToken(GrammarParser.SEMI, 0)
def ID(self, i: int = None):
if i is None:
return self.getTokens(GrammarParser.ID)
else:
return self.getToken(GrammarParser.ID, i)
def COLONCOLON(self):
return self.getToken(GrammarParser.COLONCOLON, 0)
def COLON(self):
return self.getToken(GrammarParser.COLON, 0)
def chain_id(self):
return self.getTypedRuleContext(GrammarParser.Chain_idContext, 0)
def IF(self):
return self.getToken(GrammarParser.IF, 0)
def LBRACK(self):
return self.getToken(GrammarParser.LBRACK, 0)
def cond_expression(self):
return self.getTypedRuleContext(GrammarParser.Cond_expressionContext, 0)
def RBRACK(self):
return self.getToken(GrammarParser.RBRACK, 0)
def enterRule(self, listener: ParseTreeListener):
if hasattr(listener, "enterExitForceTransitionDefinition"):
listener.enterExitForceTransitionDefinition(self)
def exitRule(self, listener: ParseTreeListener):
if hasattr(listener, "exitExitForceTransitionDefinition"):
listener.exitExitForceTransitionDefinition(self)
def transition_force_definition(self):
localctx = GrammarParser.Transition_force_definitionContext(
self, self._ctx, self.state
)
self.enterRule(localctx, 10, self.RULE_transition_force_definition)
self._la = 0 # Token type
try:
self.state = 255
self._errHandler.sync(self)
la_ = self._interp.adaptivePredict(self._input, 18, self._ctx)
if la_ == 1:
localctx = GrammarParser.NormalForceTransitionDefinitionContext(
self, localctx
)
self.enterOuterAlt(localctx, 1)
self.state = 191
self.match(GrammarParser.BANG)
self.state = 192
localctx.from_state = self.match(GrammarParser.ID)
self.state = 193
self.match(GrammarParser.ARROW)
self.state = 194
localctx.to_state = self.match(GrammarParser.ID)
self.state = 205
self._errHandler.sync(self)
la_ = self._interp.adaptivePredict(self._input, 14, self._ctx)
if la_ == 1:
self.state = 195
self.match(GrammarParser.COLONCOLON)
self.state = 196
localctx.from_id = self.match(GrammarParser.ID)
elif la_ == 2:
self.state = 197
self.match(GrammarParser.COLON)
self.state = 198
self.chain_id()
elif la_ == 3:
self.state = 199
self.match(GrammarParser.COLON)
self.state = 200
self.match(GrammarParser.IF)
self.state = 201
self.match(GrammarParser.LBRACK)
self.state = 202
self.cond_expression(0)
self.state = 203
self.match(GrammarParser.RBRACK)
self.state = 207
self.match(GrammarParser.SEMI)
pass
elif la_ == 2:
localctx = GrammarParser.ExitForceTransitionDefinitionContext(
self, localctx
)
self.enterOuterAlt(localctx, 2)
self.state = 208
self.match(GrammarParser.BANG)
self.state = 209
localctx.from_state = self.match(GrammarParser.ID)
self.state = 210
self.match(GrammarParser.ARROW)
self.state = 211
self.match(GrammarParser.INIT_MARKER)
self.state = 222
self._errHandler.sync(self)
la_ = self._interp.adaptivePredict(self._input, 15, self._ctx)
if la_ == 1:
self.state = 212
self.match(GrammarParser.COLONCOLON)
self.state = 213
localctx.from_id = self.match(GrammarParser.ID)
elif la_ == 2:
self.state = 214
self.match(GrammarParser.COLON)
self.state = 215
self.chain_id()
elif la_ == 3:
self.state = 216
self.match(GrammarParser.COLON)
self.state = 217
self.match(GrammarParser.IF)
self.state = 218
self.match(GrammarParser.LBRACK)
self.state = 219
self.cond_expression(0)
self.state = 220
self.match(GrammarParser.RBRACK)
self.state = 224
self.match(GrammarParser.SEMI)
pass
elif la_ == 3:
localctx = GrammarParser.NormalAllForceTransitionDefinitionContext(
self, localctx
)
self.enterOuterAlt(localctx, 3)
self.state = 225
self.match(GrammarParser.BANG)
self.state = 226
self.match(GrammarParser.STAR)
self.state = 227
self.match(GrammarParser.ARROW)
self.state = 228
localctx.to_state = self.match(GrammarParser.ID)
self.state = 237
self._errHandler.sync(self)
la_ = self._interp.adaptivePredict(self._input, 16, self._ctx)
if la_ == 1:
self.state = 229
_la = self._input.LA(1)
if not (
_la == GrammarParser.COLONCOLON or _la == GrammarParser.COLON
):
self._errHandler.recoverInline(self)
else:
self._errHandler.reportMatch(self)
self.consume()
self.state = 230
self.chain_id()
elif la_ == 2:
self.state = 231
self.match(GrammarParser.COLON)
self.state = 232
self.match(GrammarParser.IF)
self.state = 233
self.match(GrammarParser.LBRACK)
self.state = 234
self.cond_expression(0)
self.state = 235
self.match(GrammarParser.RBRACK)
self.state = 239
self.match(GrammarParser.SEMI)
pass
elif la_ == 4:
localctx = GrammarParser.ExitAllForceTransitionDefinitionContext(
self, localctx
)
self.enterOuterAlt(localctx, 4)
self.state = 240
self.match(GrammarParser.BANG)
self.state = 241
self.match(GrammarParser.STAR)
self.state = 242
self.match(GrammarParser.ARROW)
self.state = 243
self.match(GrammarParser.INIT_MARKER)
self.state = 252
self._errHandler.sync(self)
la_ = self._interp.adaptivePredict(self._input, 17, self._ctx)
if la_ == 1:
self.state = 244
_la = self._input.LA(1)
if not (
_la == GrammarParser.COLONCOLON or _la == GrammarParser.COLON
):
self._errHandler.recoverInline(self)
else:
self._errHandler.reportMatch(self)
self.consume()
self.state = 245
self.chain_id()
elif la_ == 2:
self.state = 246
self.match(GrammarParser.COLON)
self.state = 247
self.match(GrammarParser.IF)
self.state = 248
self.match(GrammarParser.LBRACK)
self.state = 249
self.cond_expression(0)
self.state = 250
self.match(GrammarParser.RBRACK)
self.state = 254
self.match(GrammarParser.SEMI)
pass
except RecognitionException as re:
localctx.exception = re
self._errHandler.reportError(self, re)
self._errHandler.recover(self, re)
finally:
self.exitRule()
return localctx
class Enter_definitionContext(ParserRuleContext):
__slots__ = "parser"
def __init__(
self, parser, parent: ParserRuleContext = None, invokingState: int = -1
):
super().__init__(parent, invokingState)
self.parser = parser
def getRuleIndex(self):
return GrammarParser.RULE_enter_definition
def copyFrom(self, ctx: ParserRuleContext):
super().copyFrom(ctx)
class EnterRefFuncContext(Enter_definitionContext):
def __init__(
self, parser, ctx: ParserRuleContext
): # actually a GrammarParser.Enter_definitionContext
super().__init__(parser)
self.func_name = None # Token
self.copyFrom(ctx)
def ENTER(self):
return self.getToken(GrammarParser.ENTER, 0)
def REF(self):
return self.getToken(GrammarParser.REF, 0)
def chain_id(self):
return self.getTypedRuleContext(GrammarParser.Chain_idContext, 0)
def SEMI(self):
return self.getToken(GrammarParser.SEMI, 0)
def ID(self):
return self.getToken(GrammarParser.ID, 0)
def enterRule(self, listener: ParseTreeListener):
if hasattr(listener, "enterEnterRefFunc"):
listener.enterEnterRefFunc(self)
def exitRule(self, listener: ParseTreeListener):
if hasattr(listener, "exitEnterRefFunc"):
listener.exitEnterRefFunc(self)
class EnterOperationsContext(Enter_definitionContext):
def __init__(
self, parser, ctx: ParserRuleContext
): # actually a GrammarParser.Enter_definitionContext
super().__init__(parser)
self.func_name = None # Token
self.copyFrom(ctx)
def ENTER(self):
return self.getToken(GrammarParser.ENTER, 0)
def LBRACE(self):
return self.getToken(GrammarParser.LBRACE, 0)
def operational_statement_set(self):
return self.getTypedRuleContext(
GrammarParser.Operational_statement_setContext, 0
)
def RBRACE(self):
return self.getToken(GrammarParser.RBRACE, 0)
def ID(self):
return self.getToken(GrammarParser.ID, 0)
def enterRule(self, listener: ParseTreeListener):
if hasattr(listener, "enterEnterOperations"):
listener.enterEnterOperations(self)
def exitRule(self, listener: ParseTreeListener):
if hasattr(listener, "exitEnterOperations"):
listener.exitEnterOperations(self)
class EnterAbstractFuncContext(Enter_definitionContext):
def __init__(
self, parser, ctx: ParserRuleContext
): # actually a GrammarParser.Enter_definitionContext
super().__init__(parser)
self.func_name = None # Token
self.raw_doc = None # Token
self.copyFrom(ctx)
def ENTER(self):
return self.getToken(GrammarParser.ENTER, 0)
def ABSTRACT(self):
return self.getToken(GrammarParser.ABSTRACT, 0)
def SEMI(self):
return self.getToken(GrammarParser.SEMI, 0)
def ID(self):
return self.getToken(GrammarParser.ID, 0)
def MULTILINE_COMMENT(self):
return self.getToken(GrammarParser.MULTILINE_COMMENT, 0)
def enterRule(self, listener: ParseTreeListener):
if hasattr(listener, "enterEnterAbstractFunc"):
listener.enterEnterAbstractFunc(self)
def exitRule(self, listener: ParseTreeListener):
if hasattr(listener, "exitEnterAbstractFunc"):
listener.exitEnterAbstractFunc(self)
def enter_definition(self):
localctx = GrammarParser.Enter_definitionContext(self, self._ctx, self.state)
self.enterRule(localctx, 12, self.RULE_enter_definition)
self._la = 0 # Token type
try:
self.state = 283
self._errHandler.sync(self)
la_ = self._interp.adaptivePredict(self._input, 22, self._ctx)
if la_ == 1:
localctx = GrammarParser.EnterOperationsContext(self, localctx)
self.enterOuterAlt(localctx, 1)
self.state = 257
self.match(GrammarParser.ENTER)
self.state = 259
self._errHandler.sync(self)
_la = self._input.LA(1)
if _la == GrammarParser.ID:
self.state = 258
localctx.func_name = self.match(GrammarParser.ID)
self.state = 261
self.match(GrammarParser.LBRACE)
self.state = 262
self.operational_statement_set()
self.state = 263
self.match(GrammarParser.RBRACE)
pass
elif la_ == 2:
localctx = GrammarParser.EnterAbstractFuncContext(self, localctx)
self.enterOuterAlt(localctx, 2)
self.state = 265
self.match(GrammarParser.ENTER)
self.state = 266
self.match(GrammarParser.ABSTRACT)
self.state = 267
localctx.func_name = self.match(GrammarParser.ID)
self.state = 268
self.match(GrammarParser.SEMI)
pass
elif la_ == 3:
localctx = GrammarParser.EnterAbstractFuncContext(self, localctx)
self.enterOuterAlt(localctx, 3)
self.state = 269
self.match(GrammarParser.ENTER)
self.state = 270
self.match(GrammarParser.ABSTRACT)
self.state = 272
self._errHandler.sync(self)
_la = self._input.LA(1)
if _la == GrammarParser.ID:
self.state = 271
localctx.func_name = self.match(GrammarParser.ID)
self.state = 274
localctx.raw_doc = self.match(GrammarParser.MULTILINE_COMMENT)
pass
elif la_ == 4:
localctx = GrammarParser.EnterRefFuncContext(self, localctx)
self.enterOuterAlt(localctx, 4)
self.state = 275
self.match(GrammarParser.ENTER)
self.state = 277
self._errHandler.sync(self)
_la = self._input.LA(1)
if _la == GrammarParser.ID:
self.state = 276
localctx.func_name = self.match(GrammarParser.ID)
self.state = 279
self.match(GrammarParser.REF)
self.state = 280
self.chain_id()
self.state = 281
self.match(GrammarParser.SEMI)
pass
except RecognitionException as re:
localctx.exception = re
self._errHandler.reportError(self, re)
self._errHandler.recover(self, re)
finally:
self.exitRule()
return localctx
class Exit_definitionContext(ParserRuleContext):
__slots__ = "parser"
def __init__(
self, parser, parent: ParserRuleContext = None, invokingState: int = -1
):
super().__init__(parent, invokingState)
self.parser = parser
def getRuleIndex(self):
return GrammarParser.RULE_exit_definition
def copyFrom(self, ctx: ParserRuleContext):
super().copyFrom(ctx)
class ExitOperationsContext(Exit_definitionContext):
def __init__(
self, parser, ctx: ParserRuleContext
): # actually a GrammarParser.Exit_definitionContext
super().__init__(parser)
self.func_name = None # Token
self.copyFrom(ctx)
def EXIT(self):
return self.getToken(GrammarParser.EXIT, 0)
def LBRACE(self):
return self.getToken(GrammarParser.LBRACE, 0)
def operational_statement_set(self):
return self.getTypedRuleContext(
GrammarParser.Operational_statement_setContext, 0
)
def RBRACE(self):
return self.getToken(GrammarParser.RBRACE, 0)
def ID(self):
return self.getToken(GrammarParser.ID, 0)
def enterRule(self, listener: ParseTreeListener):
if hasattr(listener, "enterExitOperations"):
listener.enterExitOperations(self)
def exitRule(self, listener: ParseTreeListener):
if hasattr(listener, "exitExitOperations"):
listener.exitExitOperations(self)
class ExitRefFuncContext(Exit_definitionContext):
def __init__(
self, parser, ctx: ParserRuleContext
): # actually a GrammarParser.Exit_definitionContext
super().__init__(parser)
self.func_name = None # Token
self.copyFrom(ctx)
def EXIT(self):
return self.getToken(GrammarParser.EXIT, 0)
def REF(self):
return self.getToken(GrammarParser.REF, 0)
def chain_id(self):
return self.getTypedRuleContext(GrammarParser.Chain_idContext, 0)
def SEMI(self):
return self.getToken(GrammarParser.SEMI, 0)
def ID(self):
return self.getToken(GrammarParser.ID, 0)
def enterRule(self, listener: ParseTreeListener):
if hasattr(listener, "enterExitRefFunc"):
listener.enterExitRefFunc(self)
def exitRule(self, listener: ParseTreeListener):
if hasattr(listener, "exitExitRefFunc"):
listener.exitExitRefFunc(self)
class ExitAbstractFuncContext(Exit_definitionContext):
def __init__(
self, parser, ctx: ParserRuleContext
): # actually a GrammarParser.Exit_definitionContext
super().__init__(parser)
self.func_name = None # Token
self.raw_doc = None # Token
self.copyFrom(ctx)
def EXIT(self):
return self.getToken(GrammarParser.EXIT, 0)
def ABSTRACT(self):
return self.getToken(GrammarParser.ABSTRACT, 0)
def SEMI(self):
return self.getToken(GrammarParser.SEMI, 0)
def ID(self):
return self.getToken(GrammarParser.ID, 0)
def MULTILINE_COMMENT(self):
return self.getToken(GrammarParser.MULTILINE_COMMENT, 0)
def enterRule(self, listener: ParseTreeListener):
if hasattr(listener, "enterExitAbstractFunc"):
listener.enterExitAbstractFunc(self)
def exitRule(self, listener: ParseTreeListener):
if hasattr(listener, "exitExitAbstractFunc"):
listener.exitExitAbstractFunc(self)
def exit_definition(self):
localctx = GrammarParser.Exit_definitionContext(self, self._ctx, self.state)
self.enterRule(localctx, 14, self.RULE_exit_definition)
self._la = 0 # Token type
try:
self.state = 311
self._errHandler.sync(self)
la_ = self._interp.adaptivePredict(self._input, 26, self._ctx)
if la_ == 1:
localctx = GrammarParser.ExitOperationsContext(self, localctx)
self.enterOuterAlt(localctx, 1)
self.state = 285
self.match(GrammarParser.EXIT)
self.state = 287
self._errHandler.sync(self)
_la = self._input.LA(1)
if _la == GrammarParser.ID:
self.state = 286
localctx.func_name = self.match(GrammarParser.ID)
self.state = 289
self.match(GrammarParser.LBRACE)
self.state = 290
self.operational_statement_set()
self.state = 291
self.match(GrammarParser.RBRACE)
pass
elif la_ == 2:
localctx = GrammarParser.ExitAbstractFuncContext(self, localctx)
self.enterOuterAlt(localctx, 2)
self.state = 293
self.match(GrammarParser.EXIT)
self.state = 294
self.match(GrammarParser.ABSTRACT)
self.state = 295
localctx.func_name = self.match(GrammarParser.ID)
self.state = 296
self.match(GrammarParser.SEMI)
pass
elif la_ == 3:
localctx = GrammarParser.ExitAbstractFuncContext(self, localctx)
self.enterOuterAlt(localctx, 3)
self.state = 297
self.match(GrammarParser.EXIT)
self.state = 298
self.match(GrammarParser.ABSTRACT)
self.state = 300
self._errHandler.sync(self)
_la = self._input.LA(1)
if _la == GrammarParser.ID:
self.state = 299
localctx.func_name = self.match(GrammarParser.ID)
self.state = 302
localctx.raw_doc = self.match(GrammarParser.MULTILINE_COMMENT)
pass
elif la_ == 4:
localctx = GrammarParser.ExitRefFuncContext(self, localctx)
self.enterOuterAlt(localctx, 4)
self.state = 303
self.match(GrammarParser.EXIT)
self.state = 305
self._errHandler.sync(self)
_la = self._input.LA(1)
if _la == GrammarParser.ID:
self.state = 304
localctx.func_name = self.match(GrammarParser.ID)
self.state = 307
self.match(GrammarParser.REF)
self.state = 308
self.chain_id()
self.state = 309
self.match(GrammarParser.SEMI)
pass
except RecognitionException as re:
localctx.exception = re
self._errHandler.reportError(self, re)
self._errHandler.recover(self, re)
finally:
self.exitRule()
return localctx
class During_definitionContext(ParserRuleContext):
__slots__ = "parser"
def __init__(
self, parser, parent: ParserRuleContext = None, invokingState: int = -1
):
super().__init__(parent, invokingState)
self.parser = parser
def getRuleIndex(self):
return GrammarParser.RULE_during_definition
def copyFrom(self, ctx: ParserRuleContext):
super().copyFrom(ctx)
class DuringOperationsContext(During_definitionContext):
def __init__(
self, parser, ctx: ParserRuleContext
): # actually a GrammarParser.During_definitionContext
super().__init__(parser)
self.aspect = None # Token
self.func_name = None # Token
self.copyFrom(ctx)
def DURING(self):
return self.getToken(GrammarParser.DURING, 0)
def LBRACE(self):
return self.getToken(GrammarParser.LBRACE, 0)
def operational_statement_set(self):
return self.getTypedRuleContext(
GrammarParser.Operational_statement_setContext, 0
)
def RBRACE(self):
return self.getToken(GrammarParser.RBRACE, 0)
def ID(self):
return self.getToken(GrammarParser.ID, 0)
def BEFORE(self):
return self.getToken(GrammarParser.BEFORE, 0)
def AFTER(self):
return self.getToken(GrammarParser.AFTER, 0)
def enterRule(self, listener: ParseTreeListener):
if hasattr(listener, "enterDuringOperations"):
listener.enterDuringOperations(self)
def exitRule(self, listener: ParseTreeListener):
if hasattr(listener, "exitDuringOperations"):
listener.exitDuringOperations(self)
class DuringAbstractFuncContext(During_definitionContext):
def __init__(
self, parser, ctx: ParserRuleContext
): # actually a GrammarParser.During_definitionContext
super().__init__(parser)
self.aspect = None # Token
self.func_name = None # Token
self.raw_doc = None # Token
self.copyFrom(ctx)
def DURING(self):
return self.getToken(GrammarParser.DURING, 0)
def ABSTRACT(self):
return self.getToken(GrammarParser.ABSTRACT, 0)
def SEMI(self):
return self.getToken(GrammarParser.SEMI, 0)
def ID(self):
return self.getToken(GrammarParser.ID, 0)
def BEFORE(self):
return self.getToken(GrammarParser.BEFORE, 0)
def AFTER(self):
return self.getToken(GrammarParser.AFTER, 0)
def MULTILINE_COMMENT(self):
return self.getToken(GrammarParser.MULTILINE_COMMENT, 0)
def enterRule(self, listener: ParseTreeListener):
if hasattr(listener, "enterDuringAbstractFunc"):
listener.enterDuringAbstractFunc(self)
def exitRule(self, listener: ParseTreeListener):
if hasattr(listener, "exitDuringAbstractFunc"):
listener.exitDuringAbstractFunc(self)
class DuringRefFuncContext(During_definitionContext):
def __init__(
self, parser, ctx: ParserRuleContext
): # actually a GrammarParser.During_definitionContext
super().__init__(parser)
self.aspect = None # Token
self.func_name = None # Token
self.copyFrom(ctx)
def DURING(self):
return self.getToken(GrammarParser.DURING, 0)
def REF(self):
return self.getToken(GrammarParser.REF, 0)
def chain_id(self):
return self.getTypedRuleContext(GrammarParser.Chain_idContext, 0)
def SEMI(self):
return self.getToken(GrammarParser.SEMI, 0)
def ID(self):
return self.getToken(GrammarParser.ID, 0)
def BEFORE(self):
return self.getToken(GrammarParser.BEFORE, 0)
def AFTER(self):
return self.getToken(GrammarParser.AFTER, 0)
def enterRule(self, listener: ParseTreeListener):
if hasattr(listener, "enterDuringRefFunc"):
listener.enterDuringRefFunc(self)
def exitRule(self, listener: ParseTreeListener):
if hasattr(listener, "exitDuringRefFunc"):
listener.exitDuringRefFunc(self)
def during_definition(self):
localctx = GrammarParser.During_definitionContext(self, self._ctx, self.state)
self.enterRule(localctx, 16, self.RULE_during_definition)
self._la = 0 # Token type
try:
self.state = 351
self._errHandler.sync(self)
la_ = self._interp.adaptivePredict(self._input, 34, self._ctx)
if la_ == 1:
localctx = GrammarParser.DuringOperationsContext(self, localctx)
self.enterOuterAlt(localctx, 1)
self.state = 313
self.match(GrammarParser.DURING)
self.state = 315
self._errHandler.sync(self)
_la = self._input.LA(1)
if _la == GrammarParser.BEFORE or _la == GrammarParser.AFTER:
self.state = 314
localctx.aspect = self._input.LT(1)
_la = self._input.LA(1)
if not (_la == GrammarParser.BEFORE or _la == GrammarParser.AFTER):
localctx.aspect = self._errHandler.recoverInline(self)
else:
self._errHandler.reportMatch(self)
self.consume()
self.state = 318
self._errHandler.sync(self)
_la = self._input.LA(1)
if _la == GrammarParser.ID:
self.state = 317
localctx.func_name = self.match(GrammarParser.ID)
self.state = 320
self.match(GrammarParser.LBRACE)
self.state = 321
self.operational_statement_set()
self.state = 322
self.match(GrammarParser.RBRACE)
pass
elif la_ == 2:
localctx = GrammarParser.DuringAbstractFuncContext(self, localctx)
self.enterOuterAlt(localctx, 2)
self.state = 324
self.match(GrammarParser.DURING)
self.state = 326
self._errHandler.sync(self)
_la = self._input.LA(1)
if _la == GrammarParser.BEFORE or _la == GrammarParser.AFTER:
self.state = 325
localctx.aspect = self._input.LT(1)
_la = self._input.LA(1)
if not (_la == GrammarParser.BEFORE or _la == GrammarParser.AFTER):
localctx.aspect = self._errHandler.recoverInline(self)
else:
self._errHandler.reportMatch(self)
self.consume()
self.state = 328
self.match(GrammarParser.ABSTRACT)
self.state = 329
localctx.func_name = self.match(GrammarParser.ID)
self.state = 330
self.match(GrammarParser.SEMI)
pass
elif la_ == 3:
localctx = GrammarParser.DuringAbstractFuncContext(self, localctx)
self.enterOuterAlt(localctx, 3)
self.state = 331
self.match(GrammarParser.DURING)
self.state = 333
self._errHandler.sync(self)
_la = self._input.LA(1)
if _la == GrammarParser.BEFORE or _la == GrammarParser.AFTER:
self.state = 332
localctx.aspect = self._input.LT(1)
_la = self._input.LA(1)
if not (_la == GrammarParser.BEFORE or _la == GrammarParser.AFTER):
localctx.aspect = self._errHandler.recoverInline(self)
else:
self._errHandler.reportMatch(self)
self.consume()
self.state = 335
self.match(GrammarParser.ABSTRACT)
self.state = 337
self._errHandler.sync(self)
_la = self._input.LA(1)
if _la == GrammarParser.ID:
self.state = 336
localctx.func_name = self.match(GrammarParser.ID)
self.state = 339
localctx.raw_doc = self.match(GrammarParser.MULTILINE_COMMENT)
pass
elif la_ == 4:
localctx = GrammarParser.DuringRefFuncContext(self, localctx)
self.enterOuterAlt(localctx, 4)
self.state = 340
self.match(GrammarParser.DURING)
self.state = 342
self._errHandler.sync(self)
_la = self._input.LA(1)
if _la == GrammarParser.BEFORE or _la == GrammarParser.AFTER:
self.state = 341
localctx.aspect = self._input.LT(1)
_la = self._input.LA(1)
if not (_la == GrammarParser.BEFORE or _la == GrammarParser.AFTER):
localctx.aspect = self._errHandler.recoverInline(self)
else:
self._errHandler.reportMatch(self)
self.consume()
self.state = 345
self._errHandler.sync(self)
_la = self._input.LA(1)
if _la == GrammarParser.ID:
self.state = 344
localctx.func_name = self.match(GrammarParser.ID)
self.state = 347
self.match(GrammarParser.REF)
self.state = 348
self.chain_id()
self.state = 349
self.match(GrammarParser.SEMI)
pass
except RecognitionException as re:
localctx.exception = re
self._errHandler.reportError(self, re)
self._errHandler.recover(self, re)
finally:
self.exitRule()
return localctx
class During_aspect_definitionContext(ParserRuleContext):
__slots__ = "parser"
def __init__(
self, parser, parent: ParserRuleContext = None, invokingState: int = -1
):
super().__init__(parent, invokingState)
self.parser = parser
def getRuleIndex(self):
return GrammarParser.RULE_during_aspect_definition
def copyFrom(self, ctx: ParserRuleContext):
super().copyFrom(ctx)
class DuringAspectRefFuncContext(During_aspect_definitionContext):
def __init__(
self, parser, ctx: ParserRuleContext
): # actually a GrammarParser.During_aspect_definitionContext
super().__init__(parser)
self.aspect = None # Token
self.func_name = None # Token
self.copyFrom(ctx)
def SHIFT_RIGHT(self):
return self.getToken(GrammarParser.SHIFT_RIGHT, 0)
def DURING(self):
return self.getToken(GrammarParser.DURING, 0)
def REF(self):
return self.getToken(GrammarParser.REF, 0)
def chain_id(self):
return self.getTypedRuleContext(GrammarParser.Chain_idContext, 0)
def SEMI(self):
return self.getToken(GrammarParser.SEMI, 0)
def BEFORE(self):
return self.getToken(GrammarParser.BEFORE, 0)
def AFTER(self):
return self.getToken(GrammarParser.AFTER, 0)
def ID(self):
return self.getToken(GrammarParser.ID, 0)
def enterRule(self, listener: ParseTreeListener):
if hasattr(listener, "enterDuringAspectRefFunc"):
listener.enterDuringAspectRefFunc(self)
def exitRule(self, listener: ParseTreeListener):
if hasattr(listener, "exitDuringAspectRefFunc"):
listener.exitDuringAspectRefFunc(self)
class DuringAspectAbstractFuncContext(During_aspect_definitionContext):
def __init__(
self, parser, ctx: ParserRuleContext
): # actually a GrammarParser.During_aspect_definitionContext
super().__init__(parser)
self.aspect = None # Token
self.func_name = None # Token
self.raw_doc = None # Token
self.copyFrom(ctx)
def SHIFT_RIGHT(self):
return self.getToken(GrammarParser.SHIFT_RIGHT, 0)
def DURING(self):
return self.getToken(GrammarParser.DURING, 0)
def ABSTRACT(self):
return self.getToken(GrammarParser.ABSTRACT, 0)
def SEMI(self):
return self.getToken(GrammarParser.SEMI, 0)
def ID(self):
return self.getToken(GrammarParser.ID, 0)
def BEFORE(self):
return self.getToken(GrammarParser.BEFORE, 0)
def AFTER(self):
return self.getToken(GrammarParser.AFTER, 0)
def MULTILINE_COMMENT(self):
return self.getToken(GrammarParser.MULTILINE_COMMENT, 0)
def enterRule(self, listener: ParseTreeListener):
if hasattr(listener, "enterDuringAspectAbstractFunc"):
listener.enterDuringAspectAbstractFunc(self)
def exitRule(self, listener: ParseTreeListener):
if hasattr(listener, "exitDuringAspectAbstractFunc"):
listener.exitDuringAspectAbstractFunc(self)
class DuringAspectOperationsContext(During_aspect_definitionContext):
def __init__(
self, parser, ctx: ParserRuleContext
): # actually a GrammarParser.During_aspect_definitionContext
super().__init__(parser)
self.aspect = None # Token
self.func_name = None # Token
self.copyFrom(ctx)
def SHIFT_RIGHT(self):
return self.getToken(GrammarParser.SHIFT_RIGHT, 0)
def DURING(self):
return self.getToken(GrammarParser.DURING, 0)
def LBRACE(self):
return self.getToken(GrammarParser.LBRACE, 0)
def operational_statement_set(self):
return self.getTypedRuleContext(
GrammarParser.Operational_statement_setContext, 0
)
def RBRACE(self):
return self.getToken(GrammarParser.RBRACE, 0)
def BEFORE(self):
return self.getToken(GrammarParser.BEFORE, 0)
def AFTER(self):
return self.getToken(GrammarParser.AFTER, 0)
def ID(self):
return self.getToken(GrammarParser.ID, 0)
def enterRule(self, listener: ParseTreeListener):
if hasattr(listener, "enterDuringAspectOperations"):
listener.enterDuringAspectOperations(self)
def exitRule(self, listener: ParseTreeListener):
if hasattr(listener, "exitDuringAspectOperations"):
listener.exitDuringAspectOperations(self)
def during_aspect_definition(self):
localctx = GrammarParser.During_aspect_definitionContext(
self, self._ctx, self.state
)
self.enterRule(localctx, 18, self.RULE_during_aspect_definition)
self._la = 0 # Token type
try:
self.state = 387
self._errHandler.sync(self)
la_ = self._interp.adaptivePredict(self._input, 38, self._ctx)
if la_ == 1:
localctx = GrammarParser.DuringAspectOperationsContext(self, localctx)
self.enterOuterAlt(localctx, 1)
self.state = 353
self.match(GrammarParser.SHIFT_RIGHT)
self.state = 354
self.match(GrammarParser.DURING)
self.state = 355
localctx.aspect = self._input.LT(1)
_la = self._input.LA(1)
if not (_la == GrammarParser.BEFORE or _la == GrammarParser.AFTER):
localctx.aspect = self._errHandler.recoverInline(self)
else:
self._errHandler.reportMatch(self)
self.consume()
self.state = 357
self._errHandler.sync(self)
_la = self._input.LA(1)
if _la == GrammarParser.ID:
self.state = 356
localctx.func_name = self.match(GrammarParser.ID)
self.state = 359
self.match(GrammarParser.LBRACE)
self.state = 360
self.operational_statement_set()
self.state = 361
self.match(GrammarParser.RBRACE)
pass
elif la_ == 2:
localctx = GrammarParser.DuringAspectAbstractFuncContext(self, localctx)
self.enterOuterAlt(localctx, 2)
self.state = 363
self.match(GrammarParser.SHIFT_RIGHT)
self.state = 364
self.match(GrammarParser.DURING)
self.state = 365
localctx.aspect = self._input.LT(1)
_la = self._input.LA(1)
if not (_la == GrammarParser.BEFORE or _la == GrammarParser.AFTER):
localctx.aspect = self._errHandler.recoverInline(self)
else:
self._errHandler.reportMatch(self)
self.consume()
self.state = 366
self.match(GrammarParser.ABSTRACT)
self.state = 367
localctx.func_name = self.match(GrammarParser.ID)
self.state = 368
self.match(GrammarParser.SEMI)
pass
elif la_ == 3:
localctx = GrammarParser.DuringAspectAbstractFuncContext(self, localctx)
self.enterOuterAlt(localctx, 3)
self.state = 369
self.match(GrammarParser.SHIFT_RIGHT)
self.state = 370
self.match(GrammarParser.DURING)
self.state = 371
localctx.aspect = self._input.LT(1)
_la = self._input.LA(1)
if not (_la == GrammarParser.BEFORE or _la == GrammarParser.AFTER):
localctx.aspect = self._errHandler.recoverInline(self)
else:
self._errHandler.reportMatch(self)
self.consume()
self.state = 372
self.match(GrammarParser.ABSTRACT)
self.state = 374
self._errHandler.sync(self)
_la = self._input.LA(1)
if _la == GrammarParser.ID:
self.state = 373
localctx.func_name = self.match(GrammarParser.ID)
self.state = 376
localctx.raw_doc = self.match(GrammarParser.MULTILINE_COMMENT)
pass
elif la_ == 4:
localctx = GrammarParser.DuringAspectRefFuncContext(self, localctx)
self.enterOuterAlt(localctx, 4)
self.state = 377
self.match(GrammarParser.SHIFT_RIGHT)
self.state = 378
self.match(GrammarParser.DURING)
self.state = 379
localctx.aspect = self._input.LT(1)
_la = self._input.LA(1)
if not (_la == GrammarParser.BEFORE or _la == GrammarParser.AFTER):
localctx.aspect = self._errHandler.recoverInline(self)
else:
self._errHandler.reportMatch(self)
self.consume()
self.state = 381
self._errHandler.sync(self)
_la = self._input.LA(1)
if _la == GrammarParser.ID:
self.state = 380
localctx.func_name = self.match(GrammarParser.ID)
self.state = 383
self.match(GrammarParser.REF)
self.state = 384
self.chain_id()
self.state = 385
self.match(GrammarParser.SEMI)
pass
except RecognitionException as re:
localctx.exception = re
self._errHandler.reportError(self, re)
self._errHandler.recover(self, re)
finally:
self.exitRule()
return localctx
class Event_definitionContext(ParserRuleContext):
__slots__ = "parser"
def __init__(
self, parser, parent: ParserRuleContext = None, invokingState: int = -1
):
super().__init__(parent, invokingState)
self.parser = parser
self.event_name = None # Token
self.extra_name = None # Token
def EVENT(self):
return self.getToken(GrammarParser.EVENT, 0)
def SEMI(self):
return self.getToken(GrammarParser.SEMI, 0)
def ID(self):
return self.getToken(GrammarParser.ID, 0)
def NAMED(self):
return self.getToken(GrammarParser.NAMED, 0)
def STRING(self):
return self.getToken(GrammarParser.STRING, 0)
def getRuleIndex(self):
return GrammarParser.RULE_event_definition
def enterRule(self, listener: ParseTreeListener):
if hasattr(listener, "enterEvent_definition"):
listener.enterEvent_definition(self)
def exitRule(self, listener: ParseTreeListener):
if hasattr(listener, "exitEvent_definition"):
listener.exitEvent_definition(self)
def event_definition(self):
localctx = GrammarParser.Event_definitionContext(self, self._ctx, self.state)
self.enterRule(localctx, 20, self.RULE_event_definition)
self._la = 0 # Token type
try:
self.enterOuterAlt(localctx, 1)
self.state = 389
self.match(GrammarParser.EVENT)
self.state = 390
localctx.event_name = self.match(GrammarParser.ID)
self.state = 393
self._errHandler.sync(self)
_la = self._input.LA(1)
if _la == GrammarParser.NAMED:
self.state = 391
self.match(GrammarParser.NAMED)
self.state = 392
localctx.extra_name = self.match(GrammarParser.STRING)
self.state = 395
self.match(GrammarParser.SEMI)
except RecognitionException as re:
localctx.exception = re
self._errHandler.reportError(self, re)
self._errHandler.recover(self, re)
finally:
self.exitRule()
return localctx
class Import_statementContext(ParserRuleContext):
__slots__ = "parser"
def __init__(
self, parser, parent: ParserRuleContext = None, invokingState: int = -1
):
super().__init__(parent, invokingState)
self.parser = parser
self.import_path = None # Token
self.state_alias = None # Token
self.extra_name = None # Token
def IMPORT(self):
return self.getToken(GrammarParser.IMPORT, 0)
def AS(self):
return self.getToken(GrammarParser.AS, 0)
def STRING(self, i: int = None):
if i is None:
return self.getTokens(GrammarParser.STRING)
else:
return self.getToken(GrammarParser.STRING, i)
def ID(self):
return self.getToken(GrammarParser.ID, 0)
def LBRACE(self):
return self.getToken(GrammarParser.LBRACE, 0)
def RBRACE(self):
return self.getToken(GrammarParser.RBRACE, 0)
def SEMI(self):
return self.getToken(GrammarParser.SEMI, 0)
def NAMED(self):
return self.getToken(GrammarParser.NAMED, 0)
def import_mapping_statement(self, i: int = None):
if i is None:
return self.getTypedRuleContexts(
GrammarParser.Import_mapping_statementContext
)
else:
return self.getTypedRuleContext(
GrammarParser.Import_mapping_statementContext, i
)
def getRuleIndex(self):
return GrammarParser.RULE_import_statement
def enterRule(self, listener: ParseTreeListener):
if hasattr(listener, "enterImport_statement"):
listener.enterImport_statement(self)
def exitRule(self, listener: ParseTreeListener):
if hasattr(listener, "exitImport_statement"):
listener.exitImport_statement(self)
def import_statement(self):
localctx = GrammarParser.Import_statementContext(self, self._ctx, self.state)
self.enterRule(localctx, 22, self.RULE_import_statement)
self._la = 0 # Token type
try:
self.enterOuterAlt(localctx, 1)
self.state = 397
self.match(GrammarParser.IMPORT)
self.state = 398
localctx.import_path = self.match(GrammarParser.STRING)
self.state = 399
self.match(GrammarParser.AS)
self.state = 400
localctx.state_alias = self.match(GrammarParser.ID)
self.state = 403
self._errHandler.sync(self)
_la = self._input.LA(1)
if _la == GrammarParser.NAMED:
self.state = 401
self.match(GrammarParser.NAMED)
self.state = 402
localctx.extra_name = self.match(GrammarParser.STRING)
self.state = 414
self._errHandler.sync(self)
token = self._input.LA(1)
if token in [GrammarParser.LBRACE]:
self.state = 405
self.match(GrammarParser.LBRACE)
self.state = 409
self._errHandler.sync(self)
_la = self._input.LA(1)
while ((_la) & ~0x3F) == 0 and (
(1 << _la)
& (
(1 << GrammarParser.DEF)
| (1 << GrammarParser.EVENT)
| (1 << GrammarParser.SEMI)
)
) != 0:
self.state = 406
self.import_mapping_statement()
self.state = 411
self._errHandler.sync(self)
_la = self._input.LA(1)
self.state = 412
self.match(GrammarParser.RBRACE)
pass
elif token in [GrammarParser.SEMI]:
self.state = 413
self.match(GrammarParser.SEMI)
pass
else:
raise NoViableAltException(self)
except RecognitionException as re:
localctx.exception = re
self._errHandler.reportError(self, re)
self._errHandler.recover(self, re)
finally:
self.exitRule()
return localctx
class Import_mapping_statementContext(ParserRuleContext):
__slots__ = "parser"
def __init__(
self, parser, parent: ParserRuleContext = None, invokingState: int = -1
):
super().__init__(parent, invokingState)
self.parser = parser
def import_def_mapping(self):
return self.getTypedRuleContext(GrammarParser.Import_def_mappingContext, 0)
def import_event_mapping(self):
return self.getTypedRuleContext(
GrammarParser.Import_event_mappingContext, 0
)
def SEMI(self):
return self.getToken(GrammarParser.SEMI, 0)
def getRuleIndex(self):
return GrammarParser.RULE_import_mapping_statement
def enterRule(self, listener: ParseTreeListener):
if hasattr(listener, "enterImport_mapping_statement"):
listener.enterImport_mapping_statement(self)
def exitRule(self, listener: ParseTreeListener):
if hasattr(listener, "exitImport_mapping_statement"):
listener.exitImport_mapping_statement(self)
def import_mapping_statement(self):
localctx = GrammarParser.Import_mapping_statementContext(
self, self._ctx, self.state
)
self.enterRule(localctx, 24, self.RULE_import_mapping_statement)
try:
self.state = 419
self._errHandler.sync(self)
token = self._input.LA(1)
if token in [GrammarParser.DEF]:
self.enterOuterAlt(localctx, 1)
self.state = 416
self.import_def_mapping()
pass
elif token in [GrammarParser.EVENT]:
self.enterOuterAlt(localctx, 2)
self.state = 417
self.import_event_mapping()
pass
elif token in [GrammarParser.SEMI]:
self.enterOuterAlt(localctx, 3)
self.state = 418
self.match(GrammarParser.SEMI)
pass
else:
raise NoViableAltException(self)
except RecognitionException as re:
localctx.exception = re
self._errHandler.reportError(self, re)
self._errHandler.recover(self, re)
finally:
self.exitRule()
return localctx
class Import_def_mappingContext(ParserRuleContext):
__slots__ = "parser"
def __init__(
self, parser, parent: ParserRuleContext = None, invokingState: int = -1
):
super().__init__(parent, invokingState)
self.parser = parser
def DEF(self):
return self.getToken(GrammarParser.DEF, 0)
def import_def_selector(self):
return self.getTypedRuleContext(GrammarParser.Import_def_selectorContext, 0)
def ARROW(self):
return self.getToken(GrammarParser.ARROW, 0)
def import_def_target_template(self):
return self.getTypedRuleContext(
GrammarParser.Import_def_target_templateContext, 0
)
def SEMI(self):
return self.getToken(GrammarParser.SEMI, 0)
def getRuleIndex(self):
return GrammarParser.RULE_import_def_mapping
def enterRule(self, listener: ParseTreeListener):
if hasattr(listener, "enterImport_def_mapping"):
listener.enterImport_def_mapping(self)
def exitRule(self, listener: ParseTreeListener):
if hasattr(listener, "exitImport_def_mapping"):
listener.exitImport_def_mapping(self)
def import_def_mapping(self):
localctx = GrammarParser.Import_def_mappingContext(self, self._ctx, self.state)
self.enterRule(localctx, 26, self.RULE_import_def_mapping)
try:
self.enterOuterAlt(localctx, 1)
self.state = 421
self.match(GrammarParser.DEF)
self.state = 422
self.import_def_selector()
self.state = 423
self.match(GrammarParser.ARROW)
self.state = 424
self.import_def_target_template()
self.state = 425
self.match(GrammarParser.SEMI)
except RecognitionException as re:
localctx.exception = re
self._errHandler.reportError(self, re)
self._errHandler.recover(self, re)
finally:
self.exitRule()
return localctx
class Import_def_selectorContext(ParserRuleContext):
__slots__ = "parser"
def __init__(
self, parser, parent: ParserRuleContext = None, invokingState: int = -1
):
super().__init__(parent, invokingState)
self.parser = parser
def getRuleIndex(self):
return GrammarParser.RULE_import_def_selector
def copyFrom(self, ctx: ParserRuleContext):
super().copyFrom(ctx)
class ImportDefFallbackSelectorContext(Import_def_selectorContext):
def __init__(
self, parser, ctx: ParserRuleContext
): # actually a GrammarParser.Import_def_selectorContext
super().__init__(parser)
self.copyFrom(ctx)
def STAR(self):
return self.getToken(GrammarParser.STAR, 0)
def enterRule(self, listener: ParseTreeListener):
if hasattr(listener, "enterImportDefFallbackSelector"):
listener.enterImportDefFallbackSelector(self)
def exitRule(self, listener: ParseTreeListener):
if hasattr(listener, "exitImportDefFallbackSelector"):
listener.exitImportDefFallbackSelector(self)
class ImportDefPatternSelectorContext(Import_def_selectorContext):
def __init__(
self, parser, ctx: ParserRuleContext
): # actually a GrammarParser.Import_def_selectorContext
super().__init__(parser)
self.selector_pattern = None # Token
self.copyFrom(ctx)
def IMPORT_DEF_SELECTOR_PATTERN(self):
return self.getToken(GrammarParser.IMPORT_DEF_SELECTOR_PATTERN, 0)
def enterRule(self, listener: ParseTreeListener):
if hasattr(listener, "enterImportDefPatternSelector"):
listener.enterImportDefPatternSelector(self)
def exitRule(self, listener: ParseTreeListener):
if hasattr(listener, "exitImportDefPatternSelector"):
listener.exitImportDefPatternSelector(self)
class ImportDefExactSelectorContext(Import_def_selectorContext):
def __init__(
self, parser, ctx: ParserRuleContext
): # actually a GrammarParser.Import_def_selectorContext
super().__init__(parser)
self.selector_name = None # Token
self.copyFrom(ctx)
def ID(self):
return self.getToken(GrammarParser.ID, 0)
def enterRule(self, listener: ParseTreeListener):
if hasattr(listener, "enterImportDefExactSelector"):
listener.enterImportDefExactSelector(self)
def exitRule(self, listener: ParseTreeListener):
if hasattr(listener, "exitImportDefExactSelector"):
listener.exitImportDefExactSelector(self)
class ImportDefSetSelectorContext(Import_def_selectorContext):
def __init__(
self, parser, ctx: ParserRuleContext
): # actually a GrammarParser.Import_def_selectorContext
super().__init__(parser)
self._ID = None # Token
self.selector_items = list() # of Tokens
self.copyFrom(ctx)
def LBRACE(self):
return self.getToken(GrammarParser.LBRACE, 0)
def RBRACE(self):
return self.getToken(GrammarParser.RBRACE, 0)
def ID(self, i: int = None):
if i is None:
return self.getTokens(GrammarParser.ID)
else:
return self.getToken(GrammarParser.ID, i)
def COMMA(self, i: int = None):
if i is None:
return self.getTokens(GrammarParser.COMMA)
else:
return self.getToken(GrammarParser.COMMA, i)
def enterRule(self, listener: ParseTreeListener):
if hasattr(listener, "enterImportDefSetSelector"):
listener.enterImportDefSetSelector(self)
def exitRule(self, listener: ParseTreeListener):
if hasattr(listener, "exitImportDefSetSelector"):
listener.exitImportDefSetSelector(self)
def import_def_selector(self):
localctx = GrammarParser.Import_def_selectorContext(self, self._ctx, self.state)
self.enterRule(localctx, 28, self.RULE_import_def_selector)
self._la = 0 # Token type
try:
self.state = 440
self._errHandler.sync(self)
token = self._input.LA(1)
if token in [GrammarParser.STAR]:
localctx = GrammarParser.ImportDefFallbackSelectorContext(
self, localctx
)
self.enterOuterAlt(localctx, 1)
self.state = 427
self.match(GrammarParser.STAR)
pass
elif token in [GrammarParser.LBRACE]:
localctx = GrammarParser.ImportDefSetSelectorContext(self, localctx)
self.enterOuterAlt(localctx, 2)
self.state = 428
self.match(GrammarParser.LBRACE)
self.state = 429
localctx._ID = self.match(GrammarParser.ID)
localctx.selector_items.append(localctx._ID)
self.state = 434
self._errHandler.sync(self)
_la = self._input.LA(1)
while _la == GrammarParser.COMMA:
self.state = 430
self.match(GrammarParser.COMMA)
self.state = 431
localctx._ID = self.match(GrammarParser.ID)
localctx.selector_items.append(localctx._ID)
self.state = 436
self._errHandler.sync(self)
_la = self._input.LA(1)
self.state = 437
self.match(GrammarParser.RBRACE)
pass
elif token in [GrammarParser.IMPORT_DEF_SELECTOR_PATTERN]:
localctx = GrammarParser.ImportDefPatternSelectorContext(self, localctx)
self.enterOuterAlt(localctx, 3)
self.state = 438
localctx.selector_pattern = self.match(
GrammarParser.IMPORT_DEF_SELECTOR_PATTERN
)
pass
elif token in [GrammarParser.ID]:
localctx = GrammarParser.ImportDefExactSelectorContext(self, localctx)
self.enterOuterAlt(localctx, 4)
self.state = 439
localctx.selector_name = self.match(GrammarParser.ID)
pass
else:
raise NoViableAltException(self)
except RecognitionException as re:
localctx.exception = re
self._errHandler.reportError(self, re)
self._errHandler.recover(self, re)
finally:
self.exitRule()
return localctx
class Import_def_target_templateContext(ParserRuleContext):
__slots__ = "parser"
def __init__(
self, parser, parent: ParserRuleContext = None, invokingState: int = -1
):
super().__init__(parent, invokingState)
self.parser = parser
self.target_text = None # Token
def ID(self):
return self.getToken(GrammarParser.ID, 0)
def IMPORT_DEF_TARGET_TEMPLATE(self):
return self.getToken(GrammarParser.IMPORT_DEF_TARGET_TEMPLATE, 0)
def STAR(self):
return self.getToken(GrammarParser.STAR, 0)
def getRuleIndex(self):
return GrammarParser.RULE_import_def_target_template
def enterRule(self, listener: ParseTreeListener):
if hasattr(listener, "enterImport_def_target_template"):
listener.enterImport_def_target_template(self)
def exitRule(self, listener: ParseTreeListener):
if hasattr(listener, "exitImport_def_target_template"):
listener.exitImport_def_target_template(self)
def import_def_target_template(self):
localctx = GrammarParser.Import_def_target_templateContext(
self, self._ctx, self.state
)
self.enterRule(localctx, 30, self.RULE_import_def_target_template)
try:
self.state = 445
self._errHandler.sync(self)
token = self._input.LA(1)
if token in [GrammarParser.ID]:
self.enterOuterAlt(localctx, 1)
self.state = 442
localctx.target_text = self.match(GrammarParser.ID)
pass
elif token in [GrammarParser.IMPORT_DEF_TARGET_TEMPLATE]:
self.enterOuterAlt(localctx, 2)
self.state = 443
localctx.target_text = self.match(
GrammarParser.IMPORT_DEF_TARGET_TEMPLATE
)
pass
elif token in [GrammarParser.STAR]:
self.enterOuterAlt(localctx, 3)
self.state = 444
localctx.target_text = self.match(GrammarParser.STAR)
pass
else:
raise NoViableAltException(self)
except RecognitionException as re:
localctx.exception = re
self._errHandler.reportError(self, re)
self._errHandler.recover(self, re)
finally:
self.exitRule()
return localctx
class Import_event_mappingContext(ParserRuleContext):
__slots__ = "parser"
def __init__(
self, parser, parent: ParserRuleContext = None, invokingState: int = -1
):
super().__init__(parent, invokingState)
self.parser = parser
self.source_event = None # Chain_idContext
self.target_event = None # Chain_idContext
self.extra_name = None # Token
def EVENT(self):
return self.getToken(GrammarParser.EVENT, 0)
def ARROW(self):
return self.getToken(GrammarParser.ARROW, 0)
def SEMI(self):
return self.getToken(GrammarParser.SEMI, 0)
def chain_id(self, i: int = None):
if i is None:
return self.getTypedRuleContexts(GrammarParser.Chain_idContext)
else:
return self.getTypedRuleContext(GrammarParser.Chain_idContext, i)
def NAMED(self):
return self.getToken(GrammarParser.NAMED, 0)
def STRING(self):
return self.getToken(GrammarParser.STRING, 0)
def getRuleIndex(self):
return GrammarParser.RULE_import_event_mapping
def enterRule(self, listener: ParseTreeListener):
if hasattr(listener, "enterImport_event_mapping"):
listener.enterImport_event_mapping(self)
def exitRule(self, listener: ParseTreeListener):
if hasattr(listener, "exitImport_event_mapping"):
listener.exitImport_event_mapping(self)
def import_event_mapping(self):
localctx = GrammarParser.Import_event_mappingContext(
self, self._ctx, self.state
)
self.enterRule(localctx, 32, self.RULE_import_event_mapping)
self._la = 0 # Token type
try:
self.enterOuterAlt(localctx, 1)
self.state = 447
self.match(GrammarParser.EVENT)
self.state = 448
localctx.source_event = self.chain_id()
self.state = 449
self.match(GrammarParser.ARROW)
self.state = 450
localctx.target_event = self.chain_id()
self.state = 453
self._errHandler.sync(self)
_la = self._input.LA(1)
if _la == GrammarParser.NAMED:
self.state = 451
self.match(GrammarParser.NAMED)
self.state = 452
localctx.extra_name = self.match(GrammarParser.STRING)
self.state = 455
self.match(GrammarParser.SEMI)
except RecognitionException as re:
localctx.exception = re
self._errHandler.reportError(self, re)
self._errHandler.recover(self, re)
finally:
self.exitRule()
return localctx
class Operation_assignmentContext(ParserRuleContext):
__slots__ = "parser"
def __init__(
self, parser, parent: ParserRuleContext = None, invokingState: int = -1
):
super().__init__(parent, invokingState)
self.parser = parser
def ID(self):
return self.getToken(GrammarParser.ID, 0)
def ASSIGN(self):
return self.getToken(GrammarParser.ASSIGN, 0)
def num_expression(self):
return self.getTypedRuleContext(GrammarParser.Num_expressionContext, 0)
def SEMI(self):
return self.getToken(GrammarParser.SEMI, 0)
def getRuleIndex(self):
return GrammarParser.RULE_operation_assignment
def enterRule(self, listener: ParseTreeListener):
if hasattr(listener, "enterOperation_assignment"):
listener.enterOperation_assignment(self)
def exitRule(self, listener: ParseTreeListener):
if hasattr(listener, "exitOperation_assignment"):
listener.exitOperation_assignment(self)
def operation_assignment(self):
localctx = GrammarParser.Operation_assignmentContext(
self, self._ctx, self.state
)
self.enterRule(localctx, 34, self.RULE_operation_assignment)
try:
self.enterOuterAlt(localctx, 1)
self.state = 457
self.match(GrammarParser.ID)
self.state = 458
self.match(GrammarParser.ASSIGN)
self.state = 459
self.num_expression(0)
self.state = 460
self.match(GrammarParser.SEMI)
except RecognitionException as re:
localctx.exception = re
self._errHandler.reportError(self, re)
self._errHandler.recover(self, re)
finally:
self.exitRule()
return localctx
class Operation_blockContext(ParserRuleContext):
__slots__ = "parser"
def __init__(
self, parser, parent: ParserRuleContext = None, invokingState: int = -1
):
super().__init__(parent, invokingState)
self.parser = parser
def LBRACE(self):
return self.getToken(GrammarParser.LBRACE, 0)
def operational_statement_set(self):
return self.getTypedRuleContext(
GrammarParser.Operational_statement_setContext, 0
)
def RBRACE(self):
return self.getToken(GrammarParser.RBRACE, 0)
def getRuleIndex(self):
return GrammarParser.RULE_operation_block
def enterRule(self, listener: ParseTreeListener):
if hasattr(listener, "enterOperation_block"):
listener.enterOperation_block(self)
def exitRule(self, listener: ParseTreeListener):
if hasattr(listener, "exitOperation_block"):
listener.exitOperation_block(self)
def operation_block(self):
localctx = GrammarParser.Operation_blockContext(self, self._ctx, self.state)
self.enterRule(localctx, 36, self.RULE_operation_block)
try:
self.enterOuterAlt(localctx, 1)
self.state = 462
self.match(GrammarParser.LBRACE)
self.state = 463
self.operational_statement_set()
self.state = 464
self.match(GrammarParser.RBRACE)
except RecognitionException as re:
localctx.exception = re
self._errHandler.reportError(self, re)
self._errHandler.recover(self, re)
finally:
self.exitRule()
return localctx
class If_statementContext(ParserRuleContext):
__slots__ = "parser"
def __init__(
self, parser, parent: ParserRuleContext = None, invokingState: int = -1
):
super().__init__(parent, invokingState)
self.parser = parser
def IF(self, i: int = None):
if i is None:
return self.getTokens(GrammarParser.IF)
else:
return self.getToken(GrammarParser.IF, i)
def LBRACK(self, i: int = None):
if i is None:
return self.getTokens(GrammarParser.LBRACK)
else:
return self.getToken(GrammarParser.LBRACK, i)
def cond_expression(self, i: int = None):
if i is None:
return self.getTypedRuleContexts(GrammarParser.Cond_expressionContext)
else:
return self.getTypedRuleContext(GrammarParser.Cond_expressionContext, i)
def RBRACK(self, i: int = None):
if i is None:
return self.getTokens(GrammarParser.RBRACK)
else:
return self.getToken(GrammarParser.RBRACK, i)
def operation_block(self, i: int = None):
if i is None:
return self.getTypedRuleContexts(GrammarParser.Operation_blockContext)
else:
return self.getTypedRuleContext(GrammarParser.Operation_blockContext, i)
def ELSE(self, i: int = None):
if i is None:
return self.getTokens(GrammarParser.ELSE)
else:
return self.getToken(GrammarParser.ELSE, i)
def getRuleIndex(self):
return GrammarParser.RULE_if_statement
def enterRule(self, listener: ParseTreeListener):
if hasattr(listener, "enterIf_statement"):
listener.enterIf_statement(self)
def exitRule(self, listener: ParseTreeListener):
if hasattr(listener, "exitIf_statement"):
listener.exitIf_statement(self)
def if_statement(self):
localctx = GrammarParser.If_statementContext(self, self._ctx, self.state)
self.enterRule(localctx, 38, self.RULE_if_statement)
self._la = 0 # Token type
try:
self.enterOuterAlt(localctx, 1)
self.state = 466
self.match(GrammarParser.IF)
self.state = 467
self.match(GrammarParser.LBRACK)
self.state = 468
self.cond_expression(0)
self.state = 469
self.match(GrammarParser.RBRACK)
self.state = 470
self.operation_block()
self.state = 480
self._errHandler.sync(self)
_alt = self._interp.adaptivePredict(self._input, 48, self._ctx)
while _alt != 2 and _alt != ATN.INVALID_ALT_NUMBER:
if _alt == 1:
self.state = 471
self.match(GrammarParser.ELSE)
self.state = 472
self.match(GrammarParser.IF)
self.state = 473
self.match(GrammarParser.LBRACK)
self.state = 474
self.cond_expression(0)
self.state = 475
self.match(GrammarParser.RBRACK)
self.state = 476
self.operation_block()
self.state = 482
self._errHandler.sync(self)
_alt = self._interp.adaptivePredict(self._input, 48, self._ctx)
self.state = 485
self._errHandler.sync(self)
_la = self._input.LA(1)
if _la == GrammarParser.ELSE:
self.state = 483
self.match(GrammarParser.ELSE)
self.state = 484
self.operation_block()
except RecognitionException as re:
localctx.exception = re
self._errHandler.reportError(self, re)
self._errHandler.recover(self, re)
finally:
self.exitRule()
return localctx
class Operational_statementContext(ParserRuleContext):
__slots__ = "parser"
def __init__(
self, parser, parent: ParserRuleContext = None, invokingState: int = -1
):
super().__init__(parent, invokingState)
self.parser = parser
def operation_assignment(self):
return self.getTypedRuleContext(
GrammarParser.Operation_assignmentContext, 0
)
def if_statement(self):
return self.getTypedRuleContext(GrammarParser.If_statementContext, 0)
def SEMI(self):
return self.getToken(GrammarParser.SEMI, 0)
def getRuleIndex(self):
return GrammarParser.RULE_operational_statement
def enterRule(self, listener: ParseTreeListener):
if hasattr(listener, "enterOperational_statement"):
listener.enterOperational_statement(self)
def exitRule(self, listener: ParseTreeListener):
if hasattr(listener, "exitOperational_statement"):
listener.exitOperational_statement(self)
def operational_statement(self):
localctx = GrammarParser.Operational_statementContext(
self, self._ctx, self.state
)
self.enterRule(localctx, 40, self.RULE_operational_statement)
try:
self.state = 490
self._errHandler.sync(self)
token = self._input.LA(1)
if token in [GrammarParser.ID]:
self.enterOuterAlt(localctx, 1)
self.state = 487
self.operation_assignment()
pass
elif token in [GrammarParser.IF]:
self.enterOuterAlt(localctx, 2)
self.state = 488
self.if_statement()
pass
elif token in [GrammarParser.SEMI]:
self.enterOuterAlt(localctx, 3)
self.state = 489
self.match(GrammarParser.SEMI)
pass
else:
raise NoViableAltException(self)
except RecognitionException as re:
localctx.exception = re
self._errHandler.reportError(self, re)
self._errHandler.recover(self, re)
finally:
self.exitRule()
return localctx
class Operational_statement_setContext(ParserRuleContext):
__slots__ = "parser"
def __init__(
self, parser, parent: ParserRuleContext = None, invokingState: int = -1
):
super().__init__(parent, invokingState)
self.parser = parser
def operational_statement(self, i: int = None):
if i is None:
return self.getTypedRuleContexts(
GrammarParser.Operational_statementContext
)
else:
return self.getTypedRuleContext(
GrammarParser.Operational_statementContext, i
)
def getRuleIndex(self):
return GrammarParser.RULE_operational_statement_set
def enterRule(self, listener: ParseTreeListener):
if hasattr(listener, "enterOperational_statement_set"):
listener.enterOperational_statement_set(self)
def exitRule(self, listener: ParseTreeListener):
if hasattr(listener, "exitOperational_statement_set"):
listener.exitOperational_statement_set(self)
def operational_statement_set(self):
localctx = GrammarParser.Operational_statement_setContext(
self, self._ctx, self.state
)
self.enterRule(localctx, 42, self.RULE_operational_statement_set)
self._la = 0 # Token type
try:
self.enterOuterAlt(localctx, 1)
self.state = 495
self._errHandler.sync(self)
_la = self._input.LA(1)
while ((_la - 16) & ~0x3F) == 0 and (
(1 << (_la - 16))
& (
(1 << (GrammarParser.IF - 16))
| (1 << (GrammarParser.SEMI - 16))
| (1 << (GrammarParser.ID - 16))
)
) != 0:
self.state = 492
self.operational_statement()
self.state = 497
self._errHandler.sync(self)
_la = self._input.LA(1)
except RecognitionException as re:
localctx.exception = re
self._errHandler.reportError(self, re)
self._errHandler.recover(self, re)
finally:
self.exitRule()
return localctx
class State_inner_statementContext(ParserRuleContext):
__slots__ = "parser"
def __init__(
self, parser, parent: ParserRuleContext = None, invokingState: int = -1
):
super().__init__(parent, invokingState)
self.parser = parser
def state_definition(self):
return self.getTypedRuleContext(GrammarParser.State_definitionContext, 0)
def transition_definition(self):
return self.getTypedRuleContext(
GrammarParser.Transition_definitionContext, 0
)
def transition_force_definition(self):
return self.getTypedRuleContext(
GrammarParser.Transition_force_definitionContext, 0
)
def enter_definition(self):
return self.getTypedRuleContext(GrammarParser.Enter_definitionContext, 0)
def during_definition(self):
return self.getTypedRuleContext(GrammarParser.During_definitionContext, 0)
def exit_definition(self):
return self.getTypedRuleContext(GrammarParser.Exit_definitionContext, 0)
def during_aspect_definition(self):
return self.getTypedRuleContext(
GrammarParser.During_aspect_definitionContext, 0
)
def event_definition(self):
return self.getTypedRuleContext(GrammarParser.Event_definitionContext, 0)
def import_statement(self):
return self.getTypedRuleContext(GrammarParser.Import_statementContext, 0)
def SEMI(self):
return self.getToken(GrammarParser.SEMI, 0)
def getRuleIndex(self):
return GrammarParser.RULE_state_inner_statement
def enterRule(self, listener: ParseTreeListener):
if hasattr(listener, "enterState_inner_statement"):
listener.enterState_inner_statement(self)
def exitRule(self, listener: ParseTreeListener):
if hasattr(listener, "exitState_inner_statement"):
listener.exitState_inner_statement(self)
def state_inner_statement(self):
localctx = GrammarParser.State_inner_statementContext(
self, self._ctx, self.state
)
self.enterRule(localctx, 44, self.RULE_state_inner_statement)
try:
self.state = 508
self._errHandler.sync(self)
token = self._input.LA(1)
if token in [GrammarParser.PSEUDO, GrammarParser.STATE]:
self.enterOuterAlt(localctx, 1)
self.state = 498
self.state_definition()
pass
elif token in [GrammarParser.INIT_MARKER, GrammarParser.ID]:
self.enterOuterAlt(localctx, 2)
self.state = 499
self.transition_definition()
pass
elif token in [GrammarParser.BANG]:
self.enterOuterAlt(localctx, 3)
self.state = 500
self.transition_force_definition()
pass
elif token in [GrammarParser.ENTER]:
self.enterOuterAlt(localctx, 4)
self.state = 501
self.enter_definition()
pass
elif token in [GrammarParser.DURING]:
self.enterOuterAlt(localctx, 5)
self.state = 502
self.during_definition()
pass
elif token in [GrammarParser.EXIT]:
self.enterOuterAlt(localctx, 6)
self.state = 503
self.exit_definition()
pass
elif token in [GrammarParser.SHIFT_RIGHT]:
self.enterOuterAlt(localctx, 7)
self.state = 504
self.during_aspect_definition()
pass
elif token in [GrammarParser.EVENT]:
self.enterOuterAlt(localctx, 8)
self.state = 505
self.event_definition()
pass
elif token in [GrammarParser.IMPORT]:
self.enterOuterAlt(localctx, 9)
self.state = 506
self.import_statement()
pass
elif token in [GrammarParser.SEMI]:
self.enterOuterAlt(localctx, 10)
self.state = 507
self.match(GrammarParser.SEMI)
pass
else:
raise NoViableAltException(self)
except RecognitionException as re:
localctx.exception = re
self._errHandler.reportError(self, re)
self._errHandler.recover(self, re)
finally:
self.exitRule()
return localctx
class Operation_programContext(ParserRuleContext):
__slots__ = "parser"
def __init__(
self, parser, parent: ParserRuleContext = None, invokingState: int = -1
):
super().__init__(parent, invokingState)
self.parser = parser
def EOF(self):
return self.getToken(GrammarParser.EOF, 0)
def operational_assignment(self, i: int = None):
if i is None:
return self.getTypedRuleContexts(
GrammarParser.Operational_assignmentContext
)
else:
return self.getTypedRuleContext(
GrammarParser.Operational_assignmentContext, i
)
def getRuleIndex(self):
return GrammarParser.RULE_operation_program
def enterRule(self, listener: ParseTreeListener):
if hasattr(listener, "enterOperation_program"):
listener.enterOperation_program(self)
def exitRule(self, listener: ParseTreeListener):
if hasattr(listener, "exitOperation_program"):
listener.exitOperation_program(self)
def operation_program(self):
localctx = GrammarParser.Operation_programContext(self, self._ctx, self.state)
self.enterRule(localctx, 46, self.RULE_operation_program)
self._la = 0 # Token type
try:
self.enterOuterAlt(localctx, 1)
self.state = 513
self._errHandler.sync(self)
_la = self._input.LA(1)
while _la == GrammarParser.ID:
self.state = 510
self.operational_assignment()
self.state = 515
self._errHandler.sync(self)
_la = self._input.LA(1)
self.state = 516
self.match(GrammarParser.EOF)
except RecognitionException as re:
localctx.exception = re
self._errHandler.reportError(self, re)
self._errHandler.recover(self, re)
finally:
self.exitRule()
return localctx
class Preamble_programContext(ParserRuleContext):
__slots__ = "parser"
def __init__(
self, parser, parent: ParserRuleContext = None, invokingState: int = -1
):
super().__init__(parent, invokingState)
self.parser = parser
def EOF(self):
return self.getToken(GrammarParser.EOF, 0)
def preamble_statement(self, i: int = None):
if i is None:
return self.getTypedRuleContexts(
GrammarParser.Preamble_statementContext
)
else:
return self.getTypedRuleContext(
GrammarParser.Preamble_statementContext, i
)
def getRuleIndex(self):
return GrammarParser.RULE_preamble_program
def enterRule(self, listener: ParseTreeListener):
if hasattr(listener, "enterPreamble_program"):
listener.enterPreamble_program(self)
def exitRule(self, listener: ParseTreeListener):
if hasattr(listener, "exitPreamble_program"):
listener.exitPreamble_program(self)
def preamble_program(self):
localctx = GrammarParser.Preamble_programContext(self, self._ctx, self.state)
self.enterRule(localctx, 48, self.RULE_preamble_program)
self._la = 0 # Token type
try:
self.enterOuterAlt(localctx, 1)
self.state = 521
self._errHandler.sync(self)
_la = self._input.LA(1)
while _la == GrammarParser.ID:
self.state = 518
self.preamble_statement()
self.state = 523
self._errHandler.sync(self)
_la = self._input.LA(1)
self.state = 524
self.match(GrammarParser.EOF)
except RecognitionException as re:
localctx.exception = re
self._errHandler.reportError(self, re)
self._errHandler.recover(self, re)
finally:
self.exitRule()
return localctx
class Preamble_statementContext(ParserRuleContext):
__slots__ = "parser"
def __init__(
self, parser, parent: ParserRuleContext = None, invokingState: int = -1
):
super().__init__(parent, invokingState)
self.parser = parser
def initial_assignment(self):
return self.getTypedRuleContext(GrammarParser.Initial_assignmentContext, 0)
def constant_definition(self):
return self.getTypedRuleContext(GrammarParser.Constant_definitionContext, 0)
def getRuleIndex(self):
return GrammarParser.RULE_preamble_statement
def enterRule(self, listener: ParseTreeListener):
if hasattr(listener, "enterPreamble_statement"):
listener.enterPreamble_statement(self)
def exitRule(self, listener: ParseTreeListener):
if hasattr(listener, "exitPreamble_statement"):
listener.exitPreamble_statement(self)
def preamble_statement(self):
localctx = GrammarParser.Preamble_statementContext(self, self._ctx, self.state)
self.enterRule(localctx, 50, self.RULE_preamble_statement)
try:
self.state = 528
self._errHandler.sync(self)
la_ = self._interp.adaptivePredict(self._input, 55, self._ctx)
if la_ == 1:
self.enterOuterAlt(localctx, 1)
self.state = 526
self.initial_assignment()
pass
elif la_ == 2:
self.enterOuterAlt(localctx, 2)
self.state = 527
self.constant_definition()
pass
except RecognitionException as re:
localctx.exception = re
self._errHandler.reportError(self, re)
self._errHandler.recover(self, re)
finally:
self.exitRule()
return localctx
class Initial_assignmentContext(ParserRuleContext):
__slots__ = "parser"
def __init__(
self, parser, parent: ParserRuleContext = None, invokingState: int = -1
):
super().__init__(parent, invokingState)
self.parser = parser
def ID(self):
return self.getToken(GrammarParser.ID, 0)
def DECLARE_ASSIGN(self):
return self.getToken(GrammarParser.DECLARE_ASSIGN, 0)
def init_expression(self):
return self.getTypedRuleContext(GrammarParser.Init_expressionContext, 0)
def SEMI(self):
return self.getToken(GrammarParser.SEMI, 0)
def getRuleIndex(self):
return GrammarParser.RULE_initial_assignment
def enterRule(self, listener: ParseTreeListener):
if hasattr(listener, "enterInitial_assignment"):
listener.enterInitial_assignment(self)
def exitRule(self, listener: ParseTreeListener):
if hasattr(listener, "exitInitial_assignment"):
listener.exitInitial_assignment(self)
def initial_assignment(self):
localctx = GrammarParser.Initial_assignmentContext(self, self._ctx, self.state)
self.enterRule(localctx, 52, self.RULE_initial_assignment)
try:
self.enterOuterAlt(localctx, 1)
self.state = 530
self.match(GrammarParser.ID)
self.state = 531
self.match(GrammarParser.DECLARE_ASSIGN)
self.state = 532
self.init_expression(0)
self.state = 533
self.match(GrammarParser.SEMI)
except RecognitionException as re:
localctx.exception = re
self._errHandler.reportError(self, re)
self._errHandler.recover(self, re)
finally:
self.exitRule()
return localctx
class Constant_definitionContext(ParserRuleContext):
__slots__ = "parser"
def __init__(
self, parser, parent: ParserRuleContext = None, invokingState: int = -1
):
super().__init__(parent, invokingState)
self.parser = parser
def ID(self):
return self.getToken(GrammarParser.ID, 0)
def ASSIGN(self):
return self.getToken(GrammarParser.ASSIGN, 0)
def init_expression(self):
return self.getTypedRuleContext(GrammarParser.Init_expressionContext, 0)
def SEMI(self):
return self.getToken(GrammarParser.SEMI, 0)
def getRuleIndex(self):
return GrammarParser.RULE_constant_definition
def enterRule(self, listener: ParseTreeListener):
if hasattr(listener, "enterConstant_definition"):
listener.enterConstant_definition(self)
def exitRule(self, listener: ParseTreeListener):
if hasattr(listener, "exitConstant_definition"):
listener.exitConstant_definition(self)
def constant_definition(self):
localctx = GrammarParser.Constant_definitionContext(self, self._ctx, self.state)
self.enterRule(localctx, 54, self.RULE_constant_definition)
try:
self.enterOuterAlt(localctx, 1)
self.state = 535
self.match(GrammarParser.ID)
self.state = 536
self.match(GrammarParser.ASSIGN)
self.state = 537
self.init_expression(0)
self.state = 538
self.match(GrammarParser.SEMI)
except RecognitionException as re:
localctx.exception = re
self._errHandler.reportError(self, re)
self._errHandler.recover(self, re)
finally:
self.exitRule()
return localctx
class Operational_assignmentContext(ParserRuleContext):
__slots__ = "parser"
def __init__(
self, parser, parent: ParserRuleContext = None, invokingState: int = -1
):
super().__init__(parent, invokingState)
self.parser = parser
def ID(self):
return self.getToken(GrammarParser.ID, 0)
def DECLARE_ASSIGN(self):
return self.getToken(GrammarParser.DECLARE_ASSIGN, 0)
def num_expression(self):
return self.getTypedRuleContext(GrammarParser.Num_expressionContext, 0)
def SEMI(self):
return self.getToken(GrammarParser.SEMI, 0)
def getRuleIndex(self):
return GrammarParser.RULE_operational_assignment
def enterRule(self, listener: ParseTreeListener):
if hasattr(listener, "enterOperational_assignment"):
listener.enterOperational_assignment(self)
def exitRule(self, listener: ParseTreeListener):
if hasattr(listener, "exitOperational_assignment"):
listener.exitOperational_assignment(self)
def operational_assignment(self):
localctx = GrammarParser.Operational_assignmentContext(
self, self._ctx, self.state
)
self.enterRule(localctx, 56, self.RULE_operational_assignment)
try:
self.enterOuterAlt(localctx, 1)
self.state = 540
self.match(GrammarParser.ID)
self.state = 541
self.match(GrammarParser.DECLARE_ASSIGN)
self.state = 542
self.num_expression(0)
self.state = 543
self.match(GrammarParser.SEMI)
except RecognitionException as re:
localctx.exception = re
self._errHandler.reportError(self, re)
self._errHandler.recover(self, re)
finally:
self.exitRule()
return localctx
class Generic_expressionContext(ParserRuleContext):
__slots__ = "parser"
def __init__(
self, parser, parent: ParserRuleContext = None, invokingState: int = -1
):
super().__init__(parent, invokingState)
self.parser = parser
def num_expression(self):
return self.getTypedRuleContext(GrammarParser.Num_expressionContext, 0)
def cond_expression(self):
return self.getTypedRuleContext(GrammarParser.Cond_expressionContext, 0)
def getRuleIndex(self):
return GrammarParser.RULE_generic_expression
def enterRule(self, listener: ParseTreeListener):
if hasattr(listener, "enterGeneric_expression"):
listener.enterGeneric_expression(self)
def exitRule(self, listener: ParseTreeListener):
if hasattr(listener, "exitGeneric_expression"):
listener.exitGeneric_expression(self)
def generic_expression(self):
localctx = GrammarParser.Generic_expressionContext(self, self._ctx, self.state)
self.enterRule(localctx, 58, self.RULE_generic_expression)
try:
self.state = 547
self._errHandler.sync(self)
la_ = self._interp.adaptivePredict(self._input, 56, self._ctx)
if la_ == 1:
self.enterOuterAlt(localctx, 1)
self.state = 545
self.num_expression(0)
pass
elif la_ == 2:
self.enterOuterAlt(localctx, 2)
self.state = 546
self.cond_expression(0)
pass
except RecognitionException as re:
localctx.exception = re
self._errHandler.reportError(self, re)
self._errHandler.recover(self, re)
finally:
self.exitRule()
return localctx
class Init_expressionContext(ParserRuleContext):
__slots__ = "parser"
def __init__(
self, parser, parent: ParserRuleContext = None, invokingState: int = -1
):
super().__init__(parent, invokingState)
self.parser = parser
def getRuleIndex(self):
return GrammarParser.RULE_init_expression
def copyFrom(self, ctx: ParserRuleContext):
super().copyFrom(ctx)
class FuncExprInitContext(Init_expressionContext):
def __init__(
self, parser, ctx: ParserRuleContext
): # actually a GrammarParser.Init_expressionContext
super().__init__(parser)
self.func_name = None # Token
self.copyFrom(ctx)
def LPAREN(self):
return self.getToken(GrammarParser.LPAREN, 0)
def init_expression(self):
return self.getTypedRuleContext(GrammarParser.Init_expressionContext, 0)
def RPAREN(self):
return self.getToken(GrammarParser.RPAREN, 0)
def UFUNC_NAME(self):
return self.getToken(GrammarParser.UFUNC_NAME, 0)
def enterRule(self, listener: ParseTreeListener):
if hasattr(listener, "enterFuncExprInit"):
listener.enterFuncExprInit(self)
def exitRule(self, listener: ParseTreeListener):
if hasattr(listener, "exitFuncExprInit"):
listener.exitFuncExprInit(self)
class UnaryExprInitContext(Init_expressionContext):
def __init__(
self, parser, ctx: ParserRuleContext
): # actually a GrammarParser.Init_expressionContext
super().__init__(parser)
self.op = None # Token
self.copyFrom(ctx)
def init_expression(self):
return self.getTypedRuleContext(GrammarParser.Init_expressionContext, 0)
def PLUS(self):
return self.getToken(GrammarParser.PLUS, 0)
def MINUS(self):
return self.getToken(GrammarParser.MINUS, 0)
def enterRule(self, listener: ParseTreeListener):
if hasattr(listener, "enterUnaryExprInit"):
listener.enterUnaryExprInit(self)
def exitRule(self, listener: ParseTreeListener):
if hasattr(listener, "exitUnaryExprInit"):
listener.exitUnaryExprInit(self)
class BinaryExprInitContext(Init_expressionContext):
def __init__(
self, parser, ctx: ParserRuleContext
): # actually a GrammarParser.Init_expressionContext
super().__init__(parser)
self.op = None # Token
self.copyFrom(ctx)
def init_expression(self, i: int = None):
if i is None:
return self.getTypedRuleContexts(GrammarParser.Init_expressionContext)
else:
return self.getTypedRuleContext(GrammarParser.Init_expressionContext, i)
def POW(self):
return self.getToken(GrammarParser.POW, 0)
def STAR(self):
return self.getToken(GrammarParser.STAR, 0)
def SLASH(self):
return self.getToken(GrammarParser.SLASH, 0)
def PERCENT(self):
return self.getToken(GrammarParser.PERCENT, 0)
def PLUS(self):
return self.getToken(GrammarParser.PLUS, 0)
def MINUS(self):
return self.getToken(GrammarParser.MINUS, 0)
def SHIFT_LEFT(self):
return self.getToken(GrammarParser.SHIFT_LEFT, 0)
def SHIFT_RIGHT(self):
return self.getToken(GrammarParser.SHIFT_RIGHT, 0)
def AMP(self):
return self.getToken(GrammarParser.AMP, 0)
def CARET(self):
return self.getToken(GrammarParser.CARET, 0)
def PIPE(self):
return self.getToken(GrammarParser.PIPE, 0)
def enterRule(self, listener: ParseTreeListener):
if hasattr(listener, "enterBinaryExprInit"):
listener.enterBinaryExprInit(self)
def exitRule(self, listener: ParseTreeListener):
if hasattr(listener, "exitBinaryExprInit"):
listener.exitBinaryExprInit(self)
class LiteralExprInitContext(Init_expressionContext):
def __init__(
self, parser, ctx: ParserRuleContext
): # actually a GrammarParser.Init_expressionContext
super().__init__(parser)
self.copyFrom(ctx)
def num_literal(self):
return self.getTypedRuleContext(GrammarParser.Num_literalContext, 0)
def enterRule(self, listener: ParseTreeListener):
if hasattr(listener, "enterLiteralExprInit"):
listener.enterLiteralExprInit(self)
def exitRule(self, listener: ParseTreeListener):
if hasattr(listener, "exitLiteralExprInit"):
listener.exitLiteralExprInit(self)
class MathConstExprInitContext(Init_expressionContext):
def __init__(
self, parser, ctx: ParserRuleContext
): # actually a GrammarParser.Init_expressionContext
super().__init__(parser)
self.copyFrom(ctx)
def math_const(self):
return self.getTypedRuleContext(GrammarParser.Math_constContext, 0)
def enterRule(self, listener: ParseTreeListener):
if hasattr(listener, "enterMathConstExprInit"):
listener.enterMathConstExprInit(self)
def exitRule(self, listener: ParseTreeListener):
if hasattr(listener, "exitMathConstExprInit"):
listener.exitMathConstExprInit(self)
class ParenExprInitContext(Init_expressionContext):
def __init__(
self, parser, ctx: ParserRuleContext
): # actually a GrammarParser.Init_expressionContext
super().__init__(parser)
self.copyFrom(ctx)
def LPAREN(self):
return self.getToken(GrammarParser.LPAREN, 0)
def init_expression(self):
return self.getTypedRuleContext(GrammarParser.Init_expressionContext, 0)
def RPAREN(self):
return self.getToken(GrammarParser.RPAREN, 0)
def enterRule(self, listener: ParseTreeListener):
if hasattr(listener, "enterParenExprInit"):
listener.enterParenExprInit(self)
def exitRule(self, listener: ParseTreeListener):
if hasattr(listener, "exitParenExprInit"):
listener.exitParenExprInit(self)
def init_expression(self, _p: int = 0):
_parentctx = self._ctx
_parentState = self.state
localctx = GrammarParser.Init_expressionContext(self, self._ctx, _parentState)
_prevctx = localctx
_startState = 60
self.enterRecursionRule(localctx, 60, self.RULE_init_expression, _p)
self._la = 0 # Token type
try:
self.enterOuterAlt(localctx, 1)
self.state = 563
self._errHandler.sync(self)
token = self._input.LA(1)
if token in [GrammarParser.LPAREN]:
localctx = GrammarParser.ParenExprInitContext(self, localctx)
self._ctx = localctx
_prevctx = localctx
self.state = 550
self.match(GrammarParser.LPAREN)
self.state = 551
self.init_expression(0)
self.state = 552
self.match(GrammarParser.RPAREN)
pass
elif token in [
GrammarParser.FLOAT,
GrammarParser.HEX_INT,
GrammarParser.INT,
]:
localctx = GrammarParser.LiteralExprInitContext(self, localctx)
self._ctx = localctx
_prevctx = localctx
self.state = 554
self.num_literal()
pass
elif token in [
GrammarParser.PI_CONST,
GrammarParser.E_CONST,
GrammarParser.TAU_CONST,
]:
localctx = GrammarParser.MathConstExprInitContext(self, localctx)
self._ctx = localctx
_prevctx = localctx
self.state = 555
self.math_const()
pass
elif token in [GrammarParser.PLUS, GrammarParser.MINUS]:
localctx = GrammarParser.UnaryExprInitContext(self, localctx)
self._ctx = localctx
_prevctx = localctx
self.state = 556
localctx.op = self._input.LT(1)
_la = self._input.LA(1)
if not (_la == GrammarParser.PLUS or _la == GrammarParser.MINUS):
localctx.op = self._errHandler.recoverInline(self)
else:
self._errHandler.reportMatch(self)
self.consume()
self.state = 557
self.init_expression(9)
pass
elif token in [GrammarParser.UFUNC_NAME]:
localctx = GrammarParser.FuncExprInitContext(self, localctx)
self._ctx = localctx
_prevctx = localctx
self.state = 558
localctx.func_name = self.match(GrammarParser.UFUNC_NAME)
self.state = 559
self.match(GrammarParser.LPAREN)
self.state = 560
self.init_expression(0)
self.state = 561
self.match(GrammarParser.RPAREN)
pass
else:
raise NoViableAltException(self)
self._ctx.stop = self._input.LT(-1)
self.state = 588
self._errHandler.sync(self)
_alt = self._interp.adaptivePredict(self._input, 59, self._ctx)
while _alt != 2 and _alt != ATN.INVALID_ALT_NUMBER:
if _alt == 1:
if self._parseListeners is not None:
self.triggerExitRuleEvent()
_prevctx = localctx
self.state = 586
self._errHandler.sync(self)
la_ = self._interp.adaptivePredict(self._input, 58, self._ctx)
if la_ == 1:
localctx = GrammarParser.BinaryExprInitContext(
self,
GrammarParser.Init_expressionContext(
self, _parentctx, _parentState
),
)
self.pushNewRecursionContext(
localctx, _startState, self.RULE_init_expression
)
self.state = 565
if not self.precpred(self._ctx, 8):
from antlr4.error.Errors import FailedPredicateException
raise FailedPredicateException(
self, "self.precpred(self._ctx, 8)"
)
self.state = 566
localctx.op = self.match(GrammarParser.POW)
self.state = 567
self.init_expression(8)
pass
elif la_ == 2:
localctx = GrammarParser.BinaryExprInitContext(
self,
GrammarParser.Init_expressionContext(
self, _parentctx, _parentState
),
)
self.pushNewRecursionContext(
localctx, _startState, self.RULE_init_expression
)
self.state = 568
if not self.precpred(self._ctx, 7):
from antlr4.error.Errors import FailedPredicateException
raise FailedPredicateException(
self, "self.precpred(self._ctx, 7)"
)
self.state = 569
localctx.op = self._input.LT(1)
_la = self._input.LA(1)
if not (
((_la) & ~0x3F) == 0
and (
(1 << _la)
& (
(1 << GrammarParser.SLASH)
| (1 << GrammarParser.STAR)
| (1 << GrammarParser.PERCENT)
)
)
!= 0
):
localctx.op = self._errHandler.recoverInline(self)
else:
self._errHandler.reportMatch(self)
self.consume()
self.state = 570
self.init_expression(8)
pass
elif la_ == 3:
localctx = GrammarParser.BinaryExprInitContext(
self,
GrammarParser.Init_expressionContext(
self, _parentctx, _parentState
),
)
self.pushNewRecursionContext(
localctx, _startState, self.RULE_init_expression
)
self.state = 571
if not self.precpred(self._ctx, 6):
from antlr4.error.Errors import FailedPredicateException
raise FailedPredicateException(
self, "self.precpred(self._ctx, 6)"
)
self.state = 572
localctx.op = self._input.LT(1)
_la = self._input.LA(1)
if not (
_la == GrammarParser.PLUS or _la == GrammarParser.MINUS
):
localctx.op = self._errHandler.recoverInline(self)
else:
self._errHandler.reportMatch(self)
self.consume()
self.state = 573
self.init_expression(7)
pass
elif la_ == 4:
localctx = GrammarParser.BinaryExprInitContext(
self,
GrammarParser.Init_expressionContext(
self, _parentctx, _parentState
),
)
self.pushNewRecursionContext(
localctx, _startState, self.RULE_init_expression
)
self.state = 574
if not self.precpred(self._ctx, 5):
from antlr4.error.Errors import FailedPredicateException
raise FailedPredicateException(
self, "self.precpred(self._ctx, 5)"
)
self.state = 575
localctx.op = self._input.LT(1)
_la = self._input.LA(1)
if not (
_la == GrammarParser.SHIFT_RIGHT
or _la == GrammarParser.SHIFT_LEFT
):
localctx.op = self._errHandler.recoverInline(self)
else:
self._errHandler.reportMatch(self)
self.consume()
self.state = 576
self.init_expression(6)
pass
elif la_ == 5:
localctx = GrammarParser.BinaryExprInitContext(
self,
GrammarParser.Init_expressionContext(
self, _parentctx, _parentState
),
)
self.pushNewRecursionContext(
localctx, _startState, self.RULE_init_expression
)
self.state = 577
if not self.precpred(self._ctx, 4):
from antlr4.error.Errors import FailedPredicateException
raise FailedPredicateException(
self, "self.precpred(self._ctx, 4)"
)
self.state = 578
localctx.op = self.match(GrammarParser.AMP)
self.state = 579
self.init_expression(5)
pass
elif la_ == 6:
localctx = GrammarParser.BinaryExprInitContext(
self,
GrammarParser.Init_expressionContext(
self, _parentctx, _parentState
),
)
self.pushNewRecursionContext(
localctx, _startState, self.RULE_init_expression
)
self.state = 580
if not self.precpred(self._ctx, 3):
from antlr4.error.Errors import FailedPredicateException
raise FailedPredicateException(
self, "self.precpred(self._ctx, 3)"
)
self.state = 581
localctx.op = self.match(GrammarParser.CARET)
self.state = 582
self.init_expression(4)
pass
elif la_ == 7:
localctx = GrammarParser.BinaryExprInitContext(
self,
GrammarParser.Init_expressionContext(
self, _parentctx, _parentState
),
)
self.pushNewRecursionContext(
localctx, _startState, self.RULE_init_expression
)
self.state = 583
if not self.precpred(self._ctx, 2):
from antlr4.error.Errors import FailedPredicateException
raise FailedPredicateException(
self, "self.precpred(self._ctx, 2)"
)
self.state = 584
localctx.op = self.match(GrammarParser.PIPE)
self.state = 585
self.init_expression(3)
pass
self.state = 590
self._errHandler.sync(self)
_alt = self._interp.adaptivePredict(self._input, 59, self._ctx)
except RecognitionException as re:
localctx.exception = re
self._errHandler.reportError(self, re)
self._errHandler.recover(self, re)
finally:
self.unrollRecursionContexts(_parentctx)
return localctx
class Num_expressionContext(ParserRuleContext):
__slots__ = "parser"
def __init__(
self, parser, parent: ParserRuleContext = None, invokingState: int = -1
):
super().__init__(parent, invokingState)
self.parser = parser
def getRuleIndex(self):
return GrammarParser.RULE_num_expression
def copyFrom(self, ctx: ParserRuleContext):
super().copyFrom(ctx)
class UnaryExprNumContext(Num_expressionContext):
def __init__(
self, parser, ctx: ParserRuleContext
): # actually a GrammarParser.Num_expressionContext
super().__init__(parser)
self.op = None # Token
self.copyFrom(ctx)
def num_expression(self):
return self.getTypedRuleContext(GrammarParser.Num_expressionContext, 0)
def PLUS(self):
return self.getToken(GrammarParser.PLUS, 0)
def MINUS(self):
return self.getToken(GrammarParser.MINUS, 0)
def enterRule(self, listener: ParseTreeListener):
if hasattr(listener, "enterUnaryExprNum"):
listener.enterUnaryExprNum(self)
def exitRule(self, listener: ParseTreeListener):
if hasattr(listener, "exitUnaryExprNum"):
listener.exitUnaryExprNum(self)
class FuncExprNumContext(Num_expressionContext):
def __init__(
self, parser, ctx: ParserRuleContext
): # actually a GrammarParser.Num_expressionContext
super().__init__(parser)
self.func_name = None # Token
self.copyFrom(ctx)
def LPAREN(self):
return self.getToken(GrammarParser.LPAREN, 0)
def num_expression(self):
return self.getTypedRuleContext(GrammarParser.Num_expressionContext, 0)
def RPAREN(self):
return self.getToken(GrammarParser.RPAREN, 0)
def UFUNC_NAME(self):
return self.getToken(GrammarParser.UFUNC_NAME, 0)
def enterRule(self, listener: ParseTreeListener):
if hasattr(listener, "enterFuncExprNum"):
listener.enterFuncExprNum(self)
def exitRule(self, listener: ParseTreeListener):
if hasattr(listener, "exitFuncExprNum"):
listener.exitFuncExprNum(self)
class ConditionalCStyleExprNumContext(Num_expressionContext):
def __init__(
self, parser, ctx: ParserRuleContext
): # actually a GrammarParser.Num_expressionContext
super().__init__(parser)
self.copyFrom(ctx)
def LPAREN(self):
return self.getToken(GrammarParser.LPAREN, 0)
def cond_expression(self):
return self.getTypedRuleContext(GrammarParser.Cond_expressionContext, 0)
def RPAREN(self):
return self.getToken(GrammarParser.RPAREN, 0)
def QUESTION(self):
return self.getToken(GrammarParser.QUESTION, 0)
def num_expression(self, i: int = None):
if i is None:
return self.getTypedRuleContexts(GrammarParser.Num_expressionContext)
else:
return self.getTypedRuleContext(GrammarParser.Num_expressionContext, i)
def COLON(self):
return self.getToken(GrammarParser.COLON, 0)
def enterRule(self, listener: ParseTreeListener):
if hasattr(listener, "enterConditionalCStyleExprNum"):
listener.enterConditionalCStyleExprNum(self)
def exitRule(self, listener: ParseTreeListener):
if hasattr(listener, "exitConditionalCStyleExprNum"):
listener.exitConditionalCStyleExprNum(self)
class BinaryExprNumContext(Num_expressionContext):
def __init__(
self, parser, ctx: ParserRuleContext
): # actually a GrammarParser.Num_expressionContext
super().__init__(parser)
self.op = None # Token
self.copyFrom(ctx)
def num_expression(self, i: int = None):
if i is None:
return self.getTypedRuleContexts(GrammarParser.Num_expressionContext)
else:
return self.getTypedRuleContext(GrammarParser.Num_expressionContext, i)
def POW(self):
return self.getToken(GrammarParser.POW, 0)
def STAR(self):
return self.getToken(GrammarParser.STAR, 0)
def SLASH(self):
return self.getToken(GrammarParser.SLASH, 0)
def PERCENT(self):
return self.getToken(GrammarParser.PERCENT, 0)
def PLUS(self):
return self.getToken(GrammarParser.PLUS, 0)
def MINUS(self):
return self.getToken(GrammarParser.MINUS, 0)
def SHIFT_LEFT(self):
return self.getToken(GrammarParser.SHIFT_LEFT, 0)
def SHIFT_RIGHT(self):
return self.getToken(GrammarParser.SHIFT_RIGHT, 0)
def AMP(self):
return self.getToken(GrammarParser.AMP, 0)
def CARET(self):
return self.getToken(GrammarParser.CARET, 0)
def PIPE(self):
return self.getToken(GrammarParser.PIPE, 0)
def enterRule(self, listener: ParseTreeListener):
if hasattr(listener, "enterBinaryExprNum"):
listener.enterBinaryExprNum(self)
def exitRule(self, listener: ParseTreeListener):
if hasattr(listener, "exitBinaryExprNum"):
listener.exitBinaryExprNum(self)
class LiteralExprNumContext(Num_expressionContext):
def __init__(
self, parser, ctx: ParserRuleContext
): # actually a GrammarParser.Num_expressionContext
super().__init__(parser)
self.copyFrom(ctx)
def num_literal(self):
return self.getTypedRuleContext(GrammarParser.Num_literalContext, 0)
def enterRule(self, listener: ParseTreeListener):
if hasattr(listener, "enterLiteralExprNum"):
listener.enterLiteralExprNum(self)
def exitRule(self, listener: ParseTreeListener):
if hasattr(listener, "exitLiteralExprNum"):
listener.exitLiteralExprNum(self)
class MathConstExprNumContext(Num_expressionContext):
def __init__(
self, parser, ctx: ParserRuleContext
): # actually a GrammarParser.Num_expressionContext
super().__init__(parser)
self.copyFrom(ctx)
def math_const(self):
return self.getTypedRuleContext(GrammarParser.Math_constContext, 0)
def enterRule(self, listener: ParseTreeListener):
if hasattr(listener, "enterMathConstExprNum"):
listener.enterMathConstExprNum(self)
def exitRule(self, listener: ParseTreeListener):
if hasattr(listener, "exitMathConstExprNum"):
listener.exitMathConstExprNum(self)
class ParenExprNumContext(Num_expressionContext):
def __init__(
self, parser, ctx: ParserRuleContext
): # actually a GrammarParser.Num_expressionContext
super().__init__(parser)
self.copyFrom(ctx)
def LPAREN(self):
return self.getToken(GrammarParser.LPAREN, 0)
def num_expression(self):
return self.getTypedRuleContext(GrammarParser.Num_expressionContext, 0)
def RPAREN(self):
return self.getToken(GrammarParser.RPAREN, 0)
def enterRule(self, listener: ParseTreeListener):
if hasattr(listener, "enterParenExprNum"):
listener.enterParenExprNum(self)
def exitRule(self, listener: ParseTreeListener):
if hasattr(listener, "exitParenExprNum"):
listener.exitParenExprNum(self)
class IdExprNumContext(Num_expressionContext):
def __init__(
self, parser, ctx: ParserRuleContext
): # actually a GrammarParser.Num_expressionContext
super().__init__(parser)
self.copyFrom(ctx)
def ID(self):
return self.getToken(GrammarParser.ID, 0)
def enterRule(self, listener: ParseTreeListener):
if hasattr(listener, "enterIdExprNum"):
listener.enterIdExprNum(self)
def exitRule(self, listener: ParseTreeListener):
if hasattr(listener, "exitIdExprNum"):
listener.exitIdExprNum(self)
def num_expression(self, _p: int = 0):
_parentctx = self._ctx
_parentState = self.state
localctx = GrammarParser.Num_expressionContext(self, self._ctx, _parentState)
_prevctx = localctx
_startState = 62
self.enterRecursionRule(localctx, 62, self.RULE_num_expression, _p)
self._la = 0 # Token type
try:
self.enterOuterAlt(localctx, 1)
self.state = 614
self._errHandler.sync(self)
la_ = self._interp.adaptivePredict(self._input, 60, self._ctx)
if la_ == 1:
localctx = GrammarParser.ParenExprNumContext(self, localctx)
self._ctx = localctx
_prevctx = localctx
self.state = 592
self.match(GrammarParser.LPAREN)
self.state = 593
self.num_expression(0)
self.state = 594
self.match(GrammarParser.RPAREN)
pass
elif la_ == 2:
localctx = GrammarParser.LiteralExprNumContext(self, localctx)
self._ctx = localctx
_prevctx = localctx
self.state = 596
self.num_literal()
pass
elif la_ == 3:
localctx = GrammarParser.IdExprNumContext(self, localctx)
self._ctx = localctx
_prevctx = localctx
self.state = 597
self.match(GrammarParser.ID)
pass
elif la_ == 4:
localctx = GrammarParser.MathConstExprNumContext(self, localctx)
self._ctx = localctx
_prevctx = localctx
self.state = 598
self.math_const()
pass
elif la_ == 5:
localctx = GrammarParser.UnaryExprNumContext(self, localctx)
self._ctx = localctx
_prevctx = localctx
self.state = 599
localctx.op = self._input.LT(1)
_la = self._input.LA(1)
if not (_la == GrammarParser.PLUS or _la == GrammarParser.MINUS):
localctx.op = self._errHandler.recoverInline(self)
else:
self._errHandler.reportMatch(self)
self.consume()
self.state = 600
self.num_expression(10)
pass
elif la_ == 6:
localctx = GrammarParser.FuncExprNumContext(self, localctx)
self._ctx = localctx
_prevctx = localctx
self.state = 601
localctx.func_name = self.match(GrammarParser.UFUNC_NAME)
self.state = 602
self.match(GrammarParser.LPAREN)
self.state = 603
self.num_expression(0)
self.state = 604
self.match(GrammarParser.RPAREN)
pass
elif la_ == 7:
localctx = GrammarParser.ConditionalCStyleExprNumContext(self, localctx)
self._ctx = localctx
_prevctx = localctx
self.state = 606
self.match(GrammarParser.LPAREN)
self.state = 607
self.cond_expression(0)
self.state = 608
self.match(GrammarParser.RPAREN)
self.state = 609
self.match(GrammarParser.QUESTION)
self.state = 610
self.num_expression(0)
self.state = 611
self.match(GrammarParser.COLON)
self.state = 612
self.num_expression(1)
pass
self._ctx.stop = self._input.LT(-1)
self.state = 639
self._errHandler.sync(self)
_alt = self._interp.adaptivePredict(self._input, 62, self._ctx)
while _alt != 2 and _alt != ATN.INVALID_ALT_NUMBER:
if _alt == 1:
if self._parseListeners is not None:
self.triggerExitRuleEvent()
_prevctx = localctx
self.state = 637
self._errHandler.sync(self)
la_ = self._interp.adaptivePredict(self._input, 61, self._ctx)
if la_ == 1:
localctx = GrammarParser.BinaryExprNumContext(
self,
GrammarParser.Num_expressionContext(
self, _parentctx, _parentState
),
)
self.pushNewRecursionContext(
localctx, _startState, self.RULE_num_expression
)
self.state = 616
if not self.precpred(self._ctx, 9):
from antlr4.error.Errors import FailedPredicateException
raise FailedPredicateException(
self, "self.precpred(self._ctx, 9)"
)
self.state = 617
localctx.op = self.match(GrammarParser.POW)
self.state = 618
self.num_expression(9)
pass
elif la_ == 2:
localctx = GrammarParser.BinaryExprNumContext(
self,
GrammarParser.Num_expressionContext(
self, _parentctx, _parentState
),
)
self.pushNewRecursionContext(
localctx, _startState, self.RULE_num_expression
)
self.state = 619
if not self.precpred(self._ctx, 8):
from antlr4.error.Errors import FailedPredicateException
raise FailedPredicateException(
self, "self.precpred(self._ctx, 8)"
)
self.state = 620
localctx.op = self._input.LT(1)
_la = self._input.LA(1)
if not (
((_la) & ~0x3F) == 0
and (
(1 << _la)
& (
(1 << GrammarParser.SLASH)
| (1 << GrammarParser.STAR)
| (1 << GrammarParser.PERCENT)
)
)
!= 0
):
localctx.op = self._errHandler.recoverInline(self)
else:
self._errHandler.reportMatch(self)
self.consume()
self.state = 621
self.num_expression(9)
pass
elif la_ == 3:
localctx = GrammarParser.BinaryExprNumContext(
self,
GrammarParser.Num_expressionContext(
self, _parentctx, _parentState
),
)
self.pushNewRecursionContext(
localctx, _startState, self.RULE_num_expression
)
self.state = 622
if not self.precpred(self._ctx, 7):
from antlr4.error.Errors import FailedPredicateException
raise FailedPredicateException(
self, "self.precpred(self._ctx, 7)"
)
self.state = 623
localctx.op = self._input.LT(1)
_la = self._input.LA(1)
if not (
_la == GrammarParser.PLUS or _la == GrammarParser.MINUS
):
localctx.op = self._errHandler.recoverInline(self)
else:
self._errHandler.reportMatch(self)
self.consume()
self.state = 624
self.num_expression(8)
pass
elif la_ == 4:
localctx = GrammarParser.BinaryExprNumContext(
self,
GrammarParser.Num_expressionContext(
self, _parentctx, _parentState
),
)
self.pushNewRecursionContext(
localctx, _startState, self.RULE_num_expression
)
self.state = 625
if not self.precpred(self._ctx, 6):
from antlr4.error.Errors import FailedPredicateException
raise FailedPredicateException(
self, "self.precpred(self._ctx, 6)"
)
self.state = 626
localctx.op = self._input.LT(1)
_la = self._input.LA(1)
if not (
_la == GrammarParser.SHIFT_RIGHT
or _la == GrammarParser.SHIFT_LEFT
):
localctx.op = self._errHandler.recoverInline(self)
else:
self._errHandler.reportMatch(self)
self.consume()
self.state = 627
self.num_expression(7)
pass
elif la_ == 5:
localctx = GrammarParser.BinaryExprNumContext(
self,
GrammarParser.Num_expressionContext(
self, _parentctx, _parentState
),
)
self.pushNewRecursionContext(
localctx, _startState, self.RULE_num_expression
)
self.state = 628
if not self.precpred(self._ctx, 5):
from antlr4.error.Errors import FailedPredicateException
raise FailedPredicateException(
self, "self.precpred(self._ctx, 5)"
)
self.state = 629
localctx.op = self.match(GrammarParser.AMP)
self.state = 630
self.num_expression(6)
pass
elif la_ == 6:
localctx = GrammarParser.BinaryExprNumContext(
self,
GrammarParser.Num_expressionContext(
self, _parentctx, _parentState
),
)
self.pushNewRecursionContext(
localctx, _startState, self.RULE_num_expression
)
self.state = 631
if not self.precpred(self._ctx, 4):
from antlr4.error.Errors import FailedPredicateException
raise FailedPredicateException(
self, "self.precpred(self._ctx, 4)"
)
self.state = 632
localctx.op = self.match(GrammarParser.CARET)
self.state = 633
self.num_expression(5)
pass
elif la_ == 7:
localctx = GrammarParser.BinaryExprNumContext(
self,
GrammarParser.Num_expressionContext(
self, _parentctx, _parentState
),
)
self.pushNewRecursionContext(
localctx, _startState, self.RULE_num_expression
)
self.state = 634
if not self.precpred(self._ctx, 3):
from antlr4.error.Errors import FailedPredicateException
raise FailedPredicateException(
self, "self.precpred(self._ctx, 3)"
)
self.state = 635
localctx.op = self.match(GrammarParser.PIPE)
self.state = 636
self.num_expression(4)
pass
self.state = 641
self._errHandler.sync(self)
_alt = self._interp.adaptivePredict(self._input, 62, self._ctx)
except RecognitionException as re:
localctx.exception = re
self._errHandler.reportError(self, re)
self._errHandler.recover(self, re)
finally:
self.unrollRecursionContexts(_parentctx)
return localctx
class Cond_expressionContext(ParserRuleContext):
__slots__ = "parser"
def __init__(
self, parser, parent: ParserRuleContext = None, invokingState: int = -1
):
super().__init__(parent, invokingState)
self.parser = parser
def getRuleIndex(self):
return GrammarParser.RULE_cond_expression
def copyFrom(self, ctx: ParserRuleContext):
super().copyFrom(ctx)
class BinaryExprFromCondCondContext(Cond_expressionContext):
def __init__(
self, parser, ctx: ParserRuleContext
): # actually a GrammarParser.Cond_expressionContext
super().__init__(parser)
self.op = None # Token
self.copyFrom(ctx)
def cond_expression(self, i: int = None):
if i is None:
return self.getTypedRuleContexts(GrammarParser.Cond_expressionContext)
else:
return self.getTypedRuleContext(GrammarParser.Cond_expressionContext, i)
def EQ(self):
return self.getToken(GrammarParser.EQ, 0)
def NE(self):
return self.getToken(GrammarParser.NE, 0)
def enterRule(self, listener: ParseTreeListener):
if hasattr(listener, "enterBinaryExprFromCondCond"):
listener.enterBinaryExprFromCondCond(self)
def exitRule(self, listener: ParseTreeListener):
if hasattr(listener, "exitBinaryExprFromCondCond"):
listener.exitBinaryExprFromCondCond(self)
class BinaryExprCondContext(Cond_expressionContext):
def __init__(
self, parser, ctx: ParserRuleContext
): # actually a GrammarParser.Cond_expressionContext
super().__init__(parser)
self.op = None # Token
self.copyFrom(ctx)
def cond_expression(self, i: int = None):
if i is None:
return self.getTypedRuleContexts(GrammarParser.Cond_expressionContext)
else:
return self.getTypedRuleContext(GrammarParser.Cond_expressionContext, i)
def LOGICAL_AND(self):
return self.getToken(GrammarParser.LOGICAL_AND, 0)
def AND_KW(self):
return self.getToken(GrammarParser.AND_KW, 0)
def LOGICAL_OR(self):
return self.getToken(GrammarParser.LOGICAL_OR, 0)
def OR_KW(self):
return self.getToken(GrammarParser.OR_KW, 0)
def enterRule(self, listener: ParseTreeListener):
if hasattr(listener, "enterBinaryExprCond"):
listener.enterBinaryExprCond(self)
def exitRule(self, listener: ParseTreeListener):
if hasattr(listener, "exitBinaryExprCond"):
listener.exitBinaryExprCond(self)
class BinaryExprFromNumCondContext(Cond_expressionContext):
def __init__(
self, parser, ctx: ParserRuleContext
): # actually a GrammarParser.Cond_expressionContext
super().__init__(parser)
self.op = None # Token
self.copyFrom(ctx)
def num_expression(self, i: int = None):
if i is None:
return self.getTypedRuleContexts(GrammarParser.Num_expressionContext)
else:
return self.getTypedRuleContext(GrammarParser.Num_expressionContext, i)
def LT(self):
return self.getToken(GrammarParser.LT, 0)
def GT(self):
return self.getToken(GrammarParser.GT, 0)
def LE(self):
return self.getToken(GrammarParser.LE, 0)
def GE(self):
return self.getToken(GrammarParser.GE, 0)
def EQ(self):
return self.getToken(GrammarParser.EQ, 0)
def NE(self):
return self.getToken(GrammarParser.NE, 0)
def enterRule(self, listener: ParseTreeListener):
if hasattr(listener, "enterBinaryExprFromNumCond"):
listener.enterBinaryExprFromNumCond(self)
def exitRule(self, listener: ParseTreeListener):
if hasattr(listener, "exitBinaryExprFromNumCond"):
listener.exitBinaryExprFromNumCond(self)
class UnaryExprCondContext(Cond_expressionContext):
def __init__(
self, parser, ctx: ParserRuleContext
): # actually a GrammarParser.Cond_expressionContext
super().__init__(parser)
self.op = None # Token
self.copyFrom(ctx)
def cond_expression(self):
return self.getTypedRuleContext(GrammarParser.Cond_expressionContext, 0)
def BANG(self):
return self.getToken(GrammarParser.BANG, 0)
def NOT_KW(self):
return self.getToken(GrammarParser.NOT_KW, 0)
def enterRule(self, listener: ParseTreeListener):
if hasattr(listener, "enterUnaryExprCond"):
listener.enterUnaryExprCond(self)
def exitRule(self, listener: ParseTreeListener):
if hasattr(listener, "exitUnaryExprCond"):
listener.exitUnaryExprCond(self)
class ParenExprCondContext(Cond_expressionContext):
def __init__(
self, parser, ctx: ParserRuleContext
): # actually a GrammarParser.Cond_expressionContext
super().__init__(parser)
self.copyFrom(ctx)
def LPAREN(self):
return self.getToken(GrammarParser.LPAREN, 0)
def cond_expression(self):
return self.getTypedRuleContext(GrammarParser.Cond_expressionContext, 0)
def RPAREN(self):
return self.getToken(GrammarParser.RPAREN, 0)
def enterRule(self, listener: ParseTreeListener):
if hasattr(listener, "enterParenExprCond"):
listener.enterParenExprCond(self)
def exitRule(self, listener: ParseTreeListener):
if hasattr(listener, "exitParenExprCond"):
listener.exitParenExprCond(self)
class LiteralExprCondContext(Cond_expressionContext):
def __init__(
self, parser, ctx: ParserRuleContext
): # actually a GrammarParser.Cond_expressionContext
super().__init__(parser)
self.copyFrom(ctx)
def bool_literal(self):
return self.getTypedRuleContext(GrammarParser.Bool_literalContext, 0)
def enterRule(self, listener: ParseTreeListener):
if hasattr(listener, "enterLiteralExprCond"):
listener.enterLiteralExprCond(self)
def exitRule(self, listener: ParseTreeListener):
if hasattr(listener, "exitLiteralExprCond"):
listener.exitLiteralExprCond(self)
class ConditionalCStyleCondNumContext(Cond_expressionContext):
def __init__(
self, parser, ctx: ParserRuleContext
): # actually a GrammarParser.Cond_expressionContext
super().__init__(parser)
self.copyFrom(ctx)
def LPAREN(self):
return self.getToken(GrammarParser.LPAREN, 0)
def cond_expression(self, i: int = None):
if i is None:
return self.getTypedRuleContexts(GrammarParser.Cond_expressionContext)
else:
return self.getTypedRuleContext(GrammarParser.Cond_expressionContext, i)
def RPAREN(self):
return self.getToken(GrammarParser.RPAREN, 0)
def QUESTION(self):
return self.getToken(GrammarParser.QUESTION, 0)
def COLON(self):
return self.getToken(GrammarParser.COLON, 0)
def enterRule(self, listener: ParseTreeListener):
if hasattr(listener, "enterConditionalCStyleCondNum"):
listener.enterConditionalCStyleCondNum(self)
def exitRule(self, listener: ParseTreeListener):
if hasattr(listener, "exitConditionalCStyleCondNum"):
listener.exitConditionalCStyleCondNum(self)
def cond_expression(self, _p: int = 0):
_parentctx = self._ctx
_parentState = self.state
localctx = GrammarParser.Cond_expressionContext(self, self._ctx, _parentState)
_prevctx = localctx
_startState = 64
self.enterRecursionRule(localctx, 64, self.RULE_cond_expression, _p)
self._la = 0 # Token type
try:
self.enterOuterAlt(localctx, 1)
self.state = 666
self._errHandler.sync(self)
la_ = self._interp.adaptivePredict(self._input, 63, self._ctx)
if la_ == 1:
localctx = GrammarParser.ParenExprCondContext(self, localctx)
self._ctx = localctx
_prevctx = localctx
self.state = 643
self.match(GrammarParser.LPAREN)
self.state = 644
self.cond_expression(0)
self.state = 645
self.match(GrammarParser.RPAREN)
pass
elif la_ == 2:
localctx = GrammarParser.LiteralExprCondContext(self, localctx)
self._ctx = localctx
_prevctx = localctx
self.state = 647
self.bool_literal()
pass
elif la_ == 3:
localctx = GrammarParser.UnaryExprCondContext(self, localctx)
self._ctx = localctx
_prevctx = localctx
self.state = 648
localctx.op = self._input.LT(1)
_la = self._input.LA(1)
if not (_la == GrammarParser.NOT_KW or _la == GrammarParser.BANG):
localctx.op = self._errHandler.recoverInline(self)
else:
self._errHandler.reportMatch(self)
self.consume()
self.state = 649
self.cond_expression(7)
pass
elif la_ == 4:
localctx = GrammarParser.BinaryExprFromNumCondContext(self, localctx)
self._ctx = localctx
_prevctx = localctx
self.state = 650
self.num_expression(0)
self.state = 651
localctx.op = self._input.LT(1)
_la = self._input.LA(1)
if not (
((_la) & ~0x3F) == 0
and (
(1 << _la)
& (
(1 << GrammarParser.LE)
| (1 << GrammarParser.GE)
| (1 << GrammarParser.LT)
| (1 << GrammarParser.GT)
)
)
!= 0
):
localctx.op = self._errHandler.recoverInline(self)
else:
self._errHandler.reportMatch(self)
self.consume()
self.state = 652
self.num_expression(0)
pass
elif la_ == 5:
localctx = GrammarParser.BinaryExprFromNumCondContext(self, localctx)
self._ctx = localctx
_prevctx = localctx
self.state = 654
self.num_expression(0)
self.state = 655
localctx.op = self._input.LT(1)
_la = self._input.LA(1)
if not (_la == GrammarParser.EQ or _la == GrammarParser.NE):
localctx.op = self._errHandler.recoverInline(self)
else:
self._errHandler.reportMatch(self)
self.consume()
self.state = 656
self.num_expression(0)
pass
elif la_ == 6:
localctx = GrammarParser.ConditionalCStyleCondNumContext(self, localctx)
self._ctx = localctx
_prevctx = localctx
self.state = 658
self.match(GrammarParser.LPAREN)
self.state = 659
self.cond_expression(0)
self.state = 660
self.match(GrammarParser.RPAREN)
self.state = 661
self.match(GrammarParser.QUESTION)
self.state = 662
self.cond_expression(0)
self.state = 663
self.match(GrammarParser.COLON)
self.state = 664
self.cond_expression(1)
pass
self._ctx.stop = self._input.LT(-1)
self.state = 679
self._errHandler.sync(self)
_alt = self._interp.adaptivePredict(self._input, 65, self._ctx)
while _alt != 2 and _alt != ATN.INVALID_ALT_NUMBER:
if _alt == 1:
if self._parseListeners is not None:
self.triggerExitRuleEvent()
_prevctx = localctx
self.state = 677
self._errHandler.sync(self)
la_ = self._interp.adaptivePredict(self._input, 64, self._ctx)
if la_ == 1:
localctx = GrammarParser.BinaryExprFromCondCondContext(
self,
GrammarParser.Cond_expressionContext(
self, _parentctx, _parentState
),
)
self.pushNewRecursionContext(
localctx, _startState, self.RULE_cond_expression
)
self.state = 668
if not self.precpred(self._ctx, 4):
from antlr4.error.Errors import FailedPredicateException
raise FailedPredicateException(
self, "self.precpred(self._ctx, 4)"
)
self.state = 669
localctx.op = self._input.LT(1)
_la = self._input.LA(1)
if not (_la == GrammarParser.EQ or _la == GrammarParser.NE):
localctx.op = self._errHandler.recoverInline(self)
else:
self._errHandler.reportMatch(self)
self.consume()
self.state = 670
self.cond_expression(5)
pass
elif la_ == 2:
localctx = GrammarParser.BinaryExprCondContext(
self,
GrammarParser.Cond_expressionContext(
self, _parentctx, _parentState
),
)
self.pushNewRecursionContext(
localctx, _startState, self.RULE_cond_expression
)
self.state = 671
if not self.precpred(self._ctx, 3):
from antlr4.error.Errors import FailedPredicateException
raise FailedPredicateException(
self, "self.precpred(self._ctx, 3)"
)
self.state = 672
localctx.op = self._input.LT(1)
_la = self._input.LA(1)
if not (
_la == GrammarParser.AND_KW
or _la == GrammarParser.LOGICAL_AND
):
localctx.op = self._errHandler.recoverInline(self)
else:
self._errHandler.reportMatch(self)
self.consume()
self.state = 673
self.cond_expression(4)
pass
elif la_ == 3:
localctx = GrammarParser.BinaryExprCondContext(
self,
GrammarParser.Cond_expressionContext(
self, _parentctx, _parentState
),
)
self.pushNewRecursionContext(
localctx, _startState, self.RULE_cond_expression
)
self.state = 674
if not self.precpred(self._ctx, 2):
from antlr4.error.Errors import FailedPredicateException
raise FailedPredicateException(
self, "self.precpred(self._ctx, 2)"
)
self.state = 675
localctx.op = self._input.LT(1)
_la = self._input.LA(1)
if not (
_la == GrammarParser.OR_KW
or _la == GrammarParser.LOGICAL_OR
):
localctx.op = self._errHandler.recoverInline(self)
else:
self._errHandler.reportMatch(self)
self.consume()
self.state = 676
self.cond_expression(3)
pass
self.state = 681
self._errHandler.sync(self)
_alt = self._interp.adaptivePredict(self._input, 65, self._ctx)
except RecognitionException as re:
localctx.exception = re
self._errHandler.reportError(self, re)
self._errHandler.recover(self, re)
finally:
self.unrollRecursionContexts(_parentctx)
return localctx
class Num_literalContext(ParserRuleContext):
__slots__ = "parser"
def __init__(
self, parser, parent: ParserRuleContext = None, invokingState: int = -1
):
super().__init__(parent, invokingState)
self.parser = parser
def INT(self):
return self.getToken(GrammarParser.INT, 0)
def FLOAT(self):
return self.getToken(GrammarParser.FLOAT, 0)
def HEX_INT(self):
return self.getToken(GrammarParser.HEX_INT, 0)
def getRuleIndex(self):
return GrammarParser.RULE_num_literal
def enterRule(self, listener: ParseTreeListener):
if hasattr(listener, "enterNum_literal"):
listener.enterNum_literal(self)
def exitRule(self, listener: ParseTreeListener):
if hasattr(listener, "exitNum_literal"):
listener.exitNum_literal(self)
def num_literal(self):
localctx = GrammarParser.Num_literalContext(self, self._ctx, self.state)
self.enterRule(localctx, 66, self.RULE_num_literal)
self._la = 0 # Token type
try:
self.enterOuterAlt(localctx, 1)
self.state = 682
_la = self._input.LA(1)
if not (
((_la - 62) & ~0x3F) == 0
and (
(1 << (_la - 62))
& (
(1 << (GrammarParser.FLOAT - 62))
| (1 << (GrammarParser.HEX_INT - 62))
| (1 << (GrammarParser.INT - 62))
)
)
!= 0
):
self._errHandler.recoverInline(self)
else:
self._errHandler.reportMatch(self)
self.consume()
except RecognitionException as re:
localctx.exception = re
self._errHandler.reportError(self, re)
self._errHandler.recover(self, re)
finally:
self.exitRule()
return localctx
class Bool_literalContext(ParserRuleContext):
__slots__ = "parser"
def __init__(
self, parser, parent: ParserRuleContext = None, invokingState: int = -1
):
super().__init__(parent, invokingState)
self.parser = parser
def TRUE(self):
return self.getToken(GrammarParser.TRUE, 0)
def FALSE(self):
return self.getToken(GrammarParser.FALSE, 0)
def getRuleIndex(self):
return GrammarParser.RULE_bool_literal
def enterRule(self, listener: ParseTreeListener):
if hasattr(listener, "enterBool_literal"):
listener.enterBool_literal(self)
def exitRule(self, listener: ParseTreeListener):
if hasattr(listener, "exitBool_literal"):
listener.exitBool_literal(self)
def bool_literal(self):
localctx = GrammarParser.Bool_literalContext(self, self._ctx, self.state)
self.enterRule(localctx, 68, self.RULE_bool_literal)
self._la = 0 # Token type
try:
self.enterOuterAlt(localctx, 1)
self.state = 684
_la = self._input.LA(1)
if not (_la == GrammarParser.TRUE or _la == GrammarParser.FALSE):
self._errHandler.recoverInline(self)
else:
self._errHandler.reportMatch(self)
self.consume()
except RecognitionException as re:
localctx.exception = re
self._errHandler.reportError(self, re)
self._errHandler.recover(self, re)
finally:
self.exitRule()
return localctx
class Math_constContext(ParserRuleContext):
__slots__ = "parser"
def __init__(
self, parser, parent: ParserRuleContext = None, invokingState: int = -1
):
super().__init__(parent, invokingState)
self.parser = parser
def PI_CONST(self):
return self.getToken(GrammarParser.PI_CONST, 0)
def E_CONST(self):
return self.getToken(GrammarParser.E_CONST, 0)
def TAU_CONST(self):
return self.getToken(GrammarParser.TAU_CONST, 0)
def getRuleIndex(self):
return GrammarParser.RULE_math_const
def enterRule(self, listener: ParseTreeListener):
if hasattr(listener, "enterMath_const"):
listener.enterMath_const(self)
def exitRule(self, listener: ParseTreeListener):
if hasattr(listener, "exitMath_const"):
listener.exitMath_const(self)
def math_const(self):
localctx = GrammarParser.Math_constContext(self, self._ctx, self.state)
self.enterRule(localctx, 70, self.RULE_math_const)
self._la = 0 # Token type
try:
self.enterOuterAlt(localctx, 1)
self.state = 686
_la = self._input.LA(1)
if not (
((_la) & ~0x3F) == 0
and (
(1 << _la)
& (
(1 << GrammarParser.PI_CONST)
| (1 << GrammarParser.E_CONST)
| (1 << GrammarParser.TAU_CONST)
)
)
!= 0
):
self._errHandler.recoverInline(self)
else:
self._errHandler.reportMatch(self)
self.consume()
except RecognitionException as re:
localctx.exception = re
self._errHandler.reportError(self, re)
self._errHandler.recover(self, re)
finally:
self.exitRule()
return localctx
class Chain_idContext(ParserRuleContext):
__slots__ = "parser"
def __init__(
self, parser, parent: ParserRuleContext = None, invokingState: int = -1
):
super().__init__(parent, invokingState)
self.parser = parser
self.isabs = None # Token
def ID(self, i: int = None):
if i is None:
return self.getTokens(GrammarParser.ID)
else:
return self.getToken(GrammarParser.ID, i)
def DOT(self, i: int = None):
if i is None:
return self.getTokens(GrammarParser.DOT)
else:
return self.getToken(GrammarParser.DOT, i)
def SLASH(self):
return self.getToken(GrammarParser.SLASH, 0)
def getRuleIndex(self):
return GrammarParser.RULE_chain_id
def enterRule(self, listener: ParseTreeListener):
if hasattr(listener, "enterChain_id"):
listener.enterChain_id(self)
def exitRule(self, listener: ParseTreeListener):
if hasattr(listener, "exitChain_id"):
listener.exitChain_id(self)
def chain_id(self):
localctx = GrammarParser.Chain_idContext(self, self._ctx, self.state)
self.enterRule(localctx, 72, self.RULE_chain_id)
self._la = 0 # Token type
try:
self.enterOuterAlt(localctx, 1)
self.state = 689
self._errHandler.sync(self)
_la = self._input.LA(1)
if _la == GrammarParser.SLASH:
self.state = 688
localctx.isabs = self.match(GrammarParser.SLASH)
self.state = 691
self.match(GrammarParser.ID)
self.state = 696
self._errHandler.sync(self)
_la = self._input.LA(1)
while _la == GrammarParser.DOT:
self.state = 692
self.match(GrammarParser.DOT)
self.state = 693
self.match(GrammarParser.ID)
self.state = 698
self._errHandler.sync(self)
_la = self._input.LA(1)
except RecognitionException as re:
localctx.exception = re
self._errHandler.reportError(self, re)
self._errHandler.recover(self, re)
finally:
self.exitRule()
return localctx
def sempred(self, localctx: RuleContext, ruleIndex: int, predIndex: int):
if self._predicates == None:
self._predicates = dict()
self._predicates[30] = self.init_expression_sempred
self._predicates[31] = self.num_expression_sempred
self._predicates[32] = self.cond_expression_sempred
pred = self._predicates.get(ruleIndex, None)
if pred is None:
raise Exception("No predicate with index:" + str(ruleIndex))
else:
return pred(localctx, predIndex)
def init_expression_sempred(self, localctx: Init_expressionContext, predIndex: int):
if predIndex == 0:
return self.precpred(self._ctx, 8)
if predIndex == 1:
return self.precpred(self._ctx, 7)
if predIndex == 2:
return self.precpred(self._ctx, 6)
if predIndex == 3:
return self.precpred(self._ctx, 5)
if predIndex == 4:
return self.precpred(self._ctx, 4)
if predIndex == 5:
return self.precpred(self._ctx, 3)
if predIndex == 6:
return self.precpred(self._ctx, 2)
def num_expression_sempred(self, localctx: Num_expressionContext, predIndex: int):
if predIndex == 7:
return self.precpred(self._ctx, 9)
if predIndex == 8:
return self.precpred(self._ctx, 8)
if predIndex == 9:
return self.precpred(self._ctx, 7)
if predIndex == 10:
return self.precpred(self._ctx, 6)
if predIndex == 11:
return self.precpred(self._ctx, 5)
if predIndex == 12:
return self.precpred(self._ctx, 4)
if predIndex == 13:
return self.precpred(self._ctx, 3)
def cond_expression_sempred(self, localctx: Cond_expressionContext, predIndex: int):
if predIndex == 14:
return self.precpred(self._ctx, 4)
if predIndex == 15:
return self.precpred(self._ctx, 3)
if predIndex == 16:
return self.precpred(self._ctx, 2)