
Python3.test.parser.cparser.py Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of antlr4-runtime-testsuite Show documentation
Show all versions of antlr4-runtime-testsuite Show documentation
A collection of tests for ANTLR 4 Runtime libraries.
# Generated from C.bnf by ANTLR 4.5.1
# encoding: utf-8
from antlr4 import *
from io import StringIO
def serializedATN():
with StringIO() as buf:
buf.write("\3\u0430\ud6d1\u8206\uad2d\u4417\uaef1\u8d80\uaadd\3s")
buf.write("\u04e9\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("&\4\'\t\'\4(\t(\4)\t)\4*\t*\4+\t+\4,\t,\4-\t-\4.\t.\4")
buf.write("/\t/\4\60\t\60\4\61\t\61\4\62\t\62\4\63\t\63\4\64\t\64")
buf.write("\4\65\t\65\4\66\t\66\4\67\t\67\48\t8\49\t9\4:\t:\4;\t")
buf.write(";\4<\t<\4=\t=\4>\t>\4?\t?\4@\t@\4A\tA\4B\tB\4C\tC\4D\t")
buf.write("D\4E\tE\4F\tF\4G\tG\4H\tH\4I\tI\4J\tJ\4K\tK\4L\tL\4M\t")
buf.write("M\4N\tN\4O\tO\4P\tP\4Q\tQ\4R\tR\4S\tS\4T\tT\4U\tU\3\2")
buf.write("\3\2\3\2\6\2\u00ae\n\2\r\2\16\2\u00af\3\2\3\2\3\2\3\2")
buf.write("\3\2\3\2\5\2\u00b8\n\2\3\2\3\2\3\2\3\2\3\2\3\2\3\2\3\2")
buf.write("\3\2\3\2\3\2\3\2\3\2\3\2\3\2\3\2\3\2\3\2\5\2\u00cc\n\2")
buf.write("\3\3\3\3\3\3\3\3\3\3\3\3\3\3\3\4\3\4\3\4\3\4\3\4\3\4\7")
buf.write("\4\u00db\n\4\f\4\16\4\u00de\13\4\3\5\3\5\3\5\3\5\3\5\3")
buf.write("\5\3\5\5\5\u00e7\n\5\3\6\3\6\3\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\3\6\3\6\3\6\3\6\3\6\3\6")
buf.write("\3\6\3\6\3\6\3\6\3\6\3\6\3\6\3\6\3\6\3\6\3\6\3\6\5\6\u010b")
buf.write("\n\6\3\6\3\6\3\6\3\6\3\6\3\6\3\6\3\6\5\6\u0115\n\6\3\6")
buf.write("\3\6\3\6\3\6\3\6\3\6\3\6\3\6\3\6\3\6\3\6\7\6\u0122\n\6")
buf.write("\f\6\16\6\u0125\13\6\3\7\3\7\3\7\3\7\3\7\3\7\7\7\u012d")
buf.write("\n\7\f\7\16\7\u0130\13\7\3\b\3\b\3\b\3\b\3\b\3\b\3\b\3")
buf.write("\b\3\b\3\b\3\b\3\b\3\b\3\b\3\b\3\b\3\b\3\b\3\b\3\b\3\b")
buf.write("\3\b\5\b\u0148\n\b\3\t\3\t\3\n\3\n\3\n\3\n\3\n\3\n\3\n")
buf.write("\3\n\3\n\3\n\3\n\3\n\5\n\u0158\n\n\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\7\13\u0166\n")
buf.write("\13\f\13\16\13\u0169\13\13\3\f\3\f\3\f\3\f\3\f\3\f\3\f")
buf.write("\3\f\3\f\7\f\u0174\n\f\f\f\16\f\u0177\13\f\3\r\3\r\3\r")
buf.write("\3\r\3\r\3\r\3\r\3\r\3\r\7\r\u0182\n\r\f\r\16\r\u0185")
buf.write("\13\r\3\16\3\16\3\16\3\16\3\16\3\16\3\16\3\16\3\16\3\16")
buf.write("\3\16\3\16\3\16\3\16\3\16\7\16\u0196\n\16\f\16\16\16\u0199")
buf.write("\13\16\3\17\3\17\3\17\3\17\3\17\3\17\3\17\3\17\3\17\7")
buf.write("\17\u01a4\n\17\f\17\16\17\u01a7\13\17\3\20\3\20\3\20\3")
buf.write("\20\3\20\3\20\7\20\u01af\n\20\f\20\16\20\u01b2\13\20\3")
buf.write("\21\3\21\3\21\3\21\3\21\3\21\7\21\u01ba\n\21\f\21\16\21")
buf.write("\u01bd\13\21\3\22\3\22\3\22\3\22\3\22\3\22\7\22\u01c5")
buf.write("\n\22\f\22\16\22\u01c8\13\22\3\23\3\23\3\23\3\23\3\23")
buf.write("\3\23\7\23\u01d0\n\23\f\23\16\23\u01d3\13\23\3\24\3\24")
buf.write("\3\24\3\24\3\24\3\24\7\24\u01db\n\24\f\24\16\24\u01de")
buf.write("\13\24\3\25\3\25\3\25\3\25\3\25\3\25\5\25\u01e6\n\25\3")
buf.write("\26\3\26\3\26\3\26\3\26\5\26\u01ed\n\26\3\27\3\27\3\30")
buf.write("\3\30\3\30\3\30\3\30\3\30\7\30\u01f7\n\30\f\30\16\30\u01fa")
buf.write("\13\30\3\31\3\31\3\32\3\32\5\32\u0200\n\32\3\32\3\32\3")
buf.write("\32\5\32\u0205\n\32\3\33\6\33\u0208\n\33\r\33\16\33\u0209")
buf.write("\3\34\6\34\u020d\n\34\r\34\16\34\u020e\3\35\3\35\3\35")
buf.write("\3\35\3\35\5\35\u0216\n\35\3\36\3\36\3\36\3\36\3\36\3")
buf.write("\36\7\36\u021e\n\36\f\36\16\36\u0221\13\36\3\37\3\37\3")
buf.write("\37\3\37\3\37\5\37\u0228\n\37\3 \3 \3!\3!\3!\3!\3!\3!")
buf.write("\3!\3!\3!\3!\3!\3!\3!\3!\5!\u023a\n!\3\"\3\"\5\"\u023e")
buf.write("\n\"\3\"\3\"\3\"\3\"\3\"\3\"\3\"\5\"\u0247\n\"\3#\3#\3")
buf.write("$\3$\3$\3$\3$\7$\u0250\n$\f$\16$\u0253\13$\3%\3%\5%\u0257")
buf.write("\n%\3%\3%\3%\5%\u025c\n%\3&\3&\5&\u0260\n&\3&\3&\5&\u0264")
buf.write("\n&\5&\u0266\n&\3\'\3\'\3\'\3\'\3\'\3\'\7\'\u026e\n\'")
buf.write("\f\'\16\'\u0271\13\'\3(\3(\5(\u0275\n(\3(\3(\5(\u0279")
buf.write("\n(\3)\3)\5)\u027d\n)\3)\3)\3)\3)\3)\3)\5)\u0285\n)\3")
buf.write(")\3)\3)\3)\3)\3)\3)\5)\u028e\n)\3*\3*\3*\3*\3*\3*\7*\u0296")
buf.write("\n*\f*\16*\u0299\13*\3+\3+\3+\3+\3+\5+\u02a0\n+\3,\3,")
buf.write("\3-\3-\3-\3-\3-\3.\3.\3/\3/\3/\3/\3/\3/\5/\u02b1\n/\3")
buf.write("\60\3\60\3\60\3\60\3\60\3\60\3\60\3\60\3\60\3\60\5\60")
buf.write("\u02bd\n\60\3\61\5\61\u02c0\n\61\3\61\3\61\7\61\u02c4")
buf.write("\n\61\f\61\16\61\u02c7\13\61\3\62\3\62\3\62\3\62\3\62")
buf.write("\3\62\5\62\u02cf\n\62\3\62\3\62\3\62\5\62\u02d4\n\62\3")
buf.write("\62\5\62\u02d7\n\62\3\62\3\62\3\62\3\62\3\62\5\62\u02de")
buf.write("\n\62\3\62\3\62\3\62\3\62\3\62\3\62\3\62\3\62\3\62\3\62")
buf.write("\3\62\3\62\3\62\5\62\u02ed\n\62\3\62\3\62\3\62\3\62\3")
buf.write("\62\3\62\3\62\3\62\3\62\3\62\5\62\u02f9\n\62\3\62\7\62")
buf.write("\u02fc\n\62\f\62\16\62\u02ff\13\62\3\63\3\63\3\63\6\63")
buf.write("\u0304\n\63\r\63\16\63\u0305\3\63\3\63\5\63\u030a\n\63")
buf.write("\3\64\3\64\3\64\3\64\3\64\3\64\3\64\3\65\3\65\3\65\7\65")
buf.write("\u0316\n\65\f\65\16\65\u0319\13\65\3\65\5\65\u031c\n\65")
buf.write("\3\66\3\66\3\66\5\66\u0321\n\66\3\66\5\66\u0324\n\66\3")
buf.write("\66\5\66\u0327\n\66\3\67\3\67\3\67\3\67\3\67\7\67\u032e")
buf.write("\n\67\f\67\16\67\u0331\13\67\38\38\58\u0335\n8\38\38\5")
buf.write("8\u0339\n8\38\38\38\58\u033e\n8\38\38\58\u0342\n8\38\5")
buf.write("8\u0345\n8\39\39\39\39\39\79\u034c\n9\f9\169\u034f\13")
buf.write("9\3:\3:\3:\3:\3:\5:\u0356\n:\3;\3;\3;\3;\3;\3;\7;\u035e")
buf.write("\n;\f;\16;\u0361\13;\3<\3<\3<\3<\3<\5<\u0368\n<\5<\u036a")
buf.write("\n<\3=\3=\3=\3=\3=\3=\7=\u0372\n=\f=\16=\u0375\13=\3>")
buf.write("\3>\5>\u0379\n>\3?\3?\5?\u037d\n?\3?\3?\7?\u0381\n?\f")
buf.write("?\16?\u0384\13?\5?\u0386\n?\3@\3@\3@\3@\3@\7@\u038d\n")
buf.write("@\f@\16@\u0390\13@\3@\3@\5@\u0394\n@\3@\5@\u0397\n@\3")
buf.write("@\3@\3@\3@\5@\u039d\n@\3@\3@\3@\3@\3@\3@\3@\3@\3@\3@\3")
buf.write("@\3@\3@\3@\5@\u03ad\n@\3@\3@\7@\u03b1\n@\f@\16@\u03b4")
buf.write("\13@\5@\u03b6\n@\3@\3@\3@\5@\u03bb\n@\3@\5@\u03be\n@\3")
buf.write("@\3@\3@\3@\3@\5@\u03c5\n@\3@\3@\3@\3@\3@\3@\3@\3@\3@\3")
buf.write("@\3@\3@\3@\3@\3@\3@\3@\5@\u03d8\n@\3@\3@\7@\u03dc\n@\f")
buf.write("@\16@\u03df\13@\7@\u03e1\n@\f@\16@\u03e4\13@\3A\3A\3B")
buf.write("\3B\3B\3B\3B\3B\3B\3B\3B\3B\5B\u03f2\nB\3C\3C\5C\u03f6")
buf.write("\nC\3C\3C\3C\3C\3C\5C\u03fd\nC\3C\7C\u0400\nC\fC\16C\u0403")
buf.write("\13C\3D\3D\3D\3E\3E\3E\3E\3E\7E\u040d\nE\fE\16E\u0410")
buf.write("\13E\3F\3F\3F\3F\3F\3F\5F\u0418\nF\3G\3G\3G\3G\3G\6G\u041f")
buf.write("\nG\rG\16G\u0420\3G\3G\3G\3H\3H\3H\3H\3H\3H\3H\3H\3H\3")
buf.write("H\3H\3H\7H\u0432\nH\fH\16H\u0435\13H\5H\u0437\nH\3H\3")
buf.write("H\3H\3H\7H\u043d\nH\fH\16H\u0440\13H\5H\u0442\nH\7H\u0444")
buf.write("\nH\fH\16H\u0447\13H\3H\3H\5H\u044b\nH\3I\3I\3I\3I\3I")
buf.write("\3I\3I\3I\3I\3I\3I\5I\u0458\nI\3J\3J\5J\u045c\nJ\3J\3")
buf.write("J\3K\3K\3K\3K\3K\7K\u0465\nK\fK\16K\u0468\13K\3L\3L\5")
buf.write("L\u046c\nL\3M\5M\u046f\nM\3M\3M\3N\3N\3N\3N\3N\3N\3N\5")
buf.write("N\u047a\nN\3N\3N\3N\3N\3N\3N\5N\u0482\nN\3O\3O\3O\3O\3")
buf.write("O\3O\3O\3O\3O\3O\3O\3O\3O\3O\3O\3O\3O\5O\u0495\nO\3O\3")
buf.write("O\5O\u0499\nO\3O\3O\5O\u049d\nO\3O\3O\3O\3O\3O\3O\5O\u04a5")
buf.write("\nO\3O\3O\5O\u04a9\nO\3O\3O\3O\5O\u04ae\nO\3P\3P\3P\3")
buf.write("P\3P\3P\3P\3P\3P\5P\u04b9\nP\3P\3P\3P\3P\3P\5P\u04c0\n")
buf.write("P\3Q\5Q\u04c3\nQ\3Q\3Q\3R\3R\3R\3R\3R\7R\u04cc\nR\fR\16")
buf.write("R\u04cf\13R\3S\3S\3S\5S\u04d4\nS\3T\5T\u04d7\nT\3T\3T")
buf.write("\5T\u04db\nT\3T\3T\3U\3U\3U\3U\3U\7U\u04e4\nU\fU\16U\u04e7")
buf.write("\13U\3U\2\36\6\n\f\24\26\30\32\34\36 \"$&.:FLRbptx~\u0084")
buf.write("\u0088\u0094\u00a2\u00a8V\2\4\6\b\n\f\16\20\22\24\26\30")
buf.write("\32\34\36 \"$&(*,.\60\62\64\668:<>@BDFHJLNPRTVXZ\\^`b")
buf.write("dfhjlnprtvxz|~\u0080\u0082\u0084\u0086\u0088\u008a\u008c")
buf.write("\u008e\u0090\u0092\u0094\u0096\u0098\u009a\u009c\u009e")
buf.write("\u00a0\u00a2\u00a4\u00a6\u00a8\2\16\7\2IIKKMMPPUV\3\2")
buf.write("[e\b\2\21\21\34\34$$**--<<\n\2\6\b\24\24\31\31\35\35\"")
buf.write("#\'(/\60\66\67\3\2\6\b\4\2++..\6\2\25\25%%\61\61\65\65")
buf.write("\5\2\n\13!!::\4\2=>ZZ\3\2=>\4\2\r\r\17\17\4\2\20\20\61")
buf.write("\61\u0559\2\u00cb\3\2\2\2\4\u00cd\3\2\2\2\6\u00d4\3\2")
buf.write("\2\2\b\u00e6\3\2\2\2\n\u010a\3\2\2\2\f\u0126\3\2\2\2\16")
buf.write("\u0147\3\2\2\2\20\u0149\3\2\2\2\22\u0157\3\2\2\2\24\u0159")
buf.write("\3\2\2\2\26\u016a\3\2\2\2\30\u0178\3\2\2\2\32\u0186\3")
buf.write("\2\2\2\34\u019a\3\2\2\2\36\u01a8\3\2\2\2 \u01b3\3\2\2")
buf.write("\2\"\u01be\3\2\2\2$\u01c9\3\2\2\2&\u01d4\3\2\2\2(\u01df")
buf.write("\3\2\2\2*\u01ec\3\2\2\2,\u01ee\3\2\2\2.\u01f0\3\2\2\2")
buf.write("\60\u01fb\3\2\2\2\62\u0204\3\2\2\2\64\u0207\3\2\2\2\66")
buf.write("\u020c\3\2\2\28\u0215\3\2\2\2:\u0217\3\2\2\2<\u0227\3")
buf.write("\2\2\2>\u0229\3\2\2\2@\u0239\3\2\2\2B\u0246\3\2\2\2D\u0248")
buf.write("\3\2\2\2F\u024a\3\2\2\2H\u025b\3\2\2\2J\u0265\3\2\2\2")
buf.write("L\u0267\3\2\2\2N\u0278\3\2\2\2P\u028d\3\2\2\2R\u028f\3")
buf.write("\2\2\2T\u029f\3\2\2\2V\u02a1\3\2\2\2X\u02a3\3\2\2\2Z\u02a8")
buf.write("\3\2\2\2\\\u02b0\3\2\2\2^\u02bc\3\2\2\2`\u02bf\3\2\2\2")
buf.write("b\u02ce\3\2\2\2d\u0309\3\2\2\2f\u030b\3\2\2\2h\u031b\3")
buf.write("\2\2\2j\u0326\3\2\2\2l\u032f\3\2\2\2n\u0344\3\2\2\2p\u0346")
buf.write("\3\2\2\2r\u0355\3\2\2\2t\u0357\3\2\2\2v\u0369\3\2\2\2")
buf.write("x\u036b\3\2\2\2z\u0376\3\2\2\2|\u0385\3\2\2\2~\u03b5\3")
buf.write("\2\2\2\u0080\u03e5\3\2\2\2\u0082\u03f1\3\2\2\2\u0084\u03f3")
buf.write("\3\2\2\2\u0086\u0404\3\2\2\2\u0088\u0407\3\2\2\2\u008a")
buf.write("\u0417\3\2\2\2\u008c\u0419\3\2\2\2\u008e\u044a\3\2\2\2")
buf.write("\u0090\u0457\3\2\2\2\u0092\u0459\3\2\2\2\u0094\u045f\3")
buf.write("\2\2\2\u0096\u046b\3\2\2\2\u0098\u046e\3\2\2\2\u009a\u0481")
buf.write("\3\2\2\2\u009c\u04ad\3\2\2\2\u009e\u04bf\3\2\2\2\u00a0")
buf.write("\u04c2\3\2\2\2\u00a2\u04c6\3\2\2\2\u00a4\u04d3\3\2\2\2")
buf.write("\u00a6\u04d6\3\2\2\2\u00a8\u04de\3\2\2\2\u00aa\u00cc\7")
buf.write("k\2\2\u00ab\u00cc\7l\2\2\u00ac\u00ae\7m\2\2\u00ad\u00ac")
buf.write("\3\2\2\2\u00ae\u00af\3\2\2\2\u00af\u00ad\3\2\2\2\u00af")
buf.write("\u00b0\3\2\2\2\u00b0\u00cc\3\2\2\2\u00b1\u00b2\7=\2\2")
buf.write("\u00b2\u00b3\5.\30\2\u00b3\u00b4\7>\2\2\u00b4\u00cc\3")
buf.write("\2\2\2\u00b5\u00cc\5\4\3\2\u00b6\u00b8\7\3\2\2\u00b7\u00b6")
buf.write("\3\2\2\2\u00b7\u00b8\3\2\2\2\u00b8\u00b9\3\2\2\2\u00b9")
buf.write("\u00ba\7=\2\2\u00ba\u00bb\5\u0092J\2\u00bb\u00bc\7>\2")
buf.write("\2\u00bc\u00cc\3\2\2\2\u00bd\u00be\7\4\2\2\u00be\u00bf")
buf.write("\7=\2\2\u00bf\u00c0\5\16\b\2\u00c0\u00c1\7Z\2\2\u00c1")
buf.write("\u00c2\5z>\2\u00c2\u00c3\7>\2\2\u00c3\u00cc\3\2\2\2\u00c4")
buf.write("\u00c5\7\5\2\2\u00c5\u00c6\7=\2\2\u00c6\u00c7\5z>\2\u00c7")
buf.write("\u00c8\7Z\2\2\u00c8\u00c9\5\16\b\2\u00c9\u00ca\7>\2\2")
buf.write("\u00ca\u00cc\3\2\2\2\u00cb\u00aa\3\2\2\2\u00cb\u00ab\3")
buf.write("\2\2\2\u00cb\u00ad\3\2\2\2\u00cb\u00b1\3\2\2\2\u00cb\u00b5")
buf.write("\3\2\2\2\u00cb\u00b7\3\2\2\2\u00cb\u00bd\3\2\2\2\u00cb")
buf.write("\u00c4\3\2\2\2\u00cc\3\3\2\2\2\u00cd\u00ce\78\2\2\u00ce")
buf.write("\u00cf\7=\2\2\u00cf\u00d0\5*\26\2\u00d0\u00d1\7Z\2\2\u00d1")
buf.write("\u00d2\5\6\4\2\u00d2\u00d3\7>\2\2\u00d3\5\3\2\2\2\u00d4")
buf.write("\u00d5\b\4\1\2\u00d5\u00d6\5\b\5\2\u00d6\u00dc\3\2\2\2")
buf.write("\u00d7\u00d8\f\3\2\2\u00d8\u00d9\7Z\2\2\u00d9\u00db\5")
buf.write("\b\5\2\u00da\u00d7\3\2\2\2\u00db\u00de\3\2\2\2\u00dc\u00da")
buf.write("\3\2\2\2\u00dc\u00dd\3\2\2\2\u00dd\7\3\2\2\2\u00de\u00dc")
buf.write("\3\2\2\2\u00df\u00e0\5z>\2\u00e0\u00e1\7X\2\2\u00e1\u00e2")
buf.write("\5*\26\2\u00e2\u00e7\3\2\2\2\u00e3\u00e4\7\27\2\2\u00e4")
buf.write("\u00e5\7X\2\2\u00e5\u00e7\5*\26\2\u00e6\u00df\3\2\2\2")
buf.write("\u00e6\u00e3\3\2\2\2\u00e7\t\3\2\2\2\u00e8\u00e9\b\6\1")
buf.write("\2\u00e9\u010b\5\2\2\2\u00ea\u00eb\7=\2\2\u00eb\u00ec")
buf.write("\5z>\2\u00ec\u00ed\7>\2\2\u00ed\u00ee\7A\2\2\u00ee\u00ef")
buf.write("\5\u0084C\2\u00ef\u00f0\7B\2\2\u00f0\u010b\3\2\2\2\u00f1")
buf.write("\u00f2\7=\2\2\u00f2\u00f3\5z>\2\u00f3\u00f4\7>\2\2\u00f4")
buf.write("\u00f5\7A\2\2\u00f5\u00f6\5\u0084C\2\u00f6\u00f7\7Z\2")
buf.write("\2\u00f7\u00f8\7B\2\2\u00f8\u010b\3\2\2\2\u00f9\u00fa")
buf.write("\7\3\2\2\u00fa\u00fb\7=\2\2\u00fb\u00fc\5z>\2\u00fc\u00fd")
buf.write("\7>\2\2\u00fd\u00fe\7A\2\2\u00fe\u00ff\5\u0084C\2\u00ff")
buf.write("\u0100\7B\2\2\u0100\u010b\3\2\2\2\u0101\u0102\7\3\2\2")
buf.write("\u0102\u0103\7=\2\2\u0103\u0104\5z>\2\u0104\u0105\7>\2")
buf.write("\2\u0105\u0106\7A\2\2\u0106\u0107\5\u0084C\2\u0107\u0108")
buf.write("\7Z\2\2\u0108\u0109\7B\2\2\u0109\u010b\3\2\2\2\u010a\u00e8")
buf.write("\3\2\2\2\u010a\u00ea\3\2\2\2\u010a\u00f1\3\2\2\2\u010a")
buf.write("\u00f9\3\2\2\2\u010a\u0101\3\2\2\2\u010b\u0123\3\2\2\2")
buf.write("\u010c\u010d\f\f\2\2\u010d\u010e\7?\2\2\u010e\u010f\5")
buf.write(".\30\2\u010f\u0110\7@\2\2\u0110\u0122\3\2\2\2\u0111\u0112")
buf.write("\f\13\2\2\u0112\u0114\7=\2\2\u0113\u0115\5\f\7\2\u0114")
buf.write("\u0113\3\2\2\2\u0114\u0115\3\2\2\2\u0115\u0116\3\2\2\2")
buf.write("\u0116\u0122\7>\2\2\u0117\u0118\f\n\2\2\u0118\u0119\7")
buf.write("i\2\2\u0119\u0122\7k\2\2\u011a\u011b\f\t\2\2\u011b\u011c")
buf.write("\7h\2\2\u011c\u0122\7k\2\2\u011d\u011e\f\b\2\2\u011e\u0122")
buf.write("\7J\2\2\u011f\u0120\f\7\2\2\u0120\u0122\7L\2\2\u0121\u010c")
buf.write("\3\2\2\2\u0121\u0111\3\2\2\2\u0121\u0117\3\2\2\2\u0121")
buf.write("\u011a\3\2\2\2\u0121\u011d\3\2\2\2\u0121\u011f\3\2\2\2")
buf.write("\u0122\u0125\3\2\2\2\u0123\u0121\3\2\2\2\u0123\u0124\3")
buf.write("\2\2\2\u0124\13\3\2\2\2\u0125\u0123\3\2\2\2\u0126\u0127")
buf.write("\b\7\1\2\u0127\u0128\5*\26\2\u0128\u012e\3\2\2\2\u0129")
buf.write("\u012a\f\3\2\2\u012a\u012b\7Z\2\2\u012b\u012d\5*\26\2")
buf.write("\u012c\u0129\3\2\2\2\u012d\u0130\3\2\2\2\u012e\u012c\3")
buf.write("\2\2\2\u012e\u012f\3\2\2\2\u012f\r\3\2\2\2\u0130\u012e")
buf.write("\3\2\2\2\u0131\u0148\5\n\6\2\u0132\u0133\7J\2\2\u0133")
buf.write("\u0148\5\16\b\2\u0134\u0135\7L\2\2\u0135\u0148\5\16\b")
buf.write("\2\u0136\u0137\5\20\t\2\u0137\u0138\5\22\n\2\u0138\u0148")
buf.write("\3\2\2\2\u0139\u013a\7)\2\2\u013a\u0148\5\16\b\2\u013b")
buf.write("\u013c\7)\2\2\u013c\u013d\7=\2\2\u013d\u013e\5z>\2\u013e")
buf.write("\u013f\7>\2\2\u013f\u0148\3\2\2\2\u0140\u0141\7\64\2\2")
buf.write("\u0141\u0142\7=\2\2\u0142\u0143\5z>\2\u0143\u0144\7>\2")
buf.write("\2\u0144\u0148\3\2\2\2\u0145\u0146\7R\2\2\u0146\u0148")
buf.write("\7k\2\2\u0147\u0131\3\2\2\2\u0147\u0132\3\2\2\2\u0147")
buf.write("\u0134\3\2\2\2\u0147\u0136\3\2\2\2\u0147\u0139\3\2\2\2")
buf.write("\u0147\u013b\3\2\2\2\u0147\u0140\3\2\2\2\u0147\u0145\3")
buf.write("\2\2\2\u0148\17\3\2\2\2\u0149\u014a\t\2\2\2\u014a\21\3")
buf.write("\2\2\2\u014b\u0158\5\16\b\2\u014c\u014d\7=\2\2\u014d\u014e")
buf.write("\5z>\2\u014e\u014f\7>\2\2\u014f\u0150\5\22\n\2\u0150\u0158")
buf.write("\3\2\2\2\u0151\u0152\7\3\2\2\u0152\u0153\7=\2\2\u0153")
buf.write("\u0154\5z>\2\u0154\u0155\7>\2\2\u0155\u0156\5\22\n\2\u0156")
buf.write("\u0158\3\2\2\2\u0157\u014b\3\2\2\2\u0157\u014c\3\2\2\2")
buf.write("\u0157\u0151\3\2\2\2\u0158\23\3\2\2\2\u0159\u015a\b\13")
buf.write("\1\2\u015a\u015b\5\22\n\2\u015b\u0167\3\2\2\2\u015c\u015d")
buf.write("\f\5\2\2\u015d\u015e\7M\2\2\u015e\u0166\5\22\n\2\u015f")
buf.write("\u0160\f\4\2\2\u0160\u0161\7N\2\2\u0161\u0166\5\22\n\2")
buf.write("\u0162\u0163\f\3\2\2\u0163\u0164\7O\2\2\u0164\u0166\5")
buf.write("\22\n\2\u0165\u015c\3\2\2\2\u0165\u015f\3\2\2\2\u0165")
buf.write("\u0162\3\2\2\2\u0166\u0169\3\2\2\2\u0167\u0165\3\2\2\2")
buf.write("\u0167\u0168\3\2\2\2\u0168\25\3\2\2\2\u0169\u0167\3\2")
buf.write("\2\2\u016a\u016b\b\f\1\2\u016b\u016c\5\24\13\2\u016c\u0175")
buf.write("\3\2\2\2\u016d\u016e\f\4\2\2\u016e\u016f\7I\2\2\u016f")
buf.write("\u0174\5\24\13\2\u0170\u0171\f\3\2\2\u0171\u0172\7K\2")
buf.write("\2\u0172\u0174\5\24\13\2\u0173\u016d\3\2\2\2\u0173\u0170")
buf.write("\3\2\2\2\u0174\u0177\3\2\2\2\u0175\u0173\3\2\2\2\u0175")
buf.write("\u0176\3\2\2\2\u0176\27\3\2\2\2\u0177\u0175\3\2\2\2\u0178")
buf.write("\u0179\b\r\1\2\u0179\u017a\5\26\f\2\u017a\u0183\3\2\2")
buf.write("\2\u017b\u017c\f\4\2\2\u017c\u017d\7G\2\2\u017d\u0182")
buf.write("\5\26\f\2\u017e\u017f\f\3\2\2\u017f\u0180\7H\2\2\u0180")
buf.write("\u0182\5\26\f\2\u0181\u017b\3\2\2\2\u0181\u017e\3\2\2")
buf.write("\2\u0182\u0185\3\2\2\2\u0183\u0181\3\2\2\2\u0183\u0184")
buf.write("\3\2\2\2\u0184\31\3\2\2\2\u0185\u0183\3\2\2\2\u0186\u0187")
buf.write("\b\16\1\2\u0187\u0188\5\30\r\2\u0188\u0197\3\2\2\2\u0189")
buf.write("\u018a\f\6\2\2\u018a\u018b\7C\2\2\u018b\u0196\5\30\r\2")
buf.write("\u018c\u018d\f\5\2\2\u018d\u018e\7E\2\2\u018e\u0196\5")
buf.write("\30\r\2\u018f\u0190\f\4\2\2\u0190\u0191\7D\2\2\u0191\u0196")
buf.write("\5\30\r\2\u0192\u0193\f\3\2\2\u0193\u0194\7F\2\2\u0194")
buf.write("\u0196\5\30\r\2\u0195\u0189\3\2\2\2\u0195\u018c\3\2\2")
buf.write("\2\u0195\u018f\3\2\2\2\u0195\u0192\3\2\2\2\u0196\u0199")
buf.write("\3\2\2\2\u0197\u0195\3\2\2\2\u0197\u0198\3\2\2\2\u0198")
buf.write("\33\3\2\2\2\u0199\u0197\3\2\2\2\u019a\u019b\b\17\1\2\u019b")
buf.write("\u019c\5\32\16\2\u019c\u01a5\3\2\2\2\u019d\u019e\f\4\2")
buf.write("\2\u019e\u019f\7f\2\2\u019f\u01a4\5\32\16\2\u01a0\u01a1")
buf.write("\f\3\2\2\u01a1\u01a2\7g\2\2\u01a2\u01a4\5\32\16\2\u01a3")
buf.write("\u019d\3\2\2\2\u01a3\u01a0\3\2\2\2\u01a4\u01a7\3\2\2\2")
buf.write("\u01a5\u01a3\3\2\2\2\u01a5\u01a6\3\2\2\2\u01a6\35\3\2")
buf.write("\2\2\u01a7\u01a5\3\2\2\2\u01a8\u01a9\b\20\1\2\u01a9\u01aa")
buf.write("\5\34\17\2\u01aa\u01b0\3\2\2\2\u01ab\u01ac\f\3\2\2\u01ac")
buf.write("\u01ad\7P\2\2\u01ad\u01af\5\34\17\2\u01ae\u01ab\3\2\2")
buf.write("\2\u01af\u01b2\3\2\2\2\u01b0\u01ae\3\2\2\2\u01b0\u01b1")
buf.write("\3\2\2\2\u01b1\37\3\2\2\2\u01b2\u01b0\3\2\2\2\u01b3\u01b4")
buf.write("\b\21\1\2\u01b4\u01b5\5\36\20\2\u01b5\u01bb\3\2\2\2\u01b6")
buf.write("\u01b7\f\3\2\2\u01b7\u01b8\7T\2\2\u01b8\u01ba\5\36\20")
buf.write("\2\u01b9\u01b6\3\2\2\2\u01ba\u01bd\3\2\2\2\u01bb\u01b9")
buf.write("\3\2\2\2\u01bb\u01bc\3\2\2\2\u01bc!\3\2\2\2\u01bd\u01bb")
buf.write("\3\2\2\2\u01be\u01bf\b\22\1\2\u01bf\u01c0\5 \21\2\u01c0")
buf.write("\u01c6\3\2\2\2\u01c1\u01c2\f\3\2\2\u01c2\u01c3\7Q\2\2")
buf.write("\u01c3\u01c5\5 \21\2\u01c4\u01c1\3\2\2\2\u01c5\u01c8\3")
buf.write("\2\2\2\u01c6\u01c4\3\2\2\2\u01c6\u01c7\3\2\2\2\u01c7#")
buf.write("\3\2\2\2\u01c8\u01c6\3\2\2\2\u01c9\u01ca\b\23\1\2\u01ca")
buf.write("\u01cb\5\"\22\2\u01cb\u01d1\3\2\2\2\u01cc\u01cd\f\3\2")
buf.write("\2\u01cd\u01ce\7R\2\2\u01ce\u01d0\5\"\22\2\u01cf\u01cc")
buf.write("\3\2\2\2\u01d0\u01d3\3\2\2\2\u01d1\u01cf\3\2\2\2\u01d1")
buf.write("\u01d2\3\2\2\2\u01d2%\3\2\2\2\u01d3\u01d1\3\2\2\2\u01d4")
buf.write("\u01d5\b\24\1\2\u01d5\u01d6\5$\23\2\u01d6\u01dc\3\2\2")
buf.write("\2\u01d7\u01d8\f\3\2\2\u01d8\u01d9\7S\2\2\u01d9\u01db")
buf.write("\5$\23\2\u01da\u01d7\3\2\2\2\u01db\u01de\3\2\2\2\u01dc")
buf.write("\u01da\3\2\2\2\u01dc\u01dd\3\2\2\2\u01dd\'\3\2\2\2\u01de")
buf.write("\u01dc\3\2\2\2\u01df\u01e5\5&\24\2\u01e0\u01e1\7W\2\2")
buf.write("\u01e1\u01e2\5.\30\2\u01e2\u01e3\7X\2\2\u01e3\u01e4\5")
buf.write("(\25\2\u01e4\u01e6\3\2\2\2\u01e5\u01e0\3\2\2\2\u01e5\u01e6")
buf.write("\3\2\2\2\u01e6)\3\2\2\2\u01e7\u01ed\5(\25\2\u01e8\u01e9")
buf.write("\5\16\b\2\u01e9\u01ea\5,\27\2\u01ea\u01eb\5*\26\2\u01eb")
buf.write("\u01ed\3\2\2\2\u01ec\u01e7\3\2\2\2\u01ec\u01e8\3\2\2\2")
buf.write("\u01ed+\3\2\2\2\u01ee\u01ef\t\3\2\2\u01ef-\3\2\2\2\u01f0")
buf.write("\u01f1\b\30\1\2\u01f1\u01f2\5*\26\2\u01f2\u01f8\3\2\2")
buf.write("\2\u01f3\u01f4\f\3\2\2\u01f4\u01f5\7Z\2\2\u01f5\u01f7")
buf.write("\5*\26\2\u01f6\u01f3\3\2\2\2\u01f7\u01fa\3\2\2\2\u01f8")
buf.write("\u01f6\3\2\2\2\u01f8\u01f9\3\2\2\2\u01f9/\3\2\2\2\u01fa")
buf.write("\u01f8\3\2\2\2\u01fb\u01fc\5(\25\2\u01fc\61\3\2\2\2\u01fd")
buf.write("\u01ff\5\64\33\2\u01fe\u0200\5:\36\2\u01ff\u01fe\3\2\2")
buf.write("\2\u01ff\u0200\3\2\2\2\u0200\u0201\3\2\2\2\u0201\u0202")
buf.write("\7Y\2\2\u0202\u0205\3\2\2\2\u0203\u0205\5\u008cG\2\u0204")
buf.write("\u01fd\3\2\2\2\u0204\u0203\3\2\2\2\u0205\63\3\2\2\2\u0206")
buf.write("\u0208\58\35\2\u0207\u0206\3\2\2\2\u0208\u0209\3\2\2\2")
buf.write("\u0209\u0207\3\2\2\2\u0209\u020a\3\2\2\2\u020a\65\3\2")
buf.write("\2\2\u020b\u020d\58\35\2\u020c\u020b\3\2\2\2\u020d\u020e")
buf.write("\3\2\2\2\u020e\u020c\3\2\2\2\u020e\u020f\3\2\2\2\u020f")
buf.write("\67\3\2\2\2\u0210\u0216\5> \2\u0211\u0216\5@!\2\u0212")
buf.write("\u0216\5Z.\2\u0213\u0216\5\\/\2\u0214\u0216\5^\60\2\u0215")
buf.write("\u0210\3\2\2\2\u0215\u0211\3\2\2\2\u0215\u0212\3\2\2\2")
buf.write("\u0215\u0213\3\2\2\2\u0215\u0214\3\2\2\2\u02169\3\2\2")
buf.write("\2\u0217\u0218\b\36\1\2\u0218\u0219\5<\37\2\u0219\u021f")
buf.write("\3\2\2\2\u021a\u021b\f\3\2\2\u021b\u021c\7Z\2\2\u021c")
buf.write("\u021e\5<\37\2\u021d\u021a\3\2\2\2\u021e\u0221\3\2\2\2")
buf.write("\u021f\u021d\3\2\2\2\u021f\u0220\3\2\2\2\u0220;\3\2\2")
buf.write("\2\u0221\u021f\3\2\2\2\u0222\u0228\5`\61\2\u0223\u0224")
buf.write("\5`\61\2\u0224\u0225\7[\2\2\u0225\u0226\5\u0082B\2\u0226")
buf.write("\u0228\3\2\2\2\u0227\u0222\3\2\2\2\u0227\u0223\3\2\2\2")
buf.write("\u0228=\3\2\2\2\u0229\u022a\t\4\2\2\u022a?\3\2\2\2\u022b")
buf.write("\u023a\t\5\2\2\u022c\u022d\7\3\2\2\u022d\u022e\7=\2\2")
buf.write("\u022e\u022f\t\6\2\2\u022f\u023a\7>\2\2\u0230\u023a\5")
buf.write("X-\2\u0231\u023a\5B\"\2\u0232\u023a\5P)\2\u0233\u023a")
buf.write("\5\u0080A\2\u0234\u0235\7\t\2\2\u0235\u0236\7=\2\2\u0236")
buf.write("\u0237\5\60\31\2\u0237\u0238\7>\2\2\u0238\u023a\3\2\2")
buf.write("\2\u0239\u022b\3\2\2\2\u0239\u022c\3\2\2\2\u0239\u0230")
buf.write("\3\2\2\2\u0239\u0231\3\2\2\2\u0239\u0232\3\2\2\2\u0239")
buf.write("\u0233\3\2\2\2\u0239\u0234\3\2\2\2\u023aA\3\2\2\2\u023b")
buf.write("\u023d\5D#\2\u023c\u023e\7k\2\2\u023d\u023c\3\2\2\2\u023d")
buf.write("\u023e\3\2\2\2\u023e\u023f\3\2\2\2\u023f\u0240\7A\2\2")
buf.write("\u0240\u0241\5F$\2\u0241\u0242\7B\2\2\u0242\u0247\3\2")
buf.write("\2\2\u0243\u0244\5D#\2\u0244\u0245\7k\2\2\u0245\u0247")
buf.write("\3\2\2\2\u0246\u023b\3\2\2\2\u0246\u0243\3\2\2\2\u0247")
buf.write("C\3\2\2\2\u0248\u0249\t\7\2\2\u0249E\3\2\2\2\u024a\u024b")
buf.write("\b$\1\2\u024b\u024c\5H%\2\u024c\u0251\3\2\2\2\u024d\u024e")
buf.write("\f\3\2\2\u024e\u0250\5H%\2\u024f\u024d\3\2\2\2\u0250\u0253")
buf.write("\3\2\2\2\u0251\u024f\3\2\2\2\u0251\u0252\3\2\2\2\u0252")
buf.write("G\3\2\2\2\u0253\u0251\3\2\2\2\u0254\u0256\5J&\2\u0255")
buf.write("\u0257\5L\'\2\u0256\u0255\3\2\2\2\u0256\u0257\3\2\2\2")
buf.write("\u0257\u0258\3\2\2\2\u0258\u0259\7Y\2\2\u0259\u025c\3")
buf.write("\2\2\2\u025a\u025c\5\u008cG\2\u025b\u0254\3\2\2\2\u025b")
buf.write("\u025a\3\2\2\2\u025cI\3\2\2\2\u025d\u025f\5@!\2\u025e")
buf.write("\u0260\5J&\2\u025f\u025e\3\2\2\2\u025f\u0260\3\2\2\2\u0260")
buf.write("\u0266\3\2\2\2\u0261\u0263\5Z.\2\u0262\u0264\5J&\2\u0263")
buf.write("\u0262\3\2\2\2\u0263\u0264\3\2\2\2\u0264\u0266\3\2\2\2")
buf.write("\u0265\u025d\3\2\2\2\u0265\u0261\3\2\2\2\u0266K\3\2\2")
buf.write("\2\u0267\u0268\b\'\1\2\u0268\u0269\5N(\2\u0269\u026f\3")
buf.write("\2\2\2\u026a\u026b\f\3\2\2\u026b\u026c\7Z\2\2\u026c\u026e")
buf.write("\5N(\2\u026d\u026a\3\2\2\2\u026e\u0271\3\2\2\2\u026f\u026d")
buf.write("\3\2\2\2\u026f\u0270\3\2\2\2\u0270M\3\2\2\2\u0271\u026f")
buf.write("\3\2\2\2\u0272\u0279\5`\61\2\u0273\u0275\5`\61\2\u0274")
buf.write("\u0273\3\2\2\2\u0274\u0275\3\2\2\2\u0275\u0276\3\2\2\2")
buf.write("\u0276\u0277\7X\2\2\u0277\u0279\5\60\31\2\u0278\u0272")
buf.write("\3\2\2\2\u0278\u0274\3\2\2\2\u0279O\3\2\2\2\u027a\u027c")
buf.write("\7\33\2\2\u027b\u027d\7k\2\2\u027c\u027b\3\2\2\2\u027c")
buf.write("\u027d\3\2\2\2\u027d\u027e\3\2\2\2\u027e\u027f\7A\2\2")
buf.write("\u027f\u0280\5R*\2\u0280\u0281\7B\2\2\u0281\u028e\3\2")
buf.write("\2\2\u0282\u0284\7\33\2\2\u0283\u0285\7k\2\2\u0284\u0283")
buf.write("\3\2\2\2\u0284\u0285\3\2\2\2\u0285\u0286\3\2\2\2\u0286")
buf.write("\u0287\7A\2\2\u0287\u0288\5R*\2\u0288\u0289\7Z\2\2\u0289")
buf.write("\u028a\7B\2\2\u028a\u028e\3\2\2\2\u028b\u028c\7\33\2\2")
buf.write("\u028c\u028e\7k\2\2\u028d\u027a\3\2\2\2\u028d\u0282\3")
buf.write("\2\2\2\u028d\u028b\3\2\2\2\u028eQ\3\2\2\2\u028f\u0290")
buf.write("\b*\1\2\u0290\u0291\5T+\2\u0291\u0297\3\2\2\2\u0292\u0293")
buf.write("\f\3\2\2\u0293\u0294\7Z\2\2\u0294\u0296\5T+\2\u0295\u0292")
buf.write("\3\2\2\2\u0296\u0299\3\2\2\2\u0297\u0295\3\2\2\2\u0297")
buf.write("\u0298\3\2\2\2\u0298S\3\2\2\2\u0299\u0297\3\2\2\2\u029a")
buf.write("\u02a0\5V,\2\u029b\u029c\5V,\2\u029c\u029d\7[\2\2\u029d")
buf.write("\u029e\5\60\31\2\u029e\u02a0\3\2\2\2\u029f\u029a\3\2\2")
buf.write("\2\u029f\u029b\3\2\2\2\u02a0U\3\2\2\2\u02a1\u02a2\7k\2")
buf.write("\2\u02a2W\3\2\2\2\u02a3\u02a4\7\65\2\2\u02a4\u02a5\7=")
buf.write("\2\2\u02a5\u02a6\5z>\2\u02a6\u02a7\7>\2\2\u02a7Y\3\2\2")
buf.write("\2\u02a8\u02a9\t\b\2\2\u02a9[\3\2\2\2\u02aa\u02b1\t\t")
buf.write("\2\2\u02ab\u02b1\5f\64\2\u02ac\u02ad\7\f\2\2\u02ad\u02ae")
buf.write("\7=\2\2\u02ae\u02af\7k\2\2\u02af\u02b1\7>\2\2\u02b0\u02aa")
buf.write("\3\2\2\2\u02b0\u02ab\3\2\2\2\u02b0\u02ac\3\2\2\2\u02b1")
buf.write("]\3\2\2\2\u02b2\u02b3\7\63\2\2\u02b3\u02b4\7=\2\2\u02b4")
buf.write("\u02b5\5z>\2\u02b5\u02b6\7>\2\2\u02b6\u02bd\3\2\2\2\u02b7")
buf.write("\u02b8\7\63\2\2\u02b8\u02b9\7=\2\2\u02b9\u02ba\5\60\31")
buf.write("\2\u02ba\u02bb\7>\2\2\u02bb\u02bd\3\2\2\2\u02bc\u02b2")
buf.write("\3\2\2\2\u02bc\u02b7\3\2\2\2\u02bd_\3\2\2\2\u02be\u02c0")
buf.write("\5n8\2\u02bf\u02be\3\2\2\2\u02bf\u02c0\3\2\2\2\u02c0\u02c1")
buf.write("\3\2\2\2\u02c1\u02c5\5b\62\2\u02c2\u02c4\5d\63\2\u02c3")
buf.write("\u02c2\3\2\2\2\u02c4\u02c7\3\2\2\2\u02c5\u02c3\3\2\2\2")
buf.write("\u02c5\u02c6\3\2\2\2\u02c6a\3\2\2\2\u02c7\u02c5\3\2\2")
buf.write("\2\u02c8\u02c9\b\62\1\2\u02c9\u02cf\7k\2\2\u02ca\u02cb")
buf.write("\7=\2\2\u02cb\u02cc\5`\61\2\u02cc\u02cd\7>\2\2\u02cd\u02cf")
buf.write("\3\2\2\2\u02ce\u02c8\3\2\2\2\u02ce\u02ca\3\2\2\2\u02cf")
buf.write("\u02fd\3\2\2\2\u02d0\u02d1\f\b\2\2\u02d1\u02d3\7?\2\2")
buf.write("\u02d2\u02d4\5p9\2\u02d3\u02d2\3\2\2\2\u02d3\u02d4\3\2")
buf.write("\2\2\u02d4\u02d6\3\2\2\2\u02d5\u02d7\5*\26\2\u02d6\u02d5")
buf.write("\3\2\2\2\u02d6\u02d7\3\2\2\2\u02d7\u02d8\3\2\2\2\u02d8")
buf.write("\u02fc\7@\2\2\u02d9\u02da\f\7\2\2\u02da\u02db\7?\2\2\u02db")
buf.write("\u02dd\7*\2\2\u02dc\u02de\5p9\2\u02dd\u02dc\3\2\2\2\u02dd")
buf.write("\u02de\3\2\2\2\u02de\u02df\3\2\2\2\u02df\u02e0\5*\26\2")
buf.write("\u02e0\u02e1\7@\2\2\u02e1\u02fc\3\2\2\2\u02e2\u02e3\f")
buf.write("\6\2\2\u02e3\u02e4\7?\2\2\u02e4\u02e5\5p9\2\u02e5\u02e6")
buf.write("\7*\2\2\u02e6\u02e7\5*\26\2\u02e7\u02e8\7@\2\2\u02e8\u02fc")
buf.write("\3\2\2\2\u02e9\u02ea\f\5\2\2\u02ea\u02ec\7?\2\2\u02eb")
buf.write("\u02ed\5p9\2\u02ec\u02eb\3\2\2\2\u02ec\u02ed\3\2\2\2\u02ed")
buf.write("\u02ee\3\2\2\2\u02ee\u02ef\7M\2\2\u02ef\u02fc\7@\2\2\u02f0")
buf.write("\u02f1\f\4\2\2\u02f1\u02f2\7=\2\2\u02f2\u02f3\5r:\2\u02f3")
buf.write("\u02f4\7>\2\2\u02f4\u02fc\3\2\2\2\u02f5\u02f6\f\3\2\2")
buf.write("\u02f6\u02f8\7=\2\2\u02f7\u02f9\5x=\2\u02f8\u02f7\3\2")
buf.write("\2\2\u02f8\u02f9\3\2\2\2\u02f9\u02fa\3\2\2\2\u02fa\u02fc")
buf.write("\7>\2\2\u02fb\u02d0\3\2\2\2\u02fb\u02d9\3\2\2\2\u02fb")
buf.write("\u02e2\3\2\2\2\u02fb\u02e9\3\2\2\2\u02fb\u02f0\3\2\2\2")
buf.write("\u02fb\u02f5\3\2\2\2\u02fc\u02ff\3\2\2\2\u02fd\u02fb\3")
buf.write("\2\2\2\u02fd\u02fe\3\2\2\2\u02fec\3\2\2\2\u02ff\u02fd")
buf.write("\3\2\2\2\u0300\u0301\7\r\2\2\u0301\u0303\7=\2\2\u0302")
buf.write("\u0304\7m\2\2\u0303\u0302\3\2\2\2\u0304\u0305\3\2\2\2")
buf.write("\u0305\u0303\3\2\2\2\u0305\u0306\3\2\2\2\u0306\u0307\3")
buf.write("\2\2\2\u0307\u030a\7>\2\2\u0308\u030a\5f\64\2\u0309\u0300")
buf.write("\3\2\2\2\u0309\u0308\3\2\2\2\u030ae\3\2\2\2\u030b\u030c")
buf.write("\7\16\2\2\u030c\u030d\7=\2\2\u030d\u030e\7=\2\2\u030e")
buf.write("\u030f\5h\65\2\u030f\u0310\7>\2\2\u0310\u0311\7>\2\2\u0311")
buf.write("g\3\2\2\2\u0312\u0317\5j\66\2\u0313\u0314\7Z\2\2\u0314")
buf.write("\u0316\5j\66\2\u0315\u0313\3\2\2\2\u0316\u0319\3\2\2\2")
buf.write("\u0317\u0315\3\2\2\2\u0317\u0318\3\2\2\2\u0318\u031c\3")
buf.write("\2\2\2\u0319\u0317\3\2\2\2\u031a\u031c\3\2\2\2\u031b\u0312")
buf.write("\3\2\2\2\u031b\u031a\3\2\2\2\u031ci\3\2\2\2\u031d\u0323")
buf.write("\n\n\2\2\u031e\u0320\7=\2\2\u031f\u0321\5\f\7\2\u0320")
buf.write("\u031f\3\2\2\2\u0320\u0321\3\2\2\2\u0321\u0322\3\2\2\2")
buf.write("\u0322\u0324\7>\2\2\u0323\u031e\3\2\2\2\u0323\u0324\3")
buf.write("\2\2\2\u0324\u0327\3\2\2\2\u0325\u0327\3\2\2\2\u0326\u031d")
buf.write("\3\2\2\2\u0326\u0325\3\2\2\2\u0327k\3\2\2\2\u0328\u032e")
buf.write("\n\13\2\2\u0329\u032a\7=\2\2\u032a\u032b\5l\67\2\u032b")
buf.write("\u032c\7>\2\2\u032c\u032e\3\2\2\2\u032d\u0328\3\2\2\2")
buf.write("\u032d\u0329\3\2\2\2\u032e\u0331\3\2\2\2\u032f\u032d\3")
buf.write("\2\2\2\u032f\u0330\3\2\2\2\u0330m\3\2\2\2\u0331\u032f")
buf.write("\3\2\2\2\u0332\u0334\7M\2\2\u0333\u0335\5p9\2\u0334\u0333")
buf.write("\3\2\2\2\u0334\u0335\3\2\2\2\u0335\u0345\3\2\2\2\u0336")
buf.write("\u0338\7M\2\2\u0337\u0339\5p9\2\u0338\u0337\3\2\2\2\u0338")
buf.write("\u0339\3\2\2\2\u0339\u033a\3\2\2\2\u033a\u0345\5n8\2\u033b")
buf.write("\u033d\7T\2\2\u033c\u033e\5p9\2\u033d\u033c\3\2\2\2\u033d")
buf.write("\u033e\3\2\2\2\u033e\u0345\3\2\2\2\u033f\u0341\7T\2\2")
buf.write("\u0340\u0342\5p9\2\u0341\u0340\3\2\2\2\u0341\u0342\3\2")
buf.write("\2\2\u0342\u0343\3\2\2\2\u0343\u0345\5n8\2\u0344\u0332")
buf.write("\3\2\2\2\u0344\u0336\3\2\2\2\u0344\u033b\3\2\2\2\u0344")
buf.write("\u033f\3\2\2\2\u0345o\3\2\2\2\u0346\u0347\b9\1\2\u0347")
buf.write("\u0348\5Z.\2\u0348\u034d\3\2\2\2\u0349\u034a\f\3\2\2\u034a")
buf.write("\u034c\5Z.\2\u034b\u0349\3\2\2\2\u034c\u034f\3\2\2\2\u034d")
buf.write("\u034b\3\2\2\2\u034d\u034e\3\2\2\2\u034eq\3\2\2\2\u034f")
buf.write("\u034d\3\2\2\2\u0350\u0356\5t;\2\u0351\u0352\5t;\2\u0352")
buf.write("\u0353\7Z\2\2\u0353\u0354\7j\2\2\u0354\u0356\3\2\2\2\u0355")
buf.write("\u0350\3\2\2\2\u0355\u0351\3\2\2\2\u0356s\3\2\2\2\u0357")
buf.write("\u0358\b;\1\2\u0358\u0359\5v<\2\u0359\u035f\3\2\2\2\u035a")
buf.write("\u035b\f\3\2\2\u035b\u035c\7Z\2\2\u035c\u035e\5v<\2\u035d")
buf.write("\u035a\3\2\2\2\u035e\u0361\3\2\2\2\u035f\u035d\3\2\2\2")
buf.write("\u035f\u0360\3\2\2\2\u0360u\3\2\2\2\u0361\u035f\3\2\2")
buf.write("\2\u0362\u0363\5\64\33\2\u0363\u0364\5`\61\2\u0364\u036a")
buf.write("\3\2\2\2\u0365\u0367\5\66\34\2\u0366\u0368\5|?\2\u0367")
buf.write("\u0366\3\2\2\2\u0367\u0368\3\2\2\2\u0368\u036a\3\2\2\2")
buf.write("\u0369\u0362\3\2\2\2\u0369\u0365\3\2\2\2\u036aw\3\2\2")
buf.write("\2\u036b\u036c\b=\1\2\u036c\u036d\7k\2\2\u036d\u0373\3")
buf.write("\2\2\2\u036e\u036f\f\3\2\2\u036f\u0370\7Z\2\2\u0370\u0372")
buf.write("\7k\2\2\u0371\u036e\3\2\2\2\u0372\u0375\3\2\2\2\u0373")
buf.write("\u0371\3\2\2\2\u0373\u0374\3\2\2\2\u0374y\3\2\2\2\u0375")
buf.write("\u0373\3\2\2\2\u0376\u0378\5J&\2\u0377\u0379\5|?\2\u0378")
buf.write("\u0377\3\2\2\2\u0378\u0379\3\2\2\2\u0379{\3\2\2\2\u037a")
buf.write("\u0386\5n8\2\u037b\u037d\5n8\2\u037c\u037b\3\2\2\2\u037c")
buf.write("\u037d\3\2\2\2\u037d\u037e\3\2\2\2\u037e\u0382\5~@\2\u037f")
buf.write("\u0381\5d\63\2\u0380\u037f\3\2\2\2\u0381\u0384\3\2\2\2")
buf.write("\u0382\u0380\3\2\2\2\u0382\u0383\3\2\2\2\u0383\u0386\3")
buf.write("\2\2\2\u0384\u0382\3\2\2\2\u0385\u037a\3\2\2\2\u0385\u037c")
buf.write("\3\2\2\2\u0386}\3\2\2\2\u0387\u0388\b@\1\2\u0388\u0389")
buf.write("\7=\2\2\u0389\u038a\5|?\2\u038a\u038e\7>\2\2\u038b\u038d")
buf.write("\5d\63\2\u038c\u038b\3\2\2\2\u038d\u0390\3\2\2\2\u038e")
buf.write("\u038c\3\2\2\2\u038e\u038f\3\2\2\2\u038f\u03b6\3\2\2\2")
buf.write("\u0390\u038e\3\2\2\2\u0391\u0393\7?\2\2\u0392\u0394\5")
buf.write("p9\2\u0393\u0392\3\2\2\2\u0393\u0394\3\2\2\2\u0394\u0396")
buf.write("\3\2\2\2\u0395\u0397\5*\26\2\u0396\u0395\3\2\2\2\u0396")
buf.write("\u0397\3\2\2\2\u0397\u0398\3\2\2\2\u0398\u03b6\7@\2\2")
buf.write("\u0399\u039a\7?\2\2\u039a\u039c\7*\2\2\u039b\u039d\5p")
buf.write("9\2\u039c\u039b\3\2\2\2\u039c\u039d\3\2\2\2\u039d\u039e")
buf.write("\3\2\2\2\u039e\u039f\5*\26\2\u039f\u03a0\7@\2\2\u03a0")
buf.write("\u03b6\3\2\2\2\u03a1\u03a2\7?\2\2\u03a2\u03a3\5p9\2\u03a3")
buf.write("\u03a4\7*\2\2\u03a4\u03a5\5*\26\2\u03a5\u03a6\7@\2\2\u03a6")
buf.write("\u03b6\3\2\2\2\u03a7\u03a8\7?\2\2\u03a8\u03a9\7M\2\2\u03a9")
buf.write("\u03b6\7@\2\2\u03aa\u03ac\7=\2\2\u03ab\u03ad\5r:\2\u03ac")
buf.write("\u03ab\3\2\2\2\u03ac\u03ad\3\2\2\2\u03ad\u03ae\3\2\2\2")
buf.write("\u03ae\u03b2\7>\2\2\u03af\u03b1\5d\63\2\u03b0\u03af\3")
buf.write("\2\2\2\u03b1\u03b4\3\2\2\2\u03b2\u03b0\3\2\2\2\u03b2\u03b3")
buf.write("\3\2\2\2\u03b3\u03b6\3\2\2\2\u03b4\u03b2\3\2\2\2\u03b5")
buf.write("\u0387\3\2\2\2\u03b5\u0391\3\2\2\2\u03b5\u0399\3\2\2\2")
buf.write("\u03b5\u03a1\3\2\2\2\u03b5\u03a7\3\2\2\2\u03b5\u03aa\3")
buf.write("\2\2\2\u03b6\u03e2\3\2\2\2\u03b7\u03b8\f\7\2\2\u03b8\u03ba")
buf.write("\7?\2\2\u03b9\u03bb\5p9\2\u03ba\u03b9\3\2\2\2\u03ba\u03bb")
buf.write("\3\2\2\2\u03bb\u03bd\3\2\2\2\u03bc\u03be\5*\26\2\u03bd")
buf.write("\u03bc\3\2\2\2\u03bd\u03be\3\2\2\2\u03be\u03bf\3\2\2\2")
buf.write("\u03bf\u03e1\7@\2\2\u03c0\u03c1\f\6\2\2\u03c1\u03c2\7")
buf.write("?\2\2\u03c2\u03c4\7*\2\2\u03c3\u03c5\5p9\2\u03c4\u03c3")
buf.write("\3\2\2\2\u03c4\u03c5\3\2\2\2\u03c5\u03c6\3\2\2\2\u03c6")
buf.write("\u03c7\5*\26\2\u03c7\u03c8\7@\2\2\u03c8\u03e1\3\2\2\2")
buf.write("\u03c9\u03ca\f\5\2\2\u03ca\u03cb\7?\2\2\u03cb\u03cc\5")
buf.write("p9\2\u03cc\u03cd\7*\2\2\u03cd\u03ce\5*\26\2\u03ce\u03cf")
buf.write("\7@\2\2\u03cf\u03e1\3\2\2\2\u03d0\u03d1\f\4\2\2\u03d1")
buf.write("\u03d2\7?\2\2\u03d2\u03d3\7M\2\2\u03d3\u03e1\7@\2\2\u03d4")
buf.write("\u03d5\f\3\2\2\u03d5\u03d7\7=\2\2\u03d6\u03d8\5r:\2\u03d7")
buf.write("\u03d6\3\2\2\2\u03d7\u03d8\3\2\2\2\u03d8\u03d9\3\2\2\2")
buf.write("\u03d9\u03dd\7>\2\2\u03da\u03dc\5d\63\2\u03db\u03da\3")
buf.write("\2\2\2\u03dc\u03df\3\2\2\2\u03dd\u03db\3\2\2\2\u03dd\u03de")
buf.write("\3\2\2\2\u03de\u03e1\3\2\2\2\u03df\u03dd\3\2\2\2\u03e0")
buf.write("\u03b7\3\2\2\2\u03e0\u03c0\3\2\2\2\u03e0\u03c9\3\2\2\2")
buf.write("\u03e0\u03d0\3\2\2\2\u03e0\u03d4\3\2\2\2\u03e1\u03e4\3")
buf.write("\2\2\2\u03e2\u03e0\3\2\2\2\u03e2\u03e3\3\2\2\2\u03e3\177")
buf.write("\3\2\2\2\u03e4\u03e2\3\2\2\2\u03e5\u03e6\7k\2\2\u03e6")
buf.write("\u0081\3\2\2\2\u03e7\u03f2\5*\26\2\u03e8\u03e9\7A\2\2")
buf.write("\u03e9\u03ea\5\u0084C\2\u03ea\u03eb\7B\2\2\u03eb\u03f2")
buf.write("\3\2\2\2\u03ec\u03ed\7A\2\2\u03ed\u03ee\5\u0084C\2\u03ee")
buf.write("\u03ef\7Z\2\2\u03ef\u03f0\7B\2\2\u03f0\u03f2\3\2\2\2\u03f1")
buf.write("\u03e7\3\2\2\2\u03f1\u03e8\3\2\2\2\u03f1\u03ec\3\2\2\2")
buf.write("\u03f2\u0083\3\2\2\2\u03f3\u03f5\bC\1\2\u03f4\u03f6\5")
buf.write("\u0086D\2\u03f5\u03f4\3\2\2\2\u03f5\u03f6\3\2\2\2\u03f6")
buf.write("\u03f7\3\2\2\2\u03f7\u03f8\5\u0082B\2\u03f8\u0401\3\2")
buf.write("\2\2\u03f9\u03fa\f\3\2\2\u03fa\u03fc\7Z\2\2\u03fb\u03fd")
buf.write("\5\u0086D\2\u03fc\u03fb\3\2\2\2\u03fc\u03fd\3\2\2\2\u03fd")
buf.write("\u03fe\3\2\2\2\u03fe\u0400\5\u0082B\2\u03ff\u03f9\3\2")
buf.write("\2\2\u0400\u0403\3\2\2\2\u0401\u03ff\3\2\2\2\u0401\u0402")
buf.write("\3\2\2\2\u0402\u0085\3\2\2\2\u0403\u0401\3\2\2\2\u0404")
buf.write("\u0405\5\u0088E\2\u0405\u0406\7[\2\2\u0406\u0087\3\2\2")
buf.write("\2\u0407\u0408\bE\1\2\u0408\u0409\5\u008aF\2\u0409\u040e")
buf.write("\3\2\2\2\u040a\u040b\f\3\2\2\u040b\u040d\5\u008aF\2\u040c")
buf.write("\u040a\3\2\2\2\u040d\u0410\3\2\2\2\u040e\u040c\3\2\2\2")
buf.write("\u040e\u040f\3\2\2\2\u040f\u0089\3\2\2\2\u0410\u040e\3")
buf.write("\2\2\2\u0411\u0412\7?\2\2\u0412\u0413\5\60\31\2\u0413")
buf.write("\u0414\7@\2\2\u0414\u0418\3\2\2\2\u0415\u0416\7i\2\2\u0416")
buf.write("\u0418\7k\2\2\u0417\u0411\3\2\2\2\u0417\u0415\3\2\2\2")
buf.write("\u0418\u008b\3\2\2\2\u0419\u041a\7;\2\2\u041a\u041b\7")
buf.write("=\2\2\u041b\u041c\5\60\31\2\u041c\u041e\7Z\2\2\u041d\u041f")
buf.write("\7m\2\2\u041e\u041d\3\2\2\2\u041f\u0420\3\2\2\2\u0420")
buf.write("\u041e\3\2\2\2\u0420\u0421\3\2\2\2\u0421\u0422\3\2\2\2")
buf.write("\u0422\u0423\7>\2\2\u0423\u0424\7Y\2\2\u0424\u008d\3\2")
buf.write("\2\2\u0425\u044b\5\u0090I\2\u0426\u044b\5\u0092J\2\u0427")
buf.write("\u044b\5\u0098M\2\u0428\u044b\5\u009aN\2\u0429\u044b\5")
buf.write("\u009cO\2\u042a\u044b\5\u009eP\2\u042b\u042c\t\f\2\2\u042c")
buf.write("\u042d\t\r\2\2\u042d\u0436\7=\2\2\u042e\u0433\5&\24\2")
buf.write("\u042f\u0430\7Z\2\2\u0430\u0432\5&\24\2\u0431\u042f\3")
buf.write("\2\2\2\u0432\u0435\3\2\2\2\u0433\u0431\3\2\2\2\u0433\u0434")
buf.write("\3\2\2\2\u0434\u0437\3\2\2\2\u0435\u0433\3\2\2\2\u0436")
buf.write("\u042e\3\2\2\2\u0436\u0437\3\2\2\2\u0437\u0445\3\2\2\2")
buf.write("\u0438\u0441\7X\2\2\u0439\u043e\5&\24\2\u043a\u043b\7")
buf.write("Z\2\2\u043b\u043d\5&\24\2\u043c\u043a\3\2\2\2\u043d\u0440")
buf.write("\3\2\2\2\u043e\u043c\3\2\2\2\u043e\u043f\3\2\2\2\u043f")
buf.write("\u0442\3\2\2\2\u0440\u043e\3\2\2\2\u0441\u0439\3\2\2\2")
buf.write("\u0441\u0442\3\2\2\2\u0442\u0444\3\2\2\2\u0443\u0438\3")
buf.write("\2\2\2\u0444\u0447\3\2\2\2\u0445\u0443\3\2\2\2\u0445\u0446")
buf.write("\3\2\2\2\u0446\u0448\3\2\2\2\u0447\u0445\3\2\2\2\u0448")
buf.write("\u0449\7>\2\2\u0449\u044b\7Y\2\2\u044a\u0425\3\2\2\2\u044a")
buf.write("\u0426\3\2\2\2\u044a\u0427\3\2\2\2\u044a\u0428\3\2\2\2")
buf.write("\u044a\u0429\3\2\2\2\u044a\u042a\3\2\2\2\u044a\u042b\3")
buf.write("\2\2\2\u044b\u008f\3\2\2\2\u044c\u044d\7k\2\2\u044d\u044e")
buf.write("\7X\2\2\u044e\u0458\5\u008eH\2\u044f\u0450\7\23\2\2\u0450")
buf.write("\u0451\5\60\31\2\u0451\u0452\7X\2\2\u0452\u0453\5\u008e")
buf.write("H\2\u0453\u0458\3\2\2\2\u0454\u0455\7\27\2\2\u0455\u0456")
buf.write("\7X\2\2\u0456\u0458\5\u008eH\2\u0457\u044c\3\2\2\2\u0457")
buf.write("\u044f\3\2\2\2\u0457\u0454\3\2\2\2\u0458\u0091\3\2\2\2")
buf.write("\u0459\u045b\7A\2\2\u045a\u045c\5\u0094K\2\u045b\u045a")
buf.write("\3\2\2\2\u045b\u045c\3\2\2\2\u045c\u045d\3\2\2\2\u045d")
buf.write("\u045e\7B\2\2\u045e\u0093\3\2\2\2\u045f\u0460\bK\1\2\u0460")
buf.write("\u0461\5\u0096L\2\u0461\u0466\3\2\2\2\u0462\u0463\f\3")
buf.write("\2\2\u0463\u0465\5\u0096L\2\u0464\u0462\3\2\2\2\u0465")
buf.write("\u0468\3\2\2\2\u0466\u0464\3\2\2\2\u0466\u0467\3\2\2\2")
buf.write("\u0467\u0095\3\2\2\2\u0468\u0466\3\2\2\2\u0469\u046c\5")
buf.write("\62\32\2\u046a\u046c\5\u008eH\2\u046b\u0469\3\2\2\2\u046b")
buf.write("\u046a\3\2\2\2\u046c\u0097\3\2\2\2\u046d\u046f\5.\30\2")
buf.write("\u046e\u046d\3\2\2\2\u046e\u046f\3\2\2\2\u046f\u0470\3")
buf.write("\2\2\2\u0470\u0471\7Y\2\2\u0471\u0099\3\2\2\2\u0472\u0473")
buf.write("\7 \2\2\u0473\u0474\7=\2\2\u0474\u0475\5.\30\2\u0475\u0476")
buf.write("\7>\2\2\u0476\u0479\5\u008eH\2\u0477\u0478\7\32\2\2\u0478")
buf.write("\u047a\5\u008eH\2\u0479\u0477\3\2\2\2\u0479\u047a\3\2")
buf.write("\2\2\u047a\u0482\3\2\2\2\u047b\u047c\7,\2\2\u047c\u047d")
buf.write("\7=\2\2\u047d\u047e\5.\30\2\u047e\u047f\7>\2\2\u047f\u0480")
buf.write("\5\u008eH\2\u0480\u0482\3\2\2\2\u0481\u0472\3\2\2\2\u0481")
buf.write("\u047b\3\2\2\2\u0482\u009b\3\2\2\2\u0483\u0484\7\62\2")
buf.write("\2\u0484\u0485\7=\2\2\u0485\u0486\5.\30\2\u0486\u0487")
buf.write("\7>\2\2\u0487\u0488\5\u008eH\2\u0488\u04ae\3\2\2\2\u0489")
buf.write("\u048a\7\30\2\2\u048a\u048b\5\u008eH\2\u048b\u048c\7\62")
buf.write("\2\2\u048c\u048d\7=\2\2\u048d\u048e\5.\30\2\u048e\u048f")
buf.write("\7>\2\2\u048f\u0490\7Y\2\2\u0490\u04ae\3\2\2\2\u0491\u0492")
buf.write("\7\36\2\2\u0492\u0494\7=\2\2\u0493\u0495\5.\30\2\u0494")
buf.write("\u0493\3\2\2\2\u0494\u0495\3\2\2\2\u0495\u0496\3\2\2\2")
buf.write("\u0496\u0498\7Y\2\2\u0497\u0499\5.\30\2\u0498\u0497\3")
buf.write("\2\2\2\u0498\u0499\3\2\2\2\u0499\u049a\3\2\2\2\u049a\u049c")
buf.write("\7Y\2\2\u049b\u049d\5.\30\2\u049c\u049b\3\2\2\2\u049c")
buf.write("\u049d\3\2\2\2\u049d\u049e\3\2\2\2\u049e\u049f\7>\2\2")
buf.write("\u049f\u04ae\5\u008eH\2\u04a0\u04a1\7\36\2\2\u04a1\u04a2")
buf.write("\7=\2\2\u04a2\u04a4\5\62\32\2\u04a3\u04a5\5.\30\2\u04a4")
buf.write("\u04a3\3\2\2\2\u04a4\u04a5\3\2\2\2\u04a5\u04a6\3\2\2\2")
buf.write("\u04a6\u04a8\7Y\2\2\u04a7\u04a9\5.\30\2\u04a8\u04a7\3")
buf.write("\2\2\2\u04a8\u04a9\3\2\2\2\u04a9\u04aa\3\2\2\2\u04aa\u04ab")
buf.write("\7>\2\2\u04ab\u04ac\5\u008eH\2\u04ac\u04ae\3\2\2\2\u04ad")
buf.write("\u0483\3\2\2\2\u04ad\u0489\3\2\2\2\u04ad\u0491\3\2\2\2")
buf.write("\u04ad\u04a0\3\2\2\2\u04ae\u009d\3\2\2\2\u04af\u04b0\7")
buf.write("\37\2\2\u04b0\u04b1\7k\2\2\u04b1\u04c0\7Y\2\2\u04b2\u04b3")
buf.write("\7\26\2\2\u04b3\u04c0\7Y\2\2\u04b4\u04b5\7\22\2\2\u04b5")
buf.write("\u04c0\7Y\2\2\u04b6\u04b8\7&\2\2\u04b7\u04b9\5.\30\2\u04b8")
buf.write("\u04b7\3\2\2\2\u04b8\u04b9\3\2\2\2\u04b9\u04ba\3\2\2\2")
buf.write("\u04ba\u04c0\7Y\2\2\u04bb\u04bc\7\37\2\2\u04bc\u04bd\5")
buf.write("\16\b\2\u04bd\u04be\7Y\2\2\u04be\u04c0\3\2\2\2\u04bf\u04af")
buf.write("\3\2\2\2\u04bf\u04b2\3\2\2\2\u04bf\u04b4\3\2\2\2\u04bf")
buf.write("\u04b6\3\2\2\2\u04bf\u04bb\3\2\2\2\u04c0\u009f\3\2\2\2")
buf.write("\u04c1\u04c3\5\u00a2R\2\u04c2\u04c1\3\2\2\2\u04c2\u04c3")
buf.write("\3\2\2\2\u04c3\u04c4\3\2\2\2\u04c4\u04c5\7\2\2\3\u04c5")
buf.write("\u00a1\3\2\2\2\u04c6\u04c7\bR\1\2\u04c7\u04c8\5\u00a4")
buf.write("S\2\u04c8\u04cd\3\2\2\2\u04c9\u04ca\f\3\2\2\u04ca\u04cc")
buf.write("\5\u00a4S\2\u04cb\u04c9\3\2\2\2\u04cc\u04cf\3\2\2\2\u04cd")
buf.write("\u04cb\3\2\2\2\u04cd\u04ce\3\2\2\2\u04ce\u00a3\3\2\2\2")
buf.write("\u04cf\u04cd\3\2\2\2\u04d0\u04d4\5\u00a6T\2\u04d1\u04d4")
buf.write("\5\62\32\2\u04d2\u04d4\7Y\2\2\u04d3\u04d0\3\2\2\2\u04d3")
buf.write("\u04d1\3\2\2\2\u04d3\u04d2\3\2\2\2\u04d4\u00a5\3\2\2\2")
buf.write("\u04d5\u04d7\5\64\33\2\u04d6\u04d5\3\2\2\2\u04d6\u04d7")
buf.write("\3\2\2\2\u04d7\u04d8\3\2\2\2\u04d8\u04da\5`\61\2\u04d9")
buf.write("\u04db\5\u00a8U\2\u04da\u04d9\3\2\2\2\u04da\u04db\3\2")
buf.write("\2\2\u04db\u04dc\3\2\2\2\u04dc\u04dd\5\u0092J\2\u04dd")
buf.write("\u00a7\3\2\2\2\u04de\u04df\bU\1\2\u04df\u04e0\5\62\32")
buf.write("\2\u04e0\u04e5\3\2\2\2\u04e1\u04e2\f\3\2\2\u04e2\u04e4")
buf.write("\5\62\32\2\u04e3\u04e1\3\2\2\2\u04e4\u04e7\3\2\2\2\u04e5")
buf.write("\u04e3\3\2\2\2\u04e5\u04e6\3\2\2\2\u04e6\u00a9\3\2\2\2")
buf.write("\u04e7\u04e5\3\2\2\2\u008c\u00af\u00b7\u00cb\u00dc\u00e6")
buf.write("\u010a\u0114\u0121\u0123\u012e\u0147\u0157\u0165\u0167")
buf.write("\u0173\u0175\u0181\u0183\u0195\u0197\u01a3\u01a5\u01b0")
buf.write("\u01bb\u01c6\u01d1\u01dc\u01e5\u01ec\u01f8\u01ff\u0204")
buf.write("\u0209\u020e\u0215\u021f\u0227\u0239\u023d\u0246\u0251")
buf.write("\u0256\u025b\u025f\u0263\u0265\u026f\u0274\u0278\u027c")
buf.write("\u0284\u028d\u0297\u029f\u02b0\u02bc\u02bf\u02c5\u02ce")
buf.write("\u02d3\u02d6\u02dd\u02ec\u02f8\u02fb\u02fd\u0305\u0309")
buf.write("\u0317\u031b\u0320\u0323\u0326\u032d\u032f\u0334\u0338")
buf.write("\u033d\u0341\u0344\u034d\u0355\u035f\u0367\u0369\u0373")
buf.write("\u0378\u037c\u0382\u0385\u038e\u0393\u0396\u039c\u03ac")
buf.write("\u03b2\u03b5\u03ba\u03bd\u03c4\u03d7\u03dd\u03e0\u03e2")
buf.write("\u03f1\u03f5\u03fc\u0401\u040e\u0417\u0420\u0433\u0436")
buf.write("\u043e\u0441\u0445\u044a\u0457\u045b\u0466\u046b\u046e")
buf.write("\u0479\u0481\u0494\u0498\u049c\u04a4\u04a8\u04ad\u04b8")
buf.write("\u04bf\u04c2\u04cd\u04d3\u04d6\u04da\u04e5")
return buf.getvalue()
class CParser ( Parser ):
grammarFileName = "C.bnf"
atn = ATNDeserializer().deserialize(serializedATN())
decisionsToDFA = [ DFA(ds, i) for i, ds in enumerate(atn.decisionToState) ]
sharedContextCache = PredictionContextCache()
literalNames = [ "", "'__extension__'", "'__builtin_va_arg'",
"'__builtin_offsetof'", "'__m128'", "'__m128d'", "'__m128i'",
"'__typeof__'", "'__inline__'", "'__stdcall'", "'__declspec'",
"'__asm'", "'__attribute__'", "'__asm__'", "'__volatile__'",
"'auto'", "'break'", "'case'", "'char'", "'const'",
"'continue'", "'default'", "'do'", "'double'", "'else'",
"'enum'", "'extern'", "'float'", "'for'", "'goto'",
"'if'", "'inline'", "'int'", "'long'", "'register'",
"'restrict'", "'return'", "'short'", "'signed'", "'sizeof'",
"'static'", "'struct'", "'switch'", "'typedef'", "'union'",
"'unsigned'", "'void'", "'volatile'", "'while'", "'_Alignas'",
"'_Alignof'", "'_Atomic'", "'_Bool'", "'_Complex'",
"'_Generic'", "'_Imaginary'", "'_Noreturn'", "'_Static_assert'",
"'_Thread_local'", "'('", "')'", "'['", "']'", "'{'",
"'}'", "'<'", "'<='", "'>'", "'>='", "'<<'", "'>>'",
"'+'", "'++'", "'-'", "'--'", "'*'", "'/'", "'%'",
"'&'", "'|'", "'&&'", "'||'", "'^'", "'!'", "'~'",
"'?'", "':'", "';'", "','", "'='", "'*='", "'/='",
"'%='", "'+='", "'-='", "'<<='", "'>>='", "'&='", "'^='",
"'|='", "'=='", "'!='", "'->'", "'.'", "'...'" ]
symbolicNames = [ "", "", "", "",
"", "", "", "",
"", "", "", "",
"", "", "", "Auto", "Break",
"Case", "Char", "Const", "Continue", "Default", "Do",
"Double", "Else", "Enum", "Extern", "Float", "For",
"Goto", "If", "Inline", "Int", "Long", "Register",
"Restrict", "Return", "Short", "Signed", "Sizeof",
"Static", "Struct", "Switch", "Typedef", "Union",
"Unsigned", "Void", "Volatile", "While", "Alignas",
"Alignof", "Atomic", "Bool", "Complex", "Generic",
"Imaginary", "Noreturn", "StaticAssert", "ThreadLocal",
"LeftParen", "RightParen", "LeftBracket", "RightBracket",
"LeftBrace", "RightBrace", "Less", "LessEqual", "Greater",
"GreaterEqual", "LeftShift", "RightShift", "Plus",
"PlusPlus", "Minus", "MinusMinus", "Star", "Div",
"Mod", "And", "Or", "AndAnd", "OrOr", "Caret", "Not",
"Tilde", "Question", "Colon", "Semi", "Comma", "Assign",
"StarAssign", "DivAssign", "ModAssign", "PlusAssign",
"MinusAssign", "LeftShiftAssign", "RightShiftAssign",
"AndAssign", "XorAssign", "OrAssign", "Equal", "NotEqual",
"Arrow", "Dot", "Ellipsis", "Identifier", "Constant",
"StringLiteral", "LineDirective", "PragmaDirective",
"Whitespace", "Newline", "BlockComment", "LineComment" ]
RULE_primaryExpression = 0
RULE_genericSelection = 1
RULE_genericAssocList = 2
RULE_genericAssociation = 3
RULE_postfixExpression = 4
RULE_argumentExpressionList = 5
RULE_unaryExpression = 6
RULE_unaryOperator = 7
RULE_castExpression = 8
RULE_multiplicativeExpression = 9
RULE_additiveExpression = 10
RULE_shiftExpression = 11
RULE_relationalExpression = 12
RULE_equalityExpression = 13
RULE_andExpression = 14
RULE_exclusiveOrExpression = 15
RULE_inclusiveOrExpression = 16
RULE_logicalAndExpression = 17
RULE_logicalOrExpression = 18
RULE_conditionalExpression = 19
RULE_assignmentExpression = 20
RULE_assignmentOperator = 21
RULE_expression = 22
RULE_constantExpression = 23
RULE_declaration = 24
RULE_declarationSpecifiers = 25
RULE_declarationSpecifiers2 = 26
RULE_declarationSpecifier = 27
RULE_initDeclaratorList = 28
RULE_initDeclarator = 29
RULE_storageClassSpecifier = 30
RULE_typeSpecifier = 31
RULE_structOrUnionSpecifier = 32
RULE_structOrUnion = 33
RULE_structDeclarationList = 34
RULE_structDeclaration = 35
RULE_specifierQualifierList = 36
RULE_structDeclaratorList = 37
RULE_structDeclarator = 38
RULE_enumSpecifier = 39
RULE_enumeratorList = 40
RULE_enumerator = 41
RULE_enumerationConstant = 42
RULE_atomicTypeSpecifier = 43
RULE_typeQualifier = 44
RULE_functionSpecifier = 45
RULE_alignmentSpecifier = 46
RULE_declarator = 47
RULE_directDeclarator = 48
RULE_gccDeclaratorExtension = 49
RULE_gccAttributeSpecifier = 50
RULE_gccAttributeList = 51
RULE_gccAttribute = 52
RULE_nestedParenthesesBlock = 53
RULE_pointer = 54
RULE_typeQualifierList = 55
RULE_parameterTypeList = 56
RULE_parameterList = 57
RULE_parameterDeclaration = 58
RULE_identifierList = 59
RULE_typeName = 60
RULE_abstractDeclarator = 61
RULE_directAbstractDeclarator = 62
RULE_typedefName = 63
RULE_initializer = 64
RULE_initializerList = 65
RULE_designation = 66
RULE_designatorList = 67
RULE_designator = 68
RULE_staticAssertDeclaration = 69
RULE_statement = 70
RULE_labeledStatement = 71
RULE_compoundStatement = 72
RULE_blockItemList = 73
RULE_blockItem = 74
RULE_expressionStatement = 75
RULE_selectionStatement = 76
RULE_iterationStatement = 77
RULE_jumpStatement = 78
RULE_compilationUnit = 79
RULE_translationUnit = 80
RULE_externalDeclaration = 81
RULE_functionDefinition = 82
RULE_declarationList = 83
ruleNames = [ "primaryExpression", "genericSelection", "genericAssocList",
"genericAssociation", "postfixExpression", "argumentExpressionList",
"unaryExpression", "unaryOperator", "castExpression",
"multiplicativeExpression", "additiveExpression", "shiftExpression",
"relationalExpression", "equalityExpression", "andExpression",
"exclusiveOrExpression", "inclusiveOrExpression", "logicalAndExpression",
"logicalOrExpression", "conditionalExpression", "assignmentExpression",
"assignmentOperator", "expression", "constantExpression",
"declaration", "declarationSpecifiers", "declarationSpecifiers2",
"declarationSpecifier", "initDeclaratorList", "initDeclarator",
"storageClassSpecifier", "typeSpecifier", "structOrUnionSpecifier",
"structOrUnion", "structDeclarationList", "structDeclaration",
"specifierQualifierList", "structDeclaratorList", "structDeclarator",
"enumSpecifier", "enumeratorList", "enumerator", "enumerationConstant",
"atomicTypeSpecifier", "typeQualifier", "functionSpecifier",
"alignmentSpecifier", "declarator", "directDeclarator",
"gccDeclaratorExtension", "gccAttributeSpecifier", "gccAttributeList",
"gccAttribute", "nestedParenthesesBlock", "pointer",
"typeQualifierList", "parameterTypeList", "parameterList",
"parameterDeclaration", "identifierList", "typeName",
"abstractDeclarator", "directAbstractDeclarator", "typedefName",
"initializer", "initializerList", "designation", "designatorList",
"designator", "staticAssertDeclaration", "statement",
"labeledStatement", "compoundStatement", "blockItemList",
"blockItem", "expressionStatement", "selectionStatement",
"iterationStatement", "jumpStatement", "compilationUnit",
"translationUnit", "externalDeclaration", "functionDefinition",
"declarationList" ]
EOF = Token.EOF
T__0=1
T__1=2
T__2=3
T__3=4
T__4=5
T__5=6
T__6=7
T__7=8
T__8=9
T__9=10
T__10=11
T__11=12
T__12=13
T__13=14
Auto=15
Break=16
Case=17
Char=18
Const=19
Continue=20
Default=21
Do=22
Double=23
Else=24
Enum=25
Extern=26
Float=27
For=28
Goto=29
If=30
Inline=31
Int=32
Long=33
Register=34
Restrict=35
Return=36
Short=37
Signed=38
Sizeof=39
Static=40
Struct=41
Switch=42
Typedef=43
Union=44
Unsigned=45
Void=46
Volatile=47
While=48
Alignas=49
Alignof=50
Atomic=51
Bool=52
Complex=53
Generic=54
Imaginary=55
Noreturn=56
StaticAssert=57
ThreadLocal=58
LeftParen=59
RightParen=60
LeftBracket=61
RightBracket=62
LeftBrace=63
RightBrace=64
Less=65
LessEqual=66
Greater=67
GreaterEqual=68
LeftShift=69
RightShift=70
Plus=71
PlusPlus=72
Minus=73
MinusMinus=74
Star=75
Div=76
Mod=77
And=78
Or=79
AndAnd=80
OrOr=81
Caret=82
Not=83
Tilde=84
Question=85
Colon=86
Semi=87
Comma=88
Assign=89
StarAssign=90
DivAssign=91
ModAssign=92
PlusAssign=93
MinusAssign=94
LeftShiftAssign=95
RightShiftAssign=96
AndAssign=97
XorAssign=98
OrAssign=99
Equal=100
NotEqual=101
Arrow=102
Dot=103
Ellipsis=104
Identifier=105
Constant=106
StringLiteral=107
LineDirective=108
PragmaDirective=109
Whitespace=110
Newline=111
BlockComment=112
LineComment=113
def __init__(self, input:TokenStream):
super().__init__(input)
self.checkVersion("4.5.1")
self._interp = ParserATNSimulator(self, self.atn, self.decisionsToDFA, self.sharedContextCache)
self._predicates = None
class PrimaryExpressionContext(ParserRuleContext):
def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
super().__init__(parent, invokingState)
self.parser = parser
def Identifier(self):
return self.getToken(CParser.Identifier, 0)
def Constant(self):
return self.getToken(CParser.Constant, 0)
def StringLiteral(self, i:int=None):
if i is None:
return self.getTokens(CParser.StringLiteral)
else:
return self.getToken(CParser.StringLiteral, i)
def expression(self):
return self.getTypedRuleContext(CParser.ExpressionContext,0)
def genericSelection(self):
return self.getTypedRuleContext(CParser.GenericSelectionContext,0)
def compoundStatement(self):
return self.getTypedRuleContext(CParser.CompoundStatementContext,0)
def unaryExpression(self):
return self.getTypedRuleContext(CParser.UnaryExpressionContext,0)
def typeName(self):
return self.getTypedRuleContext(CParser.TypeNameContext,0)
def getRuleIndex(self):
return CParser.RULE_primaryExpression
def enterRule(self, listener:ParseTreeListener):
if hasattr( listener, "enterPrimaryExpression" ):
listener.enterPrimaryExpression(self)
def exitRule(self, listener:ParseTreeListener):
if hasattr( listener, "exitPrimaryExpression" ):
listener.exitPrimaryExpression(self)
def accept(self, visitor:ParseTreeVisitor):
if hasattr( visitor, "visitPrimaryExpression" ):
return visitor.visitPrimaryExpression(self)
else:
return visitor.visitChildren(self)
def primaryExpression(self):
localctx = CParser.PrimaryExpressionContext(self, self._ctx, self.state)
self.enterRule(localctx, 0, self.RULE_primaryExpression)
self._la = 0 # Token type
try:
self.state = 201
la_ = self._interp.adaptivePredict(self._input,2,self._ctx)
if la_ == 1:
self.enterOuterAlt(localctx, 1)
self.state = 168
self.match(CParser.Identifier)
pass
elif la_ == 2:
self.enterOuterAlt(localctx, 2)
self.state = 169
self.match(CParser.Constant)
pass
elif la_ == 3:
self.enterOuterAlt(localctx, 3)
self.state = 171
self._errHandler.sync(self)
_alt = 1
while _alt!=2 and _alt!=ATN.INVALID_ALT_NUMBER:
if _alt == 1:
self.state = 170
self.match(CParser.StringLiteral)
else:
raise NoViableAltException(self)
self.state = 173
self._errHandler.sync(self)
_alt = self._interp.adaptivePredict(self._input,0,self._ctx)
pass
elif la_ == 4:
self.enterOuterAlt(localctx, 4)
self.state = 175
self.match(CParser.LeftParen)
self.state = 176
self.expression(0)
self.state = 177
self.match(CParser.RightParen)
pass
elif la_ == 5:
self.enterOuterAlt(localctx, 5)
self.state = 179
self.genericSelection()
pass
elif la_ == 6:
self.enterOuterAlt(localctx, 6)
self.state = 181
_la = self._input.LA(1)
if _la==CParser.T__0:
self.state = 180
self.match(CParser.T__0)
self.state = 183
self.match(CParser.LeftParen)
self.state = 184
self.compoundStatement()
self.state = 185
self.match(CParser.RightParen)
pass
elif la_ == 7:
self.enterOuterAlt(localctx, 7)
self.state = 187
self.match(CParser.T__1)
self.state = 188
self.match(CParser.LeftParen)
self.state = 189
self.unaryExpression()
self.state = 190
self.match(CParser.Comma)
self.state = 191
self.typeName()
self.state = 192
self.match(CParser.RightParen)
pass
elif la_ == 8:
self.enterOuterAlt(localctx, 8)
self.state = 194
self.match(CParser.T__2)
self.state = 195
self.match(CParser.LeftParen)
self.state = 196
self.typeName()
self.state = 197
self.match(CParser.Comma)
self.state = 198
self.unaryExpression()
self.state = 199
self.match(CParser.RightParen)
pass
except RecognitionException as re:
localctx.exception = re
self._errHandler.reportError(self, re)
self._errHandler.recover(self, re)
finally:
self.exitRule()
return localctx
class GenericSelectionContext(ParserRuleContext):
def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
super().__init__(parent, invokingState)
self.parser = parser
def assignmentExpression(self):
return self.getTypedRuleContext(CParser.AssignmentExpressionContext,0)
def genericAssocList(self):
return self.getTypedRuleContext(CParser.GenericAssocListContext,0)
def getRuleIndex(self):
return CParser.RULE_genericSelection
def enterRule(self, listener:ParseTreeListener):
if hasattr( listener, "enterGenericSelection" ):
listener.enterGenericSelection(self)
def exitRule(self, listener:ParseTreeListener):
if hasattr( listener, "exitGenericSelection" ):
listener.exitGenericSelection(self)
def accept(self, visitor:ParseTreeVisitor):
if hasattr( visitor, "visitGenericSelection" ):
return visitor.visitGenericSelection(self)
else:
return visitor.visitChildren(self)
def genericSelection(self):
localctx = CParser.GenericSelectionContext(self, self._ctx, self.state)
self.enterRule(localctx, 2, self.RULE_genericSelection)
try:
self.enterOuterAlt(localctx, 1)
self.state = 203
self.match(CParser.Generic)
self.state = 204
self.match(CParser.LeftParen)
self.state = 205
self.assignmentExpression()
self.state = 206
self.match(CParser.Comma)
self.state = 207
self.genericAssocList(0)
self.state = 208
self.match(CParser.RightParen)
except RecognitionException as re:
localctx.exception = re
self._errHandler.reportError(self, re)
self._errHandler.recover(self, re)
finally:
self.exitRule()
return localctx
class GenericAssocListContext(ParserRuleContext):
def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
super().__init__(parent, invokingState)
self.parser = parser
def genericAssociation(self):
return self.getTypedRuleContext(CParser.GenericAssociationContext,0)
def genericAssocList(self):
return self.getTypedRuleContext(CParser.GenericAssocListContext,0)
def getRuleIndex(self):
return CParser.RULE_genericAssocList
def enterRule(self, listener:ParseTreeListener):
if hasattr( listener, "enterGenericAssocList" ):
listener.enterGenericAssocList(self)
def exitRule(self, listener:ParseTreeListener):
if hasattr( listener, "exitGenericAssocList" ):
listener.exitGenericAssocList(self)
def accept(self, visitor:ParseTreeVisitor):
if hasattr( visitor, "visitGenericAssocList" ):
return visitor.visitGenericAssocList(self)
else:
return visitor.visitChildren(self)
def genericAssocList(self, _p:int=0):
_parentctx = self._ctx
_parentState = self.state
localctx = CParser.GenericAssocListContext(self, self._ctx, _parentState)
_prevctx = localctx
_startState = 4
self.enterRecursionRule(localctx, 4, self.RULE_genericAssocList, _p)
try:
self.enterOuterAlt(localctx, 1)
self.state = 211
self.genericAssociation()
self._ctx.stop = self._input.LT(-1)
self.state = 218
self._errHandler.sync(self)
_alt = self._interp.adaptivePredict(self._input,3,self._ctx)
while _alt!=2 and _alt!=ATN.INVALID_ALT_NUMBER:
if _alt==1:
if self._parseListeners is not None:
self.triggerExitRuleEvent()
_prevctx = localctx
localctx = CParser.GenericAssocListContext(self, _parentctx, _parentState)
self.pushNewRecursionContext(localctx, _startState, self.RULE_genericAssocList)
self.state = 213
if not self.precpred(self._ctx, 1):
from antlr4.error.Errors import FailedPredicateException
raise FailedPredicateException(self, "self.precpred(self._ctx, 1)")
self.state = 214
self.match(CParser.Comma)
self.state = 215
self.genericAssociation()
self.state = 220
self._errHandler.sync(self)
_alt = self._interp.adaptivePredict(self._input,3,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 GenericAssociationContext(ParserRuleContext):
def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
super().__init__(parent, invokingState)
self.parser = parser
def typeName(self):
return self.getTypedRuleContext(CParser.TypeNameContext,0)
def assignmentExpression(self):
return self.getTypedRuleContext(CParser.AssignmentExpressionContext,0)
def getRuleIndex(self):
return CParser.RULE_genericAssociation
def enterRule(self, listener:ParseTreeListener):
if hasattr( listener, "enterGenericAssociation" ):
listener.enterGenericAssociation(self)
def exitRule(self, listener:ParseTreeListener):
if hasattr( listener, "exitGenericAssociation" ):
listener.exitGenericAssociation(self)
def accept(self, visitor:ParseTreeVisitor):
if hasattr( visitor, "visitGenericAssociation" ):
return visitor.visitGenericAssociation(self)
else:
return visitor.visitChildren(self)
def genericAssociation(self):
localctx = CParser.GenericAssociationContext(self, self._ctx, self.state)
self.enterRule(localctx, 6, self.RULE_genericAssociation)
try:
self.state = 228
token = self._input.LA(1)
if token in [CParser.T__0, CParser.T__3, CParser.T__4, CParser.T__5, CParser.T__6, CParser.Char, CParser.Const, CParser.Double, CParser.Enum, CParser.Float, CParser.Int, CParser.Long, CParser.Restrict, CParser.Short, CParser.Signed, CParser.Struct, CParser.Union, CParser.Unsigned, CParser.Void, CParser.Volatile, CParser.Atomic, CParser.Bool, CParser.Complex, CParser.Identifier]:
self.enterOuterAlt(localctx, 1)
self.state = 221
self.typeName()
self.state = 222
self.match(CParser.Colon)
self.state = 223
self.assignmentExpression()
elif token in [CParser.Default]:
self.enterOuterAlt(localctx, 2)
self.state = 225
self.match(CParser.Default)
self.state = 226
self.match(CParser.Colon)
self.state = 227
self.assignmentExpression()
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 PostfixExpressionContext(ParserRuleContext):
def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
super().__init__(parent, invokingState)
self.parser = parser
def primaryExpression(self):
return self.getTypedRuleContext(CParser.PrimaryExpressionContext,0)
def typeName(self):
return self.getTypedRuleContext(CParser.TypeNameContext,0)
def initializerList(self):
return self.getTypedRuleContext(CParser.InitializerListContext,0)
def postfixExpression(self):
return self.getTypedRuleContext(CParser.PostfixExpressionContext,0)
def expression(self):
return self.getTypedRuleContext(CParser.ExpressionContext,0)
def argumentExpressionList(self):
return self.getTypedRuleContext(CParser.ArgumentExpressionListContext,0)
def Identifier(self):
return self.getToken(CParser.Identifier, 0)
def getRuleIndex(self):
return CParser.RULE_postfixExpression
def enterRule(self, listener:ParseTreeListener):
if hasattr( listener, "enterPostfixExpression" ):
listener.enterPostfixExpression(self)
def exitRule(self, listener:ParseTreeListener):
if hasattr( listener, "exitPostfixExpression" ):
listener.exitPostfixExpression(self)
def accept(self, visitor:ParseTreeVisitor):
if hasattr( visitor, "visitPostfixExpression" ):
return visitor.visitPostfixExpression(self)
else:
return visitor.visitChildren(self)
def postfixExpression(self, _p:int=0):
_parentctx = self._ctx
_parentState = self.state
localctx = CParser.PostfixExpressionContext(self, self._ctx, _parentState)
_prevctx = localctx
_startState = 8
self.enterRecursionRule(localctx, 8, self.RULE_postfixExpression, _p)
self._la = 0 # Token type
try:
self.enterOuterAlt(localctx, 1)
self.state = 264
la_ = self._interp.adaptivePredict(self._input,5,self._ctx)
if la_ == 1:
self.state = 231
self.primaryExpression()
pass
elif la_ == 2:
self.state = 232
self.match(CParser.LeftParen)
self.state = 233
self.typeName()
self.state = 234
self.match(CParser.RightParen)
self.state = 235
self.match(CParser.LeftBrace)
self.state = 236
self.initializerList(0)
self.state = 237
self.match(CParser.RightBrace)
pass
elif la_ == 3:
self.state = 239
self.match(CParser.LeftParen)
self.state = 240
self.typeName()
self.state = 241
self.match(CParser.RightParen)
self.state = 242
self.match(CParser.LeftBrace)
self.state = 243
self.initializerList(0)
self.state = 244
self.match(CParser.Comma)
self.state = 245
self.match(CParser.RightBrace)
pass
elif la_ == 4:
self.state = 247
self.match(CParser.T__0)
self.state = 248
self.match(CParser.LeftParen)
self.state = 249
self.typeName()
self.state = 250
self.match(CParser.RightParen)
self.state = 251
self.match(CParser.LeftBrace)
self.state = 252
self.initializerList(0)
self.state = 253
self.match(CParser.RightBrace)
pass
elif la_ == 5:
self.state = 255
self.match(CParser.T__0)
self.state = 256
self.match(CParser.LeftParen)
self.state = 257
self.typeName()
self.state = 258
self.match(CParser.RightParen)
self.state = 259
self.match(CParser.LeftBrace)
self.state = 260
self.initializerList(0)
self.state = 261
self.match(CParser.Comma)
self.state = 262
self.match(CParser.RightBrace)
pass
self._ctx.stop = self._input.LT(-1)
self.state = 289
self._errHandler.sync(self)
_alt = self._interp.adaptivePredict(self._input,8,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 = 287
la_ = self._interp.adaptivePredict(self._input,7,self._ctx)
if la_ == 1:
localctx = CParser.PostfixExpressionContext(self, _parentctx, _parentState)
self.pushNewRecursionContext(localctx, _startState, self.RULE_postfixExpression)
self.state = 266
if not self.precpred(self._ctx, 10):
from antlr4.error.Errors import FailedPredicateException
raise FailedPredicateException(self, "self.precpred(self._ctx, 10)")
self.state = 267
self.match(CParser.LeftBracket)
self.state = 268
self.expression(0)
self.state = 269
self.match(CParser.RightBracket)
pass
elif la_ == 2:
localctx = CParser.PostfixExpressionContext(self, _parentctx, _parentState)
self.pushNewRecursionContext(localctx, _startState, self.RULE_postfixExpression)
self.state = 271
if not self.precpred(self._ctx, 9):
from antlr4.error.Errors import FailedPredicateException
raise FailedPredicateException(self, "self.precpred(self._ctx, 9)")
self.state = 272
self.match(CParser.LeftParen)
self.state = 274
_la = self._input.LA(1)
if (((_la) & ~0x3f) == 0 and ((1 << _la) & ((1 << CParser.T__0) | (1 << CParser.T__1) | (1 << CParser.T__2) | (1 << CParser.Sizeof) | (1 << CParser.Alignof) | (1 << CParser.Generic) | (1 << CParser.LeftParen))) != 0) or ((((_la - 71)) & ~0x3f) == 0 and ((1 << (_la - 71)) & ((1 << (CParser.Plus - 71)) | (1 << (CParser.PlusPlus - 71)) | (1 << (CParser.Minus - 71)) | (1 << (CParser.MinusMinus - 71)) | (1 << (CParser.Star - 71)) | (1 << (CParser.And - 71)) | (1 << (CParser.AndAnd - 71)) | (1 << (CParser.Not - 71)) | (1 << (CParser.Tilde - 71)) | (1 << (CParser.Identifier - 71)) | (1 << (CParser.Constant - 71)) | (1 << (CParser.StringLiteral - 71)))) != 0):
self.state = 273
self.argumentExpressionList(0)
self.state = 276
self.match(CParser.RightParen)
pass
elif la_ == 3:
localctx = CParser.PostfixExpressionContext(self, _parentctx, _parentState)
self.pushNewRecursionContext(localctx, _startState, self.RULE_postfixExpression)
self.state = 277
if not self.precpred(self._ctx, 8):
from antlr4.error.Errors import FailedPredicateException
raise FailedPredicateException(self, "self.precpred(self._ctx, 8)")
self.state = 278
self.match(CParser.Dot)
self.state = 279
self.match(CParser.Identifier)
pass
elif la_ == 4:
localctx = CParser.PostfixExpressionContext(self, _parentctx, _parentState)
self.pushNewRecursionContext(localctx, _startState, self.RULE_postfixExpression)
self.state = 280
if not self.precpred(self._ctx, 7):
from antlr4.error.Errors import FailedPredicateException
raise FailedPredicateException(self, "self.precpred(self._ctx, 7)")
self.state = 281
self.match(CParser.Arrow)
self.state = 282
self.match(CParser.Identifier)
pass
elif la_ == 5:
localctx = CParser.PostfixExpressionContext(self, _parentctx, _parentState)
self.pushNewRecursionContext(localctx, _startState, self.RULE_postfixExpression)
self.state = 283
if not self.precpred(self._ctx, 6):
from antlr4.error.Errors import FailedPredicateException
raise FailedPredicateException(self, "self.precpred(self._ctx, 6)")
self.state = 284
self.match(CParser.PlusPlus)
pass
elif la_ == 6:
localctx = CParser.PostfixExpressionContext(self, _parentctx, _parentState)
self.pushNewRecursionContext(localctx, _startState, self.RULE_postfixExpression)
self.state = 285
if not self.precpred(self._ctx, 5):
from antlr4.error.Errors import FailedPredicateException
raise FailedPredicateException(self, "self.precpred(self._ctx, 5)")
self.state = 286
self.match(CParser.MinusMinus)
pass
self.state = 291
self._errHandler.sync(self)
_alt = self._interp.adaptivePredict(self._input,8,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 ArgumentExpressionListContext(ParserRuleContext):
def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
super().__init__(parent, invokingState)
self.parser = parser
def assignmentExpression(self):
return self.getTypedRuleContext(CParser.AssignmentExpressionContext,0)
def argumentExpressionList(self):
return self.getTypedRuleContext(CParser.ArgumentExpressionListContext,0)
def getRuleIndex(self):
return CParser.RULE_argumentExpressionList
def enterRule(self, listener:ParseTreeListener):
if hasattr( listener, "enterArgumentExpressionList" ):
listener.enterArgumentExpressionList(self)
def exitRule(self, listener:ParseTreeListener):
if hasattr( listener, "exitArgumentExpressionList" ):
listener.exitArgumentExpressionList(self)
def accept(self, visitor:ParseTreeVisitor):
if hasattr( visitor, "visitArgumentExpressionList" ):
return visitor.visitArgumentExpressionList(self)
else:
return visitor.visitChildren(self)
def argumentExpressionList(self, _p:int=0):
_parentctx = self._ctx
_parentState = self.state
localctx = CParser.ArgumentExpressionListContext(self, self._ctx, _parentState)
_prevctx = localctx
_startState = 10
self.enterRecursionRule(localctx, 10, self.RULE_argumentExpressionList, _p)
try:
self.enterOuterAlt(localctx, 1)
self.state = 293
self.assignmentExpression()
self._ctx.stop = self._input.LT(-1)
self.state = 300
self._errHandler.sync(self)
_alt = self._interp.adaptivePredict(self._input,9,self._ctx)
while _alt!=2 and _alt!=ATN.INVALID_ALT_NUMBER:
if _alt==1:
if self._parseListeners is not None:
self.triggerExitRuleEvent()
_prevctx = localctx
localctx = CParser.ArgumentExpressionListContext(self, _parentctx, _parentState)
self.pushNewRecursionContext(localctx, _startState, self.RULE_argumentExpressionList)
self.state = 295
if not self.precpred(self._ctx, 1):
from antlr4.error.Errors import FailedPredicateException
raise FailedPredicateException(self, "self.precpred(self._ctx, 1)")
self.state = 296
self.match(CParser.Comma)
self.state = 297
self.assignmentExpression()
self.state = 302
self._errHandler.sync(self)
_alt = self._interp.adaptivePredict(self._input,9,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 UnaryExpressionContext(ParserRuleContext):
def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
super().__init__(parent, invokingState)
self.parser = parser
def postfixExpression(self):
return self.getTypedRuleContext(CParser.PostfixExpressionContext,0)
def unaryExpression(self):
return self.getTypedRuleContext(CParser.UnaryExpressionContext,0)
def unaryOperator(self):
return self.getTypedRuleContext(CParser.UnaryOperatorContext,0)
def castExpression(self):
return self.getTypedRuleContext(CParser.CastExpressionContext,0)
def typeName(self):
return self.getTypedRuleContext(CParser.TypeNameContext,0)
def Identifier(self):
return self.getToken(CParser.Identifier, 0)
def getRuleIndex(self):
return CParser.RULE_unaryExpression
def enterRule(self, listener:ParseTreeListener):
if hasattr( listener, "enterUnaryExpression" ):
listener.enterUnaryExpression(self)
def exitRule(self, listener:ParseTreeListener):
if hasattr( listener, "exitUnaryExpression" ):
listener.exitUnaryExpression(self)
def accept(self, visitor:ParseTreeVisitor):
if hasattr( visitor, "visitUnaryExpression" ):
return visitor.visitUnaryExpression(self)
else:
return visitor.visitChildren(self)
def unaryExpression(self):
localctx = CParser.UnaryExpressionContext(self, self._ctx, self.state)
self.enterRule(localctx, 12, self.RULE_unaryExpression)
try:
self.state = 325
la_ = self._interp.adaptivePredict(self._input,10,self._ctx)
if la_ == 1:
self.enterOuterAlt(localctx, 1)
self.state = 303
self.postfixExpression(0)
pass
elif la_ == 2:
self.enterOuterAlt(localctx, 2)
self.state = 304
self.match(CParser.PlusPlus)
self.state = 305
self.unaryExpression()
pass
elif la_ == 3:
self.enterOuterAlt(localctx, 3)
self.state = 306
self.match(CParser.MinusMinus)
self.state = 307
self.unaryExpression()
pass
elif la_ == 4:
self.enterOuterAlt(localctx, 4)
self.state = 308
self.unaryOperator()
self.state = 309
self.castExpression()
pass
elif la_ == 5:
self.enterOuterAlt(localctx, 5)
self.state = 311
self.match(CParser.Sizeof)
self.state = 312
self.unaryExpression()
pass
elif la_ == 6:
self.enterOuterAlt(localctx, 6)
self.state = 313
self.match(CParser.Sizeof)
self.state = 314
self.match(CParser.LeftParen)
self.state = 315
self.typeName()
self.state = 316
self.match(CParser.RightParen)
pass
elif la_ == 7:
self.enterOuterAlt(localctx, 7)
self.state = 318
self.match(CParser.Alignof)
self.state = 319
self.match(CParser.LeftParen)
self.state = 320
self.typeName()
self.state = 321
self.match(CParser.RightParen)
pass
elif la_ == 8:
self.enterOuterAlt(localctx, 8)
self.state = 323
self.match(CParser.AndAnd)
self.state = 324
self.match(CParser.Identifier)
pass
except RecognitionException as re:
localctx.exception = re
self._errHandler.reportError(self, re)
self._errHandler.recover(self, re)
finally:
self.exitRule()
return localctx
class UnaryOperatorContext(ParserRuleContext):
def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
super().__init__(parent, invokingState)
self.parser = parser
def getRuleIndex(self):
return CParser.RULE_unaryOperator
def enterRule(self, listener:ParseTreeListener):
if hasattr( listener, "enterUnaryOperator" ):
listener.enterUnaryOperator(self)
def exitRule(self, listener:ParseTreeListener):
if hasattr( listener, "exitUnaryOperator" ):
listener.exitUnaryOperator(self)
def accept(self, visitor:ParseTreeVisitor):
if hasattr( visitor, "visitUnaryOperator" ):
return visitor.visitUnaryOperator(self)
else:
return visitor.visitChildren(self)
def unaryOperator(self):
localctx = CParser.UnaryOperatorContext(self, self._ctx, self.state)
self.enterRule(localctx, 14, self.RULE_unaryOperator)
self._la = 0 # Token type
try:
self.enterOuterAlt(localctx, 1)
self.state = 327
_la = self._input.LA(1)
if not(((((_la - 71)) & ~0x3f) == 0 and ((1 << (_la - 71)) & ((1 << (CParser.Plus - 71)) | (1 << (CParser.Minus - 71)) | (1 << (CParser.Star - 71)) | (1 << (CParser.And - 71)) | (1 << (CParser.Not - 71)) | (1 << (CParser.Tilde - 71)))) != 0)):
self._errHandler.recoverInline(self)
else:
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 CastExpressionContext(ParserRuleContext):
def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
super().__init__(parent, invokingState)
self.parser = parser
def unaryExpression(self):
return self.getTypedRuleContext(CParser.UnaryExpressionContext,0)
def typeName(self):
return self.getTypedRuleContext(CParser.TypeNameContext,0)
def castExpression(self):
return self.getTypedRuleContext(CParser.CastExpressionContext,0)
def getRuleIndex(self):
return CParser.RULE_castExpression
def enterRule(self, listener:ParseTreeListener):
if hasattr( listener, "enterCastExpression" ):
listener.enterCastExpression(self)
def exitRule(self, listener:ParseTreeListener):
if hasattr( listener, "exitCastExpression" ):
listener.exitCastExpression(self)
def accept(self, visitor:ParseTreeVisitor):
if hasattr( visitor, "visitCastExpression" ):
return visitor.visitCastExpression(self)
else:
return visitor.visitChildren(self)
def castExpression(self):
localctx = CParser.CastExpressionContext(self, self._ctx, self.state)
self.enterRule(localctx, 16, self.RULE_castExpression)
try:
self.state = 341
la_ = self._interp.adaptivePredict(self._input,11,self._ctx)
if la_ == 1:
self.enterOuterAlt(localctx, 1)
self.state = 329
self.unaryExpression()
pass
elif la_ == 2:
self.enterOuterAlt(localctx, 2)
self.state = 330
self.match(CParser.LeftParen)
self.state = 331
self.typeName()
self.state = 332
self.match(CParser.RightParen)
self.state = 333
self.castExpression()
pass
elif la_ == 3:
self.enterOuterAlt(localctx, 3)
self.state = 335
self.match(CParser.T__0)
self.state = 336
self.match(CParser.LeftParen)
self.state = 337
self.typeName()
self.state = 338
self.match(CParser.RightParen)
self.state = 339
self.castExpression()
pass
except RecognitionException as re:
localctx.exception = re
self._errHandler.reportError(self, re)
self._errHandler.recover(self, re)
finally:
self.exitRule()
return localctx
class MultiplicativeExpressionContext(ParserRuleContext):
def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
super().__init__(parent, invokingState)
self.parser = parser
def castExpression(self):
return self.getTypedRuleContext(CParser.CastExpressionContext,0)
def multiplicativeExpression(self):
return self.getTypedRuleContext(CParser.MultiplicativeExpressionContext,0)
def getRuleIndex(self):
return CParser.RULE_multiplicativeExpression
def enterRule(self, listener:ParseTreeListener):
if hasattr( listener, "enterMultiplicativeExpression" ):
listener.enterMultiplicativeExpression(self)
def exitRule(self, listener:ParseTreeListener):
if hasattr( listener, "exitMultiplicativeExpression" ):
listener.exitMultiplicativeExpression(self)
def accept(self, visitor:ParseTreeVisitor):
if hasattr( visitor, "visitMultiplicativeExpression" ):
return visitor.visitMultiplicativeExpression(self)
else:
return visitor.visitChildren(self)
def multiplicativeExpression(self, _p:int=0):
_parentctx = self._ctx
_parentState = self.state
localctx = CParser.MultiplicativeExpressionContext(self, self._ctx, _parentState)
_prevctx = localctx
_startState = 18
self.enterRecursionRule(localctx, 18, self.RULE_multiplicativeExpression, _p)
try:
self.enterOuterAlt(localctx, 1)
self.state = 344
self.castExpression()
self._ctx.stop = self._input.LT(-1)
self.state = 357
self._errHandler.sync(self)
_alt = self._interp.adaptivePredict(self._input,13,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 = 355
la_ = self._interp.adaptivePredict(self._input,12,self._ctx)
if la_ == 1:
localctx = CParser.MultiplicativeExpressionContext(self, _parentctx, _parentState)
self.pushNewRecursionContext(localctx, _startState, self.RULE_multiplicativeExpression)
self.state = 346
if not self.precpred(self._ctx, 3):
from antlr4.error.Errors import FailedPredicateException
raise FailedPredicateException(self, "self.precpred(self._ctx, 3)")
self.state = 347
self.match(CParser.Star)
self.state = 348
self.castExpression()
pass
elif la_ == 2:
localctx = CParser.MultiplicativeExpressionContext(self, _parentctx, _parentState)
self.pushNewRecursionContext(localctx, _startState, self.RULE_multiplicativeExpression)
self.state = 349
if not self.precpred(self._ctx, 2):
from antlr4.error.Errors import FailedPredicateException
raise FailedPredicateException(self, "self.precpred(self._ctx, 2)")
self.state = 350
self.match(CParser.Div)
self.state = 351
self.castExpression()
pass
elif la_ == 3:
localctx = CParser.MultiplicativeExpressionContext(self, _parentctx, _parentState)
self.pushNewRecursionContext(localctx, _startState, self.RULE_multiplicativeExpression)
self.state = 352
if not self.precpred(self._ctx, 1):
from antlr4.error.Errors import FailedPredicateException
raise FailedPredicateException(self, "self.precpred(self._ctx, 1)")
self.state = 353
self.match(CParser.Mod)
self.state = 354
self.castExpression()
pass
self.state = 359
self._errHandler.sync(self)
_alt = self._interp.adaptivePredict(self._input,13,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 AdditiveExpressionContext(ParserRuleContext):
def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
super().__init__(parent, invokingState)
self.parser = parser
def multiplicativeExpression(self):
return self.getTypedRuleContext(CParser.MultiplicativeExpressionContext,0)
def additiveExpression(self):
return self.getTypedRuleContext(CParser.AdditiveExpressionContext,0)
def getRuleIndex(self):
return CParser.RULE_additiveExpression
def enterRule(self, listener:ParseTreeListener):
if hasattr( listener, "enterAdditiveExpression" ):
listener.enterAdditiveExpression(self)
def exitRule(self, listener:ParseTreeListener):
if hasattr( listener, "exitAdditiveExpression" ):
listener.exitAdditiveExpression(self)
def accept(self, visitor:ParseTreeVisitor):
if hasattr( visitor, "visitAdditiveExpression" ):
return visitor.visitAdditiveExpression(self)
else:
return visitor.visitChildren(self)
def additiveExpression(self, _p:int=0):
_parentctx = self._ctx
_parentState = self.state
localctx = CParser.AdditiveExpressionContext(self, self._ctx, _parentState)
_prevctx = localctx
_startState = 20
self.enterRecursionRule(localctx, 20, self.RULE_additiveExpression, _p)
try:
self.enterOuterAlt(localctx, 1)
self.state = 361
self.multiplicativeExpression(0)
self._ctx.stop = self._input.LT(-1)
self.state = 371
self._errHandler.sync(self)
_alt = self._interp.adaptivePredict(self._input,15,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 = 369
la_ = self._interp.adaptivePredict(self._input,14,self._ctx)
if la_ == 1:
localctx = CParser.AdditiveExpressionContext(self, _parentctx, _parentState)
self.pushNewRecursionContext(localctx, _startState, self.RULE_additiveExpression)
self.state = 363
if not self.precpred(self._ctx, 2):
from antlr4.error.Errors import FailedPredicateException
raise FailedPredicateException(self, "self.precpred(self._ctx, 2)")
self.state = 364
self.match(CParser.Plus)
self.state = 365
self.multiplicativeExpression(0)
pass
elif la_ == 2:
localctx = CParser.AdditiveExpressionContext(self, _parentctx, _parentState)
self.pushNewRecursionContext(localctx, _startState, self.RULE_additiveExpression)
self.state = 366
if not self.precpred(self._ctx, 1):
from antlr4.error.Errors import FailedPredicateException
raise FailedPredicateException(self, "self.precpred(self._ctx, 1)")
self.state = 367
self.match(CParser.Minus)
self.state = 368
self.multiplicativeExpression(0)
pass
self.state = 373
self._errHandler.sync(self)
_alt = self._interp.adaptivePredict(self._input,15,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 ShiftExpressionContext(ParserRuleContext):
def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
super().__init__(parent, invokingState)
self.parser = parser
def additiveExpression(self):
return self.getTypedRuleContext(CParser.AdditiveExpressionContext,0)
def shiftExpression(self):
return self.getTypedRuleContext(CParser.ShiftExpressionContext,0)
def getRuleIndex(self):
return CParser.RULE_shiftExpression
def enterRule(self, listener:ParseTreeListener):
if hasattr( listener, "enterShiftExpression" ):
listener.enterShiftExpression(self)
def exitRule(self, listener:ParseTreeListener):
if hasattr( listener, "exitShiftExpression" ):
listener.exitShiftExpression(self)
def accept(self, visitor:ParseTreeVisitor):
if hasattr( visitor, "visitShiftExpression" ):
return visitor.visitShiftExpression(self)
else:
return visitor.visitChildren(self)
def shiftExpression(self, _p:int=0):
_parentctx = self._ctx
_parentState = self.state
localctx = CParser.ShiftExpressionContext(self, self._ctx, _parentState)
_prevctx = localctx
_startState = 22
self.enterRecursionRule(localctx, 22, self.RULE_shiftExpression, _p)
try:
self.enterOuterAlt(localctx, 1)
self.state = 375
self.additiveExpression(0)
self._ctx.stop = self._input.LT(-1)
self.state = 385
self._errHandler.sync(self)
_alt = self._interp.adaptivePredict(self._input,17,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 = 383
la_ = self._interp.adaptivePredict(self._input,16,self._ctx)
if la_ == 1:
localctx = CParser.ShiftExpressionContext(self, _parentctx, _parentState)
self.pushNewRecursionContext(localctx, _startState, self.RULE_shiftExpression)
self.state = 377
if not self.precpred(self._ctx, 2):
from antlr4.error.Errors import FailedPredicateException
raise FailedPredicateException(self, "self.precpred(self._ctx, 2)")
self.state = 378
self.match(CParser.LeftShift)
self.state = 379
self.additiveExpression(0)
pass
elif la_ == 2:
localctx = CParser.ShiftExpressionContext(self, _parentctx, _parentState)
self.pushNewRecursionContext(localctx, _startState, self.RULE_shiftExpression)
self.state = 380
if not self.precpred(self._ctx, 1):
from antlr4.error.Errors import FailedPredicateException
raise FailedPredicateException(self, "self.precpred(self._ctx, 1)")
self.state = 381
self.match(CParser.RightShift)
self.state = 382
self.additiveExpression(0)
pass
self.state = 387
self._errHandler.sync(self)
_alt = self._interp.adaptivePredict(self._input,17,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 RelationalExpressionContext(ParserRuleContext):
def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
super().__init__(parent, invokingState)
self.parser = parser
def shiftExpression(self):
return self.getTypedRuleContext(CParser.ShiftExpressionContext,0)
def relationalExpression(self):
return self.getTypedRuleContext(CParser.RelationalExpressionContext,0)
def getRuleIndex(self):
return CParser.RULE_relationalExpression
def enterRule(self, listener:ParseTreeListener):
if hasattr( listener, "enterRelationalExpression" ):
listener.enterRelationalExpression(self)
def exitRule(self, listener:ParseTreeListener):
if hasattr( listener, "exitRelationalExpression" ):
listener.exitRelationalExpression(self)
def accept(self, visitor:ParseTreeVisitor):
if hasattr( visitor, "visitRelationalExpression" ):
return visitor.visitRelationalExpression(self)
else:
return visitor.visitChildren(self)
def relationalExpression(self, _p:int=0):
_parentctx = self._ctx
_parentState = self.state
localctx = CParser.RelationalExpressionContext(self, self._ctx, _parentState)
_prevctx = localctx
_startState = 24
self.enterRecursionRule(localctx, 24, self.RULE_relationalExpression, _p)
try:
self.enterOuterAlt(localctx, 1)
self.state = 389
self.shiftExpression(0)
self._ctx.stop = self._input.LT(-1)
self.state = 405
self._errHandler.sync(self)
_alt = self._interp.adaptivePredict(self._input,19,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 = 403
la_ = self._interp.adaptivePredict(self._input,18,self._ctx)
if la_ == 1:
localctx = CParser.RelationalExpressionContext(self, _parentctx, _parentState)
self.pushNewRecursionContext(localctx, _startState, self.RULE_relationalExpression)
self.state = 391
if not self.precpred(self._ctx, 4):
from antlr4.error.Errors import FailedPredicateException
raise FailedPredicateException(self, "self.precpred(self._ctx, 4)")
self.state = 392
self.match(CParser.Less)
self.state = 393
self.shiftExpression(0)
pass
elif la_ == 2:
localctx = CParser.RelationalExpressionContext(self, _parentctx, _parentState)
self.pushNewRecursionContext(localctx, _startState, self.RULE_relationalExpression)
self.state = 394
if not self.precpred(self._ctx, 3):
from antlr4.error.Errors import FailedPredicateException
raise FailedPredicateException(self, "self.precpred(self._ctx, 3)")
self.state = 395
self.match(CParser.Greater)
self.state = 396
self.shiftExpression(0)
pass
elif la_ == 3:
localctx = CParser.RelationalExpressionContext(self, _parentctx, _parentState)
self.pushNewRecursionContext(localctx, _startState, self.RULE_relationalExpression)
self.state = 397
if not self.precpred(self._ctx, 2):
from antlr4.error.Errors import FailedPredicateException
raise FailedPredicateException(self, "self.precpred(self._ctx, 2)")
self.state = 398
self.match(CParser.LessEqual)
self.state = 399
self.shiftExpression(0)
pass
elif la_ == 4:
localctx = CParser.RelationalExpressionContext(self, _parentctx, _parentState)
self.pushNewRecursionContext(localctx, _startState, self.RULE_relationalExpression)
self.state = 400
if not self.precpred(self._ctx, 1):
from antlr4.error.Errors import FailedPredicateException
raise FailedPredicateException(self, "self.precpred(self._ctx, 1)")
self.state = 401
self.match(CParser.GreaterEqual)
self.state = 402
self.shiftExpression(0)
pass
self.state = 407
self._errHandler.sync(self)
_alt = self._interp.adaptivePredict(self._input,19,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 EqualityExpressionContext(ParserRuleContext):
def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
super().__init__(parent, invokingState)
self.parser = parser
def relationalExpression(self):
return self.getTypedRuleContext(CParser.RelationalExpressionContext,0)
def equalityExpression(self):
return self.getTypedRuleContext(CParser.EqualityExpressionContext,0)
def getRuleIndex(self):
return CParser.RULE_equalityExpression
def enterRule(self, listener:ParseTreeListener):
if hasattr( listener, "enterEqualityExpression" ):
listener.enterEqualityExpression(self)
def exitRule(self, listener:ParseTreeListener):
if hasattr( listener, "exitEqualityExpression" ):
listener.exitEqualityExpression(self)
def accept(self, visitor:ParseTreeVisitor):
if hasattr( visitor, "visitEqualityExpression" ):
return visitor.visitEqualityExpression(self)
else:
return visitor.visitChildren(self)
def equalityExpression(self, _p:int=0):
_parentctx = self._ctx
_parentState = self.state
localctx = CParser.EqualityExpressionContext(self, self._ctx, _parentState)
_prevctx = localctx
_startState = 26
self.enterRecursionRule(localctx, 26, self.RULE_equalityExpression, _p)
try:
self.enterOuterAlt(localctx, 1)
self.state = 409
self.relationalExpression(0)
self._ctx.stop = self._input.LT(-1)
self.state = 419
self._errHandler.sync(self)
_alt = self._interp.adaptivePredict(self._input,21,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 = 417
la_ = self._interp.adaptivePredict(self._input,20,self._ctx)
if la_ == 1:
localctx = CParser.EqualityExpressionContext(self, _parentctx, _parentState)
self.pushNewRecursionContext(localctx, _startState, self.RULE_equalityExpression)
self.state = 411
if not self.precpred(self._ctx, 2):
from antlr4.error.Errors import FailedPredicateException
raise FailedPredicateException(self, "self.precpred(self._ctx, 2)")
self.state = 412
self.match(CParser.Equal)
self.state = 413
self.relationalExpression(0)
pass
elif la_ == 2:
localctx = CParser.EqualityExpressionContext(self, _parentctx, _parentState)
self.pushNewRecursionContext(localctx, _startState, self.RULE_equalityExpression)
self.state = 414
if not self.precpred(self._ctx, 1):
from antlr4.error.Errors import FailedPredicateException
raise FailedPredicateException(self, "self.precpred(self._ctx, 1)")
self.state = 415
self.match(CParser.NotEqual)
self.state = 416
self.relationalExpression(0)
pass
self.state = 421
self._errHandler.sync(self)
_alt = self._interp.adaptivePredict(self._input,21,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 AndExpressionContext(ParserRuleContext):
def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
super().__init__(parent, invokingState)
self.parser = parser
def equalityExpression(self):
return self.getTypedRuleContext(CParser.EqualityExpressionContext,0)
def andExpression(self):
return self.getTypedRuleContext(CParser.AndExpressionContext,0)
def getRuleIndex(self):
return CParser.RULE_andExpression
def enterRule(self, listener:ParseTreeListener):
if hasattr( listener, "enterAndExpression" ):
listener.enterAndExpression(self)
def exitRule(self, listener:ParseTreeListener):
if hasattr( listener, "exitAndExpression" ):
listener.exitAndExpression(self)
def accept(self, visitor:ParseTreeVisitor):
if hasattr( visitor, "visitAndExpression" ):
return visitor.visitAndExpression(self)
else:
return visitor.visitChildren(self)
def andExpression(self, _p:int=0):
_parentctx = self._ctx
_parentState = self.state
localctx = CParser.AndExpressionContext(self, self._ctx, _parentState)
_prevctx = localctx
_startState = 28
self.enterRecursionRule(localctx, 28, self.RULE_andExpression, _p)
try:
self.enterOuterAlt(localctx, 1)
self.state = 423
self.equalityExpression(0)
self._ctx.stop = self._input.LT(-1)
self.state = 430
self._errHandler.sync(self)
_alt = self._interp.adaptivePredict(self._input,22,self._ctx)
while _alt!=2 and _alt!=ATN.INVALID_ALT_NUMBER:
if _alt==1:
if self._parseListeners is not None:
self.triggerExitRuleEvent()
_prevctx = localctx
localctx = CParser.AndExpressionContext(self, _parentctx, _parentState)
self.pushNewRecursionContext(localctx, _startState, self.RULE_andExpression)
self.state = 425
if not self.precpred(self._ctx, 1):
from antlr4.error.Errors import FailedPredicateException
raise FailedPredicateException(self, "self.precpred(self._ctx, 1)")
self.state = 426
self.match(CParser.And)
self.state = 427
self.equalityExpression(0)
self.state = 432
self._errHandler.sync(self)
_alt = self._interp.adaptivePredict(self._input,22,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 ExclusiveOrExpressionContext(ParserRuleContext):
def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
super().__init__(parent, invokingState)
self.parser = parser
def andExpression(self):
return self.getTypedRuleContext(CParser.AndExpressionContext,0)
def exclusiveOrExpression(self):
return self.getTypedRuleContext(CParser.ExclusiveOrExpressionContext,0)
def getRuleIndex(self):
return CParser.RULE_exclusiveOrExpression
def enterRule(self, listener:ParseTreeListener):
if hasattr( listener, "enterExclusiveOrExpression" ):
listener.enterExclusiveOrExpression(self)
def exitRule(self, listener:ParseTreeListener):
if hasattr( listener, "exitExclusiveOrExpression" ):
listener.exitExclusiveOrExpression(self)
def accept(self, visitor:ParseTreeVisitor):
if hasattr( visitor, "visitExclusiveOrExpression" ):
return visitor.visitExclusiveOrExpression(self)
else:
return visitor.visitChildren(self)
def exclusiveOrExpression(self, _p:int=0):
_parentctx = self._ctx
_parentState = self.state
localctx = CParser.ExclusiveOrExpressionContext(self, self._ctx, _parentState)
_prevctx = localctx
_startState = 30
self.enterRecursionRule(localctx, 30, self.RULE_exclusiveOrExpression, _p)
try:
self.enterOuterAlt(localctx, 1)
self.state = 434
self.andExpression(0)
self._ctx.stop = self._input.LT(-1)
self.state = 441
self._errHandler.sync(self)
_alt = self._interp.adaptivePredict(self._input,23,self._ctx)
while _alt!=2 and _alt!=ATN.INVALID_ALT_NUMBER:
if _alt==1:
if self._parseListeners is not None:
self.triggerExitRuleEvent()
_prevctx = localctx
localctx = CParser.ExclusiveOrExpressionContext(self, _parentctx, _parentState)
self.pushNewRecursionContext(localctx, _startState, self.RULE_exclusiveOrExpression)
self.state = 436
if not self.precpred(self._ctx, 1):
from antlr4.error.Errors import FailedPredicateException
raise FailedPredicateException(self, "self.precpred(self._ctx, 1)")
self.state = 437
self.match(CParser.Caret)
self.state = 438
self.andExpression(0)
self.state = 443
self._errHandler.sync(self)
_alt = self._interp.adaptivePredict(self._input,23,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 InclusiveOrExpressionContext(ParserRuleContext):
def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
super().__init__(parent, invokingState)
self.parser = parser
def exclusiveOrExpression(self):
return self.getTypedRuleContext(CParser.ExclusiveOrExpressionContext,0)
def inclusiveOrExpression(self):
return self.getTypedRuleContext(CParser.InclusiveOrExpressionContext,0)
def getRuleIndex(self):
return CParser.RULE_inclusiveOrExpression
def enterRule(self, listener:ParseTreeListener):
if hasattr( listener, "enterInclusiveOrExpression" ):
listener.enterInclusiveOrExpression(self)
def exitRule(self, listener:ParseTreeListener):
if hasattr( listener, "exitInclusiveOrExpression" ):
listener.exitInclusiveOrExpression(self)
def accept(self, visitor:ParseTreeVisitor):
if hasattr( visitor, "visitInclusiveOrExpression" ):
return visitor.visitInclusiveOrExpression(self)
else:
return visitor.visitChildren(self)
def inclusiveOrExpression(self, _p:int=0):
_parentctx = self._ctx
_parentState = self.state
localctx = CParser.InclusiveOrExpressionContext(self, self._ctx, _parentState)
_prevctx = localctx
_startState = 32
self.enterRecursionRule(localctx, 32, self.RULE_inclusiveOrExpression, _p)
try:
self.enterOuterAlt(localctx, 1)
self.state = 445
self.exclusiveOrExpression(0)
self._ctx.stop = self._input.LT(-1)
self.state = 452
self._errHandler.sync(self)
_alt = self._interp.adaptivePredict(self._input,24,self._ctx)
while _alt!=2 and _alt!=ATN.INVALID_ALT_NUMBER:
if _alt==1:
if self._parseListeners is not None:
self.triggerExitRuleEvent()
_prevctx = localctx
localctx = CParser.InclusiveOrExpressionContext(self, _parentctx, _parentState)
self.pushNewRecursionContext(localctx, _startState, self.RULE_inclusiveOrExpression)
self.state = 447
if not self.precpred(self._ctx, 1):
from antlr4.error.Errors import FailedPredicateException
raise FailedPredicateException(self, "self.precpred(self._ctx, 1)")
self.state = 448
self.match(CParser.Or)
self.state = 449
self.exclusiveOrExpression(0)
self.state = 454
self._errHandler.sync(self)
_alt = self._interp.adaptivePredict(self._input,24,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 LogicalAndExpressionContext(ParserRuleContext):
def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
super().__init__(parent, invokingState)
self.parser = parser
def inclusiveOrExpression(self):
return self.getTypedRuleContext(CParser.InclusiveOrExpressionContext,0)
def logicalAndExpression(self):
return self.getTypedRuleContext(CParser.LogicalAndExpressionContext,0)
def getRuleIndex(self):
return CParser.RULE_logicalAndExpression
def enterRule(self, listener:ParseTreeListener):
if hasattr( listener, "enterLogicalAndExpression" ):
listener.enterLogicalAndExpression(self)
def exitRule(self, listener:ParseTreeListener):
if hasattr( listener, "exitLogicalAndExpression" ):
listener.exitLogicalAndExpression(self)
def accept(self, visitor:ParseTreeVisitor):
if hasattr( visitor, "visitLogicalAndExpression" ):
return visitor.visitLogicalAndExpression(self)
else:
return visitor.visitChildren(self)
def logicalAndExpression(self, _p:int=0):
_parentctx = self._ctx
_parentState = self.state
localctx = CParser.LogicalAndExpressionContext(self, self._ctx, _parentState)
_prevctx = localctx
_startState = 34
self.enterRecursionRule(localctx, 34, self.RULE_logicalAndExpression, _p)
try:
self.enterOuterAlt(localctx, 1)
self.state = 456
self.inclusiveOrExpression(0)
self._ctx.stop = self._input.LT(-1)
self.state = 463
self._errHandler.sync(self)
_alt = self._interp.adaptivePredict(self._input,25,self._ctx)
while _alt!=2 and _alt!=ATN.INVALID_ALT_NUMBER:
if _alt==1:
if self._parseListeners is not None:
self.triggerExitRuleEvent()
_prevctx = localctx
localctx = CParser.LogicalAndExpressionContext(self, _parentctx, _parentState)
self.pushNewRecursionContext(localctx, _startState, self.RULE_logicalAndExpression)
self.state = 458
if not self.precpred(self._ctx, 1):
from antlr4.error.Errors import FailedPredicateException
raise FailedPredicateException(self, "self.precpred(self._ctx, 1)")
self.state = 459
self.match(CParser.AndAnd)
self.state = 460
self.inclusiveOrExpression(0)
self.state = 465
self._errHandler.sync(self)
_alt = self._interp.adaptivePredict(self._input,25,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 LogicalOrExpressionContext(ParserRuleContext):
def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
super().__init__(parent, invokingState)
self.parser = parser
def logicalAndExpression(self):
return self.getTypedRuleContext(CParser.LogicalAndExpressionContext,0)
def logicalOrExpression(self):
return self.getTypedRuleContext(CParser.LogicalOrExpressionContext,0)
def getRuleIndex(self):
return CParser.RULE_logicalOrExpression
def enterRule(self, listener:ParseTreeListener):
if hasattr( listener, "enterLogicalOrExpression" ):
listener.enterLogicalOrExpression(self)
def exitRule(self, listener:ParseTreeListener):
if hasattr( listener, "exitLogicalOrExpression" ):
listener.exitLogicalOrExpression(self)
def accept(self, visitor:ParseTreeVisitor):
if hasattr( visitor, "visitLogicalOrExpression" ):
return visitor.visitLogicalOrExpression(self)
else:
return visitor.visitChildren(self)
def logicalOrExpression(self, _p:int=0):
_parentctx = self._ctx
_parentState = self.state
localctx = CParser.LogicalOrExpressionContext(self, self._ctx, _parentState)
_prevctx = localctx
_startState = 36
self.enterRecursionRule(localctx, 36, self.RULE_logicalOrExpression, _p)
try:
self.enterOuterAlt(localctx, 1)
self.state = 467
self.logicalAndExpression(0)
self._ctx.stop = self._input.LT(-1)
self.state = 474
self._errHandler.sync(self)
_alt = self._interp.adaptivePredict(self._input,26,self._ctx)
while _alt!=2 and _alt!=ATN.INVALID_ALT_NUMBER:
if _alt==1:
if self._parseListeners is not None:
self.triggerExitRuleEvent()
_prevctx = localctx
localctx = CParser.LogicalOrExpressionContext(self, _parentctx, _parentState)
self.pushNewRecursionContext(localctx, _startState, self.RULE_logicalOrExpression)
self.state = 469
if not self.precpred(self._ctx, 1):
from antlr4.error.Errors import FailedPredicateException
raise FailedPredicateException(self, "self.precpred(self._ctx, 1)")
self.state = 470
self.match(CParser.OrOr)
self.state = 471
self.logicalAndExpression(0)
self.state = 476
self._errHandler.sync(self)
_alt = self._interp.adaptivePredict(self._input,26,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 ConditionalExpressionContext(ParserRuleContext):
def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
super().__init__(parent, invokingState)
self.parser = parser
def logicalOrExpression(self):
return self.getTypedRuleContext(CParser.LogicalOrExpressionContext,0)
def expression(self):
return self.getTypedRuleContext(CParser.ExpressionContext,0)
def conditionalExpression(self):
return self.getTypedRuleContext(CParser.ConditionalExpressionContext,0)
def getRuleIndex(self):
return CParser.RULE_conditionalExpression
def enterRule(self, listener:ParseTreeListener):
if hasattr( listener, "enterConditionalExpression" ):
listener.enterConditionalExpression(self)
def exitRule(self, listener:ParseTreeListener):
if hasattr( listener, "exitConditionalExpression" ):
listener.exitConditionalExpression(self)
def accept(self, visitor:ParseTreeVisitor):
if hasattr( visitor, "visitConditionalExpression" ):
return visitor.visitConditionalExpression(self)
else:
return visitor.visitChildren(self)
def conditionalExpression(self):
localctx = CParser.ConditionalExpressionContext(self, self._ctx, self.state)
self.enterRule(localctx, 38, self.RULE_conditionalExpression)
try:
self.enterOuterAlt(localctx, 1)
self.state = 477
self.logicalOrExpression(0)
self.state = 483
la_ = self._interp.adaptivePredict(self._input,27,self._ctx)
if la_ == 1:
self.state = 478
self.match(CParser.Question)
self.state = 479
self.expression(0)
self.state = 480
self.match(CParser.Colon)
self.state = 481
self.conditionalExpression()
except RecognitionException as re:
localctx.exception = re
self._errHandler.reportError(self, re)
self._errHandler.recover(self, re)
finally:
self.exitRule()
return localctx
class AssignmentExpressionContext(ParserRuleContext):
def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
super().__init__(parent, invokingState)
self.parser = parser
def conditionalExpression(self):
return self.getTypedRuleContext(CParser.ConditionalExpressionContext,0)
def unaryExpression(self):
return self.getTypedRuleContext(CParser.UnaryExpressionContext,0)
def assignmentOperator(self):
return self.getTypedRuleContext(CParser.AssignmentOperatorContext,0)
def assignmentExpression(self):
return self.getTypedRuleContext(CParser.AssignmentExpressionContext,0)
def getRuleIndex(self):
return CParser.RULE_assignmentExpression
def enterRule(self, listener:ParseTreeListener):
if hasattr( listener, "enterAssignmentExpression" ):
listener.enterAssignmentExpression(self)
def exitRule(self, listener:ParseTreeListener):
if hasattr( listener, "exitAssignmentExpression" ):
listener.exitAssignmentExpression(self)
def accept(self, visitor:ParseTreeVisitor):
if hasattr( visitor, "visitAssignmentExpression" ):
return visitor.visitAssignmentExpression(self)
else:
return visitor.visitChildren(self)
def assignmentExpression(self):
localctx = CParser.AssignmentExpressionContext(self, self._ctx, self.state)
self.enterRule(localctx, 40, self.RULE_assignmentExpression)
try:
self.state = 490
la_ = self._interp.adaptivePredict(self._input,28,self._ctx)
if la_ == 1:
self.enterOuterAlt(localctx, 1)
self.state = 485
self.conditionalExpression()
pass
elif la_ == 2:
self.enterOuterAlt(localctx, 2)
self.state = 486
self.unaryExpression()
self.state = 487
self.assignmentOperator()
self.state = 488
self.assignmentExpression()
pass
except RecognitionException as re:
localctx.exception = re
self._errHandler.reportError(self, re)
self._errHandler.recover(self, re)
finally:
self.exitRule()
return localctx
class AssignmentOperatorContext(ParserRuleContext):
def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
super().__init__(parent, invokingState)
self.parser = parser
def getRuleIndex(self):
return CParser.RULE_assignmentOperator
def enterRule(self, listener:ParseTreeListener):
if hasattr( listener, "enterAssignmentOperator" ):
listener.enterAssignmentOperator(self)
def exitRule(self, listener:ParseTreeListener):
if hasattr( listener, "exitAssignmentOperator" ):
listener.exitAssignmentOperator(self)
def accept(self, visitor:ParseTreeVisitor):
if hasattr( visitor, "visitAssignmentOperator" ):
return visitor.visitAssignmentOperator(self)
else:
return visitor.visitChildren(self)
def assignmentOperator(self):
localctx = CParser.AssignmentOperatorContext(self, self._ctx, self.state)
self.enterRule(localctx, 42, self.RULE_assignmentOperator)
self._la = 0 # Token type
try:
self.enterOuterAlt(localctx, 1)
self.state = 492
_la = self._input.LA(1)
if not(((((_la - 89)) & ~0x3f) == 0 and ((1 << (_la - 89)) & ((1 << (CParser.Assign - 89)) | (1 << (CParser.StarAssign - 89)) | (1 << (CParser.DivAssign - 89)) | (1 << (CParser.ModAssign - 89)) | (1 << (CParser.PlusAssign - 89)) | (1 << (CParser.MinusAssign - 89)) | (1 << (CParser.LeftShiftAssign - 89)) | (1 << (CParser.RightShiftAssign - 89)) | (1 << (CParser.AndAssign - 89)) | (1 << (CParser.XorAssign - 89)) | (1 << (CParser.OrAssign - 89)))) != 0)):
self._errHandler.recoverInline(self)
else:
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 ExpressionContext(ParserRuleContext):
def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
super().__init__(parent, invokingState)
self.parser = parser
def assignmentExpression(self):
return self.getTypedRuleContext(CParser.AssignmentExpressionContext,0)
def expression(self):
return self.getTypedRuleContext(CParser.ExpressionContext,0)
def getRuleIndex(self):
return CParser.RULE_expression
def enterRule(self, listener:ParseTreeListener):
if hasattr( listener, "enterExpression" ):
listener.enterExpression(self)
def exitRule(self, listener:ParseTreeListener):
if hasattr( listener, "exitExpression" ):
listener.exitExpression(self)
def accept(self, visitor:ParseTreeVisitor):
if hasattr( visitor, "visitExpression" ):
return visitor.visitExpression(self)
else:
return visitor.visitChildren(self)
def expression(self, _p:int=0):
_parentctx = self._ctx
_parentState = self.state
localctx = CParser.ExpressionContext(self, self._ctx, _parentState)
_prevctx = localctx
_startState = 44
self.enterRecursionRule(localctx, 44, self.RULE_expression, _p)
try:
self.enterOuterAlt(localctx, 1)
self.state = 495
self.assignmentExpression()
self._ctx.stop = self._input.LT(-1)
self.state = 502
self._errHandler.sync(self)
_alt = self._interp.adaptivePredict(self._input,29,self._ctx)
while _alt!=2 and _alt!=ATN.INVALID_ALT_NUMBER:
if _alt==1:
if self._parseListeners is not None:
self.triggerExitRuleEvent()
_prevctx = localctx
localctx = CParser.ExpressionContext(self, _parentctx, _parentState)
self.pushNewRecursionContext(localctx, _startState, self.RULE_expression)
self.state = 497
if not self.precpred(self._ctx, 1):
from antlr4.error.Errors import FailedPredicateException
raise FailedPredicateException(self, "self.precpred(self._ctx, 1)")
self.state = 498
self.match(CParser.Comma)
self.state = 499
self.assignmentExpression()
self.state = 504
self._errHandler.sync(self)
_alt = self._interp.adaptivePredict(self._input,29,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 ConstantExpressionContext(ParserRuleContext):
def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
super().__init__(parent, invokingState)
self.parser = parser
def conditionalExpression(self):
return self.getTypedRuleContext(CParser.ConditionalExpressionContext,0)
def getRuleIndex(self):
return CParser.RULE_constantExpression
def enterRule(self, listener:ParseTreeListener):
if hasattr( listener, "enterConstantExpression" ):
listener.enterConstantExpression(self)
def exitRule(self, listener:ParseTreeListener):
if hasattr( listener, "exitConstantExpression" ):
listener.exitConstantExpression(self)
def accept(self, visitor:ParseTreeVisitor):
if hasattr( visitor, "visitConstantExpression" ):
return visitor.visitConstantExpression(self)
else:
return visitor.visitChildren(self)
def constantExpression(self):
localctx = CParser.ConstantExpressionContext(self, self._ctx, self.state)
self.enterRule(localctx, 46, self.RULE_constantExpression)
try:
self.enterOuterAlt(localctx, 1)
self.state = 505
self.conditionalExpression()
except RecognitionException as re:
localctx.exception = re
self._errHandler.reportError(self, re)
self._errHandler.recover(self, re)
finally:
self.exitRule()
return localctx
class DeclarationContext(ParserRuleContext):
def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
super().__init__(parent, invokingState)
self.parser = parser
def declarationSpecifiers(self):
return self.getTypedRuleContext(CParser.DeclarationSpecifiersContext,0)
def initDeclaratorList(self):
return self.getTypedRuleContext(CParser.InitDeclaratorListContext,0)
def staticAssertDeclaration(self):
return self.getTypedRuleContext(CParser.StaticAssertDeclarationContext,0)
def getRuleIndex(self):
return CParser.RULE_declaration
def enterRule(self, listener:ParseTreeListener):
if hasattr( listener, "enterDeclaration" ):
listener.enterDeclaration(self)
def exitRule(self, listener:ParseTreeListener):
if hasattr( listener, "exitDeclaration" ):
listener.exitDeclaration(self)
def accept(self, visitor:ParseTreeVisitor):
if hasattr( visitor, "visitDeclaration" ):
return visitor.visitDeclaration(self)
else:
return visitor.visitChildren(self)
def declaration(self):
localctx = CParser.DeclarationContext(self, self._ctx, self.state)
self.enterRule(localctx, 48, self.RULE_declaration)
self._la = 0 # Token type
try:
self.state = 514
token = self._input.LA(1)
if token in [CParser.T__0, CParser.T__3, CParser.T__4, CParser.T__5, CParser.T__6, CParser.T__7, CParser.T__8, CParser.T__9, CParser.T__11, CParser.Auto, CParser.Char, CParser.Const, CParser.Double, CParser.Enum, CParser.Extern, CParser.Float, CParser.Inline, CParser.Int, CParser.Long, CParser.Register, CParser.Restrict, CParser.Short, CParser.Signed, CParser.Static, CParser.Struct, CParser.Typedef, CParser.Union, CParser.Unsigned, CParser.Void, CParser.Volatile, CParser.Alignas, CParser.Atomic, CParser.Bool, CParser.Complex, CParser.Noreturn, CParser.ThreadLocal, CParser.Identifier]:
self.enterOuterAlt(localctx, 1)
self.state = 507
self.declarationSpecifiers()
self.state = 509
_la = self._input.LA(1)
if ((((_la - 59)) & ~0x3f) == 0 and ((1 << (_la - 59)) & ((1 << (CParser.LeftParen - 59)) | (1 << (CParser.Star - 59)) | (1 << (CParser.Caret - 59)) | (1 << (CParser.Identifier - 59)))) != 0):
self.state = 508
self.initDeclaratorList(0)
self.state = 511
self.match(CParser.Semi)
elif token in [CParser.StaticAssert]:
self.enterOuterAlt(localctx, 2)
self.state = 513
self.staticAssertDeclaration()
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 DeclarationSpecifiersContext(ParserRuleContext):
def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
super().__init__(parent, invokingState)
self.parser = parser
def declarationSpecifier(self, i:int=None):
if i is None:
return self.getTypedRuleContexts(CParser.DeclarationSpecifierContext)
else:
return self.getTypedRuleContext(CParser.DeclarationSpecifierContext,i)
def getRuleIndex(self):
return CParser.RULE_declarationSpecifiers
def enterRule(self, listener:ParseTreeListener):
if hasattr( listener, "enterDeclarationSpecifiers" ):
listener.enterDeclarationSpecifiers(self)
def exitRule(self, listener:ParseTreeListener):
if hasattr( listener, "exitDeclarationSpecifiers" ):
listener.exitDeclarationSpecifiers(self)
def accept(self, visitor:ParseTreeVisitor):
if hasattr( visitor, "visitDeclarationSpecifiers" ):
return visitor.visitDeclarationSpecifiers(self)
else:
return visitor.visitChildren(self)
def declarationSpecifiers(self):
localctx = CParser.DeclarationSpecifiersContext(self, self._ctx, self.state)
self.enterRule(localctx, 50, self.RULE_declarationSpecifiers)
try:
self.enterOuterAlt(localctx, 1)
self.state = 517
self._errHandler.sync(self)
_alt = 1
while _alt!=2 and _alt!=ATN.INVALID_ALT_NUMBER:
if _alt == 1:
self.state = 516
self.declarationSpecifier()
else:
raise NoViableAltException(self)
self.state = 519
self._errHandler.sync(self)
_alt = self._interp.adaptivePredict(self._input,32,self._ctx)
except RecognitionException as re:
localctx.exception = re
self._errHandler.reportError(self, re)
self._errHandler.recover(self, re)
finally:
self.exitRule()
return localctx
class DeclarationSpecifiers2Context(ParserRuleContext):
def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
super().__init__(parent, invokingState)
self.parser = parser
def declarationSpecifier(self, i:int=None):
if i is None:
return self.getTypedRuleContexts(CParser.DeclarationSpecifierContext)
else:
return self.getTypedRuleContext(CParser.DeclarationSpecifierContext,i)
def getRuleIndex(self):
return CParser.RULE_declarationSpecifiers2
def enterRule(self, listener:ParseTreeListener):
if hasattr( listener, "enterDeclarationSpecifiers2" ):
listener.enterDeclarationSpecifiers2(self)
def exitRule(self, listener:ParseTreeListener):
if hasattr( listener, "exitDeclarationSpecifiers2" ):
listener.exitDeclarationSpecifiers2(self)
def accept(self, visitor:ParseTreeVisitor):
if hasattr( visitor, "visitDeclarationSpecifiers2" ):
return visitor.visitDeclarationSpecifiers2(self)
else:
return visitor.visitChildren(self)
def declarationSpecifiers2(self):
localctx = CParser.DeclarationSpecifiers2Context(self, self._ctx, self.state)
self.enterRule(localctx, 52, self.RULE_declarationSpecifiers2)
try:
self.enterOuterAlt(localctx, 1)
self.state = 522
self._errHandler.sync(self)
_alt = 1
while _alt!=2 and _alt!=ATN.INVALID_ALT_NUMBER:
if _alt == 1:
self.state = 521
self.declarationSpecifier()
else:
raise NoViableAltException(self)
self.state = 524
self._errHandler.sync(self)
_alt = self._interp.adaptivePredict(self._input,33,self._ctx)
except RecognitionException as re:
localctx.exception = re
self._errHandler.reportError(self, re)
self._errHandler.recover(self, re)
finally:
self.exitRule()
return localctx
class DeclarationSpecifierContext(ParserRuleContext):
def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
super().__init__(parent, invokingState)
self.parser = parser
def storageClassSpecifier(self):
return self.getTypedRuleContext(CParser.StorageClassSpecifierContext,0)
def typeSpecifier(self):
return self.getTypedRuleContext(CParser.TypeSpecifierContext,0)
def typeQualifier(self):
return self.getTypedRuleContext(CParser.TypeQualifierContext,0)
def functionSpecifier(self):
return self.getTypedRuleContext(CParser.FunctionSpecifierContext,0)
def alignmentSpecifier(self):
return self.getTypedRuleContext(CParser.AlignmentSpecifierContext,0)
def getRuleIndex(self):
return CParser.RULE_declarationSpecifier
def enterRule(self, listener:ParseTreeListener):
if hasattr( listener, "enterDeclarationSpecifier" ):
listener.enterDeclarationSpecifier(self)
def exitRule(self, listener:ParseTreeListener):
if hasattr( listener, "exitDeclarationSpecifier" ):
listener.exitDeclarationSpecifier(self)
def accept(self, visitor:ParseTreeVisitor):
if hasattr( visitor, "visitDeclarationSpecifier" ):
return visitor.visitDeclarationSpecifier(self)
else:
return visitor.visitChildren(self)
def declarationSpecifier(self):
localctx = CParser.DeclarationSpecifierContext(self, self._ctx, self.state)
self.enterRule(localctx, 54, self.RULE_declarationSpecifier)
try:
self.state = 531
la_ = self._interp.adaptivePredict(self._input,34,self._ctx)
if la_ == 1:
self.enterOuterAlt(localctx, 1)
self.state = 526
self.storageClassSpecifier()
pass
elif la_ == 2:
self.enterOuterAlt(localctx, 2)
self.state = 527
self.typeSpecifier()
pass
elif la_ == 3:
self.enterOuterAlt(localctx, 3)
self.state = 528
self.typeQualifier()
pass
elif la_ == 4:
self.enterOuterAlt(localctx, 4)
self.state = 529
self.functionSpecifier()
pass
elif la_ == 5:
self.enterOuterAlt(localctx, 5)
self.state = 530
self.alignmentSpecifier()
pass
except RecognitionException as re:
localctx.exception = re
self._errHandler.reportError(self, re)
self._errHandler.recover(self, re)
finally:
self.exitRule()
return localctx
class InitDeclaratorListContext(ParserRuleContext):
def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
super().__init__(parent, invokingState)
self.parser = parser
def initDeclarator(self):
return self.getTypedRuleContext(CParser.InitDeclaratorContext,0)
def initDeclaratorList(self):
return self.getTypedRuleContext(CParser.InitDeclaratorListContext,0)
def getRuleIndex(self):
return CParser.RULE_initDeclaratorList
def enterRule(self, listener:ParseTreeListener):
if hasattr( listener, "enterInitDeclaratorList" ):
listener.enterInitDeclaratorList(self)
def exitRule(self, listener:ParseTreeListener):
if hasattr( listener, "exitInitDeclaratorList" ):
listener.exitInitDeclaratorList(self)
def accept(self, visitor:ParseTreeVisitor):
if hasattr( visitor, "visitInitDeclaratorList" ):
return visitor.visitInitDeclaratorList(self)
else:
return visitor.visitChildren(self)
def initDeclaratorList(self, _p:int=0):
_parentctx = self._ctx
_parentState = self.state
localctx = CParser.InitDeclaratorListContext(self, self._ctx, _parentState)
_prevctx = localctx
_startState = 56
self.enterRecursionRule(localctx, 56, self.RULE_initDeclaratorList, _p)
try:
self.enterOuterAlt(localctx, 1)
self.state = 534
self.initDeclarator()
self._ctx.stop = self._input.LT(-1)
self.state = 541
self._errHandler.sync(self)
_alt = self._interp.adaptivePredict(self._input,35,self._ctx)
while _alt!=2 and _alt!=ATN.INVALID_ALT_NUMBER:
if _alt==1:
if self._parseListeners is not None:
self.triggerExitRuleEvent()
_prevctx = localctx
localctx = CParser.InitDeclaratorListContext(self, _parentctx, _parentState)
self.pushNewRecursionContext(localctx, _startState, self.RULE_initDeclaratorList)
self.state = 536
if not self.precpred(self._ctx, 1):
from antlr4.error.Errors import FailedPredicateException
raise FailedPredicateException(self, "self.precpred(self._ctx, 1)")
self.state = 537
self.match(CParser.Comma)
self.state = 538
self.initDeclarator()
self.state = 543
self._errHandler.sync(self)
_alt = self._interp.adaptivePredict(self._input,35,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 InitDeclaratorContext(ParserRuleContext):
def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
super().__init__(parent, invokingState)
self.parser = parser
def declarator(self):
return self.getTypedRuleContext(CParser.DeclaratorContext,0)
def initializer(self):
return self.getTypedRuleContext(CParser.InitializerContext,0)
def getRuleIndex(self):
return CParser.RULE_initDeclarator
def enterRule(self, listener:ParseTreeListener):
if hasattr( listener, "enterInitDeclarator" ):
listener.enterInitDeclarator(self)
def exitRule(self, listener:ParseTreeListener):
if hasattr( listener, "exitInitDeclarator" ):
listener.exitInitDeclarator(self)
def accept(self, visitor:ParseTreeVisitor):
if hasattr( visitor, "visitInitDeclarator" ):
return visitor.visitInitDeclarator(self)
else:
return visitor.visitChildren(self)
def initDeclarator(self):
localctx = CParser.InitDeclaratorContext(self, self._ctx, self.state)
self.enterRule(localctx, 58, self.RULE_initDeclarator)
try:
self.state = 549
la_ = self._interp.adaptivePredict(self._input,36,self._ctx)
if la_ == 1:
self.enterOuterAlt(localctx, 1)
self.state = 544
self.declarator()
pass
elif la_ == 2:
self.enterOuterAlt(localctx, 2)
self.state = 545
self.declarator()
self.state = 546
self.match(CParser.Assign)
self.state = 547
self.initializer()
pass
except RecognitionException as re:
localctx.exception = re
self._errHandler.reportError(self, re)
self._errHandler.recover(self, re)
finally:
self.exitRule()
return localctx
class StorageClassSpecifierContext(ParserRuleContext):
def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
super().__init__(parent, invokingState)
self.parser = parser
def getRuleIndex(self):
return CParser.RULE_storageClassSpecifier
def enterRule(self, listener:ParseTreeListener):
if hasattr( listener, "enterStorageClassSpecifier" ):
listener.enterStorageClassSpecifier(self)
def exitRule(self, listener:ParseTreeListener):
if hasattr( listener, "exitStorageClassSpecifier" ):
listener.exitStorageClassSpecifier(self)
def accept(self, visitor:ParseTreeVisitor):
if hasattr( visitor, "visitStorageClassSpecifier" ):
return visitor.visitStorageClassSpecifier(self)
else:
return visitor.visitChildren(self)
def storageClassSpecifier(self):
localctx = CParser.StorageClassSpecifierContext(self, self._ctx, self.state)
self.enterRule(localctx, 60, self.RULE_storageClassSpecifier)
self._la = 0 # Token type
try:
self.enterOuterAlt(localctx, 1)
self.state = 551
_la = self._input.LA(1)
if not((((_la) & ~0x3f) == 0 and ((1 << _la) & ((1 << CParser.Auto) | (1 << CParser.Extern) | (1 << CParser.Register) | (1 << CParser.Static) | (1 << CParser.Typedef) | (1 << CParser.ThreadLocal))) != 0)):
self._errHandler.recoverInline(self)
else:
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 TypeSpecifierContext(ParserRuleContext):
def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
super().__init__(parent, invokingState)
self.parser = parser
def atomicTypeSpecifier(self):
return self.getTypedRuleContext(CParser.AtomicTypeSpecifierContext,0)
def structOrUnionSpecifier(self):
return self.getTypedRuleContext(CParser.StructOrUnionSpecifierContext,0)
def enumSpecifier(self):
return self.getTypedRuleContext(CParser.EnumSpecifierContext,0)
def typedefName(self):
return self.getTypedRuleContext(CParser.TypedefNameContext,0)
def constantExpression(self):
return self.getTypedRuleContext(CParser.ConstantExpressionContext,0)
def getRuleIndex(self):
return CParser.RULE_typeSpecifier
def enterRule(self, listener:ParseTreeListener):
if hasattr( listener, "enterTypeSpecifier" ):
listener.enterTypeSpecifier(self)
def exitRule(self, listener:ParseTreeListener):
if hasattr( listener, "exitTypeSpecifier" ):
listener.exitTypeSpecifier(self)
def accept(self, visitor:ParseTreeVisitor):
if hasattr( visitor, "visitTypeSpecifier" ):
return visitor.visitTypeSpecifier(self)
else:
return visitor.visitChildren(self)
def typeSpecifier(self):
localctx = CParser.TypeSpecifierContext(self, self._ctx, self.state)
self.enterRule(localctx, 62, self.RULE_typeSpecifier)
self._la = 0 # Token type
try:
self.state = 567
token = self._input.LA(1)
if token in [CParser.T__3, CParser.T__4, CParser.T__5, CParser.Char, CParser.Double, CParser.Float, CParser.Int, CParser.Long, CParser.Short, CParser.Signed, CParser.Unsigned, CParser.Void, CParser.Bool, CParser.Complex]:
self.enterOuterAlt(localctx, 1)
self.state = 553
_la = self._input.LA(1)
if not((((_la) & ~0x3f) == 0 and ((1 << _la) & ((1 << CParser.T__3) | (1 << CParser.T__4) | (1 << CParser.T__5) | (1 << CParser.Char) | (1 << CParser.Double) | (1 << CParser.Float) | (1 << CParser.Int) | (1 << CParser.Long) | (1 << CParser.Short) | (1 << CParser.Signed) | (1 << CParser.Unsigned) | (1 << CParser.Void) | (1 << CParser.Bool) | (1 << CParser.Complex))) != 0)):
self._errHandler.recoverInline(self)
else:
self.consume()
elif token in [CParser.T__0]:
self.enterOuterAlt(localctx, 2)
self.state = 554
self.match(CParser.T__0)
self.state = 555
self.match(CParser.LeftParen)
self.state = 556
_la = self._input.LA(1)
if not((((_la) & ~0x3f) == 0 and ((1 << _la) & ((1 << CParser.T__3) | (1 << CParser.T__4) | (1 << CParser.T__5))) != 0)):
self._errHandler.recoverInline(self)
else:
self.consume()
self.state = 557
self.match(CParser.RightParen)
elif token in [CParser.Atomic]:
self.enterOuterAlt(localctx, 3)
self.state = 558
self.atomicTypeSpecifier()
elif token in [CParser.Struct, CParser.Union]:
self.enterOuterAlt(localctx, 4)
self.state = 559
self.structOrUnionSpecifier()
elif token in [CParser.Enum]:
self.enterOuterAlt(localctx, 5)
self.state = 560
self.enumSpecifier()
elif token in [CParser.Identifier]:
self.enterOuterAlt(localctx, 6)
self.state = 561
self.typedefName()
elif token in [CParser.T__6]:
self.enterOuterAlt(localctx, 7)
self.state = 562
self.match(CParser.T__6)
self.state = 563
self.match(CParser.LeftParen)
self.state = 564
self.constantExpression()
self.state = 565
self.match(CParser.RightParen)
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 StructOrUnionSpecifierContext(ParserRuleContext):
def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
super().__init__(parent, invokingState)
self.parser = parser
def structOrUnion(self):
return self.getTypedRuleContext(CParser.StructOrUnionContext,0)
def structDeclarationList(self):
return self.getTypedRuleContext(CParser.StructDeclarationListContext,0)
def Identifier(self):
return self.getToken(CParser.Identifier, 0)
def getRuleIndex(self):
return CParser.RULE_structOrUnionSpecifier
def enterRule(self, listener:ParseTreeListener):
if hasattr( listener, "enterStructOrUnionSpecifier" ):
listener.enterStructOrUnionSpecifier(self)
def exitRule(self, listener:ParseTreeListener):
if hasattr( listener, "exitStructOrUnionSpecifier" ):
listener.exitStructOrUnionSpecifier(self)
def accept(self, visitor:ParseTreeVisitor):
if hasattr( visitor, "visitStructOrUnionSpecifier" ):
return visitor.visitStructOrUnionSpecifier(self)
else:
return visitor.visitChildren(self)
def structOrUnionSpecifier(self):
localctx = CParser.StructOrUnionSpecifierContext(self, self._ctx, self.state)
self.enterRule(localctx, 64, self.RULE_structOrUnionSpecifier)
self._la = 0 # Token type
try:
self.state = 580
la_ = self._interp.adaptivePredict(self._input,39,self._ctx)
if la_ == 1:
self.enterOuterAlt(localctx, 1)
self.state = 569
self.structOrUnion()
self.state = 571
_la = self._input.LA(1)
if _la==CParser.Identifier:
self.state = 570
self.match(CParser.Identifier)
self.state = 573
self.match(CParser.LeftBrace)
self.state = 574
self.structDeclarationList(0)
self.state = 575
self.match(CParser.RightBrace)
pass
elif la_ == 2:
self.enterOuterAlt(localctx, 2)
self.state = 577
self.structOrUnion()
self.state = 578
self.match(CParser.Identifier)
pass
except RecognitionException as re:
localctx.exception = re
self._errHandler.reportError(self, re)
self._errHandler.recover(self, re)
finally:
self.exitRule()
return localctx
class StructOrUnionContext(ParserRuleContext):
def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
super().__init__(parent, invokingState)
self.parser = parser
def getRuleIndex(self):
return CParser.RULE_structOrUnion
def enterRule(self, listener:ParseTreeListener):
if hasattr( listener, "enterStructOrUnion" ):
listener.enterStructOrUnion(self)
def exitRule(self, listener:ParseTreeListener):
if hasattr( listener, "exitStructOrUnion" ):
listener.exitStructOrUnion(self)
def accept(self, visitor:ParseTreeVisitor):
if hasattr( visitor, "visitStructOrUnion" ):
return visitor.visitStructOrUnion(self)
else:
return visitor.visitChildren(self)
def structOrUnion(self):
localctx = CParser.StructOrUnionContext(self, self._ctx, self.state)
self.enterRule(localctx, 66, self.RULE_structOrUnion)
self._la = 0 # Token type
try:
self.enterOuterAlt(localctx, 1)
self.state = 582
_la = self._input.LA(1)
if not(_la==CParser.Struct or _la==CParser.Union):
self._errHandler.recoverInline(self)
else:
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 StructDeclarationListContext(ParserRuleContext):
def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
super().__init__(parent, invokingState)
self.parser = parser
def structDeclaration(self):
return self.getTypedRuleContext(CParser.StructDeclarationContext,0)
def structDeclarationList(self):
return self.getTypedRuleContext(CParser.StructDeclarationListContext,0)
def getRuleIndex(self):
return CParser.RULE_structDeclarationList
def enterRule(self, listener:ParseTreeListener):
if hasattr( listener, "enterStructDeclarationList" ):
listener.enterStructDeclarationList(self)
def exitRule(self, listener:ParseTreeListener):
if hasattr( listener, "exitStructDeclarationList" ):
listener.exitStructDeclarationList(self)
def accept(self, visitor:ParseTreeVisitor):
if hasattr( visitor, "visitStructDeclarationList" ):
return visitor.visitStructDeclarationList(self)
else:
return visitor.visitChildren(self)
def structDeclarationList(self, _p:int=0):
_parentctx = self._ctx
_parentState = self.state
localctx = CParser.StructDeclarationListContext(self, self._ctx, _parentState)
_prevctx = localctx
_startState = 68
self.enterRecursionRule(localctx, 68, self.RULE_structDeclarationList, _p)
try:
self.enterOuterAlt(localctx, 1)
self.state = 585
self.structDeclaration()
self._ctx.stop = self._input.LT(-1)
self.state = 591
self._errHandler.sync(self)
_alt = self._interp.adaptivePredict(self._input,40,self._ctx)
while _alt!=2 and _alt!=ATN.INVALID_ALT_NUMBER:
if _alt==1:
if self._parseListeners is not None:
self.triggerExitRuleEvent()
_prevctx = localctx
localctx = CParser.StructDeclarationListContext(self, _parentctx, _parentState)
self.pushNewRecursionContext(localctx, _startState, self.RULE_structDeclarationList)
self.state = 587
if not self.precpred(self._ctx, 1):
from antlr4.error.Errors import FailedPredicateException
raise FailedPredicateException(self, "self.precpred(self._ctx, 1)")
self.state = 588
self.structDeclaration()
self.state = 593
self._errHandler.sync(self)
_alt = self._interp.adaptivePredict(self._input,40,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 StructDeclarationContext(ParserRuleContext):
def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
super().__init__(parent, invokingState)
self.parser = parser
def specifierQualifierList(self):
return self.getTypedRuleContext(CParser.SpecifierQualifierListContext,0)
def structDeclaratorList(self):
return self.getTypedRuleContext(CParser.StructDeclaratorListContext,0)
def staticAssertDeclaration(self):
return self.getTypedRuleContext(CParser.StaticAssertDeclarationContext,0)
def getRuleIndex(self):
return CParser.RULE_structDeclaration
def enterRule(self, listener:ParseTreeListener):
if hasattr( listener, "enterStructDeclaration" ):
listener.enterStructDeclaration(self)
def exitRule(self, listener:ParseTreeListener):
if hasattr( listener, "exitStructDeclaration" ):
listener.exitStructDeclaration(self)
def accept(self, visitor:ParseTreeVisitor):
if hasattr( visitor, "visitStructDeclaration" ):
return visitor.visitStructDeclaration(self)
else:
return visitor.visitChildren(self)
def structDeclaration(self):
localctx = CParser.StructDeclarationContext(self, self._ctx, self.state)
self.enterRule(localctx, 70, self.RULE_structDeclaration)
self._la = 0 # Token type
try:
self.state = 601
token = self._input.LA(1)
if token in [CParser.T__0, CParser.T__3, CParser.T__4, CParser.T__5, CParser.T__6, CParser.Char, CParser.Const, CParser.Double, CParser.Enum, CParser.Float, CParser.Int, CParser.Long, CParser.Restrict, CParser.Short, CParser.Signed, CParser.Struct, CParser.Union, CParser.Unsigned, CParser.Void, CParser.Volatile, CParser.Atomic, CParser.Bool, CParser.Complex, CParser.Identifier]:
self.enterOuterAlt(localctx, 1)
self.state = 594
self.specifierQualifierList()
self.state = 596
_la = self._input.LA(1)
if ((((_la - 59)) & ~0x3f) == 0 and ((1 << (_la - 59)) & ((1 << (CParser.LeftParen - 59)) | (1 << (CParser.Star - 59)) | (1 << (CParser.Caret - 59)) | (1 << (CParser.Colon - 59)) | (1 << (CParser.Identifier - 59)))) != 0):
self.state = 595
self.structDeclaratorList(0)
self.state = 598
self.match(CParser.Semi)
elif token in [CParser.StaticAssert]:
self.enterOuterAlt(localctx, 2)
self.state = 600
self.staticAssertDeclaration()
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 SpecifierQualifierListContext(ParserRuleContext):
def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
super().__init__(parent, invokingState)
self.parser = parser
def typeSpecifier(self):
return self.getTypedRuleContext(CParser.TypeSpecifierContext,0)
def specifierQualifierList(self):
return self.getTypedRuleContext(CParser.SpecifierQualifierListContext,0)
def typeQualifier(self):
return self.getTypedRuleContext(CParser.TypeQualifierContext,0)
def getRuleIndex(self):
return CParser.RULE_specifierQualifierList
def enterRule(self, listener:ParseTreeListener):
if hasattr( listener, "enterSpecifierQualifierList" ):
listener.enterSpecifierQualifierList(self)
def exitRule(self, listener:ParseTreeListener):
if hasattr( listener, "exitSpecifierQualifierList" ):
listener.exitSpecifierQualifierList(self)
def accept(self, visitor:ParseTreeVisitor):
if hasattr( visitor, "visitSpecifierQualifierList" ):
return visitor.visitSpecifierQualifierList(self)
else:
return visitor.visitChildren(self)
def specifierQualifierList(self):
localctx = CParser.SpecifierQualifierListContext(self, self._ctx, self.state)
self.enterRule(localctx, 72, self.RULE_specifierQualifierList)
try:
self.state = 611
la_ = self._interp.adaptivePredict(self._input,45,self._ctx)
if la_ == 1:
self.enterOuterAlt(localctx, 1)
self.state = 603
self.typeSpecifier()
self.state = 605
la_ = self._interp.adaptivePredict(self._input,43,self._ctx)
if la_ == 1:
self.state = 604
self.specifierQualifierList()
pass
elif la_ == 2:
self.enterOuterAlt(localctx, 2)
self.state = 607
self.typeQualifier()
self.state = 609
la_ = self._interp.adaptivePredict(self._input,44,self._ctx)
if la_ == 1:
self.state = 608
self.specifierQualifierList()
pass
except RecognitionException as re:
localctx.exception = re
self._errHandler.reportError(self, re)
self._errHandler.recover(self, re)
finally:
self.exitRule()
return localctx
class StructDeclaratorListContext(ParserRuleContext):
def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
super().__init__(parent, invokingState)
self.parser = parser
def structDeclarator(self):
return self.getTypedRuleContext(CParser.StructDeclaratorContext,0)
def structDeclaratorList(self):
return self.getTypedRuleContext(CParser.StructDeclaratorListContext,0)
def getRuleIndex(self):
return CParser.RULE_structDeclaratorList
def enterRule(self, listener:ParseTreeListener):
if hasattr( listener, "enterStructDeclaratorList" ):
listener.enterStructDeclaratorList(self)
def exitRule(self, listener:ParseTreeListener):
if hasattr( listener, "exitStructDeclaratorList" ):
listener.exitStructDeclaratorList(self)
def accept(self, visitor:ParseTreeVisitor):
if hasattr( visitor, "visitStructDeclaratorList" ):
return visitor.visitStructDeclaratorList(self)
else:
return visitor.visitChildren(self)
def structDeclaratorList(self, _p:int=0):
_parentctx = self._ctx
_parentState = self.state
localctx = CParser.StructDeclaratorListContext(self, self._ctx, _parentState)
_prevctx = localctx
_startState = 74
self.enterRecursionRule(localctx, 74, self.RULE_structDeclaratorList, _p)
try:
self.enterOuterAlt(localctx, 1)
self.state = 614
self.structDeclarator()
self._ctx.stop = self._input.LT(-1)
self.state = 621
self._errHandler.sync(self)
_alt = self._interp.adaptivePredict(self._input,46,self._ctx)
while _alt!=2 and _alt!=ATN.INVALID_ALT_NUMBER:
if _alt==1:
if self._parseListeners is not None:
self.triggerExitRuleEvent()
_prevctx = localctx
localctx = CParser.StructDeclaratorListContext(self, _parentctx, _parentState)
self.pushNewRecursionContext(localctx, _startState, self.RULE_structDeclaratorList)
self.state = 616
if not self.precpred(self._ctx, 1):
from antlr4.error.Errors import FailedPredicateException
raise FailedPredicateException(self, "self.precpred(self._ctx, 1)")
self.state = 617
self.match(CParser.Comma)
self.state = 618
self.structDeclarator()
self.state = 623
self._errHandler.sync(self)
_alt = self._interp.adaptivePredict(self._input,46,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 StructDeclaratorContext(ParserRuleContext):
def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
super().__init__(parent, invokingState)
self.parser = parser
def declarator(self):
return self.getTypedRuleContext(CParser.DeclaratorContext,0)
def constantExpression(self):
return self.getTypedRuleContext(CParser.ConstantExpressionContext,0)
def getRuleIndex(self):
return CParser.RULE_structDeclarator
def enterRule(self, listener:ParseTreeListener):
if hasattr( listener, "enterStructDeclarator" ):
listener.enterStructDeclarator(self)
def exitRule(self, listener:ParseTreeListener):
if hasattr( listener, "exitStructDeclarator" ):
listener.exitStructDeclarator(self)
def accept(self, visitor:ParseTreeVisitor):
if hasattr( visitor, "visitStructDeclarator" ):
return visitor.visitStructDeclarator(self)
else:
return visitor.visitChildren(self)
def structDeclarator(self):
localctx = CParser.StructDeclaratorContext(self, self._ctx, self.state)
self.enterRule(localctx, 76, self.RULE_structDeclarator)
self._la = 0 # Token type
try:
self.state = 630
la_ = self._interp.adaptivePredict(self._input,48,self._ctx)
if la_ == 1:
self.enterOuterAlt(localctx, 1)
self.state = 624
self.declarator()
pass
elif la_ == 2:
self.enterOuterAlt(localctx, 2)
self.state = 626
_la = self._input.LA(1)
if ((((_la - 59)) & ~0x3f) == 0 and ((1 << (_la - 59)) & ((1 << (CParser.LeftParen - 59)) | (1 << (CParser.Star - 59)) | (1 << (CParser.Caret - 59)) | (1 << (CParser.Identifier - 59)))) != 0):
self.state = 625
self.declarator()
self.state = 628
self.match(CParser.Colon)
self.state = 629
self.constantExpression()
pass
except RecognitionException as re:
localctx.exception = re
self._errHandler.reportError(self, re)
self._errHandler.recover(self, re)
finally:
self.exitRule()
return localctx
class EnumSpecifierContext(ParserRuleContext):
def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
super().__init__(parent, invokingState)
self.parser = parser
def enumeratorList(self):
return self.getTypedRuleContext(CParser.EnumeratorListContext,0)
def Identifier(self):
return self.getToken(CParser.Identifier, 0)
def getRuleIndex(self):
return CParser.RULE_enumSpecifier
def enterRule(self, listener:ParseTreeListener):
if hasattr( listener, "enterEnumSpecifier" ):
listener.enterEnumSpecifier(self)
def exitRule(self, listener:ParseTreeListener):
if hasattr( listener, "exitEnumSpecifier" ):
listener.exitEnumSpecifier(self)
def accept(self, visitor:ParseTreeVisitor):
if hasattr( visitor, "visitEnumSpecifier" ):
return visitor.visitEnumSpecifier(self)
else:
return visitor.visitChildren(self)
def enumSpecifier(self):
localctx = CParser.EnumSpecifierContext(self, self._ctx, self.state)
self.enterRule(localctx, 78, self.RULE_enumSpecifier)
self._la = 0 # Token type
try:
self.state = 651
la_ = self._interp.adaptivePredict(self._input,51,self._ctx)
if la_ == 1:
self.enterOuterAlt(localctx, 1)
self.state = 632
self.match(CParser.Enum)
self.state = 634
_la = self._input.LA(1)
if _la==CParser.Identifier:
self.state = 633
self.match(CParser.Identifier)
self.state = 636
self.match(CParser.LeftBrace)
self.state = 637
self.enumeratorList(0)
self.state = 638
self.match(CParser.RightBrace)
pass
elif la_ == 2:
self.enterOuterAlt(localctx, 2)
self.state = 640
self.match(CParser.Enum)
self.state = 642
_la = self._input.LA(1)
if _la==CParser.Identifier:
self.state = 641
self.match(CParser.Identifier)
self.state = 644
self.match(CParser.LeftBrace)
self.state = 645
self.enumeratorList(0)
self.state = 646
self.match(CParser.Comma)
self.state = 647
self.match(CParser.RightBrace)
pass
elif la_ == 3:
self.enterOuterAlt(localctx, 3)
self.state = 649
self.match(CParser.Enum)
self.state = 650
self.match(CParser.Identifier)
pass
except RecognitionException as re:
localctx.exception = re
self._errHandler.reportError(self, re)
self._errHandler.recover(self, re)
finally:
self.exitRule()
return localctx
class EnumeratorListContext(ParserRuleContext):
def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
super().__init__(parent, invokingState)
self.parser = parser
def enumerator(self):
return self.getTypedRuleContext(CParser.EnumeratorContext,0)
def enumeratorList(self):
return self.getTypedRuleContext(CParser.EnumeratorListContext,0)
def getRuleIndex(self):
return CParser.RULE_enumeratorList
def enterRule(self, listener:ParseTreeListener):
if hasattr( listener, "enterEnumeratorList" ):
listener.enterEnumeratorList(self)
def exitRule(self, listener:ParseTreeListener):
if hasattr( listener, "exitEnumeratorList" ):
listener.exitEnumeratorList(self)
def accept(self, visitor:ParseTreeVisitor):
if hasattr( visitor, "visitEnumeratorList" ):
return visitor.visitEnumeratorList(self)
else:
return visitor.visitChildren(self)
def enumeratorList(self, _p:int=0):
_parentctx = self._ctx
_parentState = self.state
localctx = CParser.EnumeratorListContext(self, self._ctx, _parentState)
_prevctx = localctx
_startState = 80
self.enterRecursionRule(localctx, 80, self.RULE_enumeratorList, _p)
try:
self.enterOuterAlt(localctx, 1)
self.state = 654
self.enumerator()
self._ctx.stop = self._input.LT(-1)
self.state = 661
self._errHandler.sync(self)
_alt = self._interp.adaptivePredict(self._input,52,self._ctx)
while _alt!=2 and _alt!=ATN.INVALID_ALT_NUMBER:
if _alt==1:
if self._parseListeners is not None:
self.triggerExitRuleEvent()
_prevctx = localctx
localctx = CParser.EnumeratorListContext(self, _parentctx, _parentState)
self.pushNewRecursionContext(localctx, _startState, self.RULE_enumeratorList)
self.state = 656
if not self.precpred(self._ctx, 1):
from antlr4.error.Errors import FailedPredicateException
raise FailedPredicateException(self, "self.precpred(self._ctx, 1)")
self.state = 657
self.match(CParser.Comma)
self.state = 658
self.enumerator()
self.state = 663
self._errHandler.sync(self)
_alt = self._interp.adaptivePredict(self._input,52,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 EnumeratorContext(ParserRuleContext):
def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
super().__init__(parent, invokingState)
self.parser = parser
def enumerationConstant(self):
return self.getTypedRuleContext(CParser.EnumerationConstantContext,0)
def constantExpression(self):
return self.getTypedRuleContext(CParser.ConstantExpressionContext,0)
def getRuleIndex(self):
return CParser.RULE_enumerator
def enterRule(self, listener:ParseTreeListener):
if hasattr( listener, "enterEnumerator" ):
listener.enterEnumerator(self)
def exitRule(self, listener:ParseTreeListener):
if hasattr( listener, "exitEnumerator" ):
listener.exitEnumerator(self)
def accept(self, visitor:ParseTreeVisitor):
if hasattr( visitor, "visitEnumerator" ):
return visitor.visitEnumerator(self)
else:
return visitor.visitChildren(self)
def enumerator(self):
localctx = CParser.EnumeratorContext(self, self._ctx, self.state)
self.enterRule(localctx, 82, self.RULE_enumerator)
try:
self.state = 669
la_ = self._interp.adaptivePredict(self._input,53,self._ctx)
if la_ == 1:
self.enterOuterAlt(localctx, 1)
self.state = 664
self.enumerationConstant()
pass
elif la_ == 2:
self.enterOuterAlt(localctx, 2)
self.state = 665
self.enumerationConstant()
self.state = 666
self.match(CParser.Assign)
self.state = 667
self.constantExpression()
pass
except RecognitionException as re:
localctx.exception = re
self._errHandler.reportError(self, re)
self._errHandler.recover(self, re)
finally:
self.exitRule()
return localctx
class EnumerationConstantContext(ParserRuleContext):
def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
super().__init__(parent, invokingState)
self.parser = parser
def Identifier(self):
return self.getToken(CParser.Identifier, 0)
def getRuleIndex(self):
return CParser.RULE_enumerationConstant
def enterRule(self, listener:ParseTreeListener):
if hasattr( listener, "enterEnumerationConstant" ):
listener.enterEnumerationConstant(self)
def exitRule(self, listener:ParseTreeListener):
if hasattr( listener, "exitEnumerationConstant" ):
listener.exitEnumerationConstant(self)
def accept(self, visitor:ParseTreeVisitor):
if hasattr( visitor, "visitEnumerationConstant" ):
return visitor.visitEnumerationConstant(self)
else:
return visitor.visitChildren(self)
def enumerationConstant(self):
localctx = CParser.EnumerationConstantContext(self, self._ctx, self.state)
self.enterRule(localctx, 84, self.RULE_enumerationConstant)
try:
self.enterOuterAlt(localctx, 1)
self.state = 671
self.match(CParser.Identifier)
except RecognitionException as re:
localctx.exception = re
self._errHandler.reportError(self, re)
self._errHandler.recover(self, re)
finally:
self.exitRule()
return localctx
class AtomicTypeSpecifierContext(ParserRuleContext):
def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
super().__init__(parent, invokingState)
self.parser = parser
def typeName(self):
return self.getTypedRuleContext(CParser.TypeNameContext,0)
def getRuleIndex(self):
return CParser.RULE_atomicTypeSpecifier
def enterRule(self, listener:ParseTreeListener):
if hasattr( listener, "enterAtomicTypeSpecifier" ):
listener.enterAtomicTypeSpecifier(self)
def exitRule(self, listener:ParseTreeListener):
if hasattr( listener, "exitAtomicTypeSpecifier" ):
listener.exitAtomicTypeSpecifier(self)
def accept(self, visitor:ParseTreeVisitor):
if hasattr( visitor, "visitAtomicTypeSpecifier" ):
return visitor.visitAtomicTypeSpecifier(self)
else:
return visitor.visitChildren(self)
def atomicTypeSpecifier(self):
localctx = CParser.AtomicTypeSpecifierContext(self, self._ctx, self.state)
self.enterRule(localctx, 86, self.RULE_atomicTypeSpecifier)
try:
self.enterOuterAlt(localctx, 1)
self.state = 673
self.match(CParser.Atomic)
self.state = 674
self.match(CParser.LeftParen)
self.state = 675
self.typeName()
self.state = 676
self.match(CParser.RightParen)
except RecognitionException as re:
localctx.exception = re
self._errHandler.reportError(self, re)
self._errHandler.recover(self, re)
finally:
self.exitRule()
return localctx
class TypeQualifierContext(ParserRuleContext):
def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
super().__init__(parent, invokingState)
self.parser = parser
def getRuleIndex(self):
return CParser.RULE_typeQualifier
def enterRule(self, listener:ParseTreeListener):
if hasattr( listener, "enterTypeQualifier" ):
listener.enterTypeQualifier(self)
def exitRule(self, listener:ParseTreeListener):
if hasattr( listener, "exitTypeQualifier" ):
listener.exitTypeQualifier(self)
def accept(self, visitor:ParseTreeVisitor):
if hasattr( visitor, "visitTypeQualifier" ):
return visitor.visitTypeQualifier(self)
else:
return visitor.visitChildren(self)
def typeQualifier(self):
localctx = CParser.TypeQualifierContext(self, self._ctx, self.state)
self.enterRule(localctx, 88, self.RULE_typeQualifier)
self._la = 0 # Token type
try:
self.enterOuterAlt(localctx, 1)
self.state = 678
_la = self._input.LA(1)
if not((((_la) & ~0x3f) == 0 and ((1 << _la) & ((1 << CParser.Const) | (1 << CParser.Restrict) | (1 << CParser.Volatile) | (1 << CParser.Atomic))) != 0)):
self._errHandler.recoverInline(self)
else:
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 FunctionSpecifierContext(ParserRuleContext):
def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
super().__init__(parent, invokingState)
self.parser = parser
def gccAttributeSpecifier(self):
return self.getTypedRuleContext(CParser.GccAttributeSpecifierContext,0)
def Identifier(self):
return self.getToken(CParser.Identifier, 0)
def getRuleIndex(self):
return CParser.RULE_functionSpecifier
def enterRule(self, listener:ParseTreeListener):
if hasattr( listener, "enterFunctionSpecifier" ):
listener.enterFunctionSpecifier(self)
def exitRule(self, listener:ParseTreeListener):
if hasattr( listener, "exitFunctionSpecifier" ):
listener.exitFunctionSpecifier(self)
def accept(self, visitor:ParseTreeVisitor):
if hasattr( visitor, "visitFunctionSpecifier" ):
return visitor.visitFunctionSpecifier(self)
else:
return visitor.visitChildren(self)
def functionSpecifier(self):
localctx = CParser.FunctionSpecifierContext(self, self._ctx, self.state)
self.enterRule(localctx, 90, self.RULE_functionSpecifier)
self._la = 0 # Token type
try:
self.state = 686
token = self._input.LA(1)
if token in [CParser.T__7, CParser.T__8, CParser.Inline, CParser.Noreturn]:
self.enterOuterAlt(localctx, 1)
self.state = 680
_la = self._input.LA(1)
if not((((_la) & ~0x3f) == 0 and ((1 << _la) & ((1 << CParser.T__7) | (1 << CParser.T__8) | (1 << CParser.Inline) | (1 << CParser.Noreturn))) != 0)):
self._errHandler.recoverInline(self)
else:
self.consume()
elif token in [CParser.T__11]:
self.enterOuterAlt(localctx, 2)
self.state = 681
self.gccAttributeSpecifier()
elif token in [CParser.T__9]:
self.enterOuterAlt(localctx, 3)
self.state = 682
self.match(CParser.T__9)
self.state = 683
self.match(CParser.LeftParen)
self.state = 684
self.match(CParser.Identifier)
self.state = 685
self.match(CParser.RightParen)
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 AlignmentSpecifierContext(ParserRuleContext):
def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
super().__init__(parent, invokingState)
self.parser = parser
def typeName(self):
return self.getTypedRuleContext(CParser.TypeNameContext,0)
def constantExpression(self):
return self.getTypedRuleContext(CParser.ConstantExpressionContext,0)
def getRuleIndex(self):
return CParser.RULE_alignmentSpecifier
def enterRule(self, listener:ParseTreeListener):
if hasattr( listener, "enterAlignmentSpecifier" ):
listener.enterAlignmentSpecifier(self)
def exitRule(self, listener:ParseTreeListener):
if hasattr( listener, "exitAlignmentSpecifier" ):
listener.exitAlignmentSpecifier(self)
def accept(self, visitor:ParseTreeVisitor):
if hasattr( visitor, "visitAlignmentSpecifier" ):
return visitor.visitAlignmentSpecifier(self)
else:
return visitor.visitChildren(self)
def alignmentSpecifier(self):
localctx = CParser.AlignmentSpecifierContext(self, self._ctx, self.state)
self.enterRule(localctx, 92, self.RULE_alignmentSpecifier)
try:
self.state = 698
la_ = self._interp.adaptivePredict(self._input,55,self._ctx)
if la_ == 1:
self.enterOuterAlt(localctx, 1)
self.state = 688
self.match(CParser.Alignas)
self.state = 689
self.match(CParser.LeftParen)
self.state = 690
self.typeName()
self.state = 691
self.match(CParser.RightParen)
pass
elif la_ == 2:
self.enterOuterAlt(localctx, 2)
self.state = 693
self.match(CParser.Alignas)
self.state = 694
self.match(CParser.LeftParen)
self.state = 695
self.constantExpression()
self.state = 696
self.match(CParser.RightParen)
pass
except RecognitionException as re:
localctx.exception = re
self._errHandler.reportError(self, re)
self._errHandler.recover(self, re)
finally:
self.exitRule()
return localctx
class DeclaratorContext(ParserRuleContext):
def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
super().__init__(parent, invokingState)
self.parser = parser
def directDeclarator(self):
return self.getTypedRuleContext(CParser.DirectDeclaratorContext,0)
def pointer(self):
return self.getTypedRuleContext(CParser.PointerContext,0)
def gccDeclaratorExtension(self, i:int=None):
if i is None:
return self.getTypedRuleContexts(CParser.GccDeclaratorExtensionContext)
else:
return self.getTypedRuleContext(CParser.GccDeclaratorExtensionContext,i)
def getRuleIndex(self):
return CParser.RULE_declarator
def enterRule(self, listener:ParseTreeListener):
if hasattr( listener, "enterDeclarator" ):
listener.enterDeclarator(self)
def exitRule(self, listener:ParseTreeListener):
if hasattr( listener, "exitDeclarator" ):
listener.exitDeclarator(self)
def accept(self, visitor:ParseTreeVisitor):
if hasattr( visitor, "visitDeclarator" ):
return visitor.visitDeclarator(self)
else:
return visitor.visitChildren(self)
def declarator(self):
localctx = CParser.DeclaratorContext(self, self._ctx, self.state)
self.enterRule(localctx, 94, self.RULE_declarator)
self._la = 0 # Token type
try:
self.enterOuterAlt(localctx, 1)
self.state = 701
_la = self._input.LA(1)
if _la==CParser.Star or _la==CParser.Caret:
self.state = 700
self.pointer()
self.state = 703
self.directDeclarator(0)
self.state = 707
self._errHandler.sync(self)
_alt = self._interp.adaptivePredict(self._input,57,self._ctx)
while _alt!=2 and _alt!=ATN.INVALID_ALT_NUMBER:
if _alt==1:
self.state = 704
self.gccDeclaratorExtension()
self.state = 709
self._errHandler.sync(self)
_alt = self._interp.adaptivePredict(self._input,57,self._ctx)
except RecognitionException as re:
localctx.exception = re
self._errHandler.reportError(self, re)
self._errHandler.recover(self, re)
finally:
self.exitRule()
return localctx
class DirectDeclaratorContext(ParserRuleContext):
def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
super().__init__(parent, invokingState)
self.parser = parser
def Identifier(self):
return self.getToken(CParser.Identifier, 0)
def declarator(self):
return self.getTypedRuleContext(CParser.DeclaratorContext,0)
def directDeclarator(self):
return self.getTypedRuleContext(CParser.DirectDeclaratorContext,0)
def typeQualifierList(self):
return self.getTypedRuleContext(CParser.TypeQualifierListContext,0)
def assignmentExpression(self):
return self.getTypedRuleContext(CParser.AssignmentExpressionContext,0)
def parameterTypeList(self):
return self.getTypedRuleContext(CParser.ParameterTypeListContext,0)
def identifierList(self):
return self.getTypedRuleContext(CParser.IdentifierListContext,0)
def getRuleIndex(self):
return CParser.RULE_directDeclarator
def enterRule(self, listener:ParseTreeListener):
if hasattr( listener, "enterDirectDeclarator" ):
listener.enterDirectDeclarator(self)
def exitRule(self, listener:ParseTreeListener):
if hasattr( listener, "exitDirectDeclarator" ):
listener.exitDirectDeclarator(self)
def accept(self, visitor:ParseTreeVisitor):
if hasattr( visitor, "visitDirectDeclarator" ):
return visitor.visitDirectDeclarator(self)
else:
return visitor.visitChildren(self)
def directDeclarator(self, _p:int=0):
_parentctx = self._ctx
_parentState = self.state
localctx = CParser.DirectDeclaratorContext(self, self._ctx, _parentState)
_prevctx = localctx
_startState = 96
self.enterRecursionRule(localctx, 96, self.RULE_directDeclarator, _p)
self._la = 0 # Token type
try:
self.enterOuterAlt(localctx, 1)
self.state = 716
token = self._input.LA(1)
if token in [CParser.Identifier]:
self.state = 711
self.match(CParser.Identifier)
elif token in [CParser.LeftParen]:
self.state = 712
self.match(CParser.LeftParen)
self.state = 713
self.declarator()
self.state = 714
self.match(CParser.RightParen)
else:
raise NoViableAltException(self)
self._ctx.stop = self._input.LT(-1)
self.state = 763
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 = 761
la_ = self._interp.adaptivePredict(self._input,64,self._ctx)
if la_ == 1:
localctx = CParser.DirectDeclaratorContext(self, _parentctx, _parentState)
self.pushNewRecursionContext(localctx, _startState, self.RULE_directDeclarator)
self.state = 718
if not self.precpred(self._ctx, 6):
from antlr4.error.Errors import FailedPredicateException
raise FailedPredicateException(self, "self.precpred(self._ctx, 6)")
self.state = 719
self.match(CParser.LeftBracket)
self.state = 721
_la = self._input.LA(1)
if (((_la) & ~0x3f) == 0 and ((1 << _la) & ((1 << CParser.Const) | (1 << CParser.Restrict) | (1 << CParser.Volatile) | (1 << CParser.Atomic))) != 0):
self.state = 720
self.typeQualifierList(0)
self.state = 724
_la = self._input.LA(1)
if (((_la) & ~0x3f) == 0 and ((1 << _la) & ((1 << CParser.T__0) | (1 << CParser.T__1) | (1 << CParser.T__2) | (1 << CParser.Sizeof) | (1 << CParser.Alignof) | (1 << CParser.Generic) | (1 << CParser.LeftParen))) != 0) or ((((_la - 71)) & ~0x3f) == 0 and ((1 << (_la - 71)) & ((1 << (CParser.Plus - 71)) | (1 << (CParser.PlusPlus - 71)) | (1 << (CParser.Minus - 71)) | (1 << (CParser.MinusMinus - 71)) | (1 << (CParser.Star - 71)) | (1 << (CParser.And - 71)) | (1 << (CParser.AndAnd - 71)) | (1 << (CParser.Not - 71)) | (1 << (CParser.Tilde - 71)) | (1 << (CParser.Identifier - 71)) | (1 << (CParser.Constant - 71)) | (1 << (CParser.StringLiteral - 71)))) != 0):
self.state = 723
self.assignmentExpression()
self.state = 726
self.match(CParser.RightBracket)
pass
elif la_ == 2:
localctx = CParser.DirectDeclaratorContext(self, _parentctx, _parentState)
self.pushNewRecursionContext(localctx, _startState, self.RULE_directDeclarator)
self.state = 727
if not self.precpred(self._ctx, 5):
from antlr4.error.Errors import FailedPredicateException
raise FailedPredicateException(self, "self.precpred(self._ctx, 5)")
self.state = 728
self.match(CParser.LeftBracket)
self.state = 729
self.match(CParser.Static)
self.state = 731
_la = self._input.LA(1)
if (((_la) & ~0x3f) == 0 and ((1 << _la) & ((1 << CParser.Const) | (1 << CParser.Restrict) | (1 << CParser.Volatile) | (1 << CParser.Atomic))) != 0):
self.state = 730
self.typeQualifierList(0)
self.state = 733
self.assignmentExpression()
self.state = 734
self.match(CParser.RightBracket)
pass
elif la_ == 3:
localctx = CParser.DirectDeclaratorContext(self, _parentctx, _parentState)
self.pushNewRecursionContext(localctx, _startState, self.RULE_directDeclarator)
self.state = 736
if not self.precpred(self._ctx, 4):
from antlr4.error.Errors import FailedPredicateException
raise FailedPredicateException(self, "self.precpred(self._ctx, 4)")
self.state = 737
self.match(CParser.LeftBracket)
self.state = 738
self.typeQualifierList(0)
self.state = 739
self.match(CParser.Static)
self.state = 740
self.assignmentExpression()
self.state = 741
self.match(CParser.RightBracket)
pass
elif la_ == 4:
localctx = CParser.DirectDeclaratorContext(self, _parentctx, _parentState)
self.pushNewRecursionContext(localctx, _startState, self.RULE_directDeclarator)
self.state = 743
if not self.precpred(self._ctx, 3):
from antlr4.error.Errors import FailedPredicateException
raise FailedPredicateException(self, "self.precpred(self._ctx, 3)")
self.state = 744
self.match(CParser.LeftBracket)
self.state = 746
_la = self._input.LA(1)
if (((_la) & ~0x3f) == 0 and ((1 << _la) & ((1 << CParser.Const) | (1 << CParser.Restrict) | (1 << CParser.Volatile) | (1 << CParser.Atomic))) != 0):
self.state = 745
self.typeQualifierList(0)
self.state = 748
self.match(CParser.Star)
self.state = 749
self.match(CParser.RightBracket)
pass
elif la_ == 5:
localctx = CParser.DirectDeclaratorContext(self, _parentctx, _parentState)
self.pushNewRecursionContext(localctx, _startState, self.RULE_directDeclarator)
self.state = 750
if not self.precpred(self._ctx, 2):
from antlr4.error.Errors import FailedPredicateException
raise FailedPredicateException(self, "self.precpred(self._ctx, 2)")
self.state = 751
self.match(CParser.LeftParen)
self.state = 752
self.parameterTypeList()
self.state = 753
self.match(CParser.RightParen)
pass
elif la_ == 6:
localctx = CParser.DirectDeclaratorContext(self, _parentctx, _parentState)
self.pushNewRecursionContext(localctx, _startState, self.RULE_directDeclarator)
self.state = 755
if not self.precpred(self._ctx, 1):
from antlr4.error.Errors import FailedPredicateException
raise FailedPredicateException(self, "self.precpred(self._ctx, 1)")
self.state = 756
self.match(CParser.LeftParen)
self.state = 758
_la = self._input.LA(1)
if _la==CParser.Identifier:
self.state = 757
self.identifierList(0)
self.state = 760
self.match(CParser.RightParen)
pass
self.state = 765
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 GccDeclaratorExtensionContext(ParserRuleContext):
def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
super().__init__(parent, invokingState)
self.parser = parser
def StringLiteral(self, i:int=None):
if i is None:
return self.getTokens(CParser.StringLiteral)
else:
return self.getToken(CParser.StringLiteral, i)
def gccAttributeSpecifier(self):
return self.getTypedRuleContext(CParser.GccAttributeSpecifierContext,0)
def getRuleIndex(self):
return CParser.RULE_gccDeclaratorExtension
def enterRule(self, listener:ParseTreeListener):
if hasattr( listener, "enterGccDeclaratorExtension" ):
listener.enterGccDeclaratorExtension(self)
def exitRule(self, listener:ParseTreeListener):
if hasattr( listener, "exitGccDeclaratorExtension" ):
listener.exitGccDeclaratorExtension(self)
def accept(self, visitor:ParseTreeVisitor):
if hasattr( visitor, "visitGccDeclaratorExtension" ):
return visitor.visitGccDeclaratorExtension(self)
else:
return visitor.visitChildren(self)
def gccDeclaratorExtension(self):
localctx = CParser.GccDeclaratorExtensionContext(self, self._ctx, self.state)
self.enterRule(localctx, 98, self.RULE_gccDeclaratorExtension)
self._la = 0 # Token type
try:
self.state = 775
token = self._input.LA(1)
if token in [CParser.T__10]:
self.enterOuterAlt(localctx, 1)
self.state = 766
self.match(CParser.T__10)
self.state = 767
self.match(CParser.LeftParen)
self.state = 769
self._errHandler.sync(self)
_la = self._input.LA(1)
while True:
self.state = 768
self.match(CParser.StringLiteral)
self.state = 771
self._errHandler.sync(self)
_la = self._input.LA(1)
if not (_la==CParser.StringLiteral):
break
self.state = 773
self.match(CParser.RightParen)
elif token in [CParser.T__11]:
self.enterOuterAlt(localctx, 2)
self.state = 774
self.gccAttributeSpecifier()
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 GccAttributeSpecifierContext(ParserRuleContext):
def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
super().__init__(parent, invokingState)
self.parser = parser
def gccAttributeList(self):
return self.getTypedRuleContext(CParser.GccAttributeListContext,0)
def getRuleIndex(self):
return CParser.RULE_gccAttributeSpecifier
def enterRule(self, listener:ParseTreeListener):
if hasattr( listener, "enterGccAttributeSpecifier" ):
listener.enterGccAttributeSpecifier(self)
def exitRule(self, listener:ParseTreeListener):
if hasattr( listener, "exitGccAttributeSpecifier" ):
listener.exitGccAttributeSpecifier(self)
def accept(self, visitor:ParseTreeVisitor):
if hasattr( visitor, "visitGccAttributeSpecifier" ):
return visitor.visitGccAttributeSpecifier(self)
else:
return visitor.visitChildren(self)
def gccAttributeSpecifier(self):
localctx = CParser.GccAttributeSpecifierContext(self, self._ctx, self.state)
self.enterRule(localctx, 100, self.RULE_gccAttributeSpecifier)
try:
self.enterOuterAlt(localctx, 1)
self.state = 777
self.match(CParser.T__11)
self.state = 778
self.match(CParser.LeftParen)
self.state = 779
self.match(CParser.LeftParen)
self.state = 780
self.gccAttributeList()
self.state = 781
self.match(CParser.RightParen)
self.state = 782
self.match(CParser.RightParen)
except RecognitionException as re:
localctx.exception = re
self._errHandler.reportError(self, re)
self._errHandler.recover(self, re)
finally:
self.exitRule()
return localctx
class GccAttributeListContext(ParserRuleContext):
def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
super().__init__(parent, invokingState)
self.parser = parser
def gccAttribute(self, i:int=None):
if i is None:
return self.getTypedRuleContexts(CParser.GccAttributeContext)
else:
return self.getTypedRuleContext(CParser.GccAttributeContext,i)
def getRuleIndex(self):
return CParser.RULE_gccAttributeList
def enterRule(self, listener:ParseTreeListener):
if hasattr( listener, "enterGccAttributeList" ):
listener.enterGccAttributeList(self)
def exitRule(self, listener:ParseTreeListener):
if hasattr( listener, "exitGccAttributeList" ):
listener.exitGccAttributeList(self)
def accept(self, visitor:ParseTreeVisitor):
if hasattr( visitor, "visitGccAttributeList" ):
return visitor.visitGccAttributeList(self)
else:
return visitor.visitChildren(self)
def gccAttributeList(self):
localctx = CParser.GccAttributeListContext(self, self._ctx, self.state)
self.enterRule(localctx, 102, self.RULE_gccAttributeList)
self._la = 0 # Token type
try:
self.state = 793
la_ = self._interp.adaptivePredict(self._input,69,self._ctx)
if la_ == 1:
self.enterOuterAlt(localctx, 1)
self.state = 784
self.gccAttribute()
self.state = 789
self._errHandler.sync(self)
_la = self._input.LA(1)
while _la==CParser.Comma:
self.state = 785
self.match(CParser.Comma)
self.state = 786
self.gccAttribute()
self.state = 791
self._errHandler.sync(self)
_la = self._input.LA(1)
pass
elif la_ == 2:
self.enterOuterAlt(localctx, 2)
pass
except RecognitionException as re:
localctx.exception = re
self._errHandler.reportError(self, re)
self._errHandler.recover(self, re)
finally:
self.exitRule()
return localctx
class GccAttributeContext(ParserRuleContext):
def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
super().__init__(parent, invokingState)
self.parser = parser
def argumentExpressionList(self):
return self.getTypedRuleContext(CParser.ArgumentExpressionListContext,0)
def getRuleIndex(self):
return CParser.RULE_gccAttribute
def enterRule(self, listener:ParseTreeListener):
if hasattr( listener, "enterGccAttribute" ):
listener.enterGccAttribute(self)
def exitRule(self, listener:ParseTreeListener):
if hasattr( listener, "exitGccAttribute" ):
listener.exitGccAttribute(self)
def accept(self, visitor:ParseTreeVisitor):
if hasattr( visitor, "visitGccAttribute" ):
return visitor.visitGccAttribute(self)
else:
return visitor.visitChildren(self)
def gccAttribute(self):
localctx = CParser.GccAttributeContext(self, self._ctx, self.state)
self.enterRule(localctx, 104, self.RULE_gccAttribute)
self._la = 0 # Token type
try:
self.state = 804
token = self._input.LA(1)
if token in [CParser.T__0, CParser.T__1, CParser.T__2, CParser.T__3, CParser.T__4, CParser.T__5, CParser.T__6, CParser.T__7, CParser.T__8, CParser.T__9, CParser.T__10, CParser.T__11, CParser.T__12, CParser.T__13, CParser.Auto, CParser.Break, CParser.Case, CParser.Char, CParser.Const, CParser.Continue, CParser.Default, CParser.Do, CParser.Double, CParser.Else, CParser.Enum, CParser.Extern, CParser.Float, CParser.For, CParser.Goto, CParser.If, CParser.Inline, CParser.Int, CParser.Long, CParser.Register, CParser.Restrict, CParser.Return, CParser.Short, CParser.Signed, CParser.Sizeof, CParser.Static, CParser.Struct, CParser.Switch, CParser.Typedef, CParser.Union, CParser.Unsigned, CParser.Void, CParser.Volatile, CParser.While, CParser.Alignas, CParser.Alignof, CParser.Atomic, CParser.Bool, CParser.Complex, CParser.Generic, CParser.Imaginary, CParser.Noreturn, CParser.StaticAssert, CParser.ThreadLocal, CParser.LeftBracket, CParser.RightBracket, CParser.LeftBrace, CParser.RightBrace, CParser.Less, CParser.LessEqual, CParser.Greater, CParser.GreaterEqual, CParser.LeftShift, CParser.RightShift, CParser.Plus, CParser.PlusPlus, CParser.Minus, CParser.MinusMinus, CParser.Star, CParser.Div, CParser.Mod, CParser.And, CParser.Or, CParser.AndAnd, CParser.OrOr, CParser.Caret, CParser.Not, CParser.Tilde, CParser.Question, CParser.Colon, CParser.Semi, CParser.Assign, CParser.StarAssign, CParser.DivAssign, CParser.ModAssign, CParser.PlusAssign, CParser.MinusAssign, CParser.LeftShiftAssign, CParser.RightShiftAssign, CParser.AndAssign, CParser.XorAssign, CParser.OrAssign, CParser.Equal, CParser.NotEqual, CParser.Arrow, CParser.Dot, CParser.Ellipsis, CParser.Identifier, CParser.Constant, CParser.StringLiteral, CParser.LineDirective, CParser.PragmaDirective, CParser.Whitespace, CParser.Newline, CParser.BlockComment, CParser.LineComment]:
self.enterOuterAlt(localctx, 1)
self.state = 795
_la = self._input.LA(1)
if _la <= 0 or ((((_la - 59)) & ~0x3f) == 0 and ((1 << (_la - 59)) & ((1 << (CParser.LeftParen - 59)) | (1 << (CParser.RightParen - 59)) | (1 << (CParser.Comma - 59)))) != 0):
self._errHandler.recoverInline(self)
else:
self.consume()
self.state = 801
_la = self._input.LA(1)
if _la==CParser.LeftParen:
self.state = 796
self.match(CParser.LeftParen)
self.state = 798
_la = self._input.LA(1)
if (((_la) & ~0x3f) == 0 and ((1 << _la) & ((1 << CParser.T__0) | (1 << CParser.T__1) | (1 << CParser.T__2) | (1 << CParser.Sizeof) | (1 << CParser.Alignof) | (1 << CParser.Generic) | (1 << CParser.LeftParen))) != 0) or ((((_la - 71)) & ~0x3f) == 0 and ((1 << (_la - 71)) & ((1 << (CParser.Plus - 71)) | (1 << (CParser.PlusPlus - 71)) | (1 << (CParser.Minus - 71)) | (1 << (CParser.MinusMinus - 71)) | (1 << (CParser.Star - 71)) | (1 << (CParser.And - 71)) | (1 << (CParser.AndAnd - 71)) | (1 << (CParser.Not - 71)) | (1 << (CParser.Tilde - 71)) | (1 << (CParser.Identifier - 71)) | (1 << (CParser.Constant - 71)) | (1 << (CParser.StringLiteral - 71)))) != 0):
self.state = 797
self.argumentExpressionList(0)
self.state = 800
self.match(CParser.RightParen)
elif token in [CParser.RightParen, CParser.Comma]:
self.enterOuterAlt(localctx, 2)
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 NestedParenthesesBlockContext(ParserRuleContext):
def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
super().__init__(parent, invokingState)
self.parser = parser
def nestedParenthesesBlock(self, i:int=None):
if i is None:
return self.getTypedRuleContexts(CParser.NestedParenthesesBlockContext)
else:
return self.getTypedRuleContext(CParser.NestedParenthesesBlockContext,i)
def getRuleIndex(self):
return CParser.RULE_nestedParenthesesBlock
def enterRule(self, listener:ParseTreeListener):
if hasattr( listener, "enterNestedParenthesesBlock" ):
listener.enterNestedParenthesesBlock(self)
def exitRule(self, listener:ParseTreeListener):
if hasattr( listener, "exitNestedParenthesesBlock" ):
listener.exitNestedParenthesesBlock(self)
def accept(self, visitor:ParseTreeVisitor):
if hasattr( visitor, "visitNestedParenthesesBlock" ):
return visitor.visitNestedParenthesesBlock(self)
else:
return visitor.visitChildren(self)
def nestedParenthesesBlock(self):
localctx = CParser.NestedParenthesesBlockContext(self, self._ctx, self.state)
self.enterRule(localctx, 106, self.RULE_nestedParenthesesBlock)
self._la = 0 # Token type
try:
self.enterOuterAlt(localctx, 1)
self.state = 813
self._errHandler.sync(self)
_la = self._input.LA(1)
while (((_la) & ~0x3f) == 0 and ((1 << _la) & ((1 << CParser.T__0) | (1 << CParser.T__1) | (1 << CParser.T__2) | (1 << CParser.T__3) | (1 << CParser.T__4) | (1 << CParser.T__5) | (1 << CParser.T__6) | (1 << CParser.T__7) | (1 << CParser.T__8) | (1 << CParser.T__9) | (1 << CParser.T__10) | (1 << CParser.T__11) | (1 << CParser.T__12) | (1 << CParser.T__13) | (1 << CParser.Auto) | (1 << CParser.Break) | (1 << CParser.Case) | (1 << CParser.Char) | (1 << CParser.Const) | (1 << CParser.Continue) | (1 << CParser.Default) | (1 << CParser.Do) | (1 << CParser.Double) | (1 << CParser.Else) | (1 << CParser.Enum) | (1 << CParser.Extern) | (1 << CParser.Float) | (1 << CParser.For) | (1 << CParser.Goto) | (1 << CParser.If) | (1 << CParser.Inline) | (1 << CParser.Int) | (1 << CParser.Long) | (1 << CParser.Register) | (1 << CParser.Restrict) | (1 << CParser.Return) | (1 << CParser.Short) | (1 << CParser.Signed) | (1 << CParser.Sizeof) | (1 << CParser.Static) | (1 << CParser.Struct) | (1 << CParser.Switch) | (1 << CParser.Typedef) | (1 << CParser.Union) | (1 << CParser.Unsigned) | (1 << CParser.Void) | (1 << CParser.Volatile) | (1 << CParser.While) | (1 << CParser.Alignas) | (1 << CParser.Alignof) | (1 << CParser.Atomic) | (1 << CParser.Bool) | (1 << CParser.Complex) | (1 << CParser.Generic) | (1 << CParser.Imaginary) | (1 << CParser.Noreturn) | (1 << CParser.StaticAssert) | (1 << CParser.ThreadLocal) | (1 << CParser.LeftParen) | (1 << CParser.LeftBracket) | (1 << CParser.RightBracket) | (1 << CParser.LeftBrace))) != 0) or ((((_la - 64)) & ~0x3f) == 0 and ((1 << (_la - 64)) & ((1 << (CParser.RightBrace - 64)) | (1 << (CParser.Less - 64)) | (1 << (CParser.LessEqual - 64)) | (1 << (CParser.Greater - 64)) | (1 << (CParser.GreaterEqual - 64)) | (1 << (CParser.LeftShift - 64)) | (1 << (CParser.RightShift - 64)) | (1 << (CParser.Plus - 64)) | (1 << (CParser.PlusPlus - 64)) | (1 << (CParser.Minus - 64)) | (1 << (CParser.MinusMinus - 64)) | (1 << (CParser.Star - 64)) | (1 << (CParser.Div - 64)) | (1 << (CParser.Mod - 64)) | (1 << (CParser.And - 64)) | (1 << (CParser.Or - 64)) | (1 << (CParser.AndAnd - 64)) | (1 << (CParser.OrOr - 64)) | (1 << (CParser.Caret - 64)) | (1 << (CParser.Not - 64)) | (1 << (CParser.Tilde - 64)) | (1 << (CParser.Question - 64)) | (1 << (CParser.Colon - 64)) | (1 << (CParser.Semi - 64)) | (1 << (CParser.Comma - 64)) | (1 << (CParser.Assign - 64)) | (1 << (CParser.StarAssign - 64)) | (1 << (CParser.DivAssign - 64)) | (1 << (CParser.ModAssign - 64)) | (1 << (CParser.PlusAssign - 64)) | (1 << (CParser.MinusAssign - 64)) | (1 << (CParser.LeftShiftAssign - 64)) | (1 << (CParser.RightShiftAssign - 64)) | (1 << (CParser.AndAssign - 64)) | (1 << (CParser.XorAssign - 64)) | (1 << (CParser.OrAssign - 64)) | (1 << (CParser.Equal - 64)) | (1 << (CParser.NotEqual - 64)) | (1 << (CParser.Arrow - 64)) | (1 << (CParser.Dot - 64)) | (1 << (CParser.Ellipsis - 64)) | (1 << (CParser.Identifier - 64)) | (1 << (CParser.Constant - 64)) | (1 << (CParser.StringLiteral - 64)) | (1 << (CParser.LineDirective - 64)) | (1 << (CParser.PragmaDirective - 64)) | (1 << (CParser.Whitespace - 64)) | (1 << (CParser.Newline - 64)) | (1 << (CParser.BlockComment - 64)) | (1 << (CParser.LineComment - 64)))) != 0):
self.state = 811
token = self._input.LA(1)
if token in [CParser.T__0, CParser.T__1, CParser.T__2, CParser.T__3, CParser.T__4, CParser.T__5, CParser.T__6, CParser.T__7, CParser.T__8, CParser.T__9, CParser.T__10, CParser.T__11, CParser.T__12, CParser.T__13, CParser.Auto, CParser.Break, CParser.Case, CParser.Char, CParser.Const, CParser.Continue, CParser.Default, CParser.Do, CParser.Double, CParser.Else, CParser.Enum, CParser.Extern, CParser.Float, CParser.For, CParser.Goto, CParser.If, CParser.Inline, CParser.Int, CParser.Long, CParser.Register, CParser.Restrict, CParser.Return, CParser.Short, CParser.Signed, CParser.Sizeof, CParser.Static, CParser.Struct, CParser.Switch, CParser.Typedef, CParser.Union, CParser.Unsigned, CParser.Void, CParser.Volatile, CParser.While, CParser.Alignas, CParser.Alignof, CParser.Atomic, CParser.Bool, CParser.Complex, CParser.Generic, CParser.Imaginary, CParser.Noreturn, CParser.StaticAssert, CParser.ThreadLocal, CParser.LeftBracket, CParser.RightBracket, CParser.LeftBrace, CParser.RightBrace, CParser.Less, CParser.LessEqual, CParser.Greater, CParser.GreaterEqual, CParser.LeftShift, CParser.RightShift, CParser.Plus, CParser.PlusPlus, CParser.Minus, CParser.MinusMinus, CParser.Star, CParser.Div, CParser.Mod, CParser.And, CParser.Or, CParser.AndAnd, CParser.OrOr, CParser.Caret, CParser.Not, CParser.Tilde, CParser.Question, CParser.Colon, CParser.Semi, CParser.Comma, CParser.Assign, CParser.StarAssign, CParser.DivAssign, CParser.ModAssign, CParser.PlusAssign, CParser.MinusAssign, CParser.LeftShiftAssign, CParser.RightShiftAssign, CParser.AndAssign, CParser.XorAssign, CParser.OrAssign, CParser.Equal, CParser.NotEqual, CParser.Arrow, CParser.Dot, CParser.Ellipsis, CParser.Identifier, CParser.Constant, CParser.StringLiteral, CParser.LineDirective, CParser.PragmaDirective, CParser.Whitespace, CParser.Newline, CParser.BlockComment, CParser.LineComment]:
self.state = 806
_la = self._input.LA(1)
if _la <= 0 or _la==CParser.LeftParen or _la==CParser.RightParen:
self._errHandler.recoverInline(self)
else:
self.consume()
elif token in [CParser.LeftParen]:
self.state = 807
self.match(CParser.LeftParen)
self.state = 808
self.nestedParenthesesBlock()
self.state = 809
self.match(CParser.RightParen)
else:
raise NoViableAltException(self)
self.state = 815
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 PointerContext(ParserRuleContext):
def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
super().__init__(parent, invokingState)
self.parser = parser
def typeQualifierList(self):
return self.getTypedRuleContext(CParser.TypeQualifierListContext,0)
def pointer(self):
return self.getTypedRuleContext(CParser.PointerContext,0)
def getRuleIndex(self):
return CParser.RULE_pointer
def enterRule(self, listener:ParseTreeListener):
if hasattr( listener, "enterPointer" ):
listener.enterPointer(self)
def exitRule(self, listener:ParseTreeListener):
if hasattr( listener, "exitPointer" ):
listener.exitPointer(self)
def accept(self, visitor:ParseTreeVisitor):
if hasattr( visitor, "visitPointer" ):
return visitor.visitPointer(self)
else:
return visitor.visitChildren(self)
def pointer(self):
localctx = CParser.PointerContext(self, self._ctx, self.state)
self.enterRule(localctx, 108, self.RULE_pointer)
self._la = 0 # Token type
try:
self.state = 834
la_ = self._interp.adaptivePredict(self._input,79,self._ctx)
if la_ == 1:
self.enterOuterAlt(localctx, 1)
self.state = 816
self.match(CParser.Star)
self.state = 818
la_ = self._interp.adaptivePredict(self._input,75,self._ctx)
if la_ == 1:
self.state = 817
self.typeQualifierList(0)
pass
elif la_ == 2:
self.enterOuterAlt(localctx, 2)
self.state = 820
self.match(CParser.Star)
self.state = 822
_la = self._input.LA(1)
if (((_la) & ~0x3f) == 0 and ((1 << _la) & ((1 << CParser.Const) | (1 << CParser.Restrict) | (1 << CParser.Volatile) | (1 << CParser.Atomic))) != 0):
self.state = 821
self.typeQualifierList(0)
self.state = 824
self.pointer()
pass
elif la_ == 3:
self.enterOuterAlt(localctx, 3)
self.state = 825
self.match(CParser.Caret)
self.state = 827
la_ = self._interp.adaptivePredict(self._input,77,self._ctx)
if la_ == 1:
self.state = 826
self.typeQualifierList(0)
pass
elif la_ == 4:
self.enterOuterAlt(localctx, 4)
self.state = 829
self.match(CParser.Caret)
self.state = 831
_la = self._input.LA(1)
if (((_la) & ~0x3f) == 0 and ((1 << _la) & ((1 << CParser.Const) | (1 << CParser.Restrict) | (1 << CParser.Volatile) | (1 << CParser.Atomic))) != 0):
self.state = 830
self.typeQualifierList(0)
self.state = 833
self.pointer()
pass
except RecognitionException as re:
localctx.exception = re
self._errHandler.reportError(self, re)
self._errHandler.recover(self, re)
finally:
self.exitRule()
return localctx
class TypeQualifierListContext(ParserRuleContext):
def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
super().__init__(parent, invokingState)
self.parser = parser
def typeQualifier(self):
return self.getTypedRuleContext(CParser.TypeQualifierContext,0)
def typeQualifierList(self):
return self.getTypedRuleContext(CParser.TypeQualifierListContext,0)
def getRuleIndex(self):
return CParser.RULE_typeQualifierList
def enterRule(self, listener:ParseTreeListener):
if hasattr( listener, "enterTypeQualifierList" ):
listener.enterTypeQualifierList(self)
def exitRule(self, listener:ParseTreeListener):
if hasattr( listener, "exitTypeQualifierList" ):
listener.exitTypeQualifierList(self)
def accept(self, visitor:ParseTreeVisitor):
if hasattr( visitor, "visitTypeQualifierList" ):
return visitor.visitTypeQualifierList(self)
else:
return visitor.visitChildren(self)
def typeQualifierList(self, _p:int=0):
_parentctx = self._ctx
_parentState = self.state
localctx = CParser.TypeQualifierListContext(self, self._ctx, _parentState)
_prevctx = localctx
_startState = 110
self.enterRecursionRule(localctx, 110, self.RULE_typeQualifierList, _p)
try:
self.enterOuterAlt(localctx, 1)
self.state = 837
self.typeQualifier()
self._ctx.stop = self._input.LT(-1)
self.state = 843
self._errHandler.sync(self)
_alt = self._interp.adaptivePredict(self._input,80,self._ctx)
while _alt!=2 and _alt!=ATN.INVALID_ALT_NUMBER:
if _alt==1:
if self._parseListeners is not None:
self.triggerExitRuleEvent()
_prevctx = localctx
localctx = CParser.TypeQualifierListContext(self, _parentctx, _parentState)
self.pushNewRecursionContext(localctx, _startState, self.RULE_typeQualifierList)
self.state = 839
if not self.precpred(self._ctx, 1):
from antlr4.error.Errors import FailedPredicateException
raise FailedPredicateException(self, "self.precpred(self._ctx, 1)")
self.state = 840
self.typeQualifier()
self.state = 845
self._errHandler.sync(self)
_alt = self._interp.adaptivePredict(self._input,80,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 ParameterTypeListContext(ParserRuleContext):
def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
super().__init__(parent, invokingState)
self.parser = parser
def parameterList(self):
return self.getTypedRuleContext(CParser.ParameterListContext,0)
def getRuleIndex(self):
return CParser.RULE_parameterTypeList
def enterRule(self, listener:ParseTreeListener):
if hasattr( listener, "enterParameterTypeList" ):
listener.enterParameterTypeList(self)
def exitRule(self, listener:ParseTreeListener):
if hasattr( listener, "exitParameterTypeList" ):
listener.exitParameterTypeList(self)
def accept(self, visitor:ParseTreeVisitor):
if hasattr( visitor, "visitParameterTypeList" ):
return visitor.visitParameterTypeList(self)
else:
return visitor.visitChildren(self)
def parameterTypeList(self):
localctx = CParser.ParameterTypeListContext(self, self._ctx, self.state)
self.enterRule(localctx, 112, self.RULE_parameterTypeList)
try:
self.state = 851
la_ = self._interp.adaptivePredict(self._input,81,self._ctx)
if la_ == 1:
self.enterOuterAlt(localctx, 1)
self.state = 846
self.parameterList(0)
pass
elif la_ == 2:
self.enterOuterAlt(localctx, 2)
self.state = 847
self.parameterList(0)
self.state = 848
self.match(CParser.Comma)
self.state = 849
self.match(CParser.Ellipsis)
pass
except RecognitionException as re:
localctx.exception = re
self._errHandler.reportError(self, re)
self._errHandler.recover(self, re)
finally:
self.exitRule()
return localctx
class ParameterListContext(ParserRuleContext):
def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
super().__init__(parent, invokingState)
self.parser = parser
def parameterDeclaration(self):
return self.getTypedRuleContext(CParser.ParameterDeclarationContext,0)
def parameterList(self):
return self.getTypedRuleContext(CParser.ParameterListContext,0)
def getRuleIndex(self):
return CParser.RULE_parameterList
def enterRule(self, listener:ParseTreeListener):
if hasattr( listener, "enterParameterList" ):
listener.enterParameterList(self)
def exitRule(self, listener:ParseTreeListener):
if hasattr( listener, "exitParameterList" ):
listener.exitParameterList(self)
def accept(self, visitor:ParseTreeVisitor):
if hasattr( visitor, "visitParameterList" ):
return visitor.visitParameterList(self)
else:
return visitor.visitChildren(self)
def parameterList(self, _p:int=0):
_parentctx = self._ctx
_parentState = self.state
localctx = CParser.ParameterListContext(self, self._ctx, _parentState)
_prevctx = localctx
_startState = 114
self.enterRecursionRule(localctx, 114, self.RULE_parameterList, _p)
try:
self.enterOuterAlt(localctx, 1)
self.state = 854
self.parameterDeclaration()
self._ctx.stop = self._input.LT(-1)
self.state = 861
self._errHandler.sync(self)
_alt = self._interp.adaptivePredict(self._input,82,self._ctx)
while _alt!=2 and _alt!=ATN.INVALID_ALT_NUMBER:
if _alt==1:
if self._parseListeners is not None:
self.triggerExitRuleEvent()
_prevctx = localctx
localctx = CParser.ParameterListContext(self, _parentctx, _parentState)
self.pushNewRecursionContext(localctx, _startState, self.RULE_parameterList)
self.state = 856
if not self.precpred(self._ctx, 1):
from antlr4.error.Errors import FailedPredicateException
raise FailedPredicateException(self, "self.precpred(self._ctx, 1)")
self.state = 857
self.match(CParser.Comma)
self.state = 858
self.parameterDeclaration()
self.state = 863
self._errHandler.sync(self)
_alt = self._interp.adaptivePredict(self._input,82,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 ParameterDeclarationContext(ParserRuleContext):
def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
super().__init__(parent, invokingState)
self.parser = parser
def declarationSpecifiers(self):
return self.getTypedRuleContext(CParser.DeclarationSpecifiersContext,0)
def declarator(self):
return self.getTypedRuleContext(CParser.DeclaratorContext,0)
def declarationSpecifiers2(self):
return self.getTypedRuleContext(CParser.DeclarationSpecifiers2Context,0)
def abstractDeclarator(self):
return self.getTypedRuleContext(CParser.AbstractDeclaratorContext,0)
def getRuleIndex(self):
return CParser.RULE_parameterDeclaration
def enterRule(self, listener:ParseTreeListener):
if hasattr( listener, "enterParameterDeclaration" ):
listener.enterParameterDeclaration(self)
def exitRule(self, listener:ParseTreeListener):
if hasattr( listener, "exitParameterDeclaration" ):
listener.exitParameterDeclaration(self)
def accept(self, visitor:ParseTreeVisitor):
if hasattr( visitor, "visitParameterDeclaration" ):
return visitor.visitParameterDeclaration(self)
else:
return visitor.visitChildren(self)
def parameterDeclaration(self):
localctx = CParser.ParameterDeclarationContext(self, self._ctx, self.state)
self.enterRule(localctx, 116, self.RULE_parameterDeclaration)
try:
self.state = 871
la_ = self._interp.adaptivePredict(self._input,84,self._ctx)
if la_ == 1:
self.enterOuterAlt(localctx, 1)
self.state = 864
self.declarationSpecifiers()
self.state = 865
self.declarator()
pass
elif la_ == 2:
self.enterOuterAlt(localctx, 2)
self.state = 867
self.declarationSpecifiers2()
self.state = 869
la_ = self._interp.adaptivePredict(self._input,83,self._ctx)
if la_ == 1:
self.state = 868
self.abstractDeclarator()
pass
except RecognitionException as re:
localctx.exception = re
self._errHandler.reportError(self, re)
self._errHandler.recover(self, re)
finally:
self.exitRule()
return localctx
class IdentifierListContext(ParserRuleContext):
def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
super().__init__(parent, invokingState)
self.parser = parser
def Identifier(self):
return self.getToken(CParser.Identifier, 0)
def identifierList(self):
return self.getTypedRuleContext(CParser.IdentifierListContext,0)
def getRuleIndex(self):
return CParser.RULE_identifierList
def enterRule(self, listener:ParseTreeListener):
if hasattr( listener, "enterIdentifierList" ):
listener.enterIdentifierList(self)
def exitRule(self, listener:ParseTreeListener):
if hasattr( listener, "exitIdentifierList" ):
listener.exitIdentifierList(self)
def accept(self, visitor:ParseTreeVisitor):
if hasattr( visitor, "visitIdentifierList" ):
return visitor.visitIdentifierList(self)
else:
return visitor.visitChildren(self)
def identifierList(self, _p:int=0):
_parentctx = self._ctx
_parentState = self.state
localctx = CParser.IdentifierListContext(self, self._ctx, _parentState)
_prevctx = localctx
_startState = 118
self.enterRecursionRule(localctx, 118, self.RULE_identifierList, _p)
try:
self.enterOuterAlt(localctx, 1)
self.state = 874
self.match(CParser.Identifier)
self._ctx.stop = self._input.LT(-1)
self.state = 881
self._errHandler.sync(self)
_alt = self._interp.adaptivePredict(self._input,85,self._ctx)
while _alt!=2 and _alt!=ATN.INVALID_ALT_NUMBER:
if _alt==1:
if self._parseListeners is not None:
self.triggerExitRuleEvent()
_prevctx = localctx
localctx = CParser.IdentifierListContext(self, _parentctx, _parentState)
self.pushNewRecursionContext(localctx, _startState, self.RULE_identifierList)
self.state = 876
if not self.precpred(self._ctx, 1):
from antlr4.error.Errors import FailedPredicateException
raise FailedPredicateException(self, "self.precpred(self._ctx, 1)")
self.state = 877
self.match(CParser.Comma)
self.state = 878
self.match(CParser.Identifier)
self.state = 883
self._errHandler.sync(self)
_alt = self._interp.adaptivePredict(self._input,85,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 TypeNameContext(ParserRuleContext):
def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
super().__init__(parent, invokingState)
self.parser = parser
def specifierQualifierList(self):
return self.getTypedRuleContext(CParser.SpecifierQualifierListContext,0)
def abstractDeclarator(self):
return self.getTypedRuleContext(CParser.AbstractDeclaratorContext,0)
def getRuleIndex(self):
return CParser.RULE_typeName
def enterRule(self, listener:ParseTreeListener):
if hasattr( listener, "enterTypeName" ):
listener.enterTypeName(self)
def exitRule(self, listener:ParseTreeListener):
if hasattr( listener, "exitTypeName" ):
listener.exitTypeName(self)
def accept(self, visitor:ParseTreeVisitor):
if hasattr( visitor, "visitTypeName" ):
return visitor.visitTypeName(self)
else:
return visitor.visitChildren(self)
def typeName(self):
localctx = CParser.TypeNameContext(self, self._ctx, self.state)
self.enterRule(localctx, 120, self.RULE_typeName)
self._la = 0 # Token type
try:
self.enterOuterAlt(localctx, 1)
self.state = 884
self.specifierQualifierList()
self.state = 886
_la = self._input.LA(1)
if ((((_la - 59)) & ~0x3f) == 0 and ((1 << (_la - 59)) & ((1 << (CParser.LeftParen - 59)) | (1 << (CParser.LeftBracket - 59)) | (1 << (CParser.Star - 59)) | (1 << (CParser.Caret - 59)))) != 0):
self.state = 885
self.abstractDeclarator()
except RecognitionException as re:
localctx.exception = re
self._errHandler.reportError(self, re)
self._errHandler.recover(self, re)
finally:
self.exitRule()
return localctx
class AbstractDeclaratorContext(ParserRuleContext):
def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
super().__init__(parent, invokingState)
self.parser = parser
def pointer(self):
return self.getTypedRuleContext(CParser.PointerContext,0)
def directAbstractDeclarator(self):
return self.getTypedRuleContext(CParser.DirectAbstractDeclaratorContext,0)
def gccDeclaratorExtension(self, i:int=None):
if i is None:
return self.getTypedRuleContexts(CParser.GccDeclaratorExtensionContext)
else:
return self.getTypedRuleContext(CParser.GccDeclaratorExtensionContext,i)
def getRuleIndex(self):
return CParser.RULE_abstractDeclarator
def enterRule(self, listener:ParseTreeListener):
if hasattr( listener, "enterAbstractDeclarator" ):
listener.enterAbstractDeclarator(self)
def exitRule(self, listener:ParseTreeListener):
if hasattr( listener, "exitAbstractDeclarator" ):
listener.exitAbstractDeclarator(self)
def accept(self, visitor:ParseTreeVisitor):
if hasattr( visitor, "visitAbstractDeclarator" ):
return visitor.visitAbstractDeclarator(self)
else:
return visitor.visitChildren(self)
def abstractDeclarator(self):
localctx = CParser.AbstractDeclaratorContext(self, self._ctx, self.state)
self.enterRule(localctx, 122, self.RULE_abstractDeclarator)
self._la = 0 # Token type
try:
self.state = 899
la_ = self._interp.adaptivePredict(self._input,89,self._ctx)
if la_ == 1:
self.enterOuterAlt(localctx, 1)
self.state = 888
self.pointer()
pass
elif la_ == 2:
self.enterOuterAlt(localctx, 2)
self.state = 890
_la = self._input.LA(1)
if _la==CParser.Star or _la==CParser.Caret:
self.state = 889
self.pointer()
self.state = 892
self.directAbstractDeclarator(0)
self.state = 896
self._errHandler.sync(self)
_alt = self._interp.adaptivePredict(self._input,88,self._ctx)
while _alt!=2 and _alt!=ATN.INVALID_ALT_NUMBER:
if _alt==1:
self.state = 893
self.gccDeclaratorExtension()
self.state = 898
self._errHandler.sync(self)
_alt = self._interp.adaptivePredict(self._input,88,self._ctx)
pass
except RecognitionException as re:
localctx.exception = re
self._errHandler.reportError(self, re)
self._errHandler.recover(self, re)
finally:
self.exitRule()
return localctx
class DirectAbstractDeclaratorContext(ParserRuleContext):
def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
super().__init__(parent, invokingState)
self.parser = parser
def abstractDeclarator(self):
return self.getTypedRuleContext(CParser.AbstractDeclaratorContext,0)
def gccDeclaratorExtension(self, i:int=None):
if i is None:
return self.getTypedRuleContexts(CParser.GccDeclaratorExtensionContext)
else:
return self.getTypedRuleContext(CParser.GccDeclaratorExtensionContext,i)
def typeQualifierList(self):
return self.getTypedRuleContext(CParser.TypeQualifierListContext,0)
def assignmentExpression(self):
return self.getTypedRuleContext(CParser.AssignmentExpressionContext,0)
def parameterTypeList(self):
return self.getTypedRuleContext(CParser.ParameterTypeListContext,0)
def directAbstractDeclarator(self):
return self.getTypedRuleContext(CParser.DirectAbstractDeclaratorContext,0)
def getRuleIndex(self):
return CParser.RULE_directAbstractDeclarator
def enterRule(self, listener:ParseTreeListener):
if hasattr( listener, "enterDirectAbstractDeclarator" ):
listener.enterDirectAbstractDeclarator(self)
def exitRule(self, listener:ParseTreeListener):
if hasattr( listener, "exitDirectAbstractDeclarator" ):
listener.exitDirectAbstractDeclarator(self)
def accept(self, visitor:ParseTreeVisitor):
if hasattr( visitor, "visitDirectAbstractDeclarator" ):
return visitor.visitDirectAbstractDeclarator(self)
else:
return visitor.visitChildren(self)
def directAbstractDeclarator(self, _p:int=0):
_parentctx = self._ctx
_parentState = self.state
localctx = CParser.DirectAbstractDeclaratorContext(self, self._ctx, _parentState)
_prevctx = localctx
_startState = 124
self.enterRecursionRule(localctx, 124, self.RULE_directAbstractDeclarator, _p)
self._la = 0 # Token type
try:
self.enterOuterAlt(localctx, 1)
self.state = 947
la_ = self._interp.adaptivePredict(self._input,96,self._ctx)
if la_ == 1:
self.state = 902
self.match(CParser.LeftParen)
self.state = 903
self.abstractDeclarator()
self.state = 904
self.match(CParser.RightParen)
self.state = 908
self._errHandler.sync(self)
_alt = self._interp.adaptivePredict(self._input,90,self._ctx)
while _alt!=2 and _alt!=ATN.INVALID_ALT_NUMBER:
if _alt==1:
self.state = 905
self.gccDeclaratorExtension()
self.state = 910
self._errHandler.sync(self)
_alt = self._interp.adaptivePredict(self._input,90,self._ctx)
pass
elif la_ == 2:
self.state = 911
self.match(CParser.LeftBracket)
self.state = 913
_la = self._input.LA(1)
if (((_la) & ~0x3f) == 0 and ((1 << _la) & ((1 << CParser.Const) | (1 << CParser.Restrict) | (1 << CParser.Volatile) | (1 << CParser.Atomic))) != 0):
self.state = 912
self.typeQualifierList(0)
self.state = 916
_la = self._input.LA(1)
if (((_la) & ~0x3f) == 0 and ((1 << _la) & ((1 << CParser.T__0) | (1 << CParser.T__1) | (1 << CParser.T__2) | (1 << CParser.Sizeof) | (1 << CParser.Alignof) | (1 << CParser.Generic) | (1 << CParser.LeftParen))) != 0) or ((((_la - 71)) & ~0x3f) == 0 and ((1 << (_la - 71)) & ((1 << (CParser.Plus - 71)) | (1 << (CParser.PlusPlus - 71)) | (1 << (CParser.Minus - 71)) | (1 << (CParser.MinusMinus - 71)) | (1 << (CParser.Star - 71)) | (1 << (CParser.And - 71)) | (1 << (CParser.AndAnd - 71)) | (1 << (CParser.Not - 71)) | (1 << (CParser.Tilde - 71)) | (1 << (CParser.Identifier - 71)) | (1 << (CParser.Constant - 71)) | (1 << (CParser.StringLiteral - 71)))) != 0):
self.state = 915
self.assignmentExpression()
self.state = 918
self.match(CParser.RightBracket)
pass
elif la_ == 3:
self.state = 919
self.match(CParser.LeftBracket)
self.state = 920
self.match(CParser.Static)
self.state = 922
_la = self._input.LA(1)
if (((_la) & ~0x3f) == 0 and ((1 << _la) & ((1 << CParser.Const) | (1 << CParser.Restrict) | (1 << CParser.Volatile) | (1 << CParser.Atomic))) != 0):
self.state = 921
self.typeQualifierList(0)
self.state = 924
self.assignmentExpression()
self.state = 925
self.match(CParser.RightBracket)
pass
elif la_ == 4:
self.state = 927
self.match(CParser.LeftBracket)
self.state = 928
self.typeQualifierList(0)
self.state = 929
self.match(CParser.Static)
self.state = 930
self.assignmentExpression()
self.state = 931
self.match(CParser.RightBracket)
pass
elif la_ == 5:
self.state = 933
self.match(CParser.LeftBracket)
self.state = 934
self.match(CParser.Star)
self.state = 935
self.match(CParser.RightBracket)
pass
elif la_ == 6:
self.state = 936
self.match(CParser.LeftParen)
self.state = 938
_la = self._input.LA(1)
if (((_la) & ~0x3f) == 0 and ((1 << _la) & ((1 << CParser.T__0) | (1 << CParser.T__3) | (1 << CParser.T__4) | (1 << CParser.T__5) | (1 << CParser.T__6) | (1 << CParser.T__7) | (1 << CParser.T__8) | (1 << CParser.T__9) | (1 << CParser.T__11) | (1 << CParser.Auto) | (1 << CParser.Char) | (1 << CParser.Const) | (1 << CParser.Double) | (1 << CParser.Enum) | (1 << CParser.Extern) | (1 << CParser.Float) | (1 << CParser.Inline) | (1 << CParser.Int) | (1 << CParser.Long) | (1 << CParser.Register) | (1 << CParser.Restrict) | (1 << CParser.Short) | (1 << CParser.Signed) | (1 << CParser.Static) | (1 << CParser.Struct) | (1 << CParser.Typedef) | (1 << CParser.Union) | (1 << CParser.Unsigned) | (1 << CParser.Void) | (1 << CParser.Volatile) | (1 << CParser.Alignas) | (1 << CParser.Atomic) | (1 << CParser.Bool) | (1 << CParser.Complex) | (1 << CParser.Noreturn) | (1 << CParser.ThreadLocal))) != 0) or _la==CParser.Identifier:
self.state = 937
self.parameterTypeList()
self.state = 940
self.match(CParser.RightParen)
self.state = 944
self._errHandler.sync(self)
_alt = self._interp.adaptivePredict(self._input,95,self._ctx)
while _alt!=2 and _alt!=ATN.INVALID_ALT_NUMBER:
if _alt==1:
self.state = 941
self.gccDeclaratorExtension()
self.state = 946
self._errHandler.sync(self)
_alt = self._interp.adaptivePredict(self._input,95,self._ctx)
pass
self._ctx.stop = self._input.LT(-1)
self.state = 992
self._errHandler.sync(self)
_alt = self._interp.adaptivePredict(self._input,103,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 = 990
la_ = self._interp.adaptivePredict(self._input,102,self._ctx)
if la_ == 1:
localctx = CParser.DirectAbstractDeclaratorContext(self, _parentctx, _parentState)
self.pushNewRecursionContext(localctx, _startState, self.RULE_directAbstractDeclarator)
self.state = 949
if not self.precpred(self._ctx, 5):
from antlr4.error.Errors import FailedPredicateException
raise FailedPredicateException(self, "self.precpred(self._ctx, 5)")
self.state = 950
self.match(CParser.LeftBracket)
self.state = 952
_la = self._input.LA(1)
if (((_la) & ~0x3f) == 0 and ((1 << _la) & ((1 << CParser.Const) | (1 << CParser.Restrict) | (1 << CParser.Volatile) | (1 << CParser.Atomic))) != 0):
self.state = 951
self.typeQualifierList(0)
self.state = 955
_la = self._input.LA(1)
if (((_la) & ~0x3f) == 0 and ((1 << _la) & ((1 << CParser.T__0) | (1 << CParser.T__1) | (1 << CParser.T__2) | (1 << CParser.Sizeof) | (1 << CParser.Alignof) | (1 << CParser.Generic) | (1 << CParser.LeftParen))) != 0) or ((((_la - 71)) & ~0x3f) == 0 and ((1 << (_la - 71)) & ((1 << (CParser.Plus - 71)) | (1 << (CParser.PlusPlus - 71)) | (1 << (CParser.Minus - 71)) | (1 << (CParser.MinusMinus - 71)) | (1 << (CParser.Star - 71)) | (1 << (CParser.And - 71)) | (1 << (CParser.AndAnd - 71)) | (1 << (CParser.Not - 71)) | (1 << (CParser.Tilde - 71)) | (1 << (CParser.Identifier - 71)) | (1 << (CParser.Constant - 71)) | (1 << (CParser.StringLiteral - 71)))) != 0):
self.state = 954
self.assignmentExpression()
self.state = 957
self.match(CParser.RightBracket)
pass
elif la_ == 2:
localctx = CParser.DirectAbstractDeclaratorContext(self, _parentctx, _parentState)
self.pushNewRecursionContext(localctx, _startState, self.RULE_directAbstractDeclarator)
self.state = 958
if not self.precpred(self._ctx, 4):
from antlr4.error.Errors import FailedPredicateException
raise FailedPredicateException(self, "self.precpred(self._ctx, 4)")
self.state = 959
self.match(CParser.LeftBracket)
self.state = 960
self.match(CParser.Static)
self.state = 962
_la = self._input.LA(1)
if (((_la) & ~0x3f) == 0 and ((1 << _la) & ((1 << CParser.Const) | (1 << CParser.Restrict) | (1 << CParser.Volatile) | (1 << CParser.Atomic))) != 0):
self.state = 961
self.typeQualifierList(0)
self.state = 964
self.assignmentExpression()
self.state = 965
self.match(CParser.RightBracket)
pass
elif la_ == 3:
localctx = CParser.DirectAbstractDeclaratorContext(self, _parentctx, _parentState)
self.pushNewRecursionContext(localctx, _startState, self.RULE_directAbstractDeclarator)
self.state = 967
if not self.precpred(self._ctx, 3):
from antlr4.error.Errors import FailedPredicateException
raise FailedPredicateException(self, "self.precpred(self._ctx, 3)")
self.state = 968
self.match(CParser.LeftBracket)
self.state = 969
self.typeQualifierList(0)
self.state = 970
self.match(CParser.Static)
self.state = 971
self.assignmentExpression()
self.state = 972
self.match(CParser.RightBracket)
pass
elif la_ == 4:
localctx = CParser.DirectAbstractDeclaratorContext(self, _parentctx, _parentState)
self.pushNewRecursionContext(localctx, _startState, self.RULE_directAbstractDeclarator)
self.state = 974
if not self.precpred(self._ctx, 2):
from antlr4.error.Errors import FailedPredicateException
raise FailedPredicateException(self, "self.precpred(self._ctx, 2)")
self.state = 975
self.match(CParser.LeftBracket)
self.state = 976
self.match(CParser.Star)
self.state = 977
self.match(CParser.RightBracket)
pass
elif la_ == 5:
localctx = CParser.DirectAbstractDeclaratorContext(self, _parentctx, _parentState)
self.pushNewRecursionContext(localctx, _startState, self.RULE_directAbstractDeclarator)
self.state = 978
if not self.precpred(self._ctx, 1):
from antlr4.error.Errors import FailedPredicateException
raise FailedPredicateException(self, "self.precpred(self._ctx, 1)")
self.state = 979
self.match(CParser.LeftParen)
self.state = 981
_la = self._input.LA(1)
if (((_la) & ~0x3f) == 0 and ((1 << _la) & ((1 << CParser.T__0) | (1 << CParser.T__3) | (1 << CParser.T__4) | (1 << CParser.T__5) | (1 << CParser.T__6) | (1 << CParser.T__7) | (1 << CParser.T__8) | (1 << CParser.T__9) | (1 << CParser.T__11) | (1 << CParser.Auto) | (1 << CParser.Char) | (1 << CParser.Const) | (1 << CParser.Double) | (1 << CParser.Enum) | (1 << CParser.Extern) | (1 << CParser.Float) | (1 << CParser.Inline) | (1 << CParser.Int) | (1 << CParser.Long) | (1 << CParser.Register) | (1 << CParser.Restrict) | (1 << CParser.Short) | (1 << CParser.Signed) | (1 << CParser.Static) | (1 << CParser.Struct) | (1 << CParser.Typedef) | (1 << CParser.Union) | (1 << CParser.Unsigned) | (1 << CParser.Void) | (1 << CParser.Volatile) | (1 << CParser.Alignas) | (1 << CParser.Atomic) | (1 << CParser.Bool) | (1 << CParser.Complex) | (1 << CParser.Noreturn) | (1 << CParser.ThreadLocal))) != 0) or _la==CParser.Identifier:
self.state = 980
self.parameterTypeList()
self.state = 983
self.match(CParser.RightParen)
self.state = 987
self._errHandler.sync(self)
_alt = self._interp.adaptivePredict(self._input,101,self._ctx)
while _alt!=2 and _alt!=ATN.INVALID_ALT_NUMBER:
if _alt==1:
self.state = 984
self.gccDeclaratorExtension()
self.state = 989
self._errHandler.sync(self)
_alt = self._interp.adaptivePredict(self._input,101,self._ctx)
pass
self.state = 994
self._errHandler.sync(self)
_alt = self._interp.adaptivePredict(self._input,103,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 TypedefNameContext(ParserRuleContext):
def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
super().__init__(parent, invokingState)
self.parser = parser
def Identifier(self):
return self.getToken(CParser.Identifier, 0)
def getRuleIndex(self):
return CParser.RULE_typedefName
def enterRule(self, listener:ParseTreeListener):
if hasattr( listener, "enterTypedefName" ):
listener.enterTypedefName(self)
def exitRule(self, listener:ParseTreeListener):
if hasattr( listener, "exitTypedefName" ):
listener.exitTypedefName(self)
def accept(self, visitor:ParseTreeVisitor):
if hasattr( visitor, "visitTypedefName" ):
return visitor.visitTypedefName(self)
else:
return visitor.visitChildren(self)
def typedefName(self):
localctx = CParser.TypedefNameContext(self, self._ctx, self.state)
self.enterRule(localctx, 126, self.RULE_typedefName)
try:
self.enterOuterAlt(localctx, 1)
self.state = 995
self.match(CParser.Identifier)
except RecognitionException as re:
localctx.exception = re
self._errHandler.reportError(self, re)
self._errHandler.recover(self, re)
finally:
self.exitRule()
return localctx
class InitializerContext(ParserRuleContext):
def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
super().__init__(parent, invokingState)
self.parser = parser
def assignmentExpression(self):
return self.getTypedRuleContext(CParser.AssignmentExpressionContext,0)
def initializerList(self):
return self.getTypedRuleContext(CParser.InitializerListContext,0)
def getRuleIndex(self):
return CParser.RULE_initializer
def enterRule(self, listener:ParseTreeListener):
if hasattr( listener, "enterInitializer" ):
listener.enterInitializer(self)
def exitRule(self, listener:ParseTreeListener):
if hasattr( listener, "exitInitializer" ):
listener.exitInitializer(self)
def accept(self, visitor:ParseTreeVisitor):
if hasattr( visitor, "visitInitializer" ):
return visitor.visitInitializer(self)
else:
return visitor.visitChildren(self)
def initializer(self):
localctx = CParser.InitializerContext(self, self._ctx, self.state)
self.enterRule(localctx, 128, self.RULE_initializer)
try:
self.state = 1007
la_ = self._interp.adaptivePredict(self._input,104,self._ctx)
if la_ == 1:
self.enterOuterAlt(localctx, 1)
self.state = 997
self.assignmentExpression()
pass
elif la_ == 2:
self.enterOuterAlt(localctx, 2)
self.state = 998
self.match(CParser.LeftBrace)
self.state = 999
self.initializerList(0)
self.state = 1000
self.match(CParser.RightBrace)
pass
elif la_ == 3:
self.enterOuterAlt(localctx, 3)
self.state = 1002
self.match(CParser.LeftBrace)
self.state = 1003
self.initializerList(0)
self.state = 1004
self.match(CParser.Comma)
self.state = 1005
self.match(CParser.RightBrace)
pass
except RecognitionException as re:
localctx.exception = re
self._errHandler.reportError(self, re)
self._errHandler.recover(self, re)
finally:
self.exitRule()
return localctx
class InitializerListContext(ParserRuleContext):
def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
super().__init__(parent, invokingState)
self.parser = parser
def initializer(self):
return self.getTypedRuleContext(CParser.InitializerContext,0)
def designation(self):
return self.getTypedRuleContext(CParser.DesignationContext,0)
def initializerList(self):
return self.getTypedRuleContext(CParser.InitializerListContext,0)
def getRuleIndex(self):
return CParser.RULE_initializerList
def enterRule(self, listener:ParseTreeListener):
if hasattr( listener, "enterInitializerList" ):
listener.enterInitializerList(self)
def exitRule(self, listener:ParseTreeListener):
if hasattr( listener, "exitInitializerList" ):
listener.exitInitializerList(self)
def accept(self, visitor:ParseTreeVisitor):
if hasattr( visitor, "visitInitializerList" ):
return visitor.visitInitializerList(self)
else:
return visitor.visitChildren(self)
def initializerList(self, _p:int=0):
_parentctx = self._ctx
_parentState = self.state
localctx = CParser.InitializerListContext(self, self._ctx, _parentState)
_prevctx = localctx
_startState = 130
self.enterRecursionRule(localctx, 130, self.RULE_initializerList, _p)
self._la = 0 # Token type
try:
self.enterOuterAlt(localctx, 1)
self.state = 1011
_la = self._input.LA(1)
if _la==CParser.LeftBracket or _la==CParser.Dot:
self.state = 1010
self.designation()
self.state = 1013
self.initializer()
self._ctx.stop = self._input.LT(-1)
self.state = 1023
self._errHandler.sync(self)
_alt = self._interp.adaptivePredict(self._input,107,self._ctx)
while _alt!=2 and _alt!=ATN.INVALID_ALT_NUMBER:
if _alt==1:
if self._parseListeners is not None:
self.triggerExitRuleEvent()
_prevctx = localctx
localctx = CParser.InitializerListContext(self, _parentctx, _parentState)
self.pushNewRecursionContext(localctx, _startState, self.RULE_initializerList)
self.state = 1015
if not self.precpred(self._ctx, 1):
from antlr4.error.Errors import FailedPredicateException
raise FailedPredicateException(self, "self.precpred(self._ctx, 1)")
self.state = 1016
self.match(CParser.Comma)
self.state = 1018
_la = self._input.LA(1)
if _la==CParser.LeftBracket or _la==CParser.Dot:
self.state = 1017
self.designation()
self.state = 1020
self.initializer()
self.state = 1025
self._errHandler.sync(self)
_alt = self._interp.adaptivePredict(self._input,107,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 DesignationContext(ParserRuleContext):
def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
super().__init__(parent, invokingState)
self.parser = parser
def designatorList(self):
return self.getTypedRuleContext(CParser.DesignatorListContext,0)
def getRuleIndex(self):
return CParser.RULE_designation
def enterRule(self, listener:ParseTreeListener):
if hasattr( listener, "enterDesignation" ):
listener.enterDesignation(self)
def exitRule(self, listener:ParseTreeListener):
if hasattr( listener, "exitDesignation" ):
listener.exitDesignation(self)
def accept(self, visitor:ParseTreeVisitor):
if hasattr( visitor, "visitDesignation" ):
return visitor.visitDesignation(self)
else:
return visitor.visitChildren(self)
def designation(self):
localctx = CParser.DesignationContext(self, self._ctx, self.state)
self.enterRule(localctx, 132, self.RULE_designation)
try:
self.enterOuterAlt(localctx, 1)
self.state = 1026
self.designatorList(0)
self.state = 1027
self.match(CParser.Assign)
except RecognitionException as re:
localctx.exception = re
self._errHandler.reportError(self, re)
self._errHandler.recover(self, re)
finally:
self.exitRule()
return localctx
class DesignatorListContext(ParserRuleContext):
def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
super().__init__(parent, invokingState)
self.parser = parser
def designator(self):
return self.getTypedRuleContext(CParser.DesignatorContext,0)
def designatorList(self):
return self.getTypedRuleContext(CParser.DesignatorListContext,0)
def getRuleIndex(self):
return CParser.RULE_designatorList
def enterRule(self, listener:ParseTreeListener):
if hasattr( listener, "enterDesignatorList" ):
listener.enterDesignatorList(self)
def exitRule(self, listener:ParseTreeListener):
if hasattr( listener, "exitDesignatorList" ):
listener.exitDesignatorList(self)
def accept(self, visitor:ParseTreeVisitor):
if hasattr( visitor, "visitDesignatorList" ):
return visitor.visitDesignatorList(self)
else:
return visitor.visitChildren(self)
def designatorList(self, _p:int=0):
_parentctx = self._ctx
_parentState = self.state
localctx = CParser.DesignatorListContext(self, self._ctx, _parentState)
_prevctx = localctx
_startState = 134
self.enterRecursionRule(localctx, 134, self.RULE_designatorList, _p)
try:
self.enterOuterAlt(localctx, 1)
self.state = 1030
self.designator()
self._ctx.stop = self._input.LT(-1)
self.state = 1036
self._errHandler.sync(self)
_alt = self._interp.adaptivePredict(self._input,108,self._ctx)
while _alt!=2 and _alt!=ATN.INVALID_ALT_NUMBER:
if _alt==1:
if self._parseListeners is not None:
self.triggerExitRuleEvent()
_prevctx = localctx
localctx = CParser.DesignatorListContext(self, _parentctx, _parentState)
self.pushNewRecursionContext(localctx, _startState, self.RULE_designatorList)
self.state = 1032
if not self.precpred(self._ctx, 1):
from antlr4.error.Errors import FailedPredicateException
raise FailedPredicateException(self, "self.precpred(self._ctx, 1)")
self.state = 1033
self.designator()
self.state = 1038
self._errHandler.sync(self)
_alt = self._interp.adaptivePredict(self._input,108,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 DesignatorContext(ParserRuleContext):
def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
super().__init__(parent, invokingState)
self.parser = parser
def constantExpression(self):
return self.getTypedRuleContext(CParser.ConstantExpressionContext,0)
def Identifier(self):
return self.getToken(CParser.Identifier, 0)
def getRuleIndex(self):
return CParser.RULE_designator
def enterRule(self, listener:ParseTreeListener):
if hasattr( listener, "enterDesignator" ):
listener.enterDesignator(self)
def exitRule(self, listener:ParseTreeListener):
if hasattr( listener, "exitDesignator" ):
listener.exitDesignator(self)
def accept(self, visitor:ParseTreeVisitor):
if hasattr( visitor, "visitDesignator" ):
return visitor.visitDesignator(self)
else:
return visitor.visitChildren(self)
def designator(self):
localctx = CParser.DesignatorContext(self, self._ctx, self.state)
self.enterRule(localctx, 136, self.RULE_designator)
try:
self.state = 1045
token = self._input.LA(1)
if token in [CParser.LeftBracket]:
self.enterOuterAlt(localctx, 1)
self.state = 1039
self.match(CParser.LeftBracket)
self.state = 1040
self.constantExpression()
self.state = 1041
self.match(CParser.RightBracket)
elif token in [CParser.Dot]:
self.enterOuterAlt(localctx, 2)
self.state = 1043
self.match(CParser.Dot)
self.state = 1044
self.match(CParser.Identifier)
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 StaticAssertDeclarationContext(ParserRuleContext):
def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
super().__init__(parent, invokingState)
self.parser = parser
def constantExpression(self):
return self.getTypedRuleContext(CParser.ConstantExpressionContext,0)
def StringLiteral(self, i:int=None):
if i is None:
return self.getTokens(CParser.StringLiteral)
else:
return self.getToken(CParser.StringLiteral, i)
def getRuleIndex(self):
return CParser.RULE_staticAssertDeclaration
def enterRule(self, listener:ParseTreeListener):
if hasattr( listener, "enterStaticAssertDeclaration" ):
listener.enterStaticAssertDeclaration(self)
def exitRule(self, listener:ParseTreeListener):
if hasattr( listener, "exitStaticAssertDeclaration" ):
listener.exitStaticAssertDeclaration(self)
def accept(self, visitor:ParseTreeVisitor):
if hasattr( visitor, "visitStaticAssertDeclaration" ):
return visitor.visitStaticAssertDeclaration(self)
else:
return visitor.visitChildren(self)
def staticAssertDeclaration(self):
localctx = CParser.StaticAssertDeclarationContext(self, self._ctx, self.state)
self.enterRule(localctx, 138, self.RULE_staticAssertDeclaration)
self._la = 0 # Token type
try:
self.enterOuterAlt(localctx, 1)
self.state = 1047
self.match(CParser.StaticAssert)
self.state = 1048
self.match(CParser.LeftParen)
self.state = 1049
self.constantExpression()
self.state = 1050
self.match(CParser.Comma)
self.state = 1052
self._errHandler.sync(self)
_la = self._input.LA(1)
while True:
self.state = 1051
self.match(CParser.StringLiteral)
self.state = 1054
self._errHandler.sync(self)
_la = self._input.LA(1)
if not (_la==CParser.StringLiteral):
break
self.state = 1056
self.match(CParser.RightParen)
self.state = 1057
self.match(CParser.Semi)
except RecognitionException as re:
localctx.exception = re
self._errHandler.reportError(self, re)
self._errHandler.recover(self, re)
finally:
self.exitRule()
return localctx
class StatementContext(ParserRuleContext):
def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
super().__init__(parent, invokingState)
self.parser = parser
def labeledStatement(self):
return self.getTypedRuleContext(CParser.LabeledStatementContext,0)
def compoundStatement(self):
return self.getTypedRuleContext(CParser.CompoundStatementContext,0)
def expressionStatement(self):
return self.getTypedRuleContext(CParser.ExpressionStatementContext,0)
def selectionStatement(self):
return self.getTypedRuleContext(CParser.SelectionStatementContext,0)
def iterationStatement(self):
return self.getTypedRuleContext(CParser.IterationStatementContext,0)
def jumpStatement(self):
return self.getTypedRuleContext(CParser.JumpStatementContext,0)
def logicalOrExpression(self, i:int=None):
if i is None:
return self.getTypedRuleContexts(CParser.LogicalOrExpressionContext)
else:
return self.getTypedRuleContext(CParser.LogicalOrExpressionContext,i)
def getRuleIndex(self):
return CParser.RULE_statement
def enterRule(self, listener:ParseTreeListener):
if hasattr( listener, "enterStatement" ):
listener.enterStatement(self)
def exitRule(self, listener:ParseTreeListener):
if hasattr( listener, "exitStatement" ):
listener.exitStatement(self)
def accept(self, visitor:ParseTreeVisitor):
if hasattr( visitor, "visitStatement" ):
return visitor.visitStatement(self)
else:
return visitor.visitChildren(self)
def statement(self):
localctx = CParser.StatementContext(self, self._ctx, self.state)
self.enterRule(localctx, 140, self.RULE_statement)
self._la = 0 # Token type
try:
self.state = 1096
la_ = self._interp.adaptivePredict(self._input,116,self._ctx)
if la_ == 1:
self.enterOuterAlt(localctx, 1)
self.state = 1059
self.labeledStatement()
pass
elif la_ == 2:
self.enterOuterAlt(localctx, 2)
self.state = 1060
self.compoundStatement()
pass
elif la_ == 3:
self.enterOuterAlt(localctx, 3)
self.state = 1061
self.expressionStatement()
pass
elif la_ == 4:
self.enterOuterAlt(localctx, 4)
self.state = 1062
self.selectionStatement()
pass
elif la_ == 5:
self.enterOuterAlt(localctx, 5)
self.state = 1063
self.iterationStatement()
pass
elif la_ == 6:
self.enterOuterAlt(localctx, 6)
self.state = 1064
self.jumpStatement()
pass
elif la_ == 7:
self.enterOuterAlt(localctx, 7)
self.state = 1065
_la = self._input.LA(1)
if not(_la==CParser.T__10 or _la==CParser.T__12):
self._errHandler.recoverInline(self)
else:
self.consume()
self.state = 1066
_la = self._input.LA(1)
if not(_la==CParser.T__13 or _la==CParser.Volatile):
self._errHandler.recoverInline(self)
else:
self.consume()
self.state = 1067
self.match(CParser.LeftParen)
self.state = 1076
_la = self._input.LA(1)
if (((_la) & ~0x3f) == 0 and ((1 << _la) & ((1 << CParser.T__0) | (1 << CParser.T__1) | (1 << CParser.T__2) | (1 << CParser.Sizeof) | (1 << CParser.Alignof) | (1 << CParser.Generic) | (1 << CParser.LeftParen))) != 0) or ((((_la - 71)) & ~0x3f) == 0 and ((1 << (_la - 71)) & ((1 << (CParser.Plus - 71)) | (1 << (CParser.PlusPlus - 71)) | (1 << (CParser.Minus - 71)) | (1 << (CParser.MinusMinus - 71)) | (1 << (CParser.Star - 71)) | (1 << (CParser.And - 71)) | (1 << (CParser.AndAnd - 71)) | (1 << (CParser.Not - 71)) | (1 << (CParser.Tilde - 71)) | (1 << (CParser.Identifier - 71)) | (1 << (CParser.Constant - 71)) | (1 << (CParser.StringLiteral - 71)))) != 0):
self.state = 1068
self.logicalOrExpression(0)
self.state = 1073
self._errHandler.sync(self)
_la = self._input.LA(1)
while _la==CParser.Comma:
self.state = 1069
self.match(CParser.Comma)
self.state = 1070
self.logicalOrExpression(0)
self.state = 1075
self._errHandler.sync(self)
_la = self._input.LA(1)
self.state = 1091
self._errHandler.sync(self)
_la = self._input.LA(1)
while _la==CParser.Colon:
self.state = 1078
self.match(CParser.Colon)
self.state = 1087
_la = self._input.LA(1)
if (((_la) & ~0x3f) == 0 and ((1 << _la) & ((1 << CParser.T__0) | (1 << CParser.T__1) | (1 << CParser.T__2) | (1 << CParser.Sizeof) | (1 << CParser.Alignof) | (1 << CParser.Generic) | (1 << CParser.LeftParen))) != 0) or ((((_la - 71)) & ~0x3f) == 0 and ((1 << (_la - 71)) & ((1 << (CParser.Plus - 71)) | (1 << (CParser.PlusPlus - 71)) | (1 << (CParser.Minus - 71)) | (1 << (CParser.MinusMinus - 71)) | (1 << (CParser.Star - 71)) | (1 << (CParser.And - 71)) | (1 << (CParser.AndAnd - 71)) | (1 << (CParser.Not - 71)) | (1 << (CParser.Tilde - 71)) | (1 << (CParser.Identifier - 71)) | (1 << (CParser.Constant - 71)) | (1 << (CParser.StringLiteral - 71)))) != 0):
self.state = 1079
self.logicalOrExpression(0)
self.state = 1084
self._errHandler.sync(self)
_la = self._input.LA(1)
while _la==CParser.Comma:
self.state = 1080
self.match(CParser.Comma)
self.state = 1081
self.logicalOrExpression(0)
self.state = 1086
self._errHandler.sync(self)
_la = self._input.LA(1)
self.state = 1093
self._errHandler.sync(self)
_la = self._input.LA(1)
self.state = 1094
self.match(CParser.RightParen)
self.state = 1095
self.match(CParser.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 LabeledStatementContext(ParserRuleContext):
def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
super().__init__(parent, invokingState)
self.parser = parser
def Identifier(self):
return self.getToken(CParser.Identifier, 0)
def statement(self):
return self.getTypedRuleContext(CParser.StatementContext,0)
def constantExpression(self):
return self.getTypedRuleContext(CParser.ConstantExpressionContext,0)
def getRuleIndex(self):
return CParser.RULE_labeledStatement
def enterRule(self, listener:ParseTreeListener):
if hasattr( listener, "enterLabeledStatement" ):
listener.enterLabeledStatement(self)
def exitRule(self, listener:ParseTreeListener):
if hasattr( listener, "exitLabeledStatement" ):
listener.exitLabeledStatement(self)
def accept(self, visitor:ParseTreeVisitor):
if hasattr( visitor, "visitLabeledStatement" ):
return visitor.visitLabeledStatement(self)
else:
return visitor.visitChildren(self)
def labeledStatement(self):
localctx = CParser.LabeledStatementContext(self, self._ctx, self.state)
self.enterRule(localctx, 142, self.RULE_labeledStatement)
try:
self.state = 1109
token = self._input.LA(1)
if token in [CParser.Identifier]:
self.enterOuterAlt(localctx, 1)
self.state = 1098
self.match(CParser.Identifier)
self.state = 1099
self.match(CParser.Colon)
self.state = 1100
self.statement()
elif token in [CParser.Case]:
self.enterOuterAlt(localctx, 2)
self.state = 1101
self.match(CParser.Case)
self.state = 1102
self.constantExpression()
self.state = 1103
self.match(CParser.Colon)
self.state = 1104
self.statement()
elif token in [CParser.Default]:
self.enterOuterAlt(localctx, 3)
self.state = 1106
self.match(CParser.Default)
self.state = 1107
self.match(CParser.Colon)
self.state = 1108
self.statement()
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 CompoundStatementContext(ParserRuleContext):
def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
super().__init__(parent, invokingState)
self.parser = parser
def blockItemList(self):
return self.getTypedRuleContext(CParser.BlockItemListContext,0)
def getRuleIndex(self):
return CParser.RULE_compoundStatement
def enterRule(self, listener:ParseTreeListener):
if hasattr( listener, "enterCompoundStatement" ):
listener.enterCompoundStatement(self)
def exitRule(self, listener:ParseTreeListener):
if hasattr( listener, "exitCompoundStatement" ):
listener.exitCompoundStatement(self)
def accept(self, visitor:ParseTreeVisitor):
if hasattr( visitor, "visitCompoundStatement" ):
return visitor.visitCompoundStatement(self)
else:
return visitor.visitChildren(self)
def compoundStatement(self):
localctx = CParser.CompoundStatementContext(self, self._ctx, self.state)
self.enterRule(localctx, 144, self.RULE_compoundStatement)
self._la = 0 # Token type
try:
self.enterOuterAlt(localctx, 1)
self.state = 1111
self.match(CParser.LeftBrace)
self.state = 1113
_la = self._input.LA(1)
if (((_la) & ~0x3f) == 0 and ((1 << _la) & ((1 << CParser.T__0) | (1 << CParser.T__1) | (1 << CParser.T__2) | (1 << CParser.T__3) | (1 << CParser.T__4) | (1 << CParser.T__5) | (1 << CParser.T__6) | (1 << CParser.T__7) | (1 << CParser.T__8) | (1 << CParser.T__9) | (1 << CParser.T__10) | (1 << CParser.T__11) | (1 << CParser.T__12) | (1 << CParser.Auto) | (1 << CParser.Break) | (1 << CParser.Case) | (1 << CParser.Char) | (1 << CParser.Const) | (1 << CParser.Continue) | (1 << CParser.Default) | (1 << CParser.Do) | (1 << CParser.Double) | (1 << CParser.Enum) | (1 << CParser.Extern) | (1 << CParser.Float) | (1 << CParser.For) | (1 << CParser.Goto) | (1 << CParser.If) | (1 << CParser.Inline) | (1 << CParser.Int) | (1 << CParser.Long) | (1 << CParser.Register) | (1 << CParser.Restrict) | (1 << CParser.Return) | (1 << CParser.Short) | (1 << CParser.Signed) | (1 << CParser.Sizeof) | (1 << CParser.Static) | (1 << CParser.Struct) | (1 << CParser.Switch) | (1 << CParser.Typedef) | (1 << CParser.Union) | (1 << CParser.Unsigned) | (1 << CParser.Void) | (1 << CParser.Volatile) | (1 << CParser.While) | (1 << CParser.Alignas) | (1 << CParser.Alignof) | (1 << CParser.Atomic) | (1 << CParser.Bool) | (1 << CParser.Complex) | (1 << CParser.Generic) | (1 << CParser.Noreturn) | (1 << CParser.StaticAssert) | (1 << CParser.ThreadLocal) | (1 << CParser.LeftParen) | (1 << CParser.LeftBrace))) != 0) or ((((_la - 71)) & ~0x3f) == 0 and ((1 << (_la - 71)) & ((1 << (CParser.Plus - 71)) | (1 << (CParser.PlusPlus - 71)) | (1 << (CParser.Minus - 71)) | (1 << (CParser.MinusMinus - 71)) | (1 << (CParser.Star - 71)) | (1 << (CParser.And - 71)) | (1 << (CParser.AndAnd - 71)) | (1 << (CParser.Not - 71)) | (1 << (CParser.Tilde - 71)) | (1 << (CParser.Semi - 71)) | (1 << (CParser.Identifier - 71)) | (1 << (CParser.Constant - 71)) | (1 << (CParser.StringLiteral - 71)))) != 0):
self.state = 1112
self.blockItemList(0)
self.state = 1115
self.match(CParser.RightBrace)
except RecognitionException as re:
localctx.exception = re
self._errHandler.reportError(self, re)
self._errHandler.recover(self, re)
finally:
self.exitRule()
return localctx
class BlockItemListContext(ParserRuleContext):
def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
super().__init__(parent, invokingState)
self.parser = parser
def blockItem(self):
return self.getTypedRuleContext(CParser.BlockItemContext,0)
def blockItemList(self):
return self.getTypedRuleContext(CParser.BlockItemListContext,0)
def getRuleIndex(self):
return CParser.RULE_blockItemList
def enterRule(self, listener:ParseTreeListener):
if hasattr( listener, "enterBlockItemList" ):
listener.enterBlockItemList(self)
def exitRule(self, listener:ParseTreeListener):
if hasattr( listener, "exitBlockItemList" ):
listener.exitBlockItemList(self)
def accept(self, visitor:ParseTreeVisitor):
if hasattr( visitor, "visitBlockItemList" ):
return visitor.visitBlockItemList(self)
else:
return visitor.visitChildren(self)
def blockItemList(self, _p:int=0):
_parentctx = self._ctx
_parentState = self.state
localctx = CParser.BlockItemListContext(self, self._ctx, _parentState)
_prevctx = localctx
_startState = 146
self.enterRecursionRule(localctx, 146, self.RULE_blockItemList, _p)
try:
self.enterOuterAlt(localctx, 1)
self.state = 1118
self.blockItem()
self._ctx.stop = self._input.LT(-1)
self.state = 1124
self._errHandler.sync(self)
_alt = self._interp.adaptivePredict(self._input,119,self._ctx)
while _alt!=2 and _alt!=ATN.INVALID_ALT_NUMBER:
if _alt==1:
if self._parseListeners is not None:
self.triggerExitRuleEvent()
_prevctx = localctx
localctx = CParser.BlockItemListContext(self, _parentctx, _parentState)
self.pushNewRecursionContext(localctx, _startState, self.RULE_blockItemList)
self.state = 1120
if not self.precpred(self._ctx, 1):
from antlr4.error.Errors import FailedPredicateException
raise FailedPredicateException(self, "self.precpred(self._ctx, 1)")
self.state = 1121
self.blockItem()
self.state = 1126
self._errHandler.sync(self)
_alt = self._interp.adaptivePredict(self._input,119,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 BlockItemContext(ParserRuleContext):
def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
super().__init__(parent, invokingState)
self.parser = parser
def declaration(self):
return self.getTypedRuleContext(CParser.DeclarationContext,0)
def statement(self):
return self.getTypedRuleContext(CParser.StatementContext,0)
def getRuleIndex(self):
return CParser.RULE_blockItem
def enterRule(self, listener:ParseTreeListener):
if hasattr( listener, "enterBlockItem" ):
listener.enterBlockItem(self)
def exitRule(self, listener:ParseTreeListener):
if hasattr( listener, "exitBlockItem" ):
listener.exitBlockItem(self)
def accept(self, visitor:ParseTreeVisitor):
if hasattr( visitor, "visitBlockItem" ):
return visitor.visitBlockItem(self)
else:
return visitor.visitChildren(self)
def blockItem(self):
localctx = CParser.BlockItemContext(self, self._ctx, self.state)
self.enterRule(localctx, 148, self.RULE_blockItem)
try:
self.state = 1129
la_ = self._interp.adaptivePredict(self._input,120,self._ctx)
if la_ == 1:
self.enterOuterAlt(localctx, 1)
self.state = 1127
self.declaration()
pass
elif la_ == 2:
self.enterOuterAlt(localctx, 2)
self.state = 1128
self.statement()
pass
except RecognitionException as re:
localctx.exception = re
self._errHandler.reportError(self, re)
self._errHandler.recover(self, re)
finally:
self.exitRule()
return localctx
class ExpressionStatementContext(ParserRuleContext):
def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
super().__init__(parent, invokingState)
self.parser = parser
def expression(self):
return self.getTypedRuleContext(CParser.ExpressionContext,0)
def getRuleIndex(self):
return CParser.RULE_expressionStatement
def enterRule(self, listener:ParseTreeListener):
if hasattr( listener, "enterExpressionStatement" ):
listener.enterExpressionStatement(self)
def exitRule(self, listener:ParseTreeListener):
if hasattr( listener, "exitExpressionStatement" ):
listener.exitExpressionStatement(self)
def accept(self, visitor:ParseTreeVisitor):
if hasattr( visitor, "visitExpressionStatement" ):
return visitor.visitExpressionStatement(self)
else:
return visitor.visitChildren(self)
def expressionStatement(self):
localctx = CParser.ExpressionStatementContext(self, self._ctx, self.state)
self.enterRule(localctx, 150, self.RULE_expressionStatement)
self._la = 0 # Token type
try:
self.enterOuterAlt(localctx, 1)
self.state = 1132
_la = self._input.LA(1)
if (((_la) & ~0x3f) == 0 and ((1 << _la) & ((1 << CParser.T__0) | (1 << CParser.T__1) | (1 << CParser.T__2) | (1 << CParser.Sizeof) | (1 << CParser.Alignof) | (1 << CParser.Generic) | (1 << CParser.LeftParen))) != 0) or ((((_la - 71)) & ~0x3f) == 0 and ((1 << (_la - 71)) & ((1 << (CParser.Plus - 71)) | (1 << (CParser.PlusPlus - 71)) | (1 << (CParser.Minus - 71)) | (1 << (CParser.MinusMinus - 71)) | (1 << (CParser.Star - 71)) | (1 << (CParser.And - 71)) | (1 << (CParser.AndAnd - 71)) | (1 << (CParser.Not - 71)) | (1 << (CParser.Tilde - 71)) | (1 << (CParser.Identifier - 71)) | (1 << (CParser.Constant - 71)) | (1 << (CParser.StringLiteral - 71)))) != 0):
self.state = 1131
self.expression(0)
self.state = 1134
self.match(CParser.Semi)
except RecognitionException as re:
localctx.exception = re
self._errHandler.reportError(self, re)
self._errHandler.recover(self, re)
finally:
self.exitRule()
return localctx
class SelectionStatementContext(ParserRuleContext):
def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
super().__init__(parent, invokingState)
self.parser = parser
def expression(self):
return self.getTypedRuleContext(CParser.ExpressionContext,0)
def statement(self, i:int=None):
if i is None:
return self.getTypedRuleContexts(CParser.StatementContext)
else:
return self.getTypedRuleContext(CParser.StatementContext,i)
def getRuleIndex(self):
return CParser.RULE_selectionStatement
def enterRule(self, listener:ParseTreeListener):
if hasattr( listener, "enterSelectionStatement" ):
listener.enterSelectionStatement(self)
def exitRule(self, listener:ParseTreeListener):
if hasattr( listener, "exitSelectionStatement" ):
listener.exitSelectionStatement(self)
def accept(self, visitor:ParseTreeVisitor):
if hasattr( visitor, "visitSelectionStatement" ):
return visitor.visitSelectionStatement(self)
else:
return visitor.visitChildren(self)
def selectionStatement(self):
localctx = CParser.SelectionStatementContext(self, self._ctx, self.state)
self.enterRule(localctx, 152, self.RULE_selectionStatement)
try:
self.state = 1151
token = self._input.LA(1)
if token in [CParser.If]:
self.enterOuterAlt(localctx, 1)
self.state = 1136
self.match(CParser.If)
self.state = 1137
self.match(CParser.LeftParen)
self.state = 1138
self.expression(0)
self.state = 1139
self.match(CParser.RightParen)
self.state = 1140
self.statement()
self.state = 1143
la_ = self._interp.adaptivePredict(self._input,122,self._ctx)
if la_ == 1:
self.state = 1141
self.match(CParser.Else)
self.state = 1142
self.statement()
elif token in [CParser.Switch]:
self.enterOuterAlt(localctx, 2)
self.state = 1145
self.match(CParser.Switch)
self.state = 1146
self.match(CParser.LeftParen)
self.state = 1147
self.expression(0)
self.state = 1148
self.match(CParser.RightParen)
self.state = 1149
self.statement()
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 IterationStatementContext(ParserRuleContext):
def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
super().__init__(parent, invokingState)
self.parser = parser
def expression(self, i:int=None):
if i is None:
return self.getTypedRuleContexts(CParser.ExpressionContext)
else:
return self.getTypedRuleContext(CParser.ExpressionContext,i)
def statement(self):
return self.getTypedRuleContext(CParser.StatementContext,0)
def declaration(self):
return self.getTypedRuleContext(CParser.DeclarationContext,0)
def getRuleIndex(self):
return CParser.RULE_iterationStatement
def enterRule(self, listener:ParseTreeListener):
if hasattr( listener, "enterIterationStatement" ):
listener.enterIterationStatement(self)
def exitRule(self, listener:ParseTreeListener):
if hasattr( listener, "exitIterationStatement" ):
listener.exitIterationStatement(self)
def accept(self, visitor:ParseTreeVisitor):
if hasattr( visitor, "visitIterationStatement" ):
return visitor.visitIterationStatement(self)
else:
return visitor.visitChildren(self)
def iterationStatement(self):
localctx = CParser.IterationStatementContext(self, self._ctx, self.state)
self.enterRule(localctx, 154, self.RULE_iterationStatement)
self._la = 0 # Token type
try:
self.state = 1195
la_ = self._interp.adaptivePredict(self._input,129,self._ctx)
if la_ == 1:
self.enterOuterAlt(localctx, 1)
self.state = 1153
self.match(CParser.While)
self.state = 1154
self.match(CParser.LeftParen)
self.state = 1155
self.expression(0)
self.state = 1156
self.match(CParser.RightParen)
self.state = 1157
self.statement()
pass
elif la_ == 2:
self.enterOuterAlt(localctx, 2)
self.state = 1159
self.match(CParser.Do)
self.state = 1160
self.statement()
self.state = 1161
self.match(CParser.While)
self.state = 1162
self.match(CParser.LeftParen)
self.state = 1163
self.expression(0)
self.state = 1164
self.match(CParser.RightParen)
self.state = 1165
self.match(CParser.Semi)
pass
elif la_ == 3:
self.enterOuterAlt(localctx, 3)
self.state = 1167
self.match(CParser.For)
self.state = 1168
self.match(CParser.LeftParen)
self.state = 1170
_la = self._input.LA(1)
if (((_la) & ~0x3f) == 0 and ((1 << _la) & ((1 << CParser.T__0) | (1 << CParser.T__1) | (1 << CParser.T__2) | (1 << CParser.Sizeof) | (1 << CParser.Alignof) | (1 << CParser.Generic) | (1 << CParser.LeftParen))) != 0) or ((((_la - 71)) & ~0x3f) == 0 and ((1 << (_la - 71)) & ((1 << (CParser.Plus - 71)) | (1 << (CParser.PlusPlus - 71)) | (1 << (CParser.Minus - 71)) | (1 << (CParser.MinusMinus - 71)) | (1 << (CParser.Star - 71)) | (1 << (CParser.And - 71)) | (1 << (CParser.AndAnd - 71)) | (1 << (CParser.Not - 71)) | (1 << (CParser.Tilde - 71)) | (1 << (CParser.Identifier - 71)) | (1 << (CParser.Constant - 71)) | (1 << (CParser.StringLiteral - 71)))) != 0):
self.state = 1169
self.expression(0)
self.state = 1172
self.match(CParser.Semi)
self.state = 1174
_la = self._input.LA(1)
if (((_la) & ~0x3f) == 0 and ((1 << _la) & ((1 << CParser.T__0) | (1 << CParser.T__1) | (1 << CParser.T__2) | (1 << CParser.Sizeof) | (1 << CParser.Alignof) | (1 << CParser.Generic) | (1 << CParser.LeftParen))) != 0) or ((((_la - 71)) & ~0x3f) == 0 and ((1 << (_la - 71)) & ((1 << (CParser.Plus - 71)) | (1 << (CParser.PlusPlus - 71)) | (1 << (CParser.Minus - 71)) | (1 << (CParser.MinusMinus - 71)) | (1 << (CParser.Star - 71)) | (1 << (CParser.And - 71)) | (1 << (CParser.AndAnd - 71)) | (1 << (CParser.Not - 71)) | (1 << (CParser.Tilde - 71)) | (1 << (CParser.Identifier - 71)) | (1 << (CParser.Constant - 71)) | (1 << (CParser.StringLiteral - 71)))) != 0):
self.state = 1173
self.expression(0)
self.state = 1176
self.match(CParser.Semi)
self.state = 1178
_la = self._input.LA(1)
if (((_la) & ~0x3f) == 0 and ((1 << _la) & ((1 << CParser.T__0) | (1 << CParser.T__1) | (1 << CParser.T__2) | (1 << CParser.Sizeof) | (1 << CParser.Alignof) | (1 << CParser.Generic) | (1 << CParser.LeftParen))) != 0) or ((((_la - 71)) & ~0x3f) == 0 and ((1 << (_la - 71)) & ((1 << (CParser.Plus - 71)) | (1 << (CParser.PlusPlus - 71)) | (1 << (CParser.Minus - 71)) | (1 << (CParser.MinusMinus - 71)) | (1 << (CParser.Star - 71)) | (1 << (CParser.And - 71)) | (1 << (CParser.AndAnd - 71)) | (1 << (CParser.Not - 71)) | (1 << (CParser.Tilde - 71)) | (1 << (CParser.Identifier - 71)) | (1 << (CParser.Constant - 71)) | (1 << (CParser.StringLiteral - 71)))) != 0):
self.state = 1177
self.expression(0)
self.state = 1180
self.match(CParser.RightParen)
self.state = 1181
self.statement()
pass
elif la_ == 4:
self.enterOuterAlt(localctx, 4)
self.state = 1182
self.match(CParser.For)
self.state = 1183
self.match(CParser.LeftParen)
self.state = 1184
self.declaration()
self.state = 1186
_la = self._input.LA(1)
if (((_la) & ~0x3f) == 0 and ((1 << _la) & ((1 << CParser.T__0) | (1 << CParser.T__1) | (1 << CParser.T__2) | (1 << CParser.Sizeof) | (1 << CParser.Alignof) | (1 << CParser.Generic) | (1 << CParser.LeftParen))) != 0) or ((((_la - 71)) & ~0x3f) == 0 and ((1 << (_la - 71)) & ((1 << (CParser.Plus - 71)) | (1 << (CParser.PlusPlus - 71)) | (1 << (CParser.Minus - 71)) | (1 << (CParser.MinusMinus - 71)) | (1 << (CParser.Star - 71)) | (1 << (CParser.And - 71)) | (1 << (CParser.AndAnd - 71)) | (1 << (CParser.Not - 71)) | (1 << (CParser.Tilde - 71)) | (1 << (CParser.Identifier - 71)) | (1 << (CParser.Constant - 71)) | (1 << (CParser.StringLiteral - 71)))) != 0):
self.state = 1185
self.expression(0)
self.state = 1188
self.match(CParser.Semi)
self.state = 1190
_la = self._input.LA(1)
if (((_la) & ~0x3f) == 0 and ((1 << _la) & ((1 << CParser.T__0) | (1 << CParser.T__1) | (1 << CParser.T__2) | (1 << CParser.Sizeof) | (1 << CParser.Alignof) | (1 << CParser.Generic) | (1 << CParser.LeftParen))) != 0) or ((((_la - 71)) & ~0x3f) == 0 and ((1 << (_la - 71)) & ((1 << (CParser.Plus - 71)) | (1 << (CParser.PlusPlus - 71)) | (1 << (CParser.Minus - 71)) | (1 << (CParser.MinusMinus - 71)) | (1 << (CParser.Star - 71)) | (1 << (CParser.And - 71)) | (1 << (CParser.AndAnd - 71)) | (1 << (CParser.Not - 71)) | (1 << (CParser.Tilde - 71)) | (1 << (CParser.Identifier - 71)) | (1 << (CParser.Constant - 71)) | (1 << (CParser.StringLiteral - 71)))) != 0):
self.state = 1189
self.expression(0)
self.state = 1192
self.match(CParser.RightParen)
self.state = 1193
self.statement()
pass
except RecognitionException as re:
localctx.exception = re
self._errHandler.reportError(self, re)
self._errHandler.recover(self, re)
finally:
self.exitRule()
return localctx
class JumpStatementContext(ParserRuleContext):
def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
super().__init__(parent, invokingState)
self.parser = parser
def Identifier(self):
return self.getToken(CParser.Identifier, 0)
def expression(self):
return self.getTypedRuleContext(CParser.ExpressionContext,0)
def unaryExpression(self):
return self.getTypedRuleContext(CParser.UnaryExpressionContext,0)
def getRuleIndex(self):
return CParser.RULE_jumpStatement
def enterRule(self, listener:ParseTreeListener):
if hasattr( listener, "enterJumpStatement" ):
listener.enterJumpStatement(self)
def exitRule(self, listener:ParseTreeListener):
if hasattr( listener, "exitJumpStatement" ):
listener.exitJumpStatement(self)
def accept(self, visitor:ParseTreeVisitor):
if hasattr( visitor, "visitJumpStatement" ):
return visitor.visitJumpStatement(self)
else:
return visitor.visitChildren(self)
def jumpStatement(self):
localctx = CParser.JumpStatementContext(self, self._ctx, self.state)
self.enterRule(localctx, 156, self.RULE_jumpStatement)
self._la = 0 # Token type
try:
self.state = 1213
la_ = self._interp.adaptivePredict(self._input,131,self._ctx)
if la_ == 1:
self.enterOuterAlt(localctx, 1)
self.state = 1197
self.match(CParser.Goto)
self.state = 1198
self.match(CParser.Identifier)
self.state = 1199
self.match(CParser.Semi)
pass
elif la_ == 2:
self.enterOuterAlt(localctx, 2)
self.state = 1200
self.match(CParser.Continue)
self.state = 1201
self.match(CParser.Semi)
pass
elif la_ == 3:
self.enterOuterAlt(localctx, 3)
self.state = 1202
self.match(CParser.Break)
self.state = 1203
self.match(CParser.Semi)
pass
elif la_ == 4:
self.enterOuterAlt(localctx, 4)
self.state = 1204
self.match(CParser.Return)
self.state = 1206
_la = self._input.LA(1)
if (((_la) & ~0x3f) == 0 and ((1 << _la) & ((1 << CParser.T__0) | (1 << CParser.T__1) | (1 << CParser.T__2) | (1 << CParser.Sizeof) | (1 << CParser.Alignof) | (1 << CParser.Generic) | (1 << CParser.LeftParen))) != 0) or ((((_la - 71)) & ~0x3f) == 0 and ((1 << (_la - 71)) & ((1 << (CParser.Plus - 71)) | (1 << (CParser.PlusPlus - 71)) | (1 << (CParser.Minus - 71)) | (1 << (CParser.MinusMinus - 71)) | (1 << (CParser.Star - 71)) | (1 << (CParser.And - 71)) | (1 << (CParser.AndAnd - 71)) | (1 << (CParser.Not - 71)) | (1 << (CParser.Tilde - 71)) | (1 << (CParser.Identifier - 71)) | (1 << (CParser.Constant - 71)) | (1 << (CParser.StringLiteral - 71)))) != 0):
self.state = 1205
self.expression(0)
self.state = 1208
self.match(CParser.Semi)
pass
elif la_ == 5:
self.enterOuterAlt(localctx, 5)
self.state = 1209
self.match(CParser.Goto)
self.state = 1210
self.unaryExpression()
self.state = 1211
self.match(CParser.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 CompilationUnitContext(ParserRuleContext):
def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
super().__init__(parent, invokingState)
self.parser = parser
def EOF(self):
return self.getToken(CParser.EOF, 0)
def translationUnit(self):
return self.getTypedRuleContext(CParser.TranslationUnitContext,0)
def getRuleIndex(self):
return CParser.RULE_compilationUnit
def enterRule(self, listener:ParseTreeListener):
if hasattr( listener, "enterCompilationUnit" ):
listener.enterCompilationUnit(self)
def exitRule(self, listener:ParseTreeListener):
if hasattr( listener, "exitCompilationUnit" ):
listener.exitCompilationUnit(self)
def accept(self, visitor:ParseTreeVisitor):
if hasattr( visitor, "visitCompilationUnit" ):
return visitor.visitCompilationUnit(self)
else:
return visitor.visitChildren(self)
def compilationUnit(self):
localctx = CParser.CompilationUnitContext(self, self._ctx, self.state)
self.enterRule(localctx, 158, self.RULE_compilationUnit)
self._la = 0 # Token type
try:
self.enterOuterAlt(localctx, 1)
self.state = 1216
_la = self._input.LA(1)
if (((_la) & ~0x3f) == 0 and ((1 << _la) & ((1 << CParser.T__0) | (1 << CParser.T__3) | (1 << CParser.T__4) | (1 << CParser.T__5) | (1 << CParser.T__6) | (1 << CParser.T__7) | (1 << CParser.T__8) | (1 << CParser.T__9) | (1 << CParser.T__11) | (1 << CParser.Auto) | (1 << CParser.Char) | (1 << CParser.Const) | (1 << CParser.Double) | (1 << CParser.Enum) | (1 << CParser.Extern) | (1 << CParser.Float) | (1 << CParser.Inline) | (1 << CParser.Int) | (1 << CParser.Long) | (1 << CParser.Register) | (1 << CParser.Restrict) | (1 << CParser.Short) | (1 << CParser.Signed) | (1 << CParser.Static) | (1 << CParser.Struct) | (1 << CParser.Typedef) | (1 << CParser.Union) | (1 << CParser.Unsigned) | (1 << CParser.Void) | (1 << CParser.Volatile) | (1 << CParser.Alignas) | (1 << CParser.Atomic) | (1 << CParser.Bool) | (1 << CParser.Complex) | (1 << CParser.Noreturn) | (1 << CParser.StaticAssert) | (1 << CParser.ThreadLocal) | (1 << CParser.LeftParen))) != 0) or ((((_la - 75)) & ~0x3f) == 0 and ((1 << (_la - 75)) & ((1 << (CParser.Star - 75)) | (1 << (CParser.Caret - 75)) | (1 << (CParser.Semi - 75)) | (1 << (CParser.Identifier - 75)))) != 0):
self.state = 1215
self.translationUnit(0)
self.state = 1218
self.match(CParser.EOF)
except RecognitionException as re:
localctx.exception = re
self._errHandler.reportError(self, re)
self._errHandler.recover(self, re)
finally:
self.exitRule()
return localctx
class TranslationUnitContext(ParserRuleContext):
def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
super().__init__(parent, invokingState)
self.parser = parser
def externalDeclaration(self):
return self.getTypedRuleContext(CParser.ExternalDeclarationContext,0)
def translationUnit(self):
return self.getTypedRuleContext(CParser.TranslationUnitContext,0)
def getRuleIndex(self):
return CParser.RULE_translationUnit
def enterRule(self, listener:ParseTreeListener):
if hasattr( listener, "enterTranslationUnit" ):
listener.enterTranslationUnit(self)
def exitRule(self, listener:ParseTreeListener):
if hasattr( listener, "exitTranslationUnit" ):
listener.exitTranslationUnit(self)
def accept(self, visitor:ParseTreeVisitor):
if hasattr( visitor, "visitTranslationUnit" ):
return visitor.visitTranslationUnit(self)
else:
return visitor.visitChildren(self)
def translationUnit(self, _p:int=0):
_parentctx = self._ctx
_parentState = self.state
localctx = CParser.TranslationUnitContext(self, self._ctx, _parentState)
_prevctx = localctx
_startState = 160
self.enterRecursionRule(localctx, 160, self.RULE_translationUnit, _p)
try:
self.enterOuterAlt(localctx, 1)
self.state = 1221
self.externalDeclaration()
self._ctx.stop = self._input.LT(-1)
self.state = 1227
self._errHandler.sync(self)
_alt = self._interp.adaptivePredict(self._input,133,self._ctx)
while _alt!=2 and _alt!=ATN.INVALID_ALT_NUMBER:
if _alt==1:
if self._parseListeners is not None:
self.triggerExitRuleEvent()
_prevctx = localctx
localctx = CParser.TranslationUnitContext(self, _parentctx, _parentState)
self.pushNewRecursionContext(localctx, _startState, self.RULE_translationUnit)
self.state = 1223
if not self.precpred(self._ctx, 1):
from antlr4.error.Errors import FailedPredicateException
raise FailedPredicateException(self, "self.precpred(self._ctx, 1)")
self.state = 1224
self.externalDeclaration()
self.state = 1229
self._errHandler.sync(self)
_alt = self._interp.adaptivePredict(self._input,133,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 ExternalDeclarationContext(ParserRuleContext):
def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
super().__init__(parent, invokingState)
self.parser = parser
def functionDefinition(self):
return self.getTypedRuleContext(CParser.FunctionDefinitionContext,0)
def declaration(self):
return self.getTypedRuleContext(CParser.DeclarationContext,0)
def getRuleIndex(self):
return CParser.RULE_externalDeclaration
def enterRule(self, listener:ParseTreeListener):
if hasattr( listener, "enterExternalDeclaration" ):
listener.enterExternalDeclaration(self)
def exitRule(self, listener:ParseTreeListener):
if hasattr( listener, "exitExternalDeclaration" ):
listener.exitExternalDeclaration(self)
def accept(self, visitor:ParseTreeVisitor):
if hasattr( visitor, "visitExternalDeclaration" ):
return visitor.visitExternalDeclaration(self)
else:
return visitor.visitChildren(self)
def externalDeclaration(self):
localctx = CParser.ExternalDeclarationContext(self, self._ctx, self.state)
self.enterRule(localctx, 162, self.RULE_externalDeclaration)
try:
self.state = 1233
la_ = self._interp.adaptivePredict(self._input,134,self._ctx)
if la_ == 1:
self.enterOuterAlt(localctx, 1)
self.state = 1230
self.functionDefinition()
pass
elif la_ == 2:
self.enterOuterAlt(localctx, 2)
self.state = 1231
self.declaration()
pass
elif la_ == 3:
self.enterOuterAlt(localctx, 3)
self.state = 1232
self.match(CParser.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 FunctionDefinitionContext(ParserRuleContext):
def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
super().__init__(parent, invokingState)
self.parser = parser
def declarator(self):
return self.getTypedRuleContext(CParser.DeclaratorContext,0)
def compoundStatement(self):
return self.getTypedRuleContext(CParser.CompoundStatementContext,0)
def declarationSpecifiers(self):
return self.getTypedRuleContext(CParser.DeclarationSpecifiersContext,0)
def declarationList(self):
return self.getTypedRuleContext(CParser.DeclarationListContext,0)
def getRuleIndex(self):
return CParser.RULE_functionDefinition
def enterRule(self, listener:ParseTreeListener):
if hasattr( listener, "enterFunctionDefinition" ):
listener.enterFunctionDefinition(self)
def exitRule(self, listener:ParseTreeListener):
if hasattr( listener, "exitFunctionDefinition" ):
listener.exitFunctionDefinition(self)
def accept(self, visitor:ParseTreeVisitor):
if hasattr( visitor, "visitFunctionDefinition" ):
return visitor.visitFunctionDefinition(self)
else:
return visitor.visitChildren(self)
def functionDefinition(self):
localctx = CParser.FunctionDefinitionContext(self, self._ctx, self.state)
self.enterRule(localctx, 164, self.RULE_functionDefinition)
self._la = 0 # Token type
try:
self.enterOuterAlt(localctx, 1)
self.state = 1236
la_ = self._interp.adaptivePredict(self._input,135,self._ctx)
if la_ == 1:
self.state = 1235
self.declarationSpecifiers()
self.state = 1238
self.declarator()
self.state = 1240
_la = self._input.LA(1)
if (((_la) & ~0x3f) == 0 and ((1 << _la) & ((1 << CParser.T__0) | (1 << CParser.T__3) | (1 << CParser.T__4) | (1 << CParser.T__5) | (1 << CParser.T__6) | (1 << CParser.T__7) | (1 << CParser.T__8) | (1 << CParser.T__9) | (1 << CParser.T__11) | (1 << CParser.Auto) | (1 << CParser.Char) | (1 << CParser.Const) | (1 << CParser.Double) | (1 << CParser.Enum) | (1 << CParser.Extern) | (1 << CParser.Float) | (1 << CParser.Inline) | (1 << CParser.Int) | (1 << CParser.Long) | (1 << CParser.Register) | (1 << CParser.Restrict) | (1 << CParser.Short) | (1 << CParser.Signed) | (1 << CParser.Static) | (1 << CParser.Struct) | (1 << CParser.Typedef) | (1 << CParser.Union) | (1 << CParser.Unsigned) | (1 << CParser.Void) | (1 << CParser.Volatile) | (1 << CParser.Alignas) | (1 << CParser.Atomic) | (1 << CParser.Bool) | (1 << CParser.Complex) | (1 << CParser.Noreturn) | (1 << CParser.StaticAssert) | (1 << CParser.ThreadLocal))) != 0) or _la==CParser.Identifier:
self.state = 1239
self.declarationList(0)
self.state = 1242
self.compoundStatement()
except RecognitionException as re:
localctx.exception = re
self._errHandler.reportError(self, re)
self._errHandler.recover(self, re)
finally:
self.exitRule()
return localctx
class DeclarationListContext(ParserRuleContext):
def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
super().__init__(parent, invokingState)
self.parser = parser
def declaration(self):
return self.getTypedRuleContext(CParser.DeclarationContext,0)
def declarationList(self):
return self.getTypedRuleContext(CParser.DeclarationListContext,0)
def getRuleIndex(self):
return CParser.RULE_declarationList
def enterRule(self, listener:ParseTreeListener):
if hasattr( listener, "enterDeclarationList" ):
listener.enterDeclarationList(self)
def exitRule(self, listener:ParseTreeListener):
if hasattr( listener, "exitDeclarationList" ):
listener.exitDeclarationList(self)
def accept(self, visitor:ParseTreeVisitor):
if hasattr( visitor, "visitDeclarationList" ):
return visitor.visitDeclarationList(self)
else:
return visitor.visitChildren(self)
def declarationList(self, _p:int=0):
_parentctx = self._ctx
_parentState = self.state
localctx = CParser.DeclarationListContext(self, self._ctx, _parentState)
_prevctx = localctx
_startState = 166
self.enterRecursionRule(localctx, 166, self.RULE_declarationList, _p)
try:
self.enterOuterAlt(localctx, 1)
self.state = 1245
self.declaration()
self._ctx.stop = self._input.LT(-1)
self.state = 1251
self._errHandler.sync(self)
_alt = self._interp.adaptivePredict(self._input,137,self._ctx)
while _alt!=2 and _alt!=ATN.INVALID_ALT_NUMBER:
if _alt==1:
if self._parseListeners is not None:
self.triggerExitRuleEvent()
_prevctx = localctx
localctx = CParser.DeclarationListContext(self, _parentctx, _parentState)
self.pushNewRecursionContext(localctx, _startState, self.RULE_declarationList)
self.state = 1247
if not self.precpred(self._ctx, 1):
from antlr4.error.Errors import FailedPredicateException
raise FailedPredicateException(self, "self.precpred(self._ctx, 1)")
self.state = 1248
self.declaration()
self.state = 1253
self._errHandler.sync(self)
_alt = self._interp.adaptivePredict(self._input,137,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
def sempred(self, localctx:RuleContext, ruleIndex:int, predIndex:int):
if self._predicates == None:
self._predicates = dict()
self._predicates[2] = self.genericAssocList_sempred
self._predicates[4] = self.postfixExpression_sempred
self._predicates[5] = self.argumentExpressionList_sempred
self._predicates[9] = self.multiplicativeExpression_sempred
self._predicates[10] = self.additiveExpression_sempred
self._predicates[11] = self.shiftExpression_sempred
self._predicates[12] = self.relationalExpression_sempred
self._predicates[13] = self.equalityExpression_sempred
self._predicates[14] = self.andExpression_sempred
self._predicates[15] = self.exclusiveOrExpression_sempred
self._predicates[16] = self.inclusiveOrExpression_sempred
self._predicates[17] = self.logicalAndExpression_sempred
self._predicates[18] = self.logicalOrExpression_sempred
self._predicates[22] = self.expression_sempred
self._predicates[28] = self.initDeclaratorList_sempred
self._predicates[34] = self.structDeclarationList_sempred
self._predicates[37] = self.structDeclaratorList_sempred
self._predicates[40] = self.enumeratorList_sempred
self._predicates[48] = self.directDeclarator_sempred
self._predicates[55] = self.typeQualifierList_sempred
self._predicates[57] = self.parameterList_sempred
self._predicates[59] = self.identifierList_sempred
self._predicates[62] = self.directAbstractDeclarator_sempred
self._predicates[65] = self.initializerList_sempred
self._predicates[67] = self.designatorList_sempred
self._predicates[73] = self.blockItemList_sempred
self._predicates[80] = self.translationUnit_sempred
self._predicates[83] = self.declarationList_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 genericAssocList_sempred(self, localctx:GenericAssocListContext, predIndex:int):
if predIndex == 0:
return self.precpred(self._ctx, 1)
def postfixExpression_sempred(self, localctx:PostfixExpressionContext, predIndex:int):
if predIndex == 1:
return self.precpred(self._ctx, 10)
if predIndex == 2:
return self.precpred(self._ctx, 9)
if predIndex == 3:
return self.precpred(self._ctx, 8)
if predIndex == 4:
return self.precpred(self._ctx, 7)
if predIndex == 5:
return self.precpred(self._ctx, 6)
if predIndex == 6:
return self.precpred(self._ctx, 5)
def argumentExpressionList_sempred(self, localctx:ArgumentExpressionListContext, predIndex:int):
if predIndex == 7:
return self.precpred(self._ctx, 1)
def multiplicativeExpression_sempred(self, localctx:MultiplicativeExpressionContext, predIndex:int):
if predIndex == 8:
return self.precpred(self._ctx, 3)
if predIndex == 9:
return self.precpred(self._ctx, 2)
if predIndex == 10:
return self.precpred(self._ctx, 1)
def additiveExpression_sempred(self, localctx:AdditiveExpressionContext, predIndex:int):
if predIndex == 11:
return self.precpred(self._ctx, 2)
if predIndex == 12:
return self.precpred(self._ctx, 1)
def shiftExpression_sempred(self, localctx:ShiftExpressionContext, predIndex:int):
if predIndex == 13:
return self.precpred(self._ctx, 2)
if predIndex == 14:
return self.precpred(self._ctx, 1)
def relationalExpression_sempred(self, localctx:RelationalExpressionContext, predIndex:int):
if predIndex == 15:
return self.precpred(self._ctx, 4)
if predIndex == 16:
return self.precpred(self._ctx, 3)
if predIndex == 17:
return self.precpred(self._ctx, 2)
if predIndex == 18:
return self.precpred(self._ctx, 1)
def equalityExpression_sempred(self, localctx:EqualityExpressionContext, predIndex:int):
if predIndex == 19:
return self.precpred(self._ctx, 2)
if predIndex == 20:
return self.precpred(self._ctx, 1)
def andExpression_sempred(self, localctx:AndExpressionContext, predIndex:int):
if predIndex == 21:
return self.precpred(self._ctx, 1)
def exclusiveOrExpression_sempred(self, localctx:ExclusiveOrExpressionContext, predIndex:int):
if predIndex == 22:
return self.precpred(self._ctx, 1)
def inclusiveOrExpression_sempred(self, localctx:InclusiveOrExpressionContext, predIndex:int):
if predIndex == 23:
return self.precpred(self._ctx, 1)
def logicalAndExpression_sempred(self, localctx:LogicalAndExpressionContext, predIndex:int):
if predIndex == 24:
return self.precpred(self._ctx, 1)
def logicalOrExpression_sempred(self, localctx:LogicalOrExpressionContext, predIndex:int):
if predIndex == 25:
return self.precpred(self._ctx, 1)
def expression_sempred(self, localctx:ExpressionContext, predIndex:int):
if predIndex == 26:
return self.precpred(self._ctx, 1)
def initDeclaratorList_sempred(self, localctx:InitDeclaratorListContext, predIndex:int):
if predIndex == 27:
return self.precpred(self._ctx, 1)
def structDeclarationList_sempred(self, localctx:StructDeclarationListContext, predIndex:int):
if predIndex == 28:
return self.precpred(self._ctx, 1)
def structDeclaratorList_sempred(self, localctx:StructDeclaratorListContext, predIndex:int):
if predIndex == 29:
return self.precpred(self._ctx, 1)
def enumeratorList_sempred(self, localctx:EnumeratorListContext, predIndex:int):
if predIndex == 30:
return self.precpred(self._ctx, 1)
def directDeclarator_sempred(self, localctx:DirectDeclaratorContext, predIndex:int):
if predIndex == 31:
return self.precpred(self._ctx, 6)
if predIndex == 32:
return self.precpred(self._ctx, 5)
if predIndex == 33:
return self.precpred(self._ctx, 4)
if predIndex == 34:
return self.precpred(self._ctx, 3)
if predIndex == 35:
return self.precpred(self._ctx, 2)
if predIndex == 36:
return self.precpred(self._ctx, 1)
def typeQualifierList_sempred(self, localctx:TypeQualifierListContext, predIndex:int):
if predIndex == 37:
return self.precpred(self._ctx, 1)
def parameterList_sempred(self, localctx:ParameterListContext, predIndex:int):
if predIndex == 38:
return self.precpred(self._ctx, 1)
def identifierList_sempred(self, localctx:IdentifierListContext, predIndex:int):
if predIndex == 39:
return self.precpred(self._ctx, 1)
def directAbstractDeclarator_sempred(self, localctx:DirectAbstractDeclaratorContext, predIndex:int):
if predIndex == 40:
return self.precpred(self._ctx, 5)
if predIndex == 41:
return self.precpred(self._ctx, 4)
if predIndex == 42:
return self.precpred(self._ctx, 3)
if predIndex == 43:
return self.precpred(self._ctx, 2)
if predIndex == 44:
return self.precpred(self._ctx, 1)
def initializerList_sempred(self, localctx:InitializerListContext, predIndex:int):
if predIndex == 45:
return self.precpred(self._ctx, 1)
def designatorList_sempred(self, localctx:DesignatorListContext, predIndex:int):
if predIndex == 46:
return self.precpred(self._ctx, 1)
def blockItemList_sempred(self, localctx:BlockItemListContext, predIndex:int):
if predIndex == 47:
return self.precpred(self._ctx, 1)
def translationUnit_sempred(self, localctx:TranslationUnitContext, predIndex:int):
if predIndex == 48:
return self.precpred(self._ctx, 1)
def declarationList_sempred(self, localctx:DeclarationListContext, predIndex:int):
if predIndex == 49:
return self.precpred(self._ctx, 1)
© 2015 - 2025 Weber Informatics LLC | Privacy Policy