Source code for pyfcstm.dsl.grammar.GrammarParser

# 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\3a") buf.write("\u02c4\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"\3"\3"\3"\3"\3"\3"\7"') buf.write('\u02ae\n"\f"\16"\u02b1\13"\3#\3#\3$\3$\3%\3%\3&\5') buf.write("&\u02ba\n&\3&\3&\3&\7&\u02bf\n&\f&\16&\u02c2\13&\3&\2") buf.write("\5>@B'\2\4\6\b\n\f\16\20\22\24\26\30\32\34\36 \"$&(*") buf.write(",.\60\62\64\668:<>@BDFHJ\2\22\3\2\24\25\4\2++\66\66\3") buf.write('\2\r\16\3\2;<\4\289==\3\2!"\4\2\33\33::\4\2#$AB\3\2%') buf.write("&\4\2\35\35%&\4\2\31\31''\4\2\32\32((\4\2\34\34))\3") buf.write("\2DF\3\2GH\3\2\26\30\2\u031e\2L\3\2\2\2\4R\3\2\2\2\6X") buf.write("\3\2\2\2\bz\3\2\2\2\n\u00bf\3\2\2\2\f\u0101\3\2\2\2\16") buf.write("\u011d\3\2\2\2\20\u0139\3\2\2\2\22\u0161\3\2\2\2\24\u0185") buf.write("\3\2\2\2\26\u0187\3\2\2\2\30\u018f\3\2\2\2\32\u01a5\3") buf.write("\2\2\2\34\u01a7\3\2\2\2\36\u01ba\3\2\2\2 \u01bf\3\2\2") buf.write('\2"\u01c1\3\2\2\2$\u01cb\3\2\2\2&\u01d0\3\2\2\2(\u01d4') buf.write("\3\2\2\2*\u01ec\3\2\2\2,\u01f1\3\2\2\2.\u01fe\3\2\2\2") buf.write("\60\u0203\3\2\2\2\62\u020b\3\2\2\2\64\u0212\3\2\2\2\66") buf.write("\u0214\3\2\2\28\u0219\3\2\2\2:\u021e\3\2\2\2<\u0225\3") buf.write("\2\2\2>\u0235\3\2\2\2@\u0268\3\2\2\2B\u029c\3\2\2\2D\u02b2") buf.write("\3\2\2\2F\u02b4\3\2\2\2H\u02b6\3\2\2\2J\u02b9\3\2\2\2") buf.write('LM\5B"\2MN\7\2\2\3N\3\3\2\2\2OQ\5\6\4\2PO\3\2\2\2QT\3') buf.write("\2\2\2RP\3\2\2\2RS\3\2\2\2SU\3\2\2\2TR\3\2\2\2UV\5\b\5") buf.write("\2VW\7\2\2\3W\5\3\2\2\2XY\7\4\2\2YZ\t\2\2\2Z[\7J\2\2[") buf.write("\\\7C\2\2\\]\5> \2]^\7-\2\2^\7\3\2\2\2_a\7\b\2\2`_\3\2") buf.write("\2\2`a\3\2\2\2ab\3\2\2\2bc\7\t\2\2cf\7J\2\2de\7\7\2\2") buf.write("eg\7K\2\2fd\3\2\2\2fg\3\2\2\2gh\3\2\2\2h{\7-\2\2ik\7\b") buf.write("\2\2ji\3\2\2\2jk\3\2\2\2kl\3\2\2\2lm\7\t\2\2mp\7J\2\2") buf.write("no\7\7\2\2oq\7K\2\2pn\3\2\2\2pq\3\2\2\2qr\3\2\2\2rv\7") buf.write("/\2\2su\5.\30\2ts\3\2\2\2ux\3\2\2\2vt\3\2\2\2vw\3\2\2") buf.write("\2wy\3\2\2\2xv\3\2\2\2y{\7\60\2\2z`\3\2\2\2zj\3\2\2\2") buf.write("{\t\3\2\2\2|}\7\37\2\2}~\7,\2\2~\u0087\7J\2\2\177\u0080") buf.write("\t\3\2\2\u0080\u0088\5J&\2\u0081\u0082\7\66\2\2\u0082") buf.write('\u0083\7\22\2\2\u0083\u0084\7\61\2\2\u0084\u0085\5B"') buf.write("\2\u0085\u0086\7\62\2\2\u0086\u0088\3\2\2\2\u0087\177") buf.write("\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("\60\2\2\u008e\u0090\3\2\2\2\u008f\u0089\3\2\2\2\u008f") buf.write("\u008a\3\2\2\2\u0090\u00c0\3\2\2\2\u0091\u0092\7J\2\2") buf.write("\u0092\u0093\7,\2\2\u0093\u009e\7J\2\2\u0094\u0095\7+") buf.write("\2\2\u0095\u009f\7J\2\2\u0096\u0097\7\66\2\2\u0097\u009f") buf.write("\5J&\2\u0098\u0099\7\66\2\2\u0099\u009a\7\22\2\2\u009a") buf.write('\u009b\7\61\2\2\u009b\u009c\5B"\2\u009c\u009d\7\62\2') buf.write("\2\u009d\u009f\3\2\2\2\u009e\u0094\3\2\2\2\u009e\u0096") buf.write("\3\2\2\2\u009e\u0098\3\2\2\2\u009e\u009f\3\2\2\2\u009f") buf.write("\u00a6\3\2\2\2\u00a0\u00a7\7-\2\2\u00a1\u00a2\7\21\2\2") buf.write("\u00a2\u00a3\7/\2\2\u00a3\u00a4\5,\27\2\u00a4\u00a5\7") buf.write("\60\2\2\u00a5\u00a7\3\2\2\2\u00a6\u00a0\3\2\2\2\u00a6") buf.write("\u00a1\3\2\2\2\u00a7\u00c0\3\2\2\2\u00a8\u00a9\7J\2\2") buf.write("\u00a9\u00aa\7,\2\2\u00aa\u00b5\7\37\2\2\u00ab\u00ac\7") buf.write("+\2\2\u00ac\u00b6\7J\2\2\u00ad\u00ae\7\66\2\2\u00ae\u00b6") buf.write("\5J&\2\u00af\u00b0\7\66\2\2\u00b0\u00b1\7\22\2\2\u00b1") buf.write('\u00b2\7\61\2\2\u00b2\u00b3\5B"\2\u00b3\u00b4\7\62\2') buf.write("\2\u00b4\u00b6\3\2\2\2\u00b5\u00ab\3\2\2\2\u00b5\u00ad") buf.write("\3\2\2\2\u00b5\u00af\3\2\2\2\u00b5\u00b6\3\2\2\2\u00b6") buf.write("\u00bd\3\2\2\2\u00b7\u00be\7-\2\2\u00b8\u00b9\7\21\2\2") buf.write("\u00b9\u00ba\7/\2\2\u00ba\u00bb\5,\27\2\u00bb\u00bc\7") buf.write("\60\2\2\u00bc\u00be\3\2\2\2\u00bd\u00b7\3\2\2\2\u00bd") buf.write("\u00b8\3\2\2\2\u00be\u00c0\3\2\2\2\u00bf|\3\2\2\2\u00bf") buf.write("\u0091\3\2\2\2\u00bf\u00a8\3\2\2\2\u00c0\13\3\2\2\2\u00c1") buf.write("\u00c2\7:\2\2\u00c2\u00c3\7J\2\2\u00c3\u00c4\7,\2\2\u00c4") buf.write("\u00cf\7J\2\2\u00c5\u00c6\7+\2\2\u00c6\u00d0\7J\2\2\u00c7") buf.write("\u00c8\7\66\2\2\u00c8\u00d0\5J&\2\u00c9\u00ca\7\66\2\2") buf.write("\u00ca\u00cb\7\22\2\2\u00cb\u00cc\7\61\2\2\u00cc\u00cd") buf.write('\5B"\2\u00cd\u00ce\7\62\2\2\u00ce\u00d0\3\2\2\2\u00cf') buf.write("\u00c5\3\2\2\2\u00cf\u00c7\3\2\2\2\u00cf\u00c9\3\2\2\2") buf.write("\u00cf\u00d0\3\2\2\2\u00d0\u00d1\3\2\2\2\u00d1\u0102\7") buf.write("-\2\2\u00d2\u00d3\7:\2\2\u00d3\u00d4\7J\2\2\u00d4\u00d5") buf.write("\7,\2\2\u00d5\u00e0\7\37\2\2\u00d6\u00d7\7+\2\2\u00d7") buf.write("\u00e1\7J\2\2\u00d8\u00d9\7\66\2\2\u00d9\u00e1\5J&\2\u00da") buf.write("\u00db\7\66\2\2\u00db\u00dc\7\22\2\2\u00dc\u00dd\7\61") buf.write('\2\2\u00dd\u00de\5B"\2\u00de\u00df\7\62\2\2\u00df\u00e1') buf.write("\3\2\2\2\u00e0\u00d6\3\2\2\2\u00e0\u00d8\3\2\2\2\u00e0") buf.write("\u00da\3\2\2\2\u00e0\u00e1\3\2\2\2\u00e1\u00e2\3\2\2\2") buf.write("\u00e2\u0102\7-\2\2\u00e3\u00e4\7:\2\2\u00e4\u00e5\79") buf.write("\2\2\u00e5\u00e6\7,\2\2\u00e6\u00ef\7J\2\2\u00e7\u00e8") buf.write("\t\3\2\2\u00e8\u00f0\5J&\2\u00e9\u00ea\7\66\2\2\u00ea") buf.write('\u00eb\7\22\2\2\u00eb\u00ec\7\61\2\2\u00ec\u00ed\5B"') buf.write("\2\u00ed\u00ee\7\62\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:\2\2\u00f3") buf.write("\u00f4\79\2\2\u00f4\u00f5\7,\2\2\u00f5\u00fe\7\37\2\2") buf.write("\u00f6\u00f7\t\3\2\2\u00f7\u00ff\5J&\2\u00f8\u00f9\7\66") buf.write("\2\2\u00f9\u00fa\7\22\2\2\u00fa\u00fb\7\61\2\2\u00fb\u00fc") buf.write('\5B"\2\u00fc\u00fd\7\62\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("\7J\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\60\2\2\u010a\u011e\3\2\2\2\u010b\u010c") buf.write("\7\n\2\2\u010c\u010d\7\17\2\2\u010d\u010e\7J\2\2\u010e") buf.write("\u011e\7-\2\2\u010f\u0110\7\n\2\2\u0110\u0112\7\17\2\2") buf.write("\u0111\u0113\7J\2\2\u0112\u0111\3\2\2\2\u0112\u0113\3") buf.write("\2\2\2\u0113\u0114\3\2\2\2\u0114\u011e\7L\2\2\u0115\u0117") buf.write("\7\n\2\2\u0116\u0118\7J\2\2\u0117\u0116\3\2\2\2\u0117") buf.write("\u0118\3\2\2\2\u0118\u0119\3\2\2\2\u0119\u011a\7\20\2") buf.write("\2\u011a\u011b\5J&\2\u011b\u011c\7-\2\2\u011c\u011e\3") buf.write("\2\2\2\u011d\u0103\3\2\2\2\u011d\u010b\3\2\2\2\u011d\u010f") buf.write("\3\2\2\2\u011d\u0115\3\2\2\2\u011e\17\3\2\2\2\u011f\u0121") buf.write("\7\13\2\2\u0120\u0122\7J\2\2\u0121\u0120\3\2\2\2\u0121") buf.write("\u0122\3\2\2\2\u0122\u0123\3\2\2\2\u0123\u0124\7/\2\2") buf.write("\u0124\u0125\5,\27\2\u0125\u0126\7\60\2\2\u0126\u013a") buf.write("\3\2\2\2\u0127\u0128\7\13\2\2\u0128\u0129\7\17\2\2\u0129") buf.write("\u012a\7J\2\2\u012a\u013a\7-\2\2\u012b\u012c\7\13\2\2") buf.write("\u012c\u012e\7\17\2\2\u012d\u012f\7J\2\2\u012e\u012d\3") buf.write("\2\2\2\u012e\u012f\3\2\2\2\u012f\u0130\3\2\2\2\u0130\u013a") buf.write("\7L\2\2\u0131\u0133\7\13\2\2\u0132\u0134\7J\2\2\u0133") buf.write("\u0132\3\2\2\2\u0133\u0134\3\2\2\2\u0134\u0135\3\2\2\2") buf.write("\u0135\u0136\7\20\2\2\u0136\u0137\5J&\2\u0137\u0138\7") buf.write("-\2\2\u0138\u013a\3\2\2\2\u0139\u011f\3\2\2\2\u0139\u0127") buf.write("\3\2\2\2\u0139\u012b\3\2\2\2\u0139\u0131\3\2\2\2\u013a") buf.write("\21\3\2\2\2\u013b\u013d\7\f\2\2\u013c\u013e\t\4\2\2\u013d") buf.write("\u013c\3\2\2\2\u013d\u013e\3\2\2\2\u013e\u0140\3\2\2\2") buf.write("\u013f\u0141\7J\2\2\u0140\u013f\3\2\2\2\u0140\u0141\3") buf.write("\2\2\2\u0141\u0142\3\2\2\2\u0142\u0143\7/\2\2\u0143\u0144") buf.write("\5,\27\2\u0144\u0145\7\60\2\2\u0145\u0162\3\2\2\2\u0146") buf.write("\u0148\7\f\2\2\u0147\u0149\t\4\2\2\u0148\u0147\3\2\2\2") buf.write("\u0148\u0149\3\2\2\2\u0149\u014a\3\2\2\2\u014a\u014b\7") buf.write("\17\2\2\u014b\u014c\7J\2\2\u014c\u0162\7-\2\2\u014d\u014f") buf.write("\7\f\2\2\u014e\u0150\t\4\2\2\u014f\u014e\3\2\2\2\u014f") buf.write("\u0150\3\2\2\2\u0150\u0151\3\2\2\2\u0151\u0153\7\17\2") buf.write("\2\u0152\u0154\7J\2\2\u0153\u0152\3\2\2\2\u0153\u0154") buf.write("\3\2\2\2\u0154\u0155\3\2\2\2\u0155\u0162\7L\2\2\u0156") buf.write("\u0158\7\f\2\2\u0157\u0159\t\4\2\2\u0158\u0157\3\2\2\2") buf.write("\u0158\u0159\3\2\2\2\u0159\u015b\3\2\2\2\u015a\u015c\7") buf.write("J\2\2\u015b\u015a\3\2\2\2\u015b\u015c\3\2\2\2\u015c\u015d") buf.write("\3\2\2\2\u015d\u015e\7\20\2\2\u015e\u015f\5J&\2\u015f") buf.write("\u0160\7-\2\2\u0160\u0162\3\2\2\2\u0161\u013b\3\2\2\2") buf.write("\u0161\u0146\3\2\2\2\u0161\u014d\3\2\2\2\u0161\u0156\3") buf.write("\2\2\2\u0162\23\3\2\2\2\u0163\u0164\7!\2\2\u0164\u0165") buf.write("\7\f\2\2\u0165\u0167\t\4\2\2\u0166\u0168\7J\2\2\u0167") buf.write("\u0166\3\2\2\2\u0167\u0168\3\2\2\2\u0168\u0169\3\2\2\2") buf.write("\u0169\u016a\7/\2\2\u016a\u016b\5,\27\2\u016b\u016c\7") buf.write("\60\2\2\u016c\u0186\3\2\2\2\u016d\u016e\7!\2\2\u016e\u016f") buf.write("\7\f\2\2\u016f\u0170\t\4\2\2\u0170\u0171\7\17\2\2\u0171") buf.write("\u0172\7J\2\2\u0172\u0186\7-\2\2\u0173\u0174\7!\2\2\u0174") buf.write("\u0175\7\f\2\2\u0175\u0176\t\4\2\2\u0176\u0178\7\17\2") buf.write("\2\u0177\u0179\7J\2\2\u0178\u0177\3\2\2\2\u0178\u0179") buf.write("\3\2\2\2\u0179\u017a\3\2\2\2\u017a\u0186\7L\2\2\u017b") buf.write("\u017c\7!\2\2\u017c\u017d\7\f\2\2\u017d\u017f\t\4\2\2") buf.write("\u017e\u0180\7J\2\2\u017f\u017e\3\2\2\2\u017f\u0180\3") buf.write("\2\2\2\u0180\u0181\3\2\2\2\u0181\u0182\7\20\2\2\u0182") buf.write("\u0183\5J&\2\u0183\u0184\7-\2\2\u0184\u0186\3\2\2\2\u0185") buf.write("\u0163\3\2\2\2\u0185\u016d\3\2\2\2\u0185\u0173\3\2\2\2") buf.write("\u0185\u017b\3\2\2\2\u0186\25\3\2\2\2\u0187\u0188\7\5") buf.write("\2\2\u0188\u018b\7J\2\2\u0189\u018a\7\7\2\2\u018a\u018c") buf.write("\7K\2\2\u018b\u0189\3\2\2\2\u018b\u018c\3\2\2\2\u018c") buf.write("\u018d\3\2\2\2\u018d\u018e\7-\2\2\u018e\27\3\2\2\2\u018f") buf.write("\u0190\7\3\2\2\u0190\u0191\7K\2\2\u0191\u0192\7\6\2\2") buf.write("\u0192\u0195\7J\2\2\u0193\u0194\7\7\2\2\u0194\u0196\7") buf.write("K\2\2\u0195\u0193\3\2\2\2\u0195\u0196\3\2\2\2\u0196\u01a0") buf.write("\3\2\2\2\u0197\u019b\7/\2\2\u0198\u019a\5\32\16\2\u0199") buf.write("\u0198\3\2\2\2\u019a\u019d\3\2\2\2\u019b\u0199\3\2\2\2") buf.write("\u019b\u019c\3\2\2\2\u019c\u019e\3\2\2\2\u019d\u019b\3") buf.write("\2\2\2\u019e\u01a1\7\60\2\2\u019f\u01a1\7-\2\2\u01a0\u0197") buf.write("\3\2\2\2\u01a0\u019f\3\2\2\2\u01a1\31\3\2\2\2\u01a2\u01a6") buf.write('\5\34\17\2\u01a3\u01a6\5"\22\2\u01a4\u01a6\7-\2\2\u01a5') buf.write("\u01a2\3\2\2\2\u01a5\u01a3\3\2\2\2\u01a5\u01a4\3\2\2\2") buf.write("\u01a6\33\3\2\2\2\u01a7\u01a8\7\4\2\2\u01a8\u01a9\5\36") buf.write("\20\2\u01a9\u01aa\7,\2\2\u01aa\u01ab\5 \21\2\u01ab\u01ac") buf.write("\7-\2\2\u01ac\35\3\2\2\2\u01ad\u01bb\79\2\2\u01ae\u01af") buf.write("\7/\2\2\u01af\u01b4\7J\2\2\u01b0\u01b1\7.\2\2\u01b1\u01b3") buf.write("\7J\2\2\u01b2\u01b0\3\2\2\2\u01b3\u01b6\3\2\2\2\u01b4") buf.write("\u01b2\3\2\2\2\u01b4\u01b5\3\2\2\2\u01b5\u01b7\3\2\2\2") buf.write("\u01b6\u01b4\3\2\2\2\u01b7\u01bb\7\60\2\2\u01b8\u01bb") buf.write("\7\\\2\2\u01b9\u01bb\7J\2\2\u01ba\u01ad\3\2\2\2\u01ba") buf.write("\u01ae\3\2\2\2\u01ba\u01b8\3\2\2\2\u01ba\u01b9\3\2\2\2") buf.write("\u01bb\37\3\2\2\2\u01bc\u01c0\7J\2\2\u01bd\u01c0\7a\2") buf.write("\2\u01be\u01c0\79\2\2\u01bf\u01bc\3\2\2\2\u01bf\u01bd") buf.write("\3\2\2\2\u01bf\u01be\3\2\2\2\u01c0!\3\2\2\2\u01c1\u01c2") buf.write("\7\5\2\2\u01c2\u01c3\5J&\2\u01c3\u01c4\7,\2\2\u01c4\u01c7") buf.write("\5J&\2\u01c5\u01c6\7\7\2\2\u01c6\u01c8\7K\2\2\u01c7\u01c5") buf.write("\3\2\2\2\u01c7\u01c8\3\2\2\2\u01c8\u01c9\3\2\2\2\u01c9") buf.write("\u01ca\7-\2\2\u01ca#\3\2\2\2\u01cb\u01cc\7J\2\2\u01cc") buf.write("\u01cd\7C\2\2\u01cd\u01ce\5@!\2\u01ce\u01cf\7-\2\2\u01cf") buf.write("%\3\2\2\2\u01d0\u01d1\7/\2\2\u01d1\u01d2\5,\27\2\u01d2") buf.write("\u01d3\7\60\2\2\u01d3'\3\2\2\2\u01d4\u01d5\7\22\2\2\u01d5") buf.write('\u01d6\7\61\2\2\u01d6\u01d7\5B"\2\u01d7\u01d8\7\62\2') buf.write("\2\u01d8\u01e2\5&\24\2\u01d9\u01da\7\23\2\2\u01da\u01db") buf.write('\7\22\2\2\u01db\u01dc\7\61\2\2\u01dc\u01dd\5B"\2\u01dd') buf.write("\u01de\7\62\2\2\u01de\u01df\5&\24\2\u01df\u01e1\3\2\2") buf.write("\2\u01e0\u01d9\3\2\2\2\u01e1\u01e4\3\2\2\2\u01e2\u01e0") buf.write("\3\2\2\2\u01e2\u01e3\3\2\2\2\u01e3\u01e7\3\2\2\2\u01e4") buf.write("\u01e2\3\2\2\2\u01e5\u01e6\7\23\2\2\u01e6\u01e8\5&\24") buf.write("\2\u01e7\u01e5\3\2\2\2\u01e7\u01e8\3\2\2\2\u01e8)\3\2") buf.write("\2\2\u01e9\u01ed\5$\23\2\u01ea\u01ed\5(\25\2\u01eb\u01ed") buf.write("\7-\2\2\u01ec\u01e9\3\2\2\2\u01ec\u01ea\3\2\2\2\u01ec") buf.write("\u01eb\3\2\2\2\u01ed+\3\2\2\2\u01ee\u01f0\5*\26\2\u01ef") buf.write("\u01ee\3\2\2\2\u01f0\u01f3\3\2\2\2\u01f1\u01ef\3\2\2\2") buf.write("\u01f1\u01f2\3\2\2\2\u01f2-\3\2\2\2\u01f3\u01f1\3\2\2") buf.write("\2\u01f4\u01ff\5\b\5\2\u01f5\u01ff\5\n\6\2\u01f6\u01ff") buf.write("\5\f\7\2\u01f7\u01ff\5\16\b\2\u01f8\u01ff\5\22\n\2\u01f9") buf.write("\u01ff\5\20\t\2\u01fa\u01ff\5\24\13\2\u01fb\u01ff\5\26") buf.write("\f\2\u01fc\u01ff\5\30\r\2\u01fd\u01ff\7-\2\2\u01fe\u01f4") buf.write("\3\2\2\2\u01fe\u01f5\3\2\2\2\u01fe\u01f6\3\2\2\2\u01fe") buf.write("\u01f7\3\2\2\2\u01fe\u01f8\3\2\2\2\u01fe\u01f9\3\2\2\2") buf.write("\u01fe\u01fa\3\2\2\2\u01fe\u01fb\3\2\2\2\u01fe\u01fc\3") buf.write("\2\2\2\u01fe\u01fd\3\2\2\2\u01ff/\3\2\2\2\u0200\u0202") buf.write("\5:\36\2\u0201\u0200\3\2\2\2\u0202\u0205\3\2\2\2\u0203") buf.write("\u0201\3\2\2\2\u0203\u0204\3\2\2\2\u0204\u0206\3\2\2\2") buf.write("\u0205\u0203\3\2\2\2\u0206\u0207\7\2\2\3\u0207\61\3\2") buf.write("\2\2\u0208\u020a\5\64\33\2\u0209\u0208\3\2\2\2\u020a\u020d") buf.write("\3\2\2\2\u020b\u0209\3\2\2\2\u020b\u020c\3\2\2\2\u020c") buf.write("\u020e\3\2\2\2\u020d\u020b\3\2\2\2\u020e\u020f\7\2\2\3") buf.write("\u020f\63\3\2\2\2\u0210\u0213\5\66\34\2\u0211\u0213\5") buf.write("8\35\2\u0212\u0210\3\2\2\2\u0212\u0211\3\2\2\2\u0213\65") buf.write("\3\2\2\2\u0214\u0215\7J\2\2\u0215\u0216\7*\2\2\u0216\u0217") buf.write("\5> \2\u0217\u0218\7-\2\2\u0218\67\3\2\2\2\u0219\u021a") buf.write("\7J\2\2\u021a\u021b\7C\2\2\u021b\u021c\5> \2\u021c\u021d") buf.write("\7-\2\2\u021d9\3\2\2\2\u021e\u021f\7J\2\2\u021f\u0220") buf.write("\7*\2\2\u0220\u0221\5@!\2\u0221\u0222\7-\2\2\u0222;\3") buf.write('\2\2\2\u0223\u0226\5@!\2\u0224\u0226\5B"\2\u0225\u0223') buf.write("\3\2\2\2\u0225\u0224\3\2\2\2\u0226=\3\2\2\2\u0227\u0228") buf.write("\b \1\2\u0228\u0229\7\63\2\2\u0229\u022a\5> \2\u022a\u022b") buf.write("\7\64\2\2\u022b\u0236\3\2\2\2\u022c\u0236\5D#\2\u022d") buf.write("\u0236\5H%\2\u022e\u022f\t\5\2\2\u022f\u0236\5> \13\u0230") buf.write("\u0231\7I\2\2\u0231\u0232\7\63\2\2\u0232\u0233\5> \2\u0233") buf.write("\u0234\7\64\2\2\u0234\u0236\3\2\2\2\u0235\u0227\3\2\2") buf.write("\2\u0235\u022c\3\2\2\2\u0235\u022d\3\2\2\2\u0235\u022e") buf.write("\3\2\2\2\u0235\u0230\3\2\2\2\u0236\u024e\3\2\2\2\u0237") buf.write("\u0238\f\n\2\2\u0238\u0239\7 \2\2\u0239\u024d\5> \n\u023a") buf.write("\u023b\f\t\2\2\u023b\u023c\t\6\2\2\u023c\u024d\5> \n\u023d") buf.write("\u023e\f\b\2\2\u023e\u023f\t\5\2\2\u023f\u024d\5> \t\u0240") buf.write("\u0241\f\7\2\2\u0241\u0242\t\7\2\2\u0242\u024d\5> \b\u0243") buf.write("\u0244\f\6\2\2\u0244\u0245\7>\2\2\u0245\u024d\5> \7\u0246") buf.write("\u0247\f\5\2\2\u0247\u0248\7?\2\2\u0248\u024d\5> \6\u0249") buf.write("\u024a\f\4\2\2\u024a\u024b\7@\2\2\u024b\u024d\5> \5\u024c") buf.write("\u0237\3\2\2\2\u024c\u023a\3\2\2\2\u024c\u023d\3\2\2\2") buf.write("\u024c\u0240\3\2\2\2\u024c\u0243\3\2\2\2\u024c\u0246\3") buf.write("\2\2\2\u024c\u0249\3\2\2\2\u024d\u0250\3\2\2\2\u024e\u024c") buf.write("\3\2\2\2\u024e\u024f\3\2\2\2\u024f?\3\2\2\2\u0250\u024e") buf.write("\3\2\2\2\u0251\u0252\b!\1\2\u0252\u0253\7\63\2\2\u0253") buf.write("\u0254\5@!\2\u0254\u0255\7\64\2\2\u0255\u0269\3\2\2\2") buf.write("\u0256\u0269\5D#\2\u0257\u0269\7J\2\2\u0258\u0269\5H%") buf.write("\2\u0259\u025a\t\5\2\2\u025a\u0269\5@!\f\u025b\u025c\7") buf.write("I\2\2\u025c\u025d\7\63\2\2\u025d\u025e\5@!\2\u025e\u025f") buf.write("\7\64\2\2\u025f\u0269\3\2\2\2\u0260\u0261\7\63\2\2\u0261") buf.write('\u0262\5B"\2\u0262\u0263\7\64\2\2\u0263\u0264\7\65\2') buf.write("\2\u0264\u0265\5@!\2\u0265\u0266\7\66\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 \2\2\u026c\u0280\5@!\13\u026d\u026e\f\n\2\2\u026e\u026f") buf.write("\t\6\2\2\u026f\u0280\5@!\13\u0270\u0271\f\t\2\2\u0271") buf.write("\u0272\t\5\2\2\u0272\u0280\5@!\n\u0273\u0274\f\b\2\2\u0274") buf.write("\u0275\t\7\2\2\u0275\u0280\5@!\t\u0276\u0277\f\7\2\2\u0277") buf.write("\u0278\7>\2\2\u0278\u0280\5@!\b\u0279\u027a\f\6\2\2\u027a") buf.write("\u027b\7?\2\2\u027b\u0280\5@!\7\u027c\u027d\f\5\2\2\u027d") buf.write("\u027e\7@\2\2\u027e\u0280\5@!\6\u027f\u026a\3\2\2\2\u027f") buf.write("\u026d\3\2\2\2\u027f\u0270\3\2\2\2\u027f\u0273\3\2\2\2") buf.write("\u027f\u0276\3\2\2\2\u027f\u0279\3\2\2\2\u027f\u027c\3") buf.write("\2\2\2\u0280\u0283\3\2\2\2\u0281\u027f\3\2\2\2\u0281\u0282") buf.write("\3\2\2\2\u0282A\3\2\2\2\u0283\u0281\3\2\2\2\u0284\u0285") buf.write('\b"\1\2\u0285\u0286\7\63\2\2\u0286\u0287\5B"\2\u0287') buf.write("\u0288\7\64\2\2\u0288\u029d\3\2\2\2\u0289\u029d\5F$\2") buf.write('\u028a\u028b\t\b\2\2\u028b\u029d\5B"\13\u028c\u028d\5') buf.write("@!\2\u028d\u028e\t\t\2\2\u028e\u028f\5@!\2\u028f\u029d") buf.write("\3\2\2\2\u0290\u0291\5@!\2\u0291\u0292\t\n\2\2\u0292\u0293") buf.write("\5@!\2\u0293\u029d\3\2\2\2\u0294\u0295\7\63\2\2\u0295") buf.write('\u0296\5B"\2\u0296\u0297\7\64\2\2\u0297\u0298\7\65\2') buf.write('\2\u0298\u0299\5B"\2\u0299\u029a\7\66\2\2\u029a\u029b') buf.write('\5B"\3\u029b\u029d\3\2\2\2\u029c\u0284\3\2\2\2\u029c') buf.write("\u0289\3\2\2\2\u029c\u028a\3\2\2\2\u029c\u028c\3\2\2\2") buf.write("\u029c\u0290\3\2\2\2\u029c\u0294\3\2\2\2\u029d\u02af\3") buf.write("\2\2\2\u029e\u029f\f\b\2\2\u029f\u02a0\t\13\2\2\u02a0") buf.write('\u02ae\5B"\t\u02a1\u02a2\f\7\2\2\u02a2\u02a3\t\f\2\2') buf.write('\u02a3\u02ae\5B"\b\u02a4\u02a5\f\6\2\2\u02a5\u02a6\7') buf.write('\36\2\2\u02a6\u02ae\5B"\7\u02a7\u02a8\f\5\2\2\u02a8\u02a9') buf.write('\t\r\2\2\u02a9\u02ae\5B"\6\u02aa\u02ab\f\4\2\2\u02ab') buf.write('\u02ac\t\16\2\2\u02ac\u02ae\5B"\4\u02ad\u029e\3\2\2\2') buf.write("\u02ad\u02a1\3\2\2\2\u02ad\u02a4\3\2\2\2\u02ad\u02a7\3") buf.write("\2\2\2\u02ad\u02aa\3\2\2\2\u02ae\u02b1\3\2\2\2\u02af\u02ad") buf.write("\3\2\2\2\u02af\u02b0\3\2\2\2\u02b0C\3\2\2\2\u02b1\u02af") buf.write("\3\2\2\2\u02b2\u02b3\t\17\2\2\u02b3E\3\2\2\2\u02b4\u02b5") buf.write("\t\20\2\2\u02b5G\3\2\2\2\u02b6\u02b7\t\21\2\2\u02b7I\3") buf.write("\2\2\2\u02b8\u02ba\78\2\2\u02b9\u02b8\3\2\2\2\u02b9\u02ba") buf.write("\3\2\2\2\u02ba\u02bb\3\2\2\2\u02bb\u02c0\7J\2\2\u02bc") buf.write("\u02bd\7\67\2\2\u02bd\u02bf\7J\2\2\u02be\u02bc\3\2\2\2") buf.write("\u02bf\u02c2\3\2\2\2\u02c0\u02be\3\2\2\2\u02c0\u02c1\3") buf.write("\2\2\2\u02c1K\3\2\2\2\u02c2\u02c0\3\2\2\2FR`fjpvz\u0087") buf.write("\u008f\u009e\u00a6\u00b5\u00bd\u00bf\u00cf\u00e0\u00ef") buf.write("\u00fe\u0101\u0105\u0112\u0117\u011d\u0121\u012e\u0133") buf.write("\u0139\u013d\u0140\u0148\u014f\u0153\u0158\u015b\u0161") buf.write("\u0167\u0178\u017f\u0185\u018b\u0195\u019b\u01a0\u01a5") buf.write("\u01b4\u01ba\u01bf\u01c7\u01e2\u01e7\u01ec\u01f1\u01fe") buf.write("\u0203\u020b\u0212\u0225\u0235\u024c\u024e\u0268\u027f") buf.write("\u0281\u029c\u02ad\u02af\u02b9\u02c0") 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'", "'implies'", "'iff'", "'xor'", "'[*]'", "'**'", "'>>'", "'<<'", "'<='", "'>='", "'=='", "'!='", "'&&'", "'||'", "'=>'", "':='", "'::'", "<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", "IMPLIES_KW", "IFF_KW", "XOR_KW", "INIT_MARKER", "POW", "SHIFT_RIGHT", "SHIFT_LEFT", "LE", "GE", "EQ", "NE", "LOGICAL_AND", "LOGICAL_OR", "IMPLIES", "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 IMPLIES_KW = 26 IFF_KW = 27 XOR_KW = 28 INIT_MARKER = 29 POW = 30 SHIFT_RIGHT = 31 SHIFT_LEFT = 32 LE = 33 GE = 34 EQ = 35 NE = 36 LOGICAL_AND = 37 LOGICAL_OR = 38 IMPLIES = 39 DECLARE_ASSIGN = 40 COLONCOLON = 41 ARROW = 42 SEMI = 43 COMMA = 44 LBRACE = 45 RBRACE = 46 LBRACK = 47 RBRACK = 48 LPAREN = 49 RPAREN = 50 QUESTION = 51 COLON = 52 DOT = 53 SLASH = 54 STAR = 55 BANG = 56 PLUS = 57 MINUS = 58 PERCENT = 59 AMP = 60 CARET = 61 PIPE = 62 LT = 63 GT = 64 ASSIGN = 65 FLOAT = 66 HEX_INT = 67 INT = 68 TRUE = 69 FALSE = 70 UFUNC_NAME = 71 ID = 72 STRING = 73 MULTILINE_COMMENT = 74 LINE_COMMENT = 75 PYTHON_COMMENT = 76 WS = 77 IMPORT_HEADER_WS = 78 IMPORT_HEADER_MULTILINE_COMMENT = 79 IMPORT_HEADER_LINE_COMMENT = 80 IMPORT_HEADER_PYTHON_COMMENT = 81 IMPORT_BLOCK_WS = 82 IMPORT_BLOCK_MULTILINE_COMMENT = 83 IMPORT_BLOCK_LINE_COMMENT = 84 IMPORT_BLOCK_PYTHON_COMMENT = 85 IMPORT_DEF_SELECTOR_WS = 86 IMPORT_DEF_SELECTOR_MULTILINE_COMMENT = 87 IMPORT_DEF_SELECTOR_LINE_COMMENT = 88 IMPORT_DEF_SELECTOR_PYTHON_COMMENT = 89 IMPORT_DEF_SELECTOR_PATTERN = 90 IMPORT_DEF_TARGET_WS = 91 IMPORT_DEF_TARGET_MULTILINE_COMMENT = 92 IMPORT_DEF_TARGET_LINE_COMMENT = 93 IMPORT_DEF_TARGET_PYTHON_COMMENT = 94 IMPORT_DEF_TARGET_TEMPLATE = 95
[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 IFF_KW(self): return self.getToken(GrammarParser.IFF_KW, 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 XOR_KW(self): return self.getToken(GrammarParser.XOR_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 IMPLIES(self): return self.getToken(GrammarParser.IMPLIES, 0) def IMPLIES_KW(self): return self.getToken(GrammarParser.IMPLIES_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(9) 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 - 33) & ~0x3F) == 0 and ( (1 << (_la - 33)) & ( (1 << (GrammarParser.LE - 33)) | (1 << (GrammarParser.GE - 33)) | (1 << (GrammarParser.LT - 33)) | (1 << (GrammarParser.GT - 33)) ) ) != 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 = 685 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 = 683 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, 6): from antlr4.error.Errors import FailedPredicateException raise FailedPredicateException( self, "self.precpred(self._ctx, 6)" ) self.state = 669 localctx.op = self._input.LT(1) _la = self._input.LA(1) if not ( ((_la) & ~0x3F) == 0 and ( (1 << _la) & ( (1 << GrammarParser.IFF_KW) | (1 << GrammarParser.EQ) | (1 << GrammarParser.NE) ) ) != 0 ): localctx.op = self._errHandler.recoverInline(self) else: self._errHandler.reportMatch(self) self.consume() self.state = 670 self.cond_expression(7) 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, 5): from antlr4.error.Errors import FailedPredicateException raise FailedPredicateException( self, "self.precpred(self._ctx, 5)" ) 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(6) 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, 4): from antlr4.error.Errors import FailedPredicateException raise FailedPredicateException( self, "self.precpred(self._ctx, 4)" ) self.state = 675 localctx.op = self.match(GrammarParser.XOR_KW) self.state = 676 self.cond_expression(5) pass elif la_ == 4: localctx = GrammarParser.BinaryExprCondContext( self, GrammarParser.Cond_expressionContext( self, _parentctx, _parentState ), ) self.pushNewRecursionContext( localctx, _startState, self.RULE_cond_expression ) self.state = 677 if not self.precpred(self._ctx, 3): from antlr4.error.Errors import FailedPredicateException raise FailedPredicateException( self, "self.precpred(self._ctx, 3)" ) self.state = 678 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 = 679 self.cond_expression(4) pass elif la_ == 5: localctx = GrammarParser.BinaryExprCondContext( self, GrammarParser.Cond_expressionContext( self, _parentctx, _parentState ), ) self.pushNewRecursionContext( localctx, _startState, self.RULE_cond_expression ) self.state = 680 if not self.precpred(self._ctx, 2): from antlr4.error.Errors import FailedPredicateException raise FailedPredicateException( self, "self.precpred(self._ctx, 2)" ) self.state = 681 localctx.op = self._input.LT(1) _la = self._input.LA(1) if not ( _la == GrammarParser.IMPLIES_KW or _la == GrammarParser.IMPLIES ): localctx.op = self._errHandler.recoverInline(self) else: self._errHandler.reportMatch(self) self.consume() self.state = 682 self.cond_expression(2) pass self.state = 687 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 = 688 _la = self._input.LA(1) if not ( ((_la - 66) & ~0x3F) == 0 and ( (1 << (_la - 66)) & ( (1 << (GrammarParser.FLOAT - 66)) | (1 << (GrammarParser.HEX_INT - 66)) | (1 << (GrammarParser.INT - 66)) ) ) != 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 = 690 _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 = 692 _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 = 695 self._errHandler.sync(self) _la = self._input.LA(1) if _la == GrammarParser.SLASH: self.state = 694 localctx.isabs = self.match(GrammarParser.SLASH) self.state = 697 self.match(GrammarParser.ID) self.state = 702 self._errHandler.sync(self) _la = self._input.LA(1) while _la == GrammarParser.DOT: self.state = 698 self.match(GrammarParser.DOT) self.state = 699 self.match(GrammarParser.ID) self.state = 704 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, 6) if predIndex == 15: return self.precpred(self._ctx, 5) if predIndex == 16: return self.precpred(self._ctx, 4) if predIndex == 17: return self.precpred(self._ctx, 3) if predIndex == 18: return self.precpred(self._ctx, 2)