X-Git-Url: https://gitweb.ps.run/toc/blobdiff_plain/5f9668526491332f62c05ad831dbf6d5fdc2b6d0..17fac686375c2823d22415e32e5b7e63bbfe7c54:/gen/TocParser.cpp diff --git a/gen/TocParser.cpp b/gen/TocParser.cpp index e1d5b1f..c5f639d 100644 --- a/gen/TocParser.cpp +++ b/gen/TocParser.cpp @@ -2,7 +2,6 @@ // Generated from Toc.g4 by ANTLR 4.9.2 -#include "TocListener.h" #include "TocParser.h" @@ -54,17 +53,6 @@ size_t TocParser::ProgContext::getRuleIndex() const { return TocParser::RuleProg; } -void TocParser::ProgContext::enterRule(tree::ParseTreeListener *listener) { - auto parserListener = dynamic_cast(listener); - if (parserListener != nullptr) - parserListener->enterProg(this); -} - -void TocParser::ProgContext::exitRule(tree::ParseTreeListener *listener) { - auto parserListener = dynamic_cast(listener); - if (parserListener != nullptr) - parserListener->exitProg(this); -} TocParser::ProgContext* TocParser::prog() { ProgContext *_localctx = _tracker.createInstance(_ctx, getState()); @@ -80,20 +68,20 @@ TocParser::ProgContext* TocParser::prog() { }); try { enterOuterAlt(_localctx, 1); - setState(81); + setState(101); _errHandler->sync(this); _la = _input->LA(1); do { - setState(80); + setState(100); decl(); - setState(83); + setState(103); _errHandler->sync(this); _la = _input->LA(1); } while ((((_la & ~ 0x3fULL) == 0) && - ((1ULL << _la) & ((1ULL << TocParser::T__0) - | (1ULL << TocParser::T__6) - | (1ULL << TocParser::T__12))) != 0)); - setState(85); + ((1ULL << _la) & ((1ULL << TocParser::T__1) + | (1ULL << TocParser::T__7) + | (1ULL << TocParser::T__13))) != 0)); + setState(105); match(TocParser::EOF); } @@ -129,17 +117,6 @@ size_t TocParser::DeclContext::getRuleIndex() const { return TocParser::RuleDecl; } -void TocParser::DeclContext::enterRule(tree::ParseTreeListener *listener) { - auto parserListener = dynamic_cast(listener); - if (parserListener != nullptr) - parserListener->enterDecl(this); -} - -void TocParser::DeclContext::exitRule(tree::ParseTreeListener *listener) { - auto parserListener = dynamic_cast(listener); - if (parserListener != nullptr) - parserListener->exitDecl(this); -} TocParser::DeclContext* TocParser::decl() { DeclContext *_localctx = _tracker.createInstance(_ctx, getState()); @@ -153,26 +130,28 @@ TocParser::DeclContext* TocParser::decl() { exitRule(); }); try { - setState(90); + setState(112); _errHandler->sync(this); switch (_input->LA(1)) { - case TocParser::T__0: { + case TocParser::T__1: { enterOuterAlt(_localctx, 1); - setState(87); + setState(107); varDecl(); + setState(108); + match(TocParser::T__0); break; } - case TocParser::T__6: { + case TocParser::T__7: { enterOuterAlt(_localctx, 2); - setState(88); + setState(110); funcDecl(); break; } - case TocParser::T__12: { + case TocParser::T__13: { enterOuterAlt(_localctx, 3); - setState(89); + setState(111); structDecl(); break; } @@ -206,17 +185,6 @@ size_t TocParser::VarDeclContext::getRuleIndex() const { return TocParser::RuleVarDecl; } -void TocParser::VarDeclContext::enterRule(tree::ParseTreeListener *listener) { - auto parserListener = dynamic_cast(listener); - if (parserListener != nullptr) - parserListener->enterVarDecl(this); -} - -void TocParser::VarDeclContext::exitRule(tree::ParseTreeListener *listener) { - auto parserListener = dynamic_cast(listener); - if (parserListener != nullptr) - parserListener->exitVarDecl(this); -} TocParser::VarDeclContext* TocParser::varDecl() { VarDeclContext *_localctx = _tracker.createInstance(_ctx, getState()); @@ -231,9 +199,9 @@ TocParser::VarDeclContext* TocParser::varDecl() { }); try { enterOuterAlt(_localctx, 1); - setState(92); - match(TocParser::T__0); - setState(93); + setState(114); + match(TocParser::T__1); + setState(115); var(); } @@ -269,17 +237,6 @@ size_t TocParser::VarContext::getRuleIndex() const { return TocParser::RuleVar; } -void TocParser::VarContext::enterRule(tree::ParseTreeListener *listener) { - auto parserListener = dynamic_cast(listener); - if (parserListener != nullptr) - parserListener->enterVar(this); -} - -void TocParser::VarContext::exitRule(tree::ParseTreeListener *listener) { - auto parserListener = dynamic_cast(listener); - if (parserListener != nullptr) - parserListener->exitVar(this); -} TocParser::VarContext* TocParser::var() { VarContext *_localctx = _tracker.createInstance(_ctx, getState()); @@ -295,21 +252,21 @@ TocParser::VarContext* TocParser::var() { }); try { enterOuterAlt(_localctx, 1); - setState(95); + setState(117); varName(); - setState(96); - match(TocParser::T__1); - setState(97); + setState(118); + match(TocParser::T__2); + setState(119); type(); - setState(101); + setState(123); _errHandler->sync(this); _la = _input->LA(1); - if (_la == TocParser::T__2) { - setState(99); - match(TocParser::T__2); - setState(100); + if (_la == TocParser::T__3) { + setState(121); + match(TocParser::T__3); + setState(122); expr(); } @@ -346,17 +303,6 @@ size_t TocParser::VarInitContext::getRuleIndex() const { return TocParser::RuleVarInit; } -void TocParser::VarInitContext::enterRule(tree::ParseTreeListener *listener) { - auto parserListener = dynamic_cast(listener); - if (parserListener != nullptr) - parserListener->enterVarInit(this); -} - -void TocParser::VarInitContext::exitRule(tree::ParseTreeListener *listener) { - auto parserListener = dynamic_cast(listener); - if (parserListener != nullptr) - parserListener->exitVarInit(this); -} TocParser::VarInitContext* TocParser::varInit() { VarInitContext *_localctx = _tracker.createInstance(_ctx, getState()); @@ -371,17 +317,17 @@ TocParser::VarInitContext* TocParser::varInit() { }); try { enterOuterAlt(_localctx, 1); - setState(103); + setState(125); varName(); - setState(104); - match(TocParser::T__1); - setState(105); + setState(126); + match(TocParser::T__2); + setState(127); type(); - setState(107); - match(TocParser::T__2); - setState(108); + setState(129); + match(TocParser::T__3); + setState(130); expr(); } @@ -417,17 +363,6 @@ size_t TocParser::TypeContext::getRuleIndex() const { return TocParser::RuleType; } -void TocParser::TypeContext::enterRule(tree::ParseTreeListener *listener) { - auto parserListener = dynamic_cast(listener); - if (parserListener != nullptr) - parserListener->enterType(this); -} - -void TocParser::TypeContext::exitRule(tree::ParseTreeListener *listener) { - auto parserListener = dynamic_cast(listener); - if (parserListener != nullptr) - parserListener->exitType(this); -} TocParser::TypeContext* TocParser::type() { TypeContext *_localctx = _tracker.createInstance(_ctx, getState()); @@ -443,17 +378,17 @@ TocParser::TypeContext* TocParser::type() { }); try { enterOuterAlt(_localctx, 1); - setState(110); + setState(132); typeName(); - setState(114); + setState(136); _errHandler->sync(this); _la = _input->LA(1); - while (_la == TocParser::T__3 + while (_la == TocParser::T__4 - || _la == TocParser::T__4) { - setState(111); + || _la == TocParser::T__5) { + setState(133); typeModifier(); - setState(116); + setState(138); _errHandler->sync(this); _la = _input->LA(1); } @@ -474,8 +409,8 @@ TocParser::TypeModifierContext::TypeModifierContext(ParserRuleContext *parent, s : ParserRuleContext(parent, invokingState) { } -tree::TerminalNode* TocParser::TypeModifierContext::NUMBER() { - return getToken(TocParser::NUMBER, 0); +tree::TerminalNode* TocParser::TypeModifierContext::INT_LIT() { + return getToken(TocParser::INT_LIT, 0); } @@ -483,17 +418,6 @@ size_t TocParser::TypeModifierContext::getRuleIndex() const { return TocParser::RuleTypeModifier; } -void TocParser::TypeModifierContext::enterRule(tree::ParseTreeListener *listener) { - auto parserListener = dynamic_cast(listener); - if (parserListener != nullptr) - parserListener->enterTypeModifier(this); -} - -void TocParser::TypeModifierContext::exitRule(tree::ParseTreeListener *listener) { - auto parserListener = dynamic_cast(listener); - if (parserListener != nullptr) - parserListener->exitTypeModifier(this); -} TocParser::TypeModifierContext* TocParser::typeModifier() { TypeModifierContext *_localctx = _tracker.createInstance(_ctx, getState()); @@ -508,30 +432,30 @@ TocParser::TypeModifierContext* TocParser::typeModifier() { exitRule(); }); try { - setState(123); + setState(145); _errHandler->sync(this); switch (_input->LA(1)) { - case TocParser::T__3: { + case TocParser::T__4: { enterOuterAlt(_localctx, 1); - setState(117); - match(TocParser::T__3); + setState(139); + match(TocParser::T__4); break; } - case TocParser::T__4: { + case TocParser::T__5: { enterOuterAlt(_localctx, 2); - setState(118); - match(TocParser::T__4); - setState(120); + setState(140); + match(TocParser::T__5); + setState(142); _errHandler->sync(this); _la = _input->LA(1); - if (_la == TocParser::NUMBER) { - setState(119); - match(TocParser::NUMBER); + if (_la == TocParser::INT_LIT) { + setState(141); + match(TocParser::INT_LIT); } - setState(122); - match(TocParser::T__5); + setState(144); + match(TocParser::T__6); break; } @@ -564,17 +488,6 @@ size_t TocParser::FuncDeclContext::getRuleIndex() const { return TocParser::RuleFuncDecl; } -void TocParser::FuncDeclContext::enterRule(tree::ParseTreeListener *listener) { - auto parserListener = dynamic_cast(listener); - if (parserListener != nullptr) - parserListener->enterFuncDecl(this); -} - -void TocParser::FuncDeclContext::exitRule(tree::ParseTreeListener *listener) { - auto parserListener = dynamic_cast(listener); - if (parserListener != nullptr) - parserListener->exitFuncDecl(this); -} TocParser::FuncDeclContext* TocParser::funcDecl() { FuncDeclContext *_localctx = _tracker.createInstance(_ctx, getState()); @@ -589,9 +502,9 @@ TocParser::FuncDeclContext* TocParser::funcDecl() { }); try { enterOuterAlt(_localctx, 1); - setState(125); - match(TocParser::T__6); - setState(126); + setState(147); + match(TocParser::T__7); + setState(148); func(); } @@ -626,26 +539,20 @@ TocParser::TypeContext* TocParser::FuncContext::type() { return getRuleContext(0); } +TocParser::GenericDeclContext* TocParser::FuncContext::genericDecl() { + return getRuleContext(0); +} + size_t TocParser::FuncContext::getRuleIndex() const { return TocParser::RuleFunc; } -void TocParser::FuncContext::enterRule(tree::ParseTreeListener *listener) { - auto parserListener = dynamic_cast(listener); - if (parserListener != nullptr) - parserListener->enterFunc(this); -} - -void TocParser::FuncContext::exitRule(tree::ParseTreeListener *listener) { - auto parserListener = dynamic_cast(listener); - if (parserListener != nullptr) - parserListener->exitFunc(this); -} TocParser::FuncContext* TocParser::func() { FuncContext *_localctx = _tracker.createInstance(_ctx, getState()); enterRule(_localctx, 16, TocParser::RuleFunc); + size_t _la = 0; #if __cplusplus > 201703L auto onExit = finally([=, this] { @@ -656,20 +563,28 @@ TocParser::FuncContext* TocParser::func() { }); try { enterOuterAlt(_localctx, 1); - setState(128); + setState(150); funcName(); - setState(129); - match(TocParser::T__7); - setState(130); - parameter(); - setState(131); + setState(152); + _errHandler->sync(this); + + _la = _input->LA(1); + if (_la == TocParser::T__14) { + setState(151); + genericDecl(); + } + setState(154); match(TocParser::T__8); + setState(155); + parameter(); + setState(156); + match(TocParser::T__9); - setState(132); - match(TocParser::T__1); - setState(133); + setState(157); + match(TocParser::T__2); + setState(158); type(); - setState(135); + setState(160); body(); } @@ -701,17 +616,6 @@ size_t TocParser::ParameterContext::getRuleIndex() const { return TocParser::RuleParameter; } -void TocParser::ParameterContext::enterRule(tree::ParseTreeListener *listener) { - auto parserListener = dynamic_cast(listener); - if (parserListener != nullptr) - parserListener->enterParameter(this); -} - -void TocParser::ParameterContext::exitRule(tree::ParseTreeListener *listener) { - auto parserListener = dynamic_cast(listener); - if (parserListener != nullptr) - parserListener->exitParameter(this); -} TocParser::ParameterContext* TocParser::parameter() { ParameterContext *_localctx = _tracker.createInstance(_ctx, getState()); @@ -727,22 +631,22 @@ TocParser::ParameterContext* TocParser::parameter() { }); try { enterOuterAlt(_localctx, 1); - setState(145); + setState(170); _errHandler->sync(this); _la = _input->LA(1); if (_la == TocParser::NAME) { - setState(137); + setState(162); var(); - setState(142); + setState(167); _errHandler->sync(this); _la = _input->LA(1); - while (_la == TocParser::T__9) { - setState(138); - match(TocParser::T__9); - setState(139); + while (_la == TocParser::T__10) { + setState(163); + match(TocParser::T__10); + setState(164); var(); - setState(144); + setState(169); _errHandler->sync(this); _la = _input->LA(1); } @@ -777,17 +681,6 @@ size_t TocParser::BodyContext::getRuleIndex() const { return TocParser::RuleBody; } -void TocParser::BodyContext::enterRule(tree::ParseTreeListener *listener) { - auto parserListener = dynamic_cast(listener); - if (parserListener != nullptr) - parserListener->enterBody(this); -} - -void TocParser::BodyContext::exitRule(tree::ParseTreeListener *listener) { - auto parserListener = dynamic_cast(listener); - if (parserListener != nullptr) - parserListener->exitBody(this); -} TocParser::BodyContext* TocParser::body() { BodyContext *_localctx = _tracker.createInstance(_ctx, getState()); @@ -803,33 +696,40 @@ TocParser::BodyContext* TocParser::body() { }); try { enterOuterAlt(_localctx, 1); - setState(147); - match(TocParser::T__10); - setState(151); + setState(172); + match(TocParser::T__11); + setState(176); _errHandler->sync(this); _la = _input->LA(1); while ((((_la & ~ 0x3fULL) == 0) && - ((1ULL << _la) & ((1ULL << TocParser::T__0) - | (1ULL << TocParser::T__7) - | (1ULL << TocParser::T__13) - | (1ULL << TocParser::T__15) - | (1ULL << TocParser::T__17) + ((1ULL << _la) & ((1ULL << TocParser::T__1) + | (1ULL << TocParser::T__4) + | (1ULL << TocParser::T__8) + | (1ULL << TocParser::T__16) | (1ULL << TocParser::T__18) - | (1ULL << TocParser::T__19) - | (1ULL << TocParser::PREFIX_OP) + | (1ULL << TocParser::T__20) + | (1ULL << TocParser::T__21) + | (1ULL << TocParser::T__22) + | (1ULL << TocParser::T__26) + | (1ULL << TocParser::T__27) + | (1ULL << TocParser::T__28) + | (1ULL << TocParser::T__29) + | (1ULL << TocParser::T__30) + | (1ULL << TocParser::T__31) + | (1ULL << TocParser::T__32) | (1ULL << TocParser::INT_LIT) | (1ULL << TocParser::DECIMAL_LIT) | (1ULL << TocParser::STRING_LIT) | (1ULL << TocParser::BOOL_LIT) | (1ULL << TocParser::NAME))) != 0)) { - setState(148); + setState(173); stmt(); - setState(153); + setState(178); _errHandler->sync(this); _la = _input->LA(1); } - setState(154); - match(TocParser::T__11); + setState(179); + match(TocParser::T__12); } catch (RecognitionException &e) { @@ -851,6 +751,10 @@ TocParser::StructNameContext* TocParser::StructDeclContext::structName() { return getRuleContext(0); } +TocParser::GenericDeclContext* TocParser::StructDeclContext::genericDecl() { + return getRuleContext(0); +} + std::vector TocParser::StructDeclContext::structMember() { return getRuleContexts(); } @@ -864,17 +768,6 @@ size_t TocParser::StructDeclContext::getRuleIndex() const { return TocParser::RuleStructDecl; } -void TocParser::StructDeclContext::enterRule(tree::ParseTreeListener *listener) { - auto parserListener = dynamic_cast(listener); - if (parserListener != nullptr) - parserListener->enterStructDecl(this); -} - -void TocParser::StructDeclContext::exitRule(tree::ParseTreeListener *listener) { - auto parserListener = dynamic_cast(listener); - if (parserListener != nullptr) - parserListener->exitStructDecl(this); -} TocParser::StructDeclContext* TocParser::structDecl() { StructDeclContext *_localctx = _tracker.createInstance(_ctx, getState()); @@ -890,24 +783,32 @@ TocParser::StructDeclContext* TocParser::structDecl() { }); try { enterOuterAlt(_localctx, 1); - setState(156); - match(TocParser::T__12); - setState(157); + setState(181); + match(TocParser::T__13); + setState(182); structName(); - setState(158); - match(TocParser::T__10); - setState(162); + setState(184); + _errHandler->sync(this); + + _la = _input->LA(1); + if (_la == TocParser::T__14) { + setState(183); + genericDecl(); + } + setState(186); + match(TocParser::T__11); + setState(190); _errHandler->sync(this); _la = _input->LA(1); while (_la == TocParser::NAME) { - setState(159); + setState(187); structMember(); - setState(164); + setState(192); _errHandler->sync(this); _la = _input->LA(1); } - setState(165); - match(TocParser::T__11); + setState(193); + match(TocParser::T__12); } catch (RecognitionException &e) { @@ -938,17 +839,6 @@ size_t TocParser::StructMemberContext::getRuleIndex() const { return TocParser::RuleStructMember; } -void TocParser::StructMemberContext::enterRule(tree::ParseTreeListener *listener) { - auto parserListener = dynamic_cast(listener); - if (parserListener != nullptr) - parserListener->enterStructMember(this); -} - -void TocParser::StructMemberContext::exitRule(tree::ParseTreeListener *listener) { - auto parserListener = dynamic_cast(listener); - if (parserListener != nullptr) - parserListener->exitStructMember(this); -} TocParser::StructMemberContext* TocParser::structMember() { StructMemberContext *_localctx = _tracker.createInstance(_ctx, getState()); @@ -962,19 +852,19 @@ TocParser::StructMemberContext* TocParser::structMember() { exitRule(); }); try { - setState(169); + setState(197); _errHandler->sync(this); - switch (getInterpreter()->adaptivePredict(_input, 10, _ctx)) { + switch (getInterpreter()->adaptivePredict(_input, 12, _ctx)) { case 1: { enterOuterAlt(_localctx, 1); - setState(167); + setState(195); structVar(); break; } case 2: { enterOuterAlt(_localctx, 2); - setState(168); + setState(196); structMethod(); break; } @@ -1008,17 +898,6 @@ size_t TocParser::StructVarContext::getRuleIndex() const { return TocParser::RuleStructVar; } -void TocParser::StructVarContext::enterRule(tree::ParseTreeListener *listener) { - auto parserListener = dynamic_cast(listener); - if (parserListener != nullptr) - parserListener->enterStructVar(this); -} - -void TocParser::StructVarContext::exitRule(tree::ParseTreeListener *listener) { - auto parserListener = dynamic_cast(listener); - if (parserListener != nullptr) - parserListener->exitStructVar(this); -} TocParser::StructVarContext* TocParser::structVar() { StructVarContext *_localctx = _tracker.createInstance(_ctx, getState()); @@ -1033,8 +912,10 @@ TocParser::StructVarContext* TocParser::structVar() { }); try { enterOuterAlt(_localctx, 1); - setState(171); + setState(199); var(); + setState(200); + match(TocParser::T__0); } catch (RecognitionException &e) { @@ -1061,17 +942,6 @@ size_t TocParser::StructMethodContext::getRuleIndex() const { return TocParser::RuleStructMethod; } -void TocParser::StructMethodContext::enterRule(tree::ParseTreeListener *listener) { - auto parserListener = dynamic_cast(listener); - if (parserListener != nullptr) - parserListener->enterStructMethod(this); -} - -void TocParser::StructMethodContext::exitRule(tree::ParseTreeListener *listener) { - auto parserListener = dynamic_cast(listener); - if (parserListener != nullptr) - parserListener->exitStructMethod(this); -} TocParser::StructMethodContext* TocParser::structMethod() { StructMethodContext *_localctx = _tracker.createInstance(_ctx, getState()); @@ -1086,7 +956,7 @@ TocParser::StructMethodContext* TocParser::structMethod() { }); try { enterOuterAlt(_localctx, 1); - setState(173); + setState(202); func(); } @@ -1099,6 +969,69 @@ TocParser::StructMethodContext* TocParser::structMethod() { return _localctx; } +//----------------- GenericDeclContext ------------------------------------------------------------------ + +TocParser::GenericDeclContext::GenericDeclContext(ParserRuleContext *parent, size_t invokingState) + : ParserRuleContext(parent, invokingState) { +} + +std::vector TocParser::GenericDeclContext::typeName() { + return getRuleContexts(); +} + +TocParser::TypeNameContext* TocParser::GenericDeclContext::typeName(size_t i) { + return getRuleContext(i); +} + + +size_t TocParser::GenericDeclContext::getRuleIndex() const { + return TocParser::RuleGenericDecl; +} + + +TocParser::GenericDeclContext* TocParser::genericDecl() { + GenericDeclContext *_localctx = _tracker.createInstance(_ctx, getState()); + enterRule(_localctx, 30, TocParser::RuleGenericDecl); + size_t _la = 0; + +#if __cplusplus > 201703L + auto onExit = finally([=, this] { +#else + auto onExit = finally([=] { +#endif + exitRule(); + }); + try { + enterOuterAlt(_localctx, 1); + setState(204); + match(TocParser::T__14); + setState(205); + typeName(); + setState(210); + _errHandler->sync(this); + _la = _input->LA(1); + while (_la == TocParser::T__10) { + setState(206); + match(TocParser::T__10); + setState(207); + typeName(); + setState(212); + _errHandler->sync(this); + _la = _input->LA(1); + } + setState(213); + match(TocParser::T__15); + + } + catch (RecognitionException &e) { + _errHandler->reportError(this, e); + _localctx->exception = std::current_exception(); + _errHandler->recover(this, _localctx->exception); + } + + return _localctx; +} + //----------------- StmtContext ------------------------------------------------------------------ TocParser::StmtContext::StmtContext(ParserRuleContext *parent, size_t invokingState) @@ -1142,21 +1075,10 @@ size_t TocParser::StmtContext::getRuleIndex() const { return TocParser::RuleStmt; } -void TocParser::StmtContext::enterRule(tree::ParseTreeListener *listener) { - auto parserListener = dynamic_cast(listener); - if (parserListener != nullptr) - parserListener->enterStmt(this); -} - -void TocParser::StmtContext::exitRule(tree::ParseTreeListener *listener) { - auto parserListener = dynamic_cast(listener); - if (parserListener != nullptr) - parserListener->exitStmt(this); -} TocParser::StmtContext* TocParser::stmt() { StmtContext *_localctx = _tracker.createInstance(_ctx, getState()); - enterRule(_localctx, 30, TocParser::RuleStmt); + enterRule(_localctx, 32, TocParser::RuleStmt); #if __cplusplus > 201703L auto onExit = finally([=, this] { @@ -1166,62 +1088,70 @@ TocParser::StmtContext* TocParser::stmt() { exitRule(); }); try { - setState(183); + setState(231); _errHandler->sync(this); - switch (getInterpreter()->adaptivePredict(_input, 11, _ctx)) { + switch (getInterpreter()->adaptivePredict(_input, 14, _ctx)) { case 1: { enterOuterAlt(_localctx, 1); - setState(175); + setState(215); varDecl(); + setState(216); + match(TocParser::T__0); break; } case 2: { enterOuterAlt(_localctx, 2); - setState(176); + setState(218); ifStmt(); break; } case 3: { enterOuterAlt(_localctx, 3); - setState(177); + setState(219); switchStmt(); break; } case 4: { enterOuterAlt(_localctx, 4); - setState(178); + setState(220); forStmt(); break; } case 5: { enterOuterAlt(_localctx, 5); - setState(179); + setState(221); whileStmt(); break; } case 6: { enterOuterAlt(_localctx, 6); - setState(180); + setState(222); assignStmt(); + setState(223); + match(TocParser::T__0); break; } case 7: { enterOuterAlt(_localctx, 7); - setState(181); + setState(225); returnStmt(); + setState(226); + match(TocParser::T__0); break; } case 8: { enterOuterAlt(_localctx, 8); - setState(182); + setState(228); expr(); + setState(229); + match(TocParser::T__0); break; } @@ -1245,20 +1175,24 @@ TocParser::IfStmtContext::IfStmtContext(ParserRuleContext *parent, size_t invoki : ParserRuleContext(parent, invokingState) { } -std::vector TocParser::IfStmtContext::expr() { - return getRuleContexts(); +TocParser::ExprContext* TocParser::IfStmtContext::expr() { + return getRuleContext(0); } -TocParser::ExprContext* TocParser::IfStmtContext::expr(size_t i) { - return getRuleContext(i); +TocParser::BodyContext* TocParser::IfStmtContext::body() { + return getRuleContext(0); +} + +std::vector TocParser::IfStmtContext::elseIfStmt() { + return getRuleContexts(); } -std::vector TocParser::IfStmtContext::body() { - return getRuleContexts(); +TocParser::ElseIfStmtContext* TocParser::IfStmtContext::elseIfStmt(size_t i) { + return getRuleContext(i); } -TocParser::BodyContext* TocParser::IfStmtContext::body(size_t i) { - return getRuleContext(i); +TocParser::ElseStmtContext* TocParser::IfStmtContext::elseStmt() { + return getRuleContext(0); } @@ -1266,21 +1200,10 @@ size_t TocParser::IfStmtContext::getRuleIndex() const { return TocParser::RuleIfStmt; } -void TocParser::IfStmtContext::enterRule(tree::ParseTreeListener *listener) { - auto parserListener = dynamic_cast(listener); - if (parserListener != nullptr) - parserListener->enterIfStmt(this); -} - -void TocParser::IfStmtContext::exitRule(tree::ParseTreeListener *listener) { - auto parserListener = dynamic_cast(listener); - if (parserListener != nullptr) - parserListener->exitIfStmt(this); -} TocParser::IfStmtContext* TocParser::ifStmt() { IfStmtContext *_localctx = _tracker.createInstance(_ctx, getState()); - enterRule(_localctx, 32, TocParser::RuleIfStmt); + enterRule(_localctx, 34, TocParser::RuleIfStmt); size_t _la = 0; #if __cplusplus > 201703L @@ -1293,39 +1216,31 @@ TocParser::IfStmtContext* TocParser::ifStmt() { try { size_t alt; enterOuterAlt(_localctx, 1); - setState(185); - match(TocParser::T__13); - setState(186); + setState(233); + match(TocParser::T__16); + setState(234); expr(); - setState(187); + setState(235); body(); - setState(195); + setState(239); _errHandler->sync(this); - alt = getInterpreter()->adaptivePredict(_input, 12, _ctx); + alt = getInterpreter()->adaptivePredict(_input, 15, _ctx); while (alt != 2 && alt != atn::ATN::INVALID_ALT_NUMBER) { if (alt == 1) { - setState(188); - match(TocParser::T__14); - setState(189); - match(TocParser::T__13); - setState(190); - expr(); - setState(191); - body(); + setState(236); + elseIfStmt(); } - setState(197); + setState(241); _errHandler->sync(this); - alt = getInterpreter()->adaptivePredict(_input, 12, _ctx); + alt = getInterpreter()->adaptivePredict(_input, 15, _ctx); } - setState(200); + setState(243); _errHandler->sync(this); _la = _input->LA(1); - if (_la == TocParser::T__14) { - setState(198); - match(TocParser::T__14); - setState(199); - body(); + if (_la == TocParser::T__17) { + setState(242); + elseStmt(); } } @@ -1338,40 +1253,29 @@ TocParser::IfStmtContext* TocParser::ifStmt() { return _localctx; } -//----------------- SwitchStmtContext ------------------------------------------------------------------ +//----------------- ElseIfStmtContext ------------------------------------------------------------------ -TocParser::SwitchStmtContext::SwitchStmtContext(ParserRuleContext *parent, size_t invokingState) +TocParser::ElseIfStmtContext::ElseIfStmtContext(ParserRuleContext *parent, size_t invokingState) : ParserRuleContext(parent, invokingState) { } -TocParser::IdentifierExprContext* TocParser::SwitchStmtContext::identifierExpr() { - return getRuleContext(0); +TocParser::ExprContext* TocParser::ElseIfStmtContext::expr() { + return getRuleContext(0); } -TocParser::SwitchBodyContext* TocParser::SwitchStmtContext::switchBody() { - return getRuleContext(0); +TocParser::BodyContext* TocParser::ElseIfStmtContext::body() { + return getRuleContext(0); } -size_t TocParser::SwitchStmtContext::getRuleIndex() const { - return TocParser::RuleSwitchStmt; -} - -void TocParser::SwitchStmtContext::enterRule(tree::ParseTreeListener *listener) { - auto parserListener = dynamic_cast(listener); - if (parserListener != nullptr) - parserListener->enterSwitchStmt(this); +size_t TocParser::ElseIfStmtContext::getRuleIndex() const { + return TocParser::RuleElseIfStmt; } -void TocParser::SwitchStmtContext::exitRule(tree::ParseTreeListener *listener) { - auto parserListener = dynamic_cast(listener); - if (parserListener != nullptr) - parserListener->exitSwitchStmt(this); -} -TocParser::SwitchStmtContext* TocParser::switchStmt() { - SwitchStmtContext *_localctx = _tracker.createInstance(_ctx, getState()); - enterRule(_localctx, 34, TocParser::RuleSwitchStmt); +TocParser::ElseIfStmtContext* TocParser::elseIfStmt() { + ElseIfStmtContext *_localctx = _tracker.createInstance(_ctx, getState()); + enterRule(_localctx, 36, TocParser::RuleElseIfStmt); #if __cplusplus > 201703L auto onExit = finally([=, this] { @@ -1382,12 +1286,14 @@ TocParser::SwitchStmtContext* TocParser::switchStmt() { }); try { enterOuterAlt(_localctx, 1); - setState(202); - match(TocParser::T__15); - setState(203); - identifierExpr(); - setState(204); - switchBody(); + setState(245); + match(TocParser::T__17); + setState(246); + match(TocParser::T__16); + setState(247); + expr(); + setState(248); + body(); } catch (RecognitionException &e) { @@ -1399,49 +1305,25 @@ TocParser::SwitchStmtContext* TocParser::switchStmt() { return _localctx; } -//----------------- SwitchBodyContext ------------------------------------------------------------------ +//----------------- ElseStmtContext ------------------------------------------------------------------ -TocParser::SwitchBodyContext::SwitchBodyContext(ParserRuleContext *parent, size_t invokingState) +TocParser::ElseStmtContext::ElseStmtContext(ParserRuleContext *parent, size_t invokingState) : ParserRuleContext(parent, invokingState) { } -std::vector TocParser::SwitchBodyContext::expr() { - return getRuleContexts(); -} - -TocParser::ExprContext* TocParser::SwitchBodyContext::expr(size_t i) { - return getRuleContext(i); -} - -std::vector TocParser::SwitchBodyContext::body() { - return getRuleContexts(); -} - -TocParser::BodyContext* TocParser::SwitchBodyContext::body(size_t i) { - return getRuleContext(i); +TocParser::BodyContext* TocParser::ElseStmtContext::body() { + return getRuleContext(0); } -size_t TocParser::SwitchBodyContext::getRuleIndex() const { - return TocParser::RuleSwitchBody; -} - -void TocParser::SwitchBodyContext::enterRule(tree::ParseTreeListener *listener) { - auto parserListener = dynamic_cast(listener); - if (parserListener != nullptr) - parserListener->enterSwitchBody(this); +size_t TocParser::ElseStmtContext::getRuleIndex() const { + return TocParser::RuleElseStmt; } -void TocParser::SwitchBodyContext::exitRule(tree::ParseTreeListener *listener) { - auto parserListener = dynamic_cast(listener); - if (parserListener != nullptr) - parserListener->exitSwitchBody(this); -} -TocParser::SwitchBodyContext* TocParser::switchBody() { - SwitchBodyContext *_localctx = _tracker.createInstance(_ctx, getState()); - enterRule(_localctx, 36, TocParser::RuleSwitchBody); - size_t _la = 0; +TocParser::ElseStmtContext* TocParser::elseStmt() { + ElseStmtContext *_localctx = _tracker.createInstance(_ctx, getState()); + enterRule(_localctx, 38, TocParser::RuleElseStmt); #if __cplusplus > 201703L auto onExit = finally([=, this] { @@ -1452,24 +1334,169 @@ TocParser::SwitchBodyContext* TocParser::switchBody() { }); try { enterOuterAlt(_localctx, 1); - setState(206); - match(TocParser::T__10); - setState(213); - _errHandler->sync(this); - _la = _input->LA(1); - while (_la == TocParser::T__16) { - setState(207); - match(TocParser::T__16); - setState(208); - expr(); - setState(209); - body(); - setState(215); + setState(250); + match(TocParser::T__17); + setState(251); + body(); + + } + catch (RecognitionException &e) { + _errHandler->reportError(this, e); + _localctx->exception = std::current_exception(); + _errHandler->recover(this, _localctx->exception); + } + + return _localctx; +} + +//----------------- SwitchStmtContext ------------------------------------------------------------------ + +TocParser::SwitchStmtContext::SwitchStmtContext(ParserRuleContext *parent, size_t invokingState) + : ParserRuleContext(parent, invokingState) { +} + +TocParser::IdentifierExprContext* TocParser::SwitchStmtContext::identifierExpr() { + return getRuleContext(0); +} + +TocParser::SwitchBodyContext* TocParser::SwitchStmtContext::switchBody() { + return getRuleContext(0); +} + + +size_t TocParser::SwitchStmtContext::getRuleIndex() const { + return TocParser::RuleSwitchStmt; +} + + +TocParser::SwitchStmtContext* TocParser::switchStmt() { + SwitchStmtContext *_localctx = _tracker.createInstance(_ctx, getState()); + enterRule(_localctx, 40, TocParser::RuleSwitchStmt); + +#if __cplusplus > 201703L + auto onExit = finally([=, this] { +#else + auto onExit = finally([=] { +#endif + exitRule(); + }); + try { + enterOuterAlt(_localctx, 1); + setState(253); + match(TocParser::T__18); + setState(254); + identifierExpr(); + setState(255); + switchBody(); + + } + catch (RecognitionException &e) { + _errHandler->reportError(this, e); + _localctx->exception = std::current_exception(); + _errHandler->recover(this, _localctx->exception); + } + + return _localctx; +} + +//----------------- SwitchBodyContext ------------------------------------------------------------------ + +TocParser::SwitchBodyContext::SwitchBodyContext(ParserRuleContext *parent, size_t invokingState) + : ParserRuleContext(parent, invokingState) { +} + +std::vector TocParser::SwitchBodyContext::switchCase() { + return getRuleContexts(); +} + +TocParser::SwitchCaseContext* TocParser::SwitchBodyContext::switchCase(size_t i) { + return getRuleContext(i); +} + + +size_t TocParser::SwitchBodyContext::getRuleIndex() const { + return TocParser::RuleSwitchBody; +} + + +TocParser::SwitchBodyContext* TocParser::switchBody() { + SwitchBodyContext *_localctx = _tracker.createInstance(_ctx, getState()); + enterRule(_localctx, 42, TocParser::RuleSwitchBody); + size_t _la = 0; + +#if __cplusplus > 201703L + auto onExit = finally([=, this] { +#else + auto onExit = finally([=] { +#endif + exitRule(); + }); + try { + enterOuterAlt(_localctx, 1); + setState(257); + match(TocParser::T__11); + setState(261); + _errHandler->sync(this); + _la = _input->LA(1); + while (_la == TocParser::T__19) { + setState(258); + switchCase(); + setState(263); _errHandler->sync(this); _la = _input->LA(1); } - setState(216); - match(TocParser::T__11); + setState(264); + match(TocParser::T__12); + + } + catch (RecognitionException &e) { + _errHandler->reportError(this, e); + _localctx->exception = std::current_exception(); + _errHandler->recover(this, _localctx->exception); + } + + return _localctx; +} + +//----------------- SwitchCaseContext ------------------------------------------------------------------ + +TocParser::SwitchCaseContext::SwitchCaseContext(ParserRuleContext *parent, size_t invokingState) + : ParserRuleContext(parent, invokingState) { +} + +TocParser::ExprContext* TocParser::SwitchCaseContext::expr() { + return getRuleContext(0); +} + +TocParser::BodyContext* TocParser::SwitchCaseContext::body() { + return getRuleContext(0); +} + + +size_t TocParser::SwitchCaseContext::getRuleIndex() const { + return TocParser::RuleSwitchCase; +} + + +TocParser::SwitchCaseContext* TocParser::switchCase() { + SwitchCaseContext *_localctx = _tracker.createInstance(_ctx, getState()); + enterRule(_localctx, 44, TocParser::RuleSwitchCase); + +#if __cplusplus > 201703L + auto onExit = finally([=, this] { +#else + auto onExit = finally([=] { +#endif + exitRule(); + }); + try { + enterOuterAlt(_localctx, 1); + setState(266); + match(TocParser::T__19); + setState(267); + expr(); + setState(268); + body(); } catch (RecognitionException &e) { @@ -1512,21 +1539,10 @@ size_t TocParser::ForStmtContext::getRuleIndex() const { return TocParser::RuleForStmt; } -void TocParser::ForStmtContext::enterRule(tree::ParseTreeListener *listener) { - auto parserListener = dynamic_cast(listener); - if (parserListener != nullptr) - parserListener->enterForStmt(this); -} - -void TocParser::ForStmtContext::exitRule(tree::ParseTreeListener *listener) { - auto parserListener = dynamic_cast(listener); - if (parserListener != nullptr) - parserListener->exitForStmt(this); -} TocParser::ForStmtContext* TocParser::forStmt() { ForStmtContext *_localctx = _tracker.createInstance(_ctx, getState()); - enterRule(_localctx, 38, TocParser::RuleForStmt); + enterRule(_localctx, 46, TocParser::RuleForStmt); #if __cplusplus > 201703L auto onExit = finally([=, this] { @@ -1537,19 +1553,19 @@ TocParser::ForStmtContext* TocParser::forStmt() { }); try { enterOuterAlt(_localctx, 1); - setState(218); - match(TocParser::T__17); - setState(221); + setState(270); + match(TocParser::T__20); + setState(273); _errHandler->sync(this); - switch (getInterpreter()->adaptivePredict(_input, 15, _ctx)) { + switch (getInterpreter()->adaptivePredict(_input, 18, _ctx)) { case 1: { - setState(219); + setState(271); varInit(); break; } case 2: { - setState(220); + setState(272); assignStmt(); break; } @@ -1557,15 +1573,15 @@ TocParser::ForStmtContext* TocParser::forStmt() { default: break; } - setState(223); - match(TocParser::T__9); - setState(224); + setState(275); + match(TocParser::T__10); + setState(276); expr(); - setState(225); - match(TocParser::T__9); - setState(226); + setState(277); + match(TocParser::T__10); + setState(278); expr(); - setState(227); + setState(279); body(); } @@ -1597,21 +1613,10 @@ size_t TocParser::WhileStmtContext::getRuleIndex() const { return TocParser::RuleWhileStmt; } -void TocParser::WhileStmtContext::enterRule(tree::ParseTreeListener *listener) { - auto parserListener = dynamic_cast(listener); - if (parserListener != nullptr) - parserListener->enterWhileStmt(this); -} - -void TocParser::WhileStmtContext::exitRule(tree::ParseTreeListener *listener) { - auto parserListener = dynamic_cast(listener); - if (parserListener != nullptr) - parserListener->exitWhileStmt(this); -} TocParser::WhileStmtContext* TocParser::whileStmt() { WhileStmtContext *_localctx = _tracker.createInstance(_ctx, getState()); - enterRule(_localctx, 40, TocParser::RuleWhileStmt); + enterRule(_localctx, 48, TocParser::RuleWhileStmt); #if __cplusplus > 201703L auto onExit = finally([=, this] { @@ -1622,11 +1627,11 @@ TocParser::WhileStmtContext* TocParser::whileStmt() { }); try { enterOuterAlt(_localctx, 1); - setState(229); - match(TocParser::T__18); - setState(230); + setState(281); + match(TocParser::T__21); + setState(282); expr(); - setState(231); + setState(283); body(); } @@ -1658,21 +1663,10 @@ size_t TocParser::AssignStmtContext::getRuleIndex() const { return TocParser::RuleAssignStmt; } -void TocParser::AssignStmtContext::enterRule(tree::ParseTreeListener *listener) { - auto parserListener = dynamic_cast(listener); - if (parserListener != nullptr) - parserListener->enterAssignStmt(this); -} - -void TocParser::AssignStmtContext::exitRule(tree::ParseTreeListener *listener) { - auto parserListener = dynamic_cast(listener); - if (parserListener != nullptr) - parserListener->exitAssignStmt(this); -} TocParser::AssignStmtContext* TocParser::assignStmt() { AssignStmtContext *_localctx = _tracker.createInstance(_ctx, getState()); - enterRule(_localctx, 42, TocParser::RuleAssignStmt); + enterRule(_localctx, 50, TocParser::RuleAssignStmt); #if __cplusplus > 201703L auto onExit = finally([=, this] { @@ -1683,11 +1677,11 @@ TocParser::AssignStmtContext* TocParser::assignStmt() { }); try { enterOuterAlt(_localctx, 1); - setState(233); + setState(285); identifierExpr(); - setState(234); - match(TocParser::T__2); - setState(235); + setState(286); + match(TocParser::T__3); + setState(287); expr(); } @@ -1715,21 +1709,10 @@ size_t TocParser::ReturnStmtContext::getRuleIndex() const { return TocParser::RuleReturnStmt; } -void TocParser::ReturnStmtContext::enterRule(tree::ParseTreeListener *listener) { - auto parserListener = dynamic_cast(listener); - if (parserListener != nullptr) - parserListener->enterReturnStmt(this); -} - -void TocParser::ReturnStmtContext::exitRule(tree::ParseTreeListener *listener) { - auto parserListener = dynamic_cast(listener); - if (parserListener != nullptr) - parserListener->exitReturnStmt(this); -} TocParser::ReturnStmtContext* TocParser::returnStmt() { ReturnStmtContext *_localctx = _tracker.createInstance(_ctx, getState()); - enterRule(_localctx, 44, TocParser::RuleReturnStmt); + enterRule(_localctx, 52, TocParser::RuleReturnStmt); #if __cplusplus > 201703L auto onExit = finally([=, this] { @@ -1740,9 +1723,9 @@ TocParser::ReturnStmtContext* TocParser::returnStmt() { }); try { enterOuterAlt(_localctx, 1); - setState(237); - match(TocParser::T__19); - setState(238); + setState(289); + match(TocParser::T__22); + setState(290); expr(); } @@ -1790,21 +1773,10 @@ size_t TocParser::ExprContext::getRuleIndex() const { return TocParser::RuleExpr; } -void TocParser::ExprContext::enterRule(tree::ParseTreeListener *listener) { - auto parserListener = dynamic_cast(listener); - if (parserListener != nullptr) - parserListener->enterExpr(this); -} - -void TocParser::ExprContext::exitRule(tree::ParseTreeListener *listener) { - auto parserListener = dynamic_cast(listener); - if (parserListener != nullptr) - parserListener->exitExpr(this); -} TocParser::ExprContext* TocParser::expr() { ExprContext *_localctx = _tracker.createInstance(_ctx, getState()); - enterRule(_localctx, 46, TocParser::RuleExpr); + enterRule(_localctx, 54, TocParser::RuleExpr); #if __cplusplus > 201703L auto onExit = finally([=, this] { @@ -1814,47 +1786,47 @@ TocParser::ExprContext* TocParser::expr() { exitRule(); }); try { - setState(246); + setState(298); _errHandler->sync(this); - switch (getInterpreter()->adaptivePredict(_input, 16, _ctx)) { + switch (getInterpreter()->adaptivePredict(_input, 19, _ctx)) { case 1: { enterOuterAlt(_localctx, 1); - setState(240); + setState(292); funcExpr(); break; } case 2: { enterOuterAlt(_localctx, 2); - setState(241); + setState(293); litExpr(); break; } case 3: { enterOuterAlt(_localctx, 3); - setState(242); + setState(294); identifierExpr(); break; } case 4: { enterOuterAlt(_localctx, 4); - setState(243); + setState(295); parenExpr(); break; } case 5: { enterOuterAlt(_localctx, 5); - setState(244); + setState(296); accessExpr(); break; } case 6: { enterOuterAlt(_localctx, 6); - setState(245); + setState(297); opExpr(); break; } @@ -1904,21 +1876,10 @@ size_t TocParser::NonOpExprContext::getRuleIndex() const { return TocParser::RuleNonOpExpr; } -void TocParser::NonOpExprContext::enterRule(tree::ParseTreeListener *listener) { - auto parserListener = dynamic_cast(listener); - if (parserListener != nullptr) - parserListener->enterNonOpExpr(this); -} - -void TocParser::NonOpExprContext::exitRule(tree::ParseTreeListener *listener) { - auto parserListener = dynamic_cast(listener); - if (parserListener != nullptr) - parserListener->exitNonOpExpr(this); -} TocParser::NonOpExprContext* TocParser::nonOpExpr() { NonOpExprContext *_localctx = _tracker.createInstance(_ctx, getState()); - enterRule(_localctx, 48, TocParser::RuleNonOpExpr); + enterRule(_localctx, 56, TocParser::RuleNonOpExpr); #if __cplusplus > 201703L auto onExit = finally([=, this] { @@ -1928,40 +1889,40 @@ TocParser::NonOpExprContext* TocParser::nonOpExpr() { exitRule(); }); try { - setState(253); + setState(305); _errHandler->sync(this); - switch (getInterpreter()->adaptivePredict(_input, 17, _ctx)) { + switch (getInterpreter()->adaptivePredict(_input, 20, _ctx)) { case 1: { enterOuterAlt(_localctx, 1); - setState(248); + setState(300); funcExpr(); break; } case 2: { enterOuterAlt(_localctx, 2); - setState(249); + setState(301); litExpr(); break; } case 3: { enterOuterAlt(_localctx, 3); - setState(250); + setState(302); identifierExpr(); break; } case 4: { enterOuterAlt(_localctx, 4); - setState(251); + setState(303); parenExpr(); break; } case 5: { enterOuterAlt(_localctx, 5); - setState(252); + setState(304); accessExpr(); break; } @@ -2003,21 +1964,10 @@ size_t TocParser::NonAccessExprContext::getRuleIndex() const { return TocParser::RuleNonAccessExpr; } -void TocParser::NonAccessExprContext::enterRule(tree::ParseTreeListener *listener) { - auto parserListener = dynamic_cast(listener); - if (parserListener != nullptr) - parserListener->enterNonAccessExpr(this); -} - -void TocParser::NonAccessExprContext::exitRule(tree::ParseTreeListener *listener) { - auto parserListener = dynamic_cast(listener); - if (parserListener != nullptr) - parserListener->exitNonAccessExpr(this); -} TocParser::NonAccessExprContext* TocParser::nonAccessExpr() { NonAccessExprContext *_localctx = _tracker.createInstance(_ctx, getState()); - enterRule(_localctx, 50, TocParser::RuleNonAccessExpr); + enterRule(_localctx, 58, TocParser::RuleNonAccessExpr); #if __cplusplus > 201703L auto onExit = finally([=, this] { @@ -2027,26 +1977,26 @@ TocParser::NonAccessExprContext* TocParser::nonAccessExpr() { exitRule(); }); try { - setState(258); + setState(310); _errHandler->sync(this); - switch (getInterpreter()->adaptivePredict(_input, 18, _ctx)) { + switch (getInterpreter()->adaptivePredict(_input, 21, _ctx)) { case 1: { enterOuterAlt(_localctx, 1); - setState(255); + setState(307); funcExpr(); break; } case 2: { enterOuterAlt(_localctx, 2); - setState(256); + setState(308); identifierExpr(); break; } case 3: { enterOuterAlt(_localctx, 3); - setState(257); + setState(309); parenExpr(); break; } @@ -2088,21 +2038,10 @@ size_t TocParser::FuncExprContext::getRuleIndex() const { return TocParser::RuleFuncExpr; } -void TocParser::FuncExprContext::enterRule(tree::ParseTreeListener *listener) { - auto parserListener = dynamic_cast(listener); - if (parserListener != nullptr) - parserListener->enterFuncExpr(this); -} - -void TocParser::FuncExprContext::exitRule(tree::ParseTreeListener *listener) { - auto parserListener = dynamic_cast(listener); - if (parserListener != nullptr) - parserListener->exitFuncExpr(this); -} TocParser::FuncExprContext* TocParser::funcExpr() { FuncExprContext *_localctx = _tracker.createInstance(_ctx, getState()); - enterRule(_localctx, 52, TocParser::RuleFuncExpr); + enterRule(_localctx, 60, TocParser::RuleFuncExpr); size_t _la = 0; #if __cplusplus > 201703L @@ -2114,39 +2053,46 @@ TocParser::FuncExprContext* TocParser::funcExpr() { }); try { enterOuterAlt(_localctx, 1); - setState(260); + setState(312); funcName(); - setState(261); - match(TocParser::T__7); - setState(270); + setState(313); + match(TocParser::T__8); + setState(322); _errHandler->sync(this); _la = _input->LA(1); if ((((_la & ~ 0x3fULL) == 0) && - ((1ULL << _la) & ((1ULL << TocParser::T__7) - | (1ULL << TocParser::PREFIX_OP) + ((1ULL << _la) & ((1ULL << TocParser::T__4) + | (1ULL << TocParser::T__8) + | (1ULL << TocParser::T__26) + | (1ULL << TocParser::T__27) + | (1ULL << TocParser::T__28) + | (1ULL << TocParser::T__29) + | (1ULL << TocParser::T__30) + | (1ULL << TocParser::T__31) + | (1ULL << TocParser::T__32) | (1ULL << TocParser::INT_LIT) | (1ULL << TocParser::DECIMAL_LIT) | (1ULL << TocParser::STRING_LIT) | (1ULL << TocParser::BOOL_LIT) | (1ULL << TocParser::NAME))) != 0)) { - setState(262); + setState(314); expr(); - setState(267); + setState(319); _errHandler->sync(this); _la = _input->LA(1); - while (_la == TocParser::T__9) { - setState(263); - match(TocParser::T__9); - setState(264); + while (_la == TocParser::T__10) { + setState(315); + match(TocParser::T__10); + setState(316); expr(); - setState(269); + setState(321); _errHandler->sync(this); _la = _input->LA(1); } } - setState(272); - match(TocParser::T__8); + setState(324); + match(TocParser::T__9); } catch (RecognitionException &e) { @@ -2185,21 +2131,10 @@ size_t TocParser::OpExprContext::getRuleIndex() const { return TocParser::RuleOpExpr; } -void TocParser::OpExprContext::enterRule(tree::ParseTreeListener *listener) { - auto parserListener = dynamic_cast(listener); - if (parserListener != nullptr) - parserListener->enterOpExpr(this); -} - -void TocParser::OpExprContext::exitRule(tree::ParseTreeListener *listener) { - auto parserListener = dynamic_cast(listener); - if (parserListener != nullptr) - parserListener->exitOpExpr(this); -} TocParser::OpExprContext* TocParser::opExpr() { OpExprContext *_localctx = _tracker.createInstance(_ctx, getState()); - enterRule(_localctx, 54, TocParser::RuleOpExpr); + enterRule(_localctx, 62, TocParser::RuleOpExpr); #if __cplusplus > 201703L auto onExit = finally([=, this] { @@ -2209,33 +2144,33 @@ TocParser::OpExprContext* TocParser::opExpr() { exitRule(); }); try { - setState(278); + setState(330); _errHandler->sync(this); - switch (getInterpreter()->adaptivePredict(_input, 21, _ctx)) { + switch (getInterpreter()->adaptivePredict(_input, 24, _ctx)) { case 1: { enterOuterAlt(_localctx, 1); - setState(274); + setState(326); binaryOp(); break; } case 2: { enterOuterAlt(_localctx, 2); - setState(275); + setState(327); prefixOp(); break; } case 3: { enterOuterAlt(_localctx, 3); - setState(276); + setState(328); postfixOp(); break; } case 4: { enterOuterAlt(_localctx, 4); - setState(277); + setState(329); ternaryOp(); break; } @@ -2268,12 +2203,12 @@ TocParser::NonOpExprContext* TocParser::BinaryOpContext::nonOpExpr(size_t i) { return getRuleContext(i); } -std::vector TocParser::BinaryOpContext::BINARY_OP() { - return getTokens(TocParser::BINARY_OP); +std::vector TocParser::BinaryOpContext::binary_op() { + return getRuleContexts(); } -tree::TerminalNode* TocParser::BinaryOpContext::BINARY_OP(size_t i) { - return getToken(TocParser::BINARY_OP, i); +TocParser::Binary_opContext* TocParser::BinaryOpContext::binary_op(size_t i) { + return getRuleContext(i); } @@ -2281,21 +2216,10 @@ size_t TocParser::BinaryOpContext::getRuleIndex() const { return TocParser::RuleBinaryOp; } -void TocParser::BinaryOpContext::enterRule(tree::ParseTreeListener *listener) { - auto parserListener = dynamic_cast(listener); - if (parserListener != nullptr) - parserListener->enterBinaryOp(this); -} - -void TocParser::BinaryOpContext::exitRule(tree::ParseTreeListener *listener) { - auto parserListener = dynamic_cast(listener); - if (parserListener != nullptr) - parserListener->exitBinaryOp(this); -} TocParser::BinaryOpContext* TocParser::binaryOp() { BinaryOpContext *_localctx = _tracker.createInstance(_ctx, getState()); - enterRule(_localctx, 56, TocParser::RuleBinaryOp); + enterRule(_localctx, 64, TocParser::RuleBinaryOp); size_t _la = 0; #if __cplusplus > 201703L @@ -2307,21 +2231,49 @@ TocParser::BinaryOpContext* TocParser::binaryOp() { }); try { enterOuterAlt(_localctx, 1); - setState(280); + setState(332); nonOpExpr(); - setState(281); - match(TocParser::BINARY_OP); - setState(282); + setState(333); + binary_op(); + setState(334); nonOpExpr(); - setState(287); + setState(340); _errHandler->sync(this); _la = _input->LA(1); - while (_la == TocParser::BINARY_OP) { - setState(283); - match(TocParser::BINARY_OP); - setState(284); + while ((((_la & ~ 0x3fULL) == 0) && + ((1ULL << _la) & ((1ULL << TocParser::T__4) + | (1ULL << TocParser::T__14) + | (1ULL << TocParser::T__15) + | (1ULL << TocParser::T__28) + | (1ULL << TocParser::T__29) + | (1ULL << TocParser::T__32) + | (1ULL << TocParser::T__33) + | (1ULL << TocParser::T__34) + | (1ULL << TocParser::T__35) + | (1ULL << TocParser::T__36) + | (1ULL << TocParser::T__37) + | (1ULL << TocParser::T__38) + | (1ULL << TocParser::T__39) + | (1ULL << TocParser::T__40) + | (1ULL << TocParser::T__41) + | (1ULL << TocParser::T__42) + | (1ULL << TocParser::T__43) + | (1ULL << TocParser::T__44) + | (1ULL << TocParser::T__45) + | (1ULL << TocParser::T__46) + | (1ULL << TocParser::T__47) + | (1ULL << TocParser::T__48) + | (1ULL << TocParser::T__49) + | (1ULL << TocParser::T__50) + | (1ULL << TocParser::T__51) + | (1ULL << TocParser::T__52) + | (1ULL << TocParser::T__53) + | (1ULL << TocParser::T__54))) != 0)) { + setState(335); + binary_op(); + setState(336); nonOpExpr(); - setState(289); + setState(342); _errHandler->sync(this); _la = _input->LA(1); } @@ -2342,8 +2294,8 @@ TocParser::PrefixOpContext::PrefixOpContext(ParserRuleContext *parent, size_t in : ParserRuleContext(parent, invokingState) { } -tree::TerminalNode* TocParser::PrefixOpContext::PREFIX_OP() { - return getToken(TocParser::PREFIX_OP, 0); +TocParser::Prefix_opContext* TocParser::PrefixOpContext::prefix_op() { + return getRuleContext(0); } TocParser::NonOpExprContext* TocParser::PrefixOpContext::nonOpExpr() { @@ -2355,21 +2307,10 @@ size_t TocParser::PrefixOpContext::getRuleIndex() const { return TocParser::RulePrefixOp; } -void TocParser::PrefixOpContext::enterRule(tree::ParseTreeListener *listener) { - auto parserListener = dynamic_cast(listener); - if (parserListener != nullptr) - parserListener->enterPrefixOp(this); -} - -void TocParser::PrefixOpContext::exitRule(tree::ParseTreeListener *listener) { - auto parserListener = dynamic_cast(listener); - if (parserListener != nullptr) - parserListener->exitPrefixOp(this); -} TocParser::PrefixOpContext* TocParser::prefixOp() { PrefixOpContext *_localctx = _tracker.createInstance(_ctx, getState()); - enterRule(_localctx, 58, TocParser::RulePrefixOp); + enterRule(_localctx, 66, TocParser::RulePrefixOp); #if __cplusplus > 201703L auto onExit = finally([=, this] { @@ -2380,9 +2321,9 @@ TocParser::PrefixOpContext* TocParser::prefixOp() { }); try { enterOuterAlt(_localctx, 1); - setState(290); - match(TocParser::PREFIX_OP); - setState(291); + setState(343); + prefix_op(); + setState(344); nonOpExpr(); } @@ -2405,8 +2346,8 @@ TocParser::NonOpExprContext* TocParser::PostfixOpContext::nonOpExpr() { return getRuleContext(0); } -tree::TerminalNode* TocParser::PostfixOpContext::POSTFIX_OP() { - return getToken(TocParser::POSTFIX_OP, 0); +TocParser::Postfix_opContext* TocParser::PostfixOpContext::postfix_op() { + return getRuleContext(0); } @@ -2414,21 +2355,10 @@ size_t TocParser::PostfixOpContext::getRuleIndex() const { return TocParser::RulePostfixOp; } -void TocParser::PostfixOpContext::enterRule(tree::ParseTreeListener *listener) { - auto parserListener = dynamic_cast(listener); - if (parserListener != nullptr) - parserListener->enterPostfixOp(this); -} - -void TocParser::PostfixOpContext::exitRule(tree::ParseTreeListener *listener) { - auto parserListener = dynamic_cast(listener); - if (parserListener != nullptr) - parserListener->exitPostfixOp(this); -} TocParser::PostfixOpContext* TocParser::postfixOp() { PostfixOpContext *_localctx = _tracker.createInstance(_ctx, getState()); - enterRule(_localctx, 60, TocParser::RulePostfixOp); + enterRule(_localctx, 68, TocParser::RulePostfixOp); #if __cplusplus > 201703L auto onExit = finally([=, this] { @@ -2439,10 +2369,10 @@ TocParser::PostfixOpContext* TocParser::postfixOp() { }); try { enterOuterAlt(_localctx, 1); - setState(293); + setState(346); nonOpExpr(); - setState(294); - match(TocParser::POSTFIX_OP); + setState(347); + postfix_op(); } catch (RecognitionException &e) { @@ -2477,21 +2407,10 @@ size_t TocParser::TernaryOpContext::getRuleIndex() const { return TocParser::RuleTernaryOp; } -void TocParser::TernaryOpContext::enterRule(tree::ParseTreeListener *listener) { - auto parserListener = dynamic_cast(listener); - if (parserListener != nullptr) - parserListener->enterTernaryOp(this); -} - -void TocParser::TernaryOpContext::exitRule(tree::ParseTreeListener *listener) { - auto parserListener = dynamic_cast(listener); - if (parserListener != nullptr) - parserListener->exitTernaryOp(this); -} TocParser::TernaryOpContext* TocParser::ternaryOp() { TernaryOpContext *_localctx = _tracker.createInstance(_ctx, getState()); - enterRule(_localctx, 62, TocParser::RuleTernaryOp); + enterRule(_localctx, 70, TocParser::RuleTernaryOp); #if __cplusplus > 201703L auto onExit = finally([=, this] { @@ -2502,15 +2421,15 @@ TocParser::TernaryOpContext* TocParser::ternaryOp() { }); try { enterOuterAlt(_localctx, 1); - setState(296); + setState(349); nonOpExpr(); - setState(297); - match(TocParser::T__20); - setState(298); + setState(350); + match(TocParser::T__23); + setState(351); expr(); - setState(299); - match(TocParser::T__1); - setState(300); + setState(352); + match(TocParser::T__2); + setState(353); expr(); } @@ -2538,21 +2457,10 @@ size_t TocParser::IdentifierExprContext::getRuleIndex() const { return TocParser::RuleIdentifierExpr; } -void TocParser::IdentifierExprContext::enterRule(tree::ParseTreeListener *listener) { - auto parserListener = dynamic_cast(listener); - if (parserListener != nullptr) - parserListener->enterIdentifierExpr(this); -} - -void TocParser::IdentifierExprContext::exitRule(tree::ParseTreeListener *listener) { - auto parserListener = dynamic_cast(listener); - if (parserListener != nullptr) - parserListener->exitIdentifierExpr(this); -} TocParser::IdentifierExprContext* TocParser::identifierExpr() { IdentifierExprContext *_localctx = _tracker.createInstance(_ctx, getState()); - enterRule(_localctx, 64, TocParser::RuleIdentifierExpr); + enterRule(_localctx, 72, TocParser::RuleIdentifierExpr); #if __cplusplus > 201703L auto onExit = finally([=, this] { @@ -2563,7 +2471,7 @@ TocParser::IdentifierExprContext* TocParser::identifierExpr() { }); try { enterOuterAlt(_localctx, 1); - setState(302); + setState(355); varName(); } @@ -2603,21 +2511,10 @@ size_t TocParser::LitExprContext::getRuleIndex() const { return TocParser::RuleLitExpr; } -void TocParser::LitExprContext::enterRule(tree::ParseTreeListener *listener) { - auto parserListener = dynamic_cast(listener); - if (parserListener != nullptr) - parserListener->enterLitExpr(this); -} - -void TocParser::LitExprContext::exitRule(tree::ParseTreeListener *listener) { - auto parserListener = dynamic_cast(listener); - if (parserListener != nullptr) - parserListener->exitLitExpr(this); -} TocParser::LitExprContext* TocParser::litExpr() { LitExprContext *_localctx = _tracker.createInstance(_ctx, getState()); - enterRule(_localctx, 66, TocParser::RuleLitExpr); + enterRule(_localctx, 74, TocParser::RuleLitExpr); size_t _la = 0; #if __cplusplus > 201703L @@ -2629,7 +2526,7 @@ TocParser::LitExprContext* TocParser::litExpr() { }); try { enterOuterAlt(_localctx, 1); - setState(304); + setState(357); _la = _input->LA(1); if (!((((_la & ~ 0x3fULL) == 0) && ((1ULL << _la) & ((1ULL << TocParser::INT_LIT) @@ -2663,20 +2560,12 @@ TocParser::NonAccessExprContext* TocParser::AccessExprContext::nonAccessExpr() { return getRuleContext(0); } -std::vector TocParser::AccessExprContext::identifierExpr() { - return getRuleContexts(); -} - -TocParser::IdentifierExprContext* TocParser::AccessExprContext::identifierExpr(size_t i) { - return getRuleContext(i); -} - -std::vector TocParser::AccessExprContext::expr() { - return getRuleContexts(); +std::vector TocParser::AccessExprContext::accessSubExpr() { + return getRuleContexts(); } -TocParser::ExprContext* TocParser::AccessExprContext::expr(size_t i) { - return getRuleContext(i); +TocParser::AccessSubExprContext* TocParser::AccessExprContext::accessSubExpr(size_t i) { + return getRuleContext(i); } @@ -2684,21 +2573,10 @@ size_t TocParser::AccessExprContext::getRuleIndex() const { return TocParser::RuleAccessExpr; } -void TocParser::AccessExprContext::enterRule(tree::ParseTreeListener *listener) { - auto parserListener = dynamic_cast(listener); - if (parserListener != nullptr) - parserListener->enterAccessExpr(this); -} - -void TocParser::AccessExprContext::exitRule(tree::ParseTreeListener *listener) { - auto parserListener = dynamic_cast(listener); - if (parserListener != nullptr) - parserListener->exitAccessExpr(this); -} TocParser::AccessExprContext* TocParser::accessExpr() { AccessExprContext *_localctx = _tracker.createInstance(_ctx, getState()); - enterRule(_localctx, 68, TocParser::RuleAccessExpr); + enterRule(_localctx, 76, TocParser::RuleAccessExpr); size_t _la = 0; #if __cplusplus > 201703L @@ -2710,53 +2588,21 @@ TocParser::AccessExprContext* TocParser::accessExpr() { }); try { enterOuterAlt(_localctx, 1); - setState(306); + setState(359); nonAccessExpr(); - setState(313); + setState(361); _errHandler->sync(this); _la = _input->LA(1); do { - setState(313); - _errHandler->sync(this); - switch (_input->LA(1)) { - case TocParser::T__21: - case TocParser::T__22: { - setState(307); - _la = _input->LA(1); - if (!(_la == TocParser::T__21 - - || _la == TocParser::T__22)) { - _errHandler->recoverInline(this); - } - else { - _errHandler->reportMatch(this); - consume(); - } - setState(308); - identifierExpr(); - break; - } - - case TocParser::T__4: { - setState(309); - match(TocParser::T__4); - setState(310); - expr(); - setState(311); - match(TocParser::T__5); - break; - } - - default: - throw NoViableAltException(this); - } - setState(315); + setState(360); + accessSubExpr(); + setState(363); _errHandler->sync(this); _la = _input->LA(1); } while ((((_la & ~ 0x3fULL) == 0) && - ((1ULL << _la) & ((1ULL << TocParser::T__4) - | (1ULL << TocParser::T__21) - | (1ULL << TocParser::T__22))) != 0)); + ((1ULL << _la) & ((1ULL << TocParser::T__5) + | (1ULL << TocParser::T__24) + | (1ULL << TocParser::T__25))) != 0)); } catch (RecognitionException &e) { @@ -2768,36 +2614,90 @@ TocParser::AccessExprContext* TocParser::accessExpr() { return _localctx; } -//----------------- ParenExprContext ------------------------------------------------------------------ +//----------------- AccessSubExprContext ------------------------------------------------------------------ -TocParser::ParenExprContext::ParenExprContext(ParserRuleContext *parent, size_t invokingState) +TocParser::AccessSubExprContext::AccessSubExprContext(ParserRuleContext *parent, size_t invokingState) : ParserRuleContext(parent, invokingState) { } -TocParser::ExprContext* TocParser::ParenExprContext::expr() { - return getRuleContext(0); +TocParser::AccessMemberContext* TocParser::AccessSubExprContext::accessMember() { + return getRuleContext(0); } - -size_t TocParser::ParenExprContext::getRuleIndex() const { - return TocParser::RuleParenExpr; +TocParser::AccessBracketsContext* TocParser::AccessSubExprContext::accessBrackets() { + return getRuleContext(0); } -void TocParser::ParenExprContext::enterRule(tree::ParseTreeListener *listener) { - auto parserListener = dynamic_cast(listener); - if (parserListener != nullptr) - parserListener->enterParenExpr(this); -} -void TocParser::ParenExprContext::exitRule(tree::ParseTreeListener *listener) { - auto parserListener = dynamic_cast(listener); - if (parserListener != nullptr) - parserListener->exitParenExpr(this); +size_t TocParser::AccessSubExprContext::getRuleIndex() const { + return TocParser::RuleAccessSubExpr; } -TocParser::ParenExprContext* TocParser::parenExpr() { - ParenExprContext *_localctx = _tracker.createInstance(_ctx, getState()); - enterRule(_localctx, 70, TocParser::RuleParenExpr); + +TocParser::AccessSubExprContext* TocParser::accessSubExpr() { + AccessSubExprContext *_localctx = _tracker.createInstance(_ctx, getState()); + enterRule(_localctx, 78, TocParser::RuleAccessSubExpr); + +#if __cplusplus > 201703L + auto onExit = finally([=, this] { +#else + auto onExit = finally([=] { +#endif + exitRule(); + }); + try { + setState(367); + _errHandler->sync(this); + switch (_input->LA(1)) { + case TocParser::T__24: + case TocParser::T__25: { + enterOuterAlt(_localctx, 1); + setState(365); + accessMember(); + break; + } + + case TocParser::T__5: { + enterOuterAlt(_localctx, 2); + setState(366); + accessBrackets(); + break; + } + + default: + throw NoViableAltException(this); + } + + } + catch (RecognitionException &e) { + _errHandler->reportError(this, e); + _localctx->exception = std::current_exception(); + _errHandler->recover(this, _localctx->exception); + } + + return _localctx; +} + +//----------------- AccessMemberContext ------------------------------------------------------------------ + +TocParser::AccessMemberContext::AccessMemberContext(ParserRuleContext *parent, size_t invokingState) + : ParserRuleContext(parent, invokingState) { +} + +TocParser::IdentifierExprContext* TocParser::AccessMemberContext::identifierExpr() { + return getRuleContext(0); +} + + +size_t TocParser::AccessMemberContext::getRuleIndex() const { + return TocParser::RuleAccessMember; +} + + +TocParser::AccessMemberContext* TocParser::accessMember() { + AccessMemberContext *_localctx = _tracker.createInstance(_ctx, getState()); + enterRule(_localctx, 80, TocParser::RuleAccessMember); + size_t _la = 0; #if __cplusplus > 201703L auto onExit = finally([=, this] { @@ -2808,12 +2708,111 @@ TocParser::ParenExprContext* TocParser::parenExpr() { }); try { enterOuterAlt(_localctx, 1); - setState(317); - match(TocParser::T__7); - setState(318); + setState(369); + _la = _input->LA(1); + if (!(_la == TocParser::T__24 + + || _la == TocParser::T__25)) { + _errHandler->recoverInline(this); + } + else { + _errHandler->reportMatch(this); + consume(); + } + setState(370); + identifierExpr(); + + } + catch (RecognitionException &e) { + _errHandler->reportError(this, e); + _localctx->exception = std::current_exception(); + _errHandler->recover(this, _localctx->exception); + } + + return _localctx; +} + +//----------------- AccessBracketsContext ------------------------------------------------------------------ + +TocParser::AccessBracketsContext::AccessBracketsContext(ParserRuleContext *parent, size_t invokingState) + : ParserRuleContext(parent, invokingState) { +} + +TocParser::ExprContext* TocParser::AccessBracketsContext::expr() { + return getRuleContext(0); +} + + +size_t TocParser::AccessBracketsContext::getRuleIndex() const { + return TocParser::RuleAccessBrackets; +} + + +TocParser::AccessBracketsContext* TocParser::accessBrackets() { + AccessBracketsContext *_localctx = _tracker.createInstance(_ctx, getState()); + enterRule(_localctx, 82, TocParser::RuleAccessBrackets); + +#if __cplusplus > 201703L + auto onExit = finally([=, this] { +#else + auto onExit = finally([=] { +#endif + exitRule(); + }); + try { + enterOuterAlt(_localctx, 1); + setState(372); + match(TocParser::T__5); + setState(373); expr(); - setState(319); + setState(374); + match(TocParser::T__6); + + } + catch (RecognitionException &e) { + _errHandler->reportError(this, e); + _localctx->exception = std::current_exception(); + _errHandler->recover(this, _localctx->exception); + } + + return _localctx; +} + +//----------------- ParenExprContext ------------------------------------------------------------------ + +TocParser::ParenExprContext::ParenExprContext(ParserRuleContext *parent, size_t invokingState) + : ParserRuleContext(parent, invokingState) { +} + +TocParser::ExprContext* TocParser::ParenExprContext::expr() { + return getRuleContext(0); +} + + +size_t TocParser::ParenExprContext::getRuleIndex() const { + return TocParser::RuleParenExpr; +} + + +TocParser::ParenExprContext* TocParser::parenExpr() { + ParenExprContext *_localctx = _tracker.createInstance(_ctx, getState()); + enterRule(_localctx, 84, TocParser::RuleParenExpr); + +#if __cplusplus > 201703L + auto onExit = finally([=, this] { +#else + auto onExit = finally([=] { +#endif + exitRule(); + }); + try { + enterOuterAlt(_localctx, 1); + setState(376); match(TocParser::T__8); + setState(377); + expr(); + setState(378); + match(TocParser::T__9); } catch (RecognitionException &e) { @@ -2840,21 +2839,10 @@ size_t TocParser::FuncNameContext::getRuleIndex() const { return TocParser::RuleFuncName; } -void TocParser::FuncNameContext::enterRule(tree::ParseTreeListener *listener) { - auto parserListener = dynamic_cast(listener); - if (parserListener != nullptr) - parserListener->enterFuncName(this); -} - -void TocParser::FuncNameContext::exitRule(tree::ParseTreeListener *listener) { - auto parserListener = dynamic_cast(listener); - if (parserListener != nullptr) - parserListener->exitFuncName(this); -} TocParser::FuncNameContext* TocParser::funcName() { FuncNameContext *_localctx = _tracker.createInstance(_ctx, getState()); - enterRule(_localctx, 72, TocParser::RuleFuncName); + enterRule(_localctx, 86, TocParser::RuleFuncName); #if __cplusplus > 201703L auto onExit = finally([=, this] { @@ -2865,7 +2853,7 @@ TocParser::FuncNameContext* TocParser::funcName() { }); try { enterOuterAlt(_localctx, 1); - setState(321); + setState(380); match(TocParser::NAME); } @@ -2893,21 +2881,10 @@ size_t TocParser::VarNameContext::getRuleIndex() const { return TocParser::RuleVarName; } -void TocParser::VarNameContext::enterRule(tree::ParseTreeListener *listener) { - auto parserListener = dynamic_cast(listener); - if (parserListener != nullptr) - parserListener->enterVarName(this); -} - -void TocParser::VarNameContext::exitRule(tree::ParseTreeListener *listener) { - auto parserListener = dynamic_cast(listener); - if (parserListener != nullptr) - parserListener->exitVarName(this); -} TocParser::VarNameContext* TocParser::varName() { VarNameContext *_localctx = _tracker.createInstance(_ctx, getState()); - enterRule(_localctx, 74, TocParser::RuleVarName); + enterRule(_localctx, 88, TocParser::RuleVarName); #if __cplusplus > 201703L auto onExit = finally([=, this] { @@ -2918,7 +2895,7 @@ TocParser::VarNameContext* TocParser::varName() { }); try { enterOuterAlt(_localctx, 1); - setState(323); + setState(382); match(TocParser::NAME); } @@ -2946,21 +2923,10 @@ size_t TocParser::TypeNameContext::getRuleIndex() const { return TocParser::RuleTypeName; } -void TocParser::TypeNameContext::enterRule(tree::ParseTreeListener *listener) { - auto parserListener = dynamic_cast(listener); - if (parserListener != nullptr) - parserListener->enterTypeName(this); -} - -void TocParser::TypeNameContext::exitRule(tree::ParseTreeListener *listener) { - auto parserListener = dynamic_cast(listener); - if (parserListener != nullptr) - parserListener->exitTypeName(this); -} TocParser::TypeNameContext* TocParser::typeName() { TypeNameContext *_localctx = _tracker.createInstance(_ctx, getState()); - enterRule(_localctx, 76, TocParser::RuleTypeName); + enterRule(_localctx, 90, TocParser::RuleTypeName); #if __cplusplus > 201703L auto onExit = finally([=, this] { @@ -2971,7 +2937,7 @@ TocParser::TypeNameContext* TocParser::typeName() { }); try { enterOuterAlt(_localctx, 1); - setState(325); + setState(384); match(TocParser::NAME); } @@ -2999,21 +2965,10 @@ size_t TocParser::StructNameContext::getRuleIndex() const { return TocParser::RuleStructName; } -void TocParser::StructNameContext::enterRule(tree::ParseTreeListener *listener) { - auto parserListener = dynamic_cast(listener); - if (parserListener != nullptr) - parserListener->enterStructName(this); -} - -void TocParser::StructNameContext::exitRule(tree::ParseTreeListener *listener) { - auto parserListener = dynamic_cast(listener); - if (parserListener != nullptr) - parserListener->exitStructName(this); -} TocParser::StructNameContext* TocParser::structName() { StructNameContext *_localctx = _tracker.createInstance(_ctx, getState()); - enterRule(_localctx, 78, TocParser::RuleStructName); + enterRule(_localctx, 92, TocParser::RuleStructName); #if __cplusplus > 201703L auto onExit = finally([=, this] { @@ -3024,7 +2979,7 @@ TocParser::StructNameContext* TocParser::structName() { }); try { enterOuterAlt(_localctx, 1); - setState(327); + setState(386); match(TocParser::NAME); } @@ -3037,6 +2992,223 @@ TocParser::StructNameContext* TocParser::structName() { return _localctx; } +//----------------- Postfix_opContext ------------------------------------------------------------------ + +TocParser::Postfix_opContext::Postfix_opContext(ParserRuleContext *parent, size_t invokingState) + : ParserRuleContext(parent, invokingState) { +} + + +size_t TocParser::Postfix_opContext::getRuleIndex() const { + return TocParser::RulePostfix_op; +} + + +TocParser::Postfix_opContext* TocParser::postfix_op() { + Postfix_opContext *_localctx = _tracker.createInstance(_ctx, getState()); + enterRule(_localctx, 94, TocParser::RulePostfix_op); + size_t _la = 0; + +#if __cplusplus > 201703L + auto onExit = finally([=, this] { +#else + auto onExit = finally([=] { +#endif + exitRule(); + }); + try { + enterOuterAlt(_localctx, 1); + setState(388); + _la = _input->LA(1); + if (!(_la == TocParser::T__26 + + || _la == TocParser::T__27)) { + _errHandler->recoverInline(this); + } + else { + _errHandler->reportMatch(this); + consume(); + } + + } + catch (RecognitionException &e) { + _errHandler->reportError(this, e); + _localctx->exception = std::current_exception(); + _errHandler->recover(this, _localctx->exception); + } + + return _localctx; +} + +//----------------- Prefix_opContext ------------------------------------------------------------------ + +TocParser::Prefix_opContext::Prefix_opContext(ParserRuleContext *parent, size_t invokingState) + : ParserRuleContext(parent, invokingState) { +} + +TocParser::Postfix_opContext* TocParser::Prefix_opContext::postfix_op() { + return getRuleContext(0); +} + + +size_t TocParser::Prefix_opContext::getRuleIndex() const { + return TocParser::RulePrefix_op; +} + + +TocParser::Prefix_opContext* TocParser::prefix_op() { + Prefix_opContext *_localctx = _tracker.createInstance(_ctx, getState()); + enterRule(_localctx, 96, TocParser::RulePrefix_op); + +#if __cplusplus > 201703L + auto onExit = finally([=, this] { +#else + auto onExit = finally([=] { +#endif + exitRule(); + }); + try { + setState(397); + _errHandler->sync(this); + switch (_input->LA(1)) { + case TocParser::T__28: { + enterOuterAlt(_localctx, 1); + setState(390); + match(TocParser::T__28); + break; + } + + case TocParser::T__29: { + enterOuterAlt(_localctx, 2); + setState(391); + match(TocParser::T__29); + break; + } + + case TocParser::T__30: { + enterOuterAlt(_localctx, 3); + setState(392); + match(TocParser::T__30); + break; + } + + case TocParser::T__31: { + enterOuterAlt(_localctx, 4); + setState(393); + match(TocParser::T__31); + break; + } + + case TocParser::T__32: { + enterOuterAlt(_localctx, 5); + setState(394); + match(TocParser::T__32); + break; + } + + case TocParser::T__4: { + enterOuterAlt(_localctx, 6); + setState(395); + match(TocParser::T__4); + break; + } + + case TocParser::T__26: + case TocParser::T__27: { + enterOuterAlt(_localctx, 7); + setState(396); + postfix_op(); + break; + } + + default: + throw NoViableAltException(this); + } + + } + catch (RecognitionException &e) { + _errHandler->reportError(this, e); + _localctx->exception = std::current_exception(); + _errHandler->recover(this, _localctx->exception); + } + + return _localctx; +} + +//----------------- Binary_opContext ------------------------------------------------------------------ + +TocParser::Binary_opContext::Binary_opContext(ParserRuleContext *parent, size_t invokingState) + : ParserRuleContext(parent, invokingState) { +} + + +size_t TocParser::Binary_opContext::getRuleIndex() const { + return TocParser::RuleBinary_op; +} + + +TocParser::Binary_opContext* TocParser::binary_op() { + Binary_opContext *_localctx = _tracker.createInstance(_ctx, getState()); + enterRule(_localctx, 98, TocParser::RuleBinary_op); + size_t _la = 0; + +#if __cplusplus > 201703L + auto onExit = finally([=, this] { +#else + auto onExit = finally([=] { +#endif + exitRule(); + }); + try { + enterOuterAlt(_localctx, 1); + setState(399); + _la = _input->LA(1); + if (!((((_la & ~ 0x3fULL) == 0) && + ((1ULL << _la) & ((1ULL << TocParser::T__4) + | (1ULL << TocParser::T__14) + | (1ULL << TocParser::T__15) + | (1ULL << TocParser::T__28) + | (1ULL << TocParser::T__29) + | (1ULL << TocParser::T__32) + | (1ULL << TocParser::T__33) + | (1ULL << TocParser::T__34) + | (1ULL << TocParser::T__35) + | (1ULL << TocParser::T__36) + | (1ULL << TocParser::T__37) + | (1ULL << TocParser::T__38) + | (1ULL << TocParser::T__39) + | (1ULL << TocParser::T__40) + | (1ULL << TocParser::T__41) + | (1ULL << TocParser::T__42) + | (1ULL << TocParser::T__43) + | (1ULL << TocParser::T__44) + | (1ULL << TocParser::T__45) + | (1ULL << TocParser::T__46) + | (1ULL << TocParser::T__47) + | (1ULL << TocParser::T__48) + | (1ULL << TocParser::T__49) + | (1ULL << TocParser::T__50) + | (1ULL << TocParser::T__51) + | (1ULL << TocParser::T__52) + | (1ULL << TocParser::T__53) + | (1ULL << TocParser::T__54))) != 0))) { + _errHandler->recoverInline(this); + } + else { + _errHandler->reportMatch(this); + consume(); + } + + } + catch (RecognitionException &e) { + _errHandler->reportError(this, e); + _localctx->exception = std::current_exception(); + _errHandler->recover(this, _localctx->exception); + } + + return _localctx; +} + // Static vars and initialization. std::vector TocParser::_decisionToDFA; atn::PredictionContextCache TocParser::_sharedContextCache; @@ -3048,23 +3220,31 @@ std::vector TocParser::_serializedATN; std::vector TocParser::_ruleNames = { "prog", "decl", "varDecl", "var", "varInit", "type", "typeModifier", "funcDecl", "func", "parameter", "body", "structDecl", "structMember", "structVar", - "structMethod", "stmt", "ifStmt", "switchStmt", "switchBody", "forStmt", - "whileStmt", "assignStmt", "returnStmt", "expr", "nonOpExpr", "nonAccessExpr", - "funcExpr", "opExpr", "binaryOp", "prefixOp", "postfixOp", "ternaryOp", - "identifierExpr", "litExpr", "accessExpr", "parenExpr", "funcName", "varName", - "typeName", "structName" + "structMethod", "genericDecl", "stmt", "ifStmt", "elseIfStmt", "elseStmt", + "switchStmt", "switchBody", "switchCase", "forStmt", "whileStmt", "assignStmt", + "returnStmt", "expr", "nonOpExpr", "nonAccessExpr", "funcExpr", "opExpr", + "binaryOp", "prefixOp", "postfixOp", "ternaryOp", "identifierExpr", "litExpr", + "accessExpr", "accessSubExpr", "accessMember", "accessBrackets", "parenExpr", + "funcName", "varName", "typeName", "structName", "postfix_op", "prefix_op", + "binary_op" }; std::vector TocParser::_literalNames = { - "", "'var'", "':'", "'='", "'*'", "'['", "']'", "'func'", "'('", "')'", - "','", "'{'", "'}'", "'struct'", "'if'", "'else'", "'switch'", "'case'", - "'for'", "'while'", "'return'", "'\u003F'", "'.'", "'->'" + "", "';'", "'var'", "':'", "'='", "'*'", "'['", "']'", "'func'", "'('", + "')'", "','", "'{'", "'}'", "'struct'", "'<'", "'>'", "'if'", "'else'", + "'switch'", "'case'", "'for'", "'while'", "'return'", "'\u003F'", "'.'", + "'->'", "'++'", "'--'", "'+'", "'-'", "'!'", "'~'", "'&'", "'/'", "'%'", + "'|'", "'^'", "'=='", "'!='", "'<='", "'>='", "'<<'", "'>>'", "'||'", + "'&&'", "'&='", "'|='", "'^='", "'<<='", "'>>='", "'+='", "'-='", "'*='", + "'/='", "'%='" }; std::vector TocParser::_symbolicNames = { "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", - "", "", "", "", "", "", "POSTFIX_OP", "PREFIX_OP", "BINARY_OP", "INT_LIT", - "DECIMAL_LIT", "STRING_LIT", "BOOL_LIT", "NAME", "WS", "NEWLINE", "NUMBER" + "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", + "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", + "", "", "INT_LIT", "DECIMAL_LIT", "STRING_LIT", "BOOL_LIT", "NAME", "WS", + "NEWLINE" }; dfa::Vocabulary TocParser::_vocabulary(_literalNames, _symbolicNames); @@ -3087,7 +3267,7 @@ TocParser::Initializer::Initializer() { static const uint16_t serializedATNSegment0[] = { 0x3, 0x608b, 0xa72a, 0x8133, 0xb9ed, 0x417c, 0x3be7, 0x7786, 0x5964, - 0x3, 0x24, 0x14c, 0x4, 0x2, 0x9, 0x2, 0x4, 0x3, 0x9, 0x3, 0x4, 0x4, + 0x3, 0x40, 0x194, 0x4, 0x2, 0x9, 0x2, 0x4, 0x3, 0x9, 0x3, 0x4, 0x4, 0x9, 0x4, 0x4, 0x5, 0x9, 0x5, 0x4, 0x6, 0x9, 0x6, 0x4, 0x7, 0x9, 0x7, 0x4, 0x8, 0x9, 0x8, 0x4, 0x9, 0x9, 0x9, 0x4, 0xa, 0x9, 0xa, 0x4, 0xb, 0x9, 0xb, 0x4, 0xc, 0x9, 0xc, 0x4, 0xd, 0x9, 0xd, 0x4, @@ -3100,218 +3280,270 @@ TocParser::Initializer::Initializer() { 0x9, 0x20, 0x4, 0x21, 0x9, 0x21, 0x4, 0x22, 0x9, 0x22, 0x4, 0x23, 0x9, 0x23, 0x4, 0x24, 0x9, 0x24, 0x4, 0x25, 0x9, 0x25, 0x4, 0x26, 0x9, 0x26, 0x4, 0x27, 0x9, 0x27, 0x4, 0x28, 0x9, 0x28, 0x4, 0x29, - 0x9, 0x29, 0x3, 0x2, 0x6, 0x2, 0x54, 0xa, 0x2, 0xd, 0x2, 0xe, 0x2, - 0x55, 0x3, 0x2, 0x3, 0x2, 0x3, 0x3, 0x3, 0x3, 0x3, 0x3, 0x5, 0x3, - 0x5d, 0xa, 0x3, 0x3, 0x4, 0x3, 0x4, 0x3, 0x4, 0x3, 0x5, 0x3, 0x5, - 0x3, 0x5, 0x3, 0x5, 0x3, 0x5, 0x3, 0x5, 0x5, 0x5, 0x68, 0xa, 0x5, - 0x3, 0x6, 0x3, 0x6, 0x3, 0x6, 0x3, 0x6, 0x3, 0x6, 0x3, 0x6, 0x3, - 0x6, 0x3, 0x7, 0x3, 0x7, 0x7, 0x7, 0x73, 0xa, 0x7, 0xc, 0x7, 0xe, - 0x7, 0x76, 0xb, 0x7, 0x3, 0x8, 0x3, 0x8, 0x3, 0x8, 0x5, 0x8, 0x7b, - 0xa, 0x8, 0x3, 0x8, 0x5, 0x8, 0x7e, 0xa, 0x8, 0x3, 0x9, 0x3, 0x9, - 0x3, 0x9, 0x3, 0xa, 0x3, 0xa, 0x3, 0xa, 0x3, 0xa, 0x3, 0xa, 0x3, - 0xa, 0x3, 0xa, 0x3, 0xa, 0x3, 0xa, 0x3, 0xb, 0x3, 0xb, 0x3, 0xb, - 0x7, 0xb, 0x8f, 0xa, 0xb, 0xc, 0xb, 0xe, 0xb, 0x92, 0xb, 0xb, 0x5, - 0xb, 0x94, 0xa, 0xb, 0x3, 0xc, 0x3, 0xc, 0x7, 0xc, 0x98, 0xa, 0xc, - 0xc, 0xc, 0xe, 0xc, 0x9b, 0xb, 0xc, 0x3, 0xc, 0x3, 0xc, 0x3, 0xd, - 0x3, 0xd, 0x3, 0xd, 0x3, 0xd, 0x7, 0xd, 0xa3, 0xa, 0xd, 0xc, 0xd, - 0xe, 0xd, 0xa6, 0xb, 0xd, 0x3, 0xd, 0x3, 0xd, 0x3, 0xe, 0x3, 0xe, - 0x5, 0xe, 0xac, 0xa, 0xe, 0x3, 0xf, 0x3, 0xf, 0x3, 0x10, 0x3, 0x10, - 0x3, 0x11, 0x3, 0x11, 0x3, 0x11, 0x3, 0x11, 0x3, 0x11, 0x3, 0x11, - 0x3, 0x11, 0x3, 0x11, 0x5, 0x11, 0xba, 0xa, 0x11, 0x3, 0x12, 0x3, - 0x12, 0x3, 0x12, 0x3, 0x12, 0x3, 0x12, 0x3, 0x12, 0x3, 0x12, 0x3, - 0x12, 0x7, 0x12, 0xc4, 0xa, 0x12, 0xc, 0x12, 0xe, 0x12, 0xc7, 0xb, - 0x12, 0x3, 0x12, 0x3, 0x12, 0x5, 0x12, 0xcb, 0xa, 0x12, 0x3, 0x13, - 0x3, 0x13, 0x3, 0x13, 0x3, 0x13, 0x3, 0x14, 0x3, 0x14, 0x3, 0x14, - 0x3, 0x14, 0x3, 0x14, 0x7, 0x14, 0xd6, 0xa, 0x14, 0xc, 0x14, 0xe, - 0x14, 0xd9, 0xb, 0x14, 0x3, 0x14, 0x3, 0x14, 0x3, 0x15, 0x3, 0x15, - 0x3, 0x15, 0x5, 0x15, 0xe0, 0xa, 0x15, 0x3, 0x15, 0x3, 0x15, 0x3, - 0x15, 0x3, 0x15, 0x3, 0x15, 0x3, 0x15, 0x3, 0x16, 0x3, 0x16, 0x3, - 0x16, 0x3, 0x16, 0x3, 0x17, 0x3, 0x17, 0x3, 0x17, 0x3, 0x17, 0x3, - 0x18, 0x3, 0x18, 0x3, 0x18, 0x3, 0x19, 0x3, 0x19, 0x3, 0x19, 0x3, - 0x19, 0x3, 0x19, 0x3, 0x19, 0x5, 0x19, 0xf9, 0xa, 0x19, 0x3, 0x1a, - 0x3, 0x1a, 0x3, 0x1a, 0x3, 0x1a, 0x3, 0x1a, 0x5, 0x1a, 0x100, 0xa, - 0x1a, 0x3, 0x1b, 0x3, 0x1b, 0x3, 0x1b, 0x5, 0x1b, 0x105, 0xa, 0x1b, - 0x3, 0x1c, 0x3, 0x1c, 0x3, 0x1c, 0x3, 0x1c, 0x3, 0x1c, 0x7, 0x1c, - 0x10c, 0xa, 0x1c, 0xc, 0x1c, 0xe, 0x1c, 0x10f, 0xb, 0x1c, 0x5, 0x1c, - 0x111, 0xa, 0x1c, 0x3, 0x1c, 0x3, 0x1c, 0x3, 0x1d, 0x3, 0x1d, 0x3, - 0x1d, 0x3, 0x1d, 0x5, 0x1d, 0x119, 0xa, 0x1d, 0x3, 0x1e, 0x3, 0x1e, - 0x3, 0x1e, 0x3, 0x1e, 0x3, 0x1e, 0x7, 0x1e, 0x120, 0xa, 0x1e, 0xc, - 0x1e, 0xe, 0x1e, 0x123, 0xb, 0x1e, 0x3, 0x1f, 0x3, 0x1f, 0x3, 0x1f, - 0x3, 0x20, 0x3, 0x20, 0x3, 0x20, 0x3, 0x21, 0x3, 0x21, 0x3, 0x21, - 0x3, 0x21, 0x3, 0x21, 0x3, 0x21, 0x3, 0x22, 0x3, 0x22, 0x3, 0x23, - 0x3, 0x23, 0x3, 0x24, 0x3, 0x24, 0x3, 0x24, 0x3, 0x24, 0x3, 0x24, - 0x3, 0x24, 0x3, 0x24, 0x6, 0x24, 0x13c, 0xa, 0x24, 0xd, 0x24, 0xe, - 0x24, 0x13d, 0x3, 0x25, 0x3, 0x25, 0x3, 0x25, 0x3, 0x25, 0x3, 0x26, - 0x3, 0x26, 0x3, 0x27, 0x3, 0x27, 0x3, 0x28, 0x3, 0x28, 0x3, 0x29, - 0x3, 0x29, 0x3, 0x29, 0x2, 0x2, 0x2a, 0x2, 0x4, 0x6, 0x8, 0xa, 0xc, - 0xe, 0x10, 0x12, 0x14, 0x16, 0x18, 0x1a, 0x1c, 0x1e, 0x20, 0x22, - 0x24, 0x26, 0x28, 0x2a, 0x2c, 0x2e, 0x30, 0x32, 0x34, 0x36, 0x38, - 0x3a, 0x3c, 0x3e, 0x40, 0x42, 0x44, 0x46, 0x48, 0x4a, 0x4c, 0x4e, - 0x50, 0x2, 0x4, 0x3, 0x2, 0x1d, 0x20, 0x3, 0x2, 0x18, 0x19, 0x2, - 0x14d, 0x2, 0x53, 0x3, 0x2, 0x2, 0x2, 0x4, 0x5c, 0x3, 0x2, 0x2, 0x2, - 0x6, 0x5e, 0x3, 0x2, 0x2, 0x2, 0x8, 0x61, 0x3, 0x2, 0x2, 0x2, 0xa, - 0x69, 0x3, 0x2, 0x2, 0x2, 0xc, 0x70, 0x3, 0x2, 0x2, 0x2, 0xe, 0x7d, - 0x3, 0x2, 0x2, 0x2, 0x10, 0x7f, 0x3, 0x2, 0x2, 0x2, 0x12, 0x82, 0x3, - 0x2, 0x2, 0x2, 0x14, 0x93, 0x3, 0x2, 0x2, 0x2, 0x16, 0x95, 0x3, 0x2, - 0x2, 0x2, 0x18, 0x9e, 0x3, 0x2, 0x2, 0x2, 0x1a, 0xab, 0x3, 0x2, 0x2, - 0x2, 0x1c, 0xad, 0x3, 0x2, 0x2, 0x2, 0x1e, 0xaf, 0x3, 0x2, 0x2, 0x2, - 0x20, 0xb9, 0x3, 0x2, 0x2, 0x2, 0x22, 0xbb, 0x3, 0x2, 0x2, 0x2, 0x24, - 0xcc, 0x3, 0x2, 0x2, 0x2, 0x26, 0xd0, 0x3, 0x2, 0x2, 0x2, 0x28, 0xdc, - 0x3, 0x2, 0x2, 0x2, 0x2a, 0xe7, 0x3, 0x2, 0x2, 0x2, 0x2c, 0xeb, 0x3, - 0x2, 0x2, 0x2, 0x2e, 0xef, 0x3, 0x2, 0x2, 0x2, 0x30, 0xf8, 0x3, 0x2, - 0x2, 0x2, 0x32, 0xff, 0x3, 0x2, 0x2, 0x2, 0x34, 0x104, 0x3, 0x2, - 0x2, 0x2, 0x36, 0x106, 0x3, 0x2, 0x2, 0x2, 0x38, 0x118, 0x3, 0x2, - 0x2, 0x2, 0x3a, 0x11a, 0x3, 0x2, 0x2, 0x2, 0x3c, 0x124, 0x3, 0x2, - 0x2, 0x2, 0x3e, 0x127, 0x3, 0x2, 0x2, 0x2, 0x40, 0x12a, 0x3, 0x2, - 0x2, 0x2, 0x42, 0x130, 0x3, 0x2, 0x2, 0x2, 0x44, 0x132, 0x3, 0x2, - 0x2, 0x2, 0x46, 0x134, 0x3, 0x2, 0x2, 0x2, 0x48, 0x13f, 0x3, 0x2, - 0x2, 0x2, 0x4a, 0x143, 0x3, 0x2, 0x2, 0x2, 0x4c, 0x145, 0x3, 0x2, - 0x2, 0x2, 0x4e, 0x147, 0x3, 0x2, 0x2, 0x2, 0x50, 0x149, 0x3, 0x2, - 0x2, 0x2, 0x52, 0x54, 0x5, 0x4, 0x3, 0x2, 0x53, 0x52, 0x3, 0x2, 0x2, - 0x2, 0x54, 0x55, 0x3, 0x2, 0x2, 0x2, 0x55, 0x53, 0x3, 0x2, 0x2, 0x2, - 0x55, 0x56, 0x3, 0x2, 0x2, 0x2, 0x56, 0x57, 0x3, 0x2, 0x2, 0x2, 0x57, - 0x58, 0x7, 0x2, 0x2, 0x3, 0x58, 0x3, 0x3, 0x2, 0x2, 0x2, 0x59, 0x5d, - 0x5, 0x6, 0x4, 0x2, 0x5a, 0x5d, 0x5, 0x10, 0x9, 0x2, 0x5b, 0x5d, - 0x5, 0x18, 0xd, 0x2, 0x5c, 0x59, 0x3, 0x2, 0x2, 0x2, 0x5c, 0x5a, - 0x3, 0x2, 0x2, 0x2, 0x5c, 0x5b, 0x3, 0x2, 0x2, 0x2, 0x5d, 0x5, 0x3, - 0x2, 0x2, 0x2, 0x5e, 0x5f, 0x7, 0x3, 0x2, 0x2, 0x5f, 0x60, 0x5, 0x8, - 0x5, 0x2, 0x60, 0x7, 0x3, 0x2, 0x2, 0x2, 0x61, 0x62, 0x5, 0x4c, 0x27, - 0x2, 0x62, 0x63, 0x7, 0x4, 0x2, 0x2, 0x63, 0x64, 0x5, 0xc, 0x7, 0x2, - 0x64, 0x67, 0x3, 0x2, 0x2, 0x2, 0x65, 0x66, 0x7, 0x5, 0x2, 0x2, 0x66, - 0x68, 0x5, 0x30, 0x19, 0x2, 0x67, 0x65, 0x3, 0x2, 0x2, 0x2, 0x67, - 0x68, 0x3, 0x2, 0x2, 0x2, 0x68, 0x9, 0x3, 0x2, 0x2, 0x2, 0x69, 0x6a, - 0x5, 0x4c, 0x27, 0x2, 0x6a, 0x6b, 0x7, 0x4, 0x2, 0x2, 0x6b, 0x6c, - 0x5, 0xc, 0x7, 0x2, 0x6c, 0x6d, 0x3, 0x2, 0x2, 0x2, 0x6d, 0x6e, 0x7, - 0x5, 0x2, 0x2, 0x6e, 0x6f, 0x5, 0x30, 0x19, 0x2, 0x6f, 0xb, 0x3, - 0x2, 0x2, 0x2, 0x70, 0x74, 0x5, 0x4e, 0x28, 0x2, 0x71, 0x73, 0x5, - 0xe, 0x8, 0x2, 0x72, 0x71, 0x3, 0x2, 0x2, 0x2, 0x73, 0x76, 0x3, 0x2, - 0x2, 0x2, 0x74, 0x72, 0x3, 0x2, 0x2, 0x2, 0x74, 0x75, 0x3, 0x2, 0x2, - 0x2, 0x75, 0xd, 0x3, 0x2, 0x2, 0x2, 0x76, 0x74, 0x3, 0x2, 0x2, 0x2, - 0x77, 0x7e, 0x7, 0x6, 0x2, 0x2, 0x78, 0x7a, 0x7, 0x7, 0x2, 0x2, 0x79, - 0x7b, 0x7, 0x24, 0x2, 0x2, 0x7a, 0x79, 0x3, 0x2, 0x2, 0x2, 0x7a, - 0x7b, 0x3, 0x2, 0x2, 0x2, 0x7b, 0x7c, 0x3, 0x2, 0x2, 0x2, 0x7c, 0x7e, - 0x7, 0x8, 0x2, 0x2, 0x7d, 0x77, 0x3, 0x2, 0x2, 0x2, 0x7d, 0x78, 0x3, - 0x2, 0x2, 0x2, 0x7e, 0xf, 0x3, 0x2, 0x2, 0x2, 0x7f, 0x80, 0x7, 0x9, - 0x2, 0x2, 0x80, 0x81, 0x5, 0x12, 0xa, 0x2, 0x81, 0x11, 0x3, 0x2, - 0x2, 0x2, 0x82, 0x83, 0x5, 0x4a, 0x26, 0x2, 0x83, 0x84, 0x7, 0xa, - 0x2, 0x2, 0x84, 0x85, 0x5, 0x14, 0xb, 0x2, 0x85, 0x86, 0x7, 0xb, - 0x2, 0x2, 0x86, 0x87, 0x7, 0x4, 0x2, 0x2, 0x87, 0x88, 0x5, 0xc, 0x7, - 0x2, 0x88, 0x89, 0x3, 0x2, 0x2, 0x2, 0x89, 0x8a, 0x5, 0x16, 0xc, - 0x2, 0x8a, 0x13, 0x3, 0x2, 0x2, 0x2, 0x8b, 0x90, 0x5, 0x8, 0x5, 0x2, - 0x8c, 0x8d, 0x7, 0xc, 0x2, 0x2, 0x8d, 0x8f, 0x5, 0x8, 0x5, 0x2, 0x8e, - 0x8c, 0x3, 0x2, 0x2, 0x2, 0x8f, 0x92, 0x3, 0x2, 0x2, 0x2, 0x90, 0x8e, - 0x3, 0x2, 0x2, 0x2, 0x90, 0x91, 0x3, 0x2, 0x2, 0x2, 0x91, 0x94, 0x3, - 0x2, 0x2, 0x2, 0x92, 0x90, 0x3, 0x2, 0x2, 0x2, 0x93, 0x8b, 0x3, 0x2, - 0x2, 0x2, 0x93, 0x94, 0x3, 0x2, 0x2, 0x2, 0x94, 0x15, 0x3, 0x2, 0x2, - 0x2, 0x95, 0x99, 0x7, 0xd, 0x2, 0x2, 0x96, 0x98, 0x5, 0x20, 0x11, - 0x2, 0x97, 0x96, 0x3, 0x2, 0x2, 0x2, 0x98, 0x9b, 0x3, 0x2, 0x2, 0x2, - 0x99, 0x97, 0x3, 0x2, 0x2, 0x2, 0x99, 0x9a, 0x3, 0x2, 0x2, 0x2, 0x9a, - 0x9c, 0x3, 0x2, 0x2, 0x2, 0x9b, 0x99, 0x3, 0x2, 0x2, 0x2, 0x9c, 0x9d, - 0x7, 0xe, 0x2, 0x2, 0x9d, 0x17, 0x3, 0x2, 0x2, 0x2, 0x9e, 0x9f, 0x7, - 0xf, 0x2, 0x2, 0x9f, 0xa0, 0x5, 0x50, 0x29, 0x2, 0xa0, 0xa4, 0x7, - 0xd, 0x2, 0x2, 0xa1, 0xa3, 0x5, 0x1a, 0xe, 0x2, 0xa2, 0xa1, 0x3, - 0x2, 0x2, 0x2, 0xa3, 0xa6, 0x3, 0x2, 0x2, 0x2, 0xa4, 0xa2, 0x3, 0x2, - 0x2, 0x2, 0xa4, 0xa5, 0x3, 0x2, 0x2, 0x2, 0xa5, 0xa7, 0x3, 0x2, 0x2, - 0x2, 0xa6, 0xa4, 0x3, 0x2, 0x2, 0x2, 0xa7, 0xa8, 0x7, 0xe, 0x2, 0x2, - 0xa8, 0x19, 0x3, 0x2, 0x2, 0x2, 0xa9, 0xac, 0x5, 0x1c, 0xf, 0x2, - 0xaa, 0xac, 0x5, 0x1e, 0x10, 0x2, 0xab, 0xa9, 0x3, 0x2, 0x2, 0x2, - 0xab, 0xaa, 0x3, 0x2, 0x2, 0x2, 0xac, 0x1b, 0x3, 0x2, 0x2, 0x2, 0xad, - 0xae, 0x5, 0x8, 0x5, 0x2, 0xae, 0x1d, 0x3, 0x2, 0x2, 0x2, 0xaf, 0xb0, - 0x5, 0x12, 0xa, 0x2, 0xb0, 0x1f, 0x3, 0x2, 0x2, 0x2, 0xb1, 0xba, - 0x5, 0x6, 0x4, 0x2, 0xb2, 0xba, 0x5, 0x22, 0x12, 0x2, 0xb3, 0xba, - 0x5, 0x24, 0x13, 0x2, 0xb4, 0xba, 0x5, 0x28, 0x15, 0x2, 0xb5, 0xba, - 0x5, 0x2a, 0x16, 0x2, 0xb6, 0xba, 0x5, 0x2c, 0x17, 0x2, 0xb7, 0xba, - 0x5, 0x2e, 0x18, 0x2, 0xb8, 0xba, 0x5, 0x30, 0x19, 0x2, 0xb9, 0xb1, - 0x3, 0x2, 0x2, 0x2, 0xb9, 0xb2, 0x3, 0x2, 0x2, 0x2, 0xb9, 0xb3, 0x3, - 0x2, 0x2, 0x2, 0xb9, 0xb4, 0x3, 0x2, 0x2, 0x2, 0xb9, 0xb5, 0x3, 0x2, - 0x2, 0x2, 0xb9, 0xb6, 0x3, 0x2, 0x2, 0x2, 0xb9, 0xb7, 0x3, 0x2, 0x2, - 0x2, 0xb9, 0xb8, 0x3, 0x2, 0x2, 0x2, 0xba, 0x21, 0x3, 0x2, 0x2, 0x2, - 0xbb, 0xbc, 0x7, 0x10, 0x2, 0x2, 0xbc, 0xbd, 0x5, 0x30, 0x19, 0x2, - 0xbd, 0xc5, 0x5, 0x16, 0xc, 0x2, 0xbe, 0xbf, 0x7, 0x11, 0x2, 0x2, - 0xbf, 0xc0, 0x7, 0x10, 0x2, 0x2, 0xc0, 0xc1, 0x5, 0x30, 0x19, 0x2, - 0xc1, 0xc2, 0x5, 0x16, 0xc, 0x2, 0xc2, 0xc4, 0x3, 0x2, 0x2, 0x2, - 0xc3, 0xbe, 0x3, 0x2, 0x2, 0x2, 0xc4, 0xc7, 0x3, 0x2, 0x2, 0x2, 0xc5, - 0xc3, 0x3, 0x2, 0x2, 0x2, 0xc5, 0xc6, 0x3, 0x2, 0x2, 0x2, 0xc6, 0xca, - 0x3, 0x2, 0x2, 0x2, 0xc7, 0xc5, 0x3, 0x2, 0x2, 0x2, 0xc8, 0xc9, 0x7, - 0x11, 0x2, 0x2, 0xc9, 0xcb, 0x5, 0x16, 0xc, 0x2, 0xca, 0xc8, 0x3, - 0x2, 0x2, 0x2, 0xca, 0xcb, 0x3, 0x2, 0x2, 0x2, 0xcb, 0x23, 0x3, 0x2, - 0x2, 0x2, 0xcc, 0xcd, 0x7, 0x12, 0x2, 0x2, 0xcd, 0xce, 0x5, 0x42, - 0x22, 0x2, 0xce, 0xcf, 0x5, 0x26, 0x14, 0x2, 0xcf, 0x25, 0x3, 0x2, - 0x2, 0x2, 0xd0, 0xd7, 0x7, 0xd, 0x2, 0x2, 0xd1, 0xd2, 0x7, 0x13, - 0x2, 0x2, 0xd2, 0xd3, 0x5, 0x30, 0x19, 0x2, 0xd3, 0xd4, 0x5, 0x16, - 0xc, 0x2, 0xd4, 0xd6, 0x3, 0x2, 0x2, 0x2, 0xd5, 0xd1, 0x3, 0x2, 0x2, - 0x2, 0xd6, 0xd9, 0x3, 0x2, 0x2, 0x2, 0xd7, 0xd5, 0x3, 0x2, 0x2, 0x2, - 0xd7, 0xd8, 0x3, 0x2, 0x2, 0x2, 0xd8, 0xda, 0x3, 0x2, 0x2, 0x2, 0xd9, - 0xd7, 0x3, 0x2, 0x2, 0x2, 0xda, 0xdb, 0x7, 0xe, 0x2, 0x2, 0xdb, 0x27, - 0x3, 0x2, 0x2, 0x2, 0xdc, 0xdf, 0x7, 0x14, 0x2, 0x2, 0xdd, 0xe0, - 0x5, 0xa, 0x6, 0x2, 0xde, 0xe0, 0x5, 0x2c, 0x17, 0x2, 0xdf, 0xdd, - 0x3, 0x2, 0x2, 0x2, 0xdf, 0xde, 0x3, 0x2, 0x2, 0x2, 0xe0, 0xe1, 0x3, - 0x2, 0x2, 0x2, 0xe1, 0xe2, 0x7, 0xc, 0x2, 0x2, 0xe2, 0xe3, 0x5, 0x30, - 0x19, 0x2, 0xe3, 0xe4, 0x7, 0xc, 0x2, 0x2, 0xe4, 0xe5, 0x5, 0x30, - 0x19, 0x2, 0xe5, 0xe6, 0x5, 0x16, 0xc, 0x2, 0xe6, 0x29, 0x3, 0x2, - 0x2, 0x2, 0xe7, 0xe8, 0x7, 0x15, 0x2, 0x2, 0xe8, 0xe9, 0x5, 0x30, - 0x19, 0x2, 0xe9, 0xea, 0x5, 0x16, 0xc, 0x2, 0xea, 0x2b, 0x3, 0x2, - 0x2, 0x2, 0xeb, 0xec, 0x5, 0x42, 0x22, 0x2, 0xec, 0xed, 0x7, 0x5, - 0x2, 0x2, 0xed, 0xee, 0x5, 0x30, 0x19, 0x2, 0xee, 0x2d, 0x3, 0x2, - 0x2, 0x2, 0xef, 0xf0, 0x7, 0x16, 0x2, 0x2, 0xf0, 0xf1, 0x5, 0x30, - 0x19, 0x2, 0xf1, 0x2f, 0x3, 0x2, 0x2, 0x2, 0xf2, 0xf9, 0x5, 0x36, - 0x1c, 0x2, 0xf3, 0xf9, 0x5, 0x44, 0x23, 0x2, 0xf4, 0xf9, 0x5, 0x42, - 0x22, 0x2, 0xf5, 0xf9, 0x5, 0x48, 0x25, 0x2, 0xf6, 0xf9, 0x5, 0x46, - 0x24, 0x2, 0xf7, 0xf9, 0x5, 0x38, 0x1d, 0x2, 0xf8, 0xf2, 0x3, 0x2, - 0x2, 0x2, 0xf8, 0xf3, 0x3, 0x2, 0x2, 0x2, 0xf8, 0xf4, 0x3, 0x2, 0x2, - 0x2, 0xf8, 0xf5, 0x3, 0x2, 0x2, 0x2, 0xf8, 0xf6, 0x3, 0x2, 0x2, 0x2, - 0xf8, 0xf7, 0x3, 0x2, 0x2, 0x2, 0xf9, 0x31, 0x3, 0x2, 0x2, 0x2, 0xfa, - 0x100, 0x5, 0x36, 0x1c, 0x2, 0xfb, 0x100, 0x5, 0x44, 0x23, 0x2, 0xfc, - 0x100, 0x5, 0x42, 0x22, 0x2, 0xfd, 0x100, 0x5, 0x48, 0x25, 0x2, 0xfe, - 0x100, 0x5, 0x46, 0x24, 0x2, 0xff, 0xfa, 0x3, 0x2, 0x2, 0x2, 0xff, - 0xfb, 0x3, 0x2, 0x2, 0x2, 0xff, 0xfc, 0x3, 0x2, 0x2, 0x2, 0xff, 0xfd, - 0x3, 0x2, 0x2, 0x2, 0xff, 0xfe, 0x3, 0x2, 0x2, 0x2, 0x100, 0x33, - 0x3, 0x2, 0x2, 0x2, 0x101, 0x105, 0x5, 0x36, 0x1c, 0x2, 0x102, 0x105, - 0x5, 0x42, 0x22, 0x2, 0x103, 0x105, 0x5, 0x48, 0x25, 0x2, 0x104, - 0x101, 0x3, 0x2, 0x2, 0x2, 0x104, 0x102, 0x3, 0x2, 0x2, 0x2, 0x104, - 0x103, 0x3, 0x2, 0x2, 0x2, 0x105, 0x35, 0x3, 0x2, 0x2, 0x2, 0x106, - 0x107, 0x5, 0x4a, 0x26, 0x2, 0x107, 0x110, 0x7, 0xa, 0x2, 0x2, 0x108, - 0x10d, 0x5, 0x30, 0x19, 0x2, 0x109, 0x10a, 0x7, 0xc, 0x2, 0x2, 0x10a, - 0x10c, 0x5, 0x30, 0x19, 0x2, 0x10b, 0x109, 0x3, 0x2, 0x2, 0x2, 0x10c, - 0x10f, 0x3, 0x2, 0x2, 0x2, 0x10d, 0x10b, 0x3, 0x2, 0x2, 0x2, 0x10d, - 0x10e, 0x3, 0x2, 0x2, 0x2, 0x10e, 0x111, 0x3, 0x2, 0x2, 0x2, 0x10f, - 0x10d, 0x3, 0x2, 0x2, 0x2, 0x110, 0x108, 0x3, 0x2, 0x2, 0x2, 0x110, - 0x111, 0x3, 0x2, 0x2, 0x2, 0x111, 0x112, 0x3, 0x2, 0x2, 0x2, 0x112, - 0x113, 0x7, 0xb, 0x2, 0x2, 0x113, 0x37, 0x3, 0x2, 0x2, 0x2, 0x114, - 0x119, 0x5, 0x3a, 0x1e, 0x2, 0x115, 0x119, 0x5, 0x3c, 0x1f, 0x2, - 0x116, 0x119, 0x5, 0x3e, 0x20, 0x2, 0x117, 0x119, 0x5, 0x40, 0x21, - 0x2, 0x118, 0x114, 0x3, 0x2, 0x2, 0x2, 0x118, 0x115, 0x3, 0x2, 0x2, - 0x2, 0x118, 0x116, 0x3, 0x2, 0x2, 0x2, 0x118, 0x117, 0x3, 0x2, 0x2, - 0x2, 0x119, 0x39, 0x3, 0x2, 0x2, 0x2, 0x11a, 0x11b, 0x5, 0x32, 0x1a, - 0x2, 0x11b, 0x11c, 0x7, 0x1c, 0x2, 0x2, 0x11c, 0x121, 0x5, 0x32, - 0x1a, 0x2, 0x11d, 0x11e, 0x7, 0x1c, 0x2, 0x2, 0x11e, 0x120, 0x5, - 0x32, 0x1a, 0x2, 0x11f, 0x11d, 0x3, 0x2, 0x2, 0x2, 0x120, 0x123, - 0x3, 0x2, 0x2, 0x2, 0x121, 0x11f, 0x3, 0x2, 0x2, 0x2, 0x121, 0x122, - 0x3, 0x2, 0x2, 0x2, 0x122, 0x3b, 0x3, 0x2, 0x2, 0x2, 0x123, 0x121, - 0x3, 0x2, 0x2, 0x2, 0x124, 0x125, 0x7, 0x1b, 0x2, 0x2, 0x125, 0x126, - 0x5, 0x32, 0x1a, 0x2, 0x126, 0x3d, 0x3, 0x2, 0x2, 0x2, 0x127, 0x128, - 0x5, 0x32, 0x1a, 0x2, 0x128, 0x129, 0x7, 0x1a, 0x2, 0x2, 0x129, 0x3f, - 0x3, 0x2, 0x2, 0x2, 0x12a, 0x12b, 0x5, 0x32, 0x1a, 0x2, 0x12b, 0x12c, - 0x7, 0x17, 0x2, 0x2, 0x12c, 0x12d, 0x5, 0x30, 0x19, 0x2, 0x12d, 0x12e, - 0x7, 0x4, 0x2, 0x2, 0x12e, 0x12f, 0x5, 0x30, 0x19, 0x2, 0x12f, 0x41, - 0x3, 0x2, 0x2, 0x2, 0x130, 0x131, 0x5, 0x4c, 0x27, 0x2, 0x131, 0x43, - 0x3, 0x2, 0x2, 0x2, 0x132, 0x133, 0x9, 0x2, 0x2, 0x2, 0x133, 0x45, - 0x3, 0x2, 0x2, 0x2, 0x134, 0x13b, 0x5, 0x34, 0x1b, 0x2, 0x135, 0x136, - 0x9, 0x3, 0x2, 0x2, 0x136, 0x13c, 0x5, 0x42, 0x22, 0x2, 0x137, 0x138, - 0x7, 0x7, 0x2, 0x2, 0x138, 0x139, 0x5, 0x30, 0x19, 0x2, 0x139, 0x13a, - 0x7, 0x8, 0x2, 0x2, 0x13a, 0x13c, 0x3, 0x2, 0x2, 0x2, 0x13b, 0x135, - 0x3, 0x2, 0x2, 0x2, 0x13b, 0x137, 0x3, 0x2, 0x2, 0x2, 0x13c, 0x13d, - 0x3, 0x2, 0x2, 0x2, 0x13d, 0x13b, 0x3, 0x2, 0x2, 0x2, 0x13d, 0x13e, - 0x3, 0x2, 0x2, 0x2, 0x13e, 0x47, 0x3, 0x2, 0x2, 0x2, 0x13f, 0x140, - 0x7, 0xa, 0x2, 0x2, 0x140, 0x141, 0x5, 0x30, 0x19, 0x2, 0x141, 0x142, - 0x7, 0xb, 0x2, 0x2, 0x142, 0x49, 0x3, 0x2, 0x2, 0x2, 0x143, 0x144, - 0x7, 0x21, 0x2, 0x2, 0x144, 0x4b, 0x3, 0x2, 0x2, 0x2, 0x145, 0x146, - 0x7, 0x21, 0x2, 0x2, 0x146, 0x4d, 0x3, 0x2, 0x2, 0x2, 0x147, 0x148, - 0x7, 0x21, 0x2, 0x2, 0x148, 0x4f, 0x3, 0x2, 0x2, 0x2, 0x149, 0x14a, - 0x7, 0x21, 0x2, 0x2, 0x14a, 0x51, 0x3, 0x2, 0x2, 0x2, 0x1b, 0x55, - 0x5c, 0x67, 0x74, 0x7a, 0x7d, 0x90, 0x93, 0x99, 0xa4, 0xab, 0xb9, - 0xc5, 0xca, 0xd7, 0xdf, 0xf8, 0xff, 0x104, 0x10d, 0x110, 0x118, 0x121, - 0x13b, 0x13d, + 0x9, 0x29, 0x4, 0x2a, 0x9, 0x2a, 0x4, 0x2b, 0x9, 0x2b, 0x4, 0x2c, + 0x9, 0x2c, 0x4, 0x2d, 0x9, 0x2d, 0x4, 0x2e, 0x9, 0x2e, 0x4, 0x2f, + 0x9, 0x2f, 0x4, 0x30, 0x9, 0x30, 0x4, 0x31, 0x9, 0x31, 0x4, 0x32, + 0x9, 0x32, 0x4, 0x33, 0x9, 0x33, 0x3, 0x2, 0x6, 0x2, 0x68, 0xa, 0x2, + 0xd, 0x2, 0xe, 0x2, 0x69, 0x3, 0x2, 0x3, 0x2, 0x3, 0x3, 0x3, 0x3, + 0x3, 0x3, 0x3, 0x3, 0x3, 0x3, 0x5, 0x3, 0x73, 0xa, 0x3, 0x3, 0x4, + 0x3, 0x4, 0x3, 0x4, 0x3, 0x5, 0x3, 0x5, 0x3, 0x5, 0x3, 0x5, 0x3, + 0x5, 0x3, 0x5, 0x5, 0x5, 0x7e, 0xa, 0x5, 0x3, 0x6, 0x3, 0x6, 0x3, + 0x6, 0x3, 0x6, 0x3, 0x6, 0x3, 0x6, 0x3, 0x6, 0x3, 0x7, 0x3, 0x7, + 0x7, 0x7, 0x89, 0xa, 0x7, 0xc, 0x7, 0xe, 0x7, 0x8c, 0xb, 0x7, 0x3, + 0x8, 0x3, 0x8, 0x3, 0x8, 0x5, 0x8, 0x91, 0xa, 0x8, 0x3, 0x8, 0x5, + 0x8, 0x94, 0xa, 0x8, 0x3, 0x9, 0x3, 0x9, 0x3, 0x9, 0x3, 0xa, 0x3, + 0xa, 0x5, 0xa, 0x9b, 0xa, 0xa, 0x3, 0xa, 0x3, 0xa, 0x3, 0xa, 0x3, + 0xa, 0x3, 0xa, 0x3, 0xa, 0x3, 0xa, 0x3, 0xa, 0x3, 0xb, 0x3, 0xb, + 0x3, 0xb, 0x7, 0xb, 0xa8, 0xa, 0xb, 0xc, 0xb, 0xe, 0xb, 0xab, 0xb, + 0xb, 0x5, 0xb, 0xad, 0xa, 0xb, 0x3, 0xc, 0x3, 0xc, 0x7, 0xc, 0xb1, + 0xa, 0xc, 0xc, 0xc, 0xe, 0xc, 0xb4, 0xb, 0xc, 0x3, 0xc, 0x3, 0xc, + 0x3, 0xd, 0x3, 0xd, 0x3, 0xd, 0x5, 0xd, 0xbb, 0xa, 0xd, 0x3, 0xd, + 0x3, 0xd, 0x7, 0xd, 0xbf, 0xa, 0xd, 0xc, 0xd, 0xe, 0xd, 0xc2, 0xb, + 0xd, 0x3, 0xd, 0x3, 0xd, 0x3, 0xe, 0x3, 0xe, 0x5, 0xe, 0xc8, 0xa, + 0xe, 0x3, 0xf, 0x3, 0xf, 0x3, 0xf, 0x3, 0x10, 0x3, 0x10, 0x3, 0x11, + 0x3, 0x11, 0x3, 0x11, 0x3, 0x11, 0x7, 0x11, 0xd3, 0xa, 0x11, 0xc, + 0x11, 0xe, 0x11, 0xd6, 0xb, 0x11, 0x3, 0x11, 0x3, 0x11, 0x3, 0x12, + 0x3, 0x12, 0x3, 0x12, 0x3, 0x12, 0x3, 0x12, 0x3, 0x12, 0x3, 0x12, + 0x3, 0x12, 0x3, 0x12, 0x3, 0x12, 0x3, 0x12, 0x3, 0x12, 0x3, 0x12, + 0x3, 0x12, 0x3, 0x12, 0x3, 0x12, 0x5, 0x12, 0xea, 0xa, 0x12, 0x3, + 0x13, 0x3, 0x13, 0x3, 0x13, 0x3, 0x13, 0x7, 0x13, 0xf0, 0xa, 0x13, + 0xc, 0x13, 0xe, 0x13, 0xf3, 0xb, 0x13, 0x3, 0x13, 0x5, 0x13, 0xf6, + 0xa, 0x13, 0x3, 0x14, 0x3, 0x14, 0x3, 0x14, 0x3, 0x14, 0x3, 0x14, + 0x3, 0x15, 0x3, 0x15, 0x3, 0x15, 0x3, 0x16, 0x3, 0x16, 0x3, 0x16, + 0x3, 0x16, 0x3, 0x17, 0x3, 0x17, 0x7, 0x17, 0x106, 0xa, 0x17, 0xc, + 0x17, 0xe, 0x17, 0x109, 0xb, 0x17, 0x3, 0x17, 0x3, 0x17, 0x3, 0x18, + 0x3, 0x18, 0x3, 0x18, 0x3, 0x18, 0x3, 0x19, 0x3, 0x19, 0x3, 0x19, + 0x5, 0x19, 0x114, 0xa, 0x19, 0x3, 0x19, 0x3, 0x19, 0x3, 0x19, 0x3, + 0x19, 0x3, 0x19, 0x3, 0x19, 0x3, 0x1a, 0x3, 0x1a, 0x3, 0x1a, 0x3, + 0x1a, 0x3, 0x1b, 0x3, 0x1b, 0x3, 0x1b, 0x3, 0x1b, 0x3, 0x1c, 0x3, + 0x1c, 0x3, 0x1c, 0x3, 0x1d, 0x3, 0x1d, 0x3, 0x1d, 0x3, 0x1d, 0x3, + 0x1d, 0x3, 0x1d, 0x5, 0x1d, 0x12d, 0xa, 0x1d, 0x3, 0x1e, 0x3, 0x1e, + 0x3, 0x1e, 0x3, 0x1e, 0x3, 0x1e, 0x5, 0x1e, 0x134, 0xa, 0x1e, 0x3, + 0x1f, 0x3, 0x1f, 0x3, 0x1f, 0x5, 0x1f, 0x139, 0xa, 0x1f, 0x3, 0x20, + 0x3, 0x20, 0x3, 0x20, 0x3, 0x20, 0x3, 0x20, 0x7, 0x20, 0x140, 0xa, + 0x20, 0xc, 0x20, 0xe, 0x20, 0x143, 0xb, 0x20, 0x5, 0x20, 0x145, 0xa, + 0x20, 0x3, 0x20, 0x3, 0x20, 0x3, 0x21, 0x3, 0x21, 0x3, 0x21, 0x3, + 0x21, 0x5, 0x21, 0x14d, 0xa, 0x21, 0x3, 0x22, 0x3, 0x22, 0x3, 0x22, + 0x3, 0x22, 0x3, 0x22, 0x3, 0x22, 0x7, 0x22, 0x155, 0xa, 0x22, 0xc, + 0x22, 0xe, 0x22, 0x158, 0xb, 0x22, 0x3, 0x23, 0x3, 0x23, 0x3, 0x23, + 0x3, 0x24, 0x3, 0x24, 0x3, 0x24, 0x3, 0x25, 0x3, 0x25, 0x3, 0x25, + 0x3, 0x25, 0x3, 0x25, 0x3, 0x25, 0x3, 0x26, 0x3, 0x26, 0x3, 0x27, + 0x3, 0x27, 0x3, 0x28, 0x3, 0x28, 0x6, 0x28, 0x16c, 0xa, 0x28, 0xd, + 0x28, 0xe, 0x28, 0x16d, 0x3, 0x29, 0x3, 0x29, 0x5, 0x29, 0x172, 0xa, + 0x29, 0x3, 0x2a, 0x3, 0x2a, 0x3, 0x2a, 0x3, 0x2b, 0x3, 0x2b, 0x3, + 0x2b, 0x3, 0x2b, 0x3, 0x2c, 0x3, 0x2c, 0x3, 0x2c, 0x3, 0x2c, 0x3, + 0x2d, 0x3, 0x2d, 0x3, 0x2e, 0x3, 0x2e, 0x3, 0x2f, 0x3, 0x2f, 0x3, + 0x30, 0x3, 0x30, 0x3, 0x31, 0x3, 0x31, 0x3, 0x32, 0x3, 0x32, 0x3, + 0x32, 0x3, 0x32, 0x3, 0x32, 0x3, 0x32, 0x3, 0x32, 0x5, 0x32, 0x190, + 0xa, 0x32, 0x3, 0x33, 0x3, 0x33, 0x3, 0x33, 0x2, 0x2, 0x34, 0x2, + 0x4, 0x6, 0x8, 0xa, 0xc, 0xe, 0x10, 0x12, 0x14, 0x16, 0x18, 0x1a, + 0x1c, 0x1e, 0x20, 0x22, 0x24, 0x26, 0x28, 0x2a, 0x2c, 0x2e, 0x30, + 0x32, 0x34, 0x36, 0x38, 0x3a, 0x3c, 0x3e, 0x40, 0x42, 0x44, 0x46, + 0x48, 0x4a, 0x4c, 0x4e, 0x50, 0x52, 0x54, 0x56, 0x58, 0x5a, 0x5c, + 0x5e, 0x60, 0x62, 0x64, 0x2, 0x6, 0x3, 0x2, 0x3a, 0x3d, 0x3, 0x2, + 0x1b, 0x1c, 0x3, 0x2, 0x1d, 0x1e, 0x6, 0x2, 0x7, 0x7, 0x11, 0x12, + 0x1f, 0x20, 0x23, 0x39, 0x2, 0x194, 0x2, 0x67, 0x3, 0x2, 0x2, 0x2, + 0x4, 0x72, 0x3, 0x2, 0x2, 0x2, 0x6, 0x74, 0x3, 0x2, 0x2, 0x2, 0x8, + 0x77, 0x3, 0x2, 0x2, 0x2, 0xa, 0x7f, 0x3, 0x2, 0x2, 0x2, 0xc, 0x86, + 0x3, 0x2, 0x2, 0x2, 0xe, 0x93, 0x3, 0x2, 0x2, 0x2, 0x10, 0x95, 0x3, + 0x2, 0x2, 0x2, 0x12, 0x98, 0x3, 0x2, 0x2, 0x2, 0x14, 0xac, 0x3, 0x2, + 0x2, 0x2, 0x16, 0xae, 0x3, 0x2, 0x2, 0x2, 0x18, 0xb7, 0x3, 0x2, 0x2, + 0x2, 0x1a, 0xc7, 0x3, 0x2, 0x2, 0x2, 0x1c, 0xc9, 0x3, 0x2, 0x2, 0x2, + 0x1e, 0xcc, 0x3, 0x2, 0x2, 0x2, 0x20, 0xce, 0x3, 0x2, 0x2, 0x2, 0x22, + 0xe9, 0x3, 0x2, 0x2, 0x2, 0x24, 0xeb, 0x3, 0x2, 0x2, 0x2, 0x26, 0xf7, + 0x3, 0x2, 0x2, 0x2, 0x28, 0xfc, 0x3, 0x2, 0x2, 0x2, 0x2a, 0xff, 0x3, + 0x2, 0x2, 0x2, 0x2c, 0x103, 0x3, 0x2, 0x2, 0x2, 0x2e, 0x10c, 0x3, + 0x2, 0x2, 0x2, 0x30, 0x110, 0x3, 0x2, 0x2, 0x2, 0x32, 0x11b, 0x3, + 0x2, 0x2, 0x2, 0x34, 0x11f, 0x3, 0x2, 0x2, 0x2, 0x36, 0x123, 0x3, + 0x2, 0x2, 0x2, 0x38, 0x12c, 0x3, 0x2, 0x2, 0x2, 0x3a, 0x133, 0x3, + 0x2, 0x2, 0x2, 0x3c, 0x138, 0x3, 0x2, 0x2, 0x2, 0x3e, 0x13a, 0x3, + 0x2, 0x2, 0x2, 0x40, 0x14c, 0x3, 0x2, 0x2, 0x2, 0x42, 0x14e, 0x3, + 0x2, 0x2, 0x2, 0x44, 0x159, 0x3, 0x2, 0x2, 0x2, 0x46, 0x15c, 0x3, + 0x2, 0x2, 0x2, 0x48, 0x15f, 0x3, 0x2, 0x2, 0x2, 0x4a, 0x165, 0x3, + 0x2, 0x2, 0x2, 0x4c, 0x167, 0x3, 0x2, 0x2, 0x2, 0x4e, 0x169, 0x3, + 0x2, 0x2, 0x2, 0x50, 0x171, 0x3, 0x2, 0x2, 0x2, 0x52, 0x173, 0x3, + 0x2, 0x2, 0x2, 0x54, 0x176, 0x3, 0x2, 0x2, 0x2, 0x56, 0x17a, 0x3, + 0x2, 0x2, 0x2, 0x58, 0x17e, 0x3, 0x2, 0x2, 0x2, 0x5a, 0x180, 0x3, + 0x2, 0x2, 0x2, 0x5c, 0x182, 0x3, 0x2, 0x2, 0x2, 0x5e, 0x184, 0x3, + 0x2, 0x2, 0x2, 0x60, 0x186, 0x3, 0x2, 0x2, 0x2, 0x62, 0x18f, 0x3, + 0x2, 0x2, 0x2, 0x64, 0x191, 0x3, 0x2, 0x2, 0x2, 0x66, 0x68, 0x5, + 0x4, 0x3, 0x2, 0x67, 0x66, 0x3, 0x2, 0x2, 0x2, 0x68, 0x69, 0x3, 0x2, + 0x2, 0x2, 0x69, 0x67, 0x3, 0x2, 0x2, 0x2, 0x69, 0x6a, 0x3, 0x2, 0x2, + 0x2, 0x6a, 0x6b, 0x3, 0x2, 0x2, 0x2, 0x6b, 0x6c, 0x7, 0x2, 0x2, 0x3, + 0x6c, 0x3, 0x3, 0x2, 0x2, 0x2, 0x6d, 0x6e, 0x5, 0x6, 0x4, 0x2, 0x6e, + 0x6f, 0x7, 0x3, 0x2, 0x2, 0x6f, 0x73, 0x3, 0x2, 0x2, 0x2, 0x70, 0x73, + 0x5, 0x10, 0x9, 0x2, 0x71, 0x73, 0x5, 0x18, 0xd, 0x2, 0x72, 0x6d, + 0x3, 0x2, 0x2, 0x2, 0x72, 0x70, 0x3, 0x2, 0x2, 0x2, 0x72, 0x71, 0x3, + 0x2, 0x2, 0x2, 0x73, 0x5, 0x3, 0x2, 0x2, 0x2, 0x74, 0x75, 0x7, 0x4, + 0x2, 0x2, 0x75, 0x76, 0x5, 0x8, 0x5, 0x2, 0x76, 0x7, 0x3, 0x2, 0x2, + 0x2, 0x77, 0x78, 0x5, 0x5a, 0x2e, 0x2, 0x78, 0x79, 0x7, 0x5, 0x2, + 0x2, 0x79, 0x7a, 0x5, 0xc, 0x7, 0x2, 0x7a, 0x7d, 0x3, 0x2, 0x2, 0x2, + 0x7b, 0x7c, 0x7, 0x6, 0x2, 0x2, 0x7c, 0x7e, 0x5, 0x38, 0x1d, 0x2, + 0x7d, 0x7b, 0x3, 0x2, 0x2, 0x2, 0x7d, 0x7e, 0x3, 0x2, 0x2, 0x2, 0x7e, + 0x9, 0x3, 0x2, 0x2, 0x2, 0x7f, 0x80, 0x5, 0x5a, 0x2e, 0x2, 0x80, + 0x81, 0x7, 0x5, 0x2, 0x2, 0x81, 0x82, 0x5, 0xc, 0x7, 0x2, 0x82, 0x83, + 0x3, 0x2, 0x2, 0x2, 0x83, 0x84, 0x7, 0x6, 0x2, 0x2, 0x84, 0x85, 0x5, + 0x38, 0x1d, 0x2, 0x85, 0xb, 0x3, 0x2, 0x2, 0x2, 0x86, 0x8a, 0x5, + 0x5c, 0x2f, 0x2, 0x87, 0x89, 0x5, 0xe, 0x8, 0x2, 0x88, 0x87, 0x3, + 0x2, 0x2, 0x2, 0x89, 0x8c, 0x3, 0x2, 0x2, 0x2, 0x8a, 0x88, 0x3, 0x2, + 0x2, 0x2, 0x8a, 0x8b, 0x3, 0x2, 0x2, 0x2, 0x8b, 0xd, 0x3, 0x2, 0x2, + 0x2, 0x8c, 0x8a, 0x3, 0x2, 0x2, 0x2, 0x8d, 0x94, 0x7, 0x7, 0x2, 0x2, + 0x8e, 0x90, 0x7, 0x8, 0x2, 0x2, 0x8f, 0x91, 0x7, 0x3a, 0x2, 0x2, + 0x90, 0x8f, 0x3, 0x2, 0x2, 0x2, 0x90, 0x91, 0x3, 0x2, 0x2, 0x2, 0x91, + 0x92, 0x3, 0x2, 0x2, 0x2, 0x92, 0x94, 0x7, 0x9, 0x2, 0x2, 0x93, 0x8d, + 0x3, 0x2, 0x2, 0x2, 0x93, 0x8e, 0x3, 0x2, 0x2, 0x2, 0x94, 0xf, 0x3, + 0x2, 0x2, 0x2, 0x95, 0x96, 0x7, 0xa, 0x2, 0x2, 0x96, 0x97, 0x5, 0x12, + 0xa, 0x2, 0x97, 0x11, 0x3, 0x2, 0x2, 0x2, 0x98, 0x9a, 0x5, 0x58, + 0x2d, 0x2, 0x99, 0x9b, 0x5, 0x20, 0x11, 0x2, 0x9a, 0x99, 0x3, 0x2, + 0x2, 0x2, 0x9a, 0x9b, 0x3, 0x2, 0x2, 0x2, 0x9b, 0x9c, 0x3, 0x2, 0x2, + 0x2, 0x9c, 0x9d, 0x7, 0xb, 0x2, 0x2, 0x9d, 0x9e, 0x5, 0x14, 0xb, + 0x2, 0x9e, 0x9f, 0x7, 0xc, 0x2, 0x2, 0x9f, 0xa0, 0x7, 0x5, 0x2, 0x2, + 0xa0, 0xa1, 0x5, 0xc, 0x7, 0x2, 0xa1, 0xa2, 0x3, 0x2, 0x2, 0x2, 0xa2, + 0xa3, 0x5, 0x16, 0xc, 0x2, 0xa3, 0x13, 0x3, 0x2, 0x2, 0x2, 0xa4, + 0xa9, 0x5, 0x8, 0x5, 0x2, 0xa5, 0xa6, 0x7, 0xd, 0x2, 0x2, 0xa6, 0xa8, + 0x5, 0x8, 0x5, 0x2, 0xa7, 0xa5, 0x3, 0x2, 0x2, 0x2, 0xa8, 0xab, 0x3, + 0x2, 0x2, 0x2, 0xa9, 0xa7, 0x3, 0x2, 0x2, 0x2, 0xa9, 0xaa, 0x3, 0x2, + 0x2, 0x2, 0xaa, 0xad, 0x3, 0x2, 0x2, 0x2, 0xab, 0xa9, 0x3, 0x2, 0x2, + 0x2, 0xac, 0xa4, 0x3, 0x2, 0x2, 0x2, 0xac, 0xad, 0x3, 0x2, 0x2, 0x2, + 0xad, 0x15, 0x3, 0x2, 0x2, 0x2, 0xae, 0xb2, 0x7, 0xe, 0x2, 0x2, 0xaf, + 0xb1, 0x5, 0x22, 0x12, 0x2, 0xb0, 0xaf, 0x3, 0x2, 0x2, 0x2, 0xb1, + 0xb4, 0x3, 0x2, 0x2, 0x2, 0xb2, 0xb0, 0x3, 0x2, 0x2, 0x2, 0xb2, 0xb3, + 0x3, 0x2, 0x2, 0x2, 0xb3, 0xb5, 0x3, 0x2, 0x2, 0x2, 0xb4, 0xb2, 0x3, + 0x2, 0x2, 0x2, 0xb5, 0xb6, 0x7, 0xf, 0x2, 0x2, 0xb6, 0x17, 0x3, 0x2, + 0x2, 0x2, 0xb7, 0xb8, 0x7, 0x10, 0x2, 0x2, 0xb8, 0xba, 0x5, 0x5e, + 0x30, 0x2, 0xb9, 0xbb, 0x5, 0x20, 0x11, 0x2, 0xba, 0xb9, 0x3, 0x2, + 0x2, 0x2, 0xba, 0xbb, 0x3, 0x2, 0x2, 0x2, 0xbb, 0xbc, 0x3, 0x2, 0x2, + 0x2, 0xbc, 0xc0, 0x7, 0xe, 0x2, 0x2, 0xbd, 0xbf, 0x5, 0x1a, 0xe, + 0x2, 0xbe, 0xbd, 0x3, 0x2, 0x2, 0x2, 0xbf, 0xc2, 0x3, 0x2, 0x2, 0x2, + 0xc0, 0xbe, 0x3, 0x2, 0x2, 0x2, 0xc0, 0xc1, 0x3, 0x2, 0x2, 0x2, 0xc1, + 0xc3, 0x3, 0x2, 0x2, 0x2, 0xc2, 0xc0, 0x3, 0x2, 0x2, 0x2, 0xc3, 0xc4, + 0x7, 0xf, 0x2, 0x2, 0xc4, 0x19, 0x3, 0x2, 0x2, 0x2, 0xc5, 0xc8, 0x5, + 0x1c, 0xf, 0x2, 0xc6, 0xc8, 0x5, 0x1e, 0x10, 0x2, 0xc7, 0xc5, 0x3, + 0x2, 0x2, 0x2, 0xc7, 0xc6, 0x3, 0x2, 0x2, 0x2, 0xc8, 0x1b, 0x3, 0x2, + 0x2, 0x2, 0xc9, 0xca, 0x5, 0x8, 0x5, 0x2, 0xca, 0xcb, 0x7, 0x3, 0x2, + 0x2, 0xcb, 0x1d, 0x3, 0x2, 0x2, 0x2, 0xcc, 0xcd, 0x5, 0x12, 0xa, + 0x2, 0xcd, 0x1f, 0x3, 0x2, 0x2, 0x2, 0xce, 0xcf, 0x7, 0x11, 0x2, + 0x2, 0xcf, 0xd4, 0x5, 0x5c, 0x2f, 0x2, 0xd0, 0xd1, 0x7, 0xd, 0x2, + 0x2, 0xd1, 0xd3, 0x5, 0x5c, 0x2f, 0x2, 0xd2, 0xd0, 0x3, 0x2, 0x2, + 0x2, 0xd3, 0xd6, 0x3, 0x2, 0x2, 0x2, 0xd4, 0xd2, 0x3, 0x2, 0x2, 0x2, + 0xd4, 0xd5, 0x3, 0x2, 0x2, 0x2, 0xd5, 0xd7, 0x3, 0x2, 0x2, 0x2, 0xd6, + 0xd4, 0x3, 0x2, 0x2, 0x2, 0xd7, 0xd8, 0x7, 0x12, 0x2, 0x2, 0xd8, + 0x21, 0x3, 0x2, 0x2, 0x2, 0xd9, 0xda, 0x5, 0x6, 0x4, 0x2, 0xda, 0xdb, + 0x7, 0x3, 0x2, 0x2, 0xdb, 0xea, 0x3, 0x2, 0x2, 0x2, 0xdc, 0xea, 0x5, + 0x24, 0x13, 0x2, 0xdd, 0xea, 0x5, 0x2a, 0x16, 0x2, 0xde, 0xea, 0x5, + 0x30, 0x19, 0x2, 0xdf, 0xea, 0x5, 0x32, 0x1a, 0x2, 0xe0, 0xe1, 0x5, + 0x34, 0x1b, 0x2, 0xe1, 0xe2, 0x7, 0x3, 0x2, 0x2, 0xe2, 0xea, 0x3, + 0x2, 0x2, 0x2, 0xe3, 0xe4, 0x5, 0x36, 0x1c, 0x2, 0xe4, 0xe5, 0x7, + 0x3, 0x2, 0x2, 0xe5, 0xea, 0x3, 0x2, 0x2, 0x2, 0xe6, 0xe7, 0x5, 0x38, + 0x1d, 0x2, 0xe7, 0xe8, 0x7, 0x3, 0x2, 0x2, 0xe8, 0xea, 0x3, 0x2, + 0x2, 0x2, 0xe9, 0xd9, 0x3, 0x2, 0x2, 0x2, 0xe9, 0xdc, 0x3, 0x2, 0x2, + 0x2, 0xe9, 0xdd, 0x3, 0x2, 0x2, 0x2, 0xe9, 0xde, 0x3, 0x2, 0x2, 0x2, + 0xe9, 0xdf, 0x3, 0x2, 0x2, 0x2, 0xe9, 0xe0, 0x3, 0x2, 0x2, 0x2, 0xe9, + 0xe3, 0x3, 0x2, 0x2, 0x2, 0xe9, 0xe6, 0x3, 0x2, 0x2, 0x2, 0xea, 0x23, + 0x3, 0x2, 0x2, 0x2, 0xeb, 0xec, 0x7, 0x13, 0x2, 0x2, 0xec, 0xed, + 0x5, 0x38, 0x1d, 0x2, 0xed, 0xf1, 0x5, 0x16, 0xc, 0x2, 0xee, 0xf0, + 0x5, 0x26, 0x14, 0x2, 0xef, 0xee, 0x3, 0x2, 0x2, 0x2, 0xf0, 0xf3, + 0x3, 0x2, 0x2, 0x2, 0xf1, 0xef, 0x3, 0x2, 0x2, 0x2, 0xf1, 0xf2, 0x3, + 0x2, 0x2, 0x2, 0xf2, 0xf5, 0x3, 0x2, 0x2, 0x2, 0xf3, 0xf1, 0x3, 0x2, + 0x2, 0x2, 0xf4, 0xf6, 0x5, 0x28, 0x15, 0x2, 0xf5, 0xf4, 0x3, 0x2, + 0x2, 0x2, 0xf5, 0xf6, 0x3, 0x2, 0x2, 0x2, 0xf6, 0x25, 0x3, 0x2, 0x2, + 0x2, 0xf7, 0xf8, 0x7, 0x14, 0x2, 0x2, 0xf8, 0xf9, 0x7, 0x13, 0x2, + 0x2, 0xf9, 0xfa, 0x5, 0x38, 0x1d, 0x2, 0xfa, 0xfb, 0x5, 0x16, 0xc, + 0x2, 0xfb, 0x27, 0x3, 0x2, 0x2, 0x2, 0xfc, 0xfd, 0x7, 0x14, 0x2, + 0x2, 0xfd, 0xfe, 0x5, 0x16, 0xc, 0x2, 0xfe, 0x29, 0x3, 0x2, 0x2, + 0x2, 0xff, 0x100, 0x7, 0x15, 0x2, 0x2, 0x100, 0x101, 0x5, 0x4a, 0x26, + 0x2, 0x101, 0x102, 0x5, 0x2c, 0x17, 0x2, 0x102, 0x2b, 0x3, 0x2, 0x2, + 0x2, 0x103, 0x107, 0x7, 0xe, 0x2, 0x2, 0x104, 0x106, 0x5, 0x2e, 0x18, + 0x2, 0x105, 0x104, 0x3, 0x2, 0x2, 0x2, 0x106, 0x109, 0x3, 0x2, 0x2, + 0x2, 0x107, 0x105, 0x3, 0x2, 0x2, 0x2, 0x107, 0x108, 0x3, 0x2, 0x2, + 0x2, 0x108, 0x10a, 0x3, 0x2, 0x2, 0x2, 0x109, 0x107, 0x3, 0x2, 0x2, + 0x2, 0x10a, 0x10b, 0x7, 0xf, 0x2, 0x2, 0x10b, 0x2d, 0x3, 0x2, 0x2, + 0x2, 0x10c, 0x10d, 0x7, 0x16, 0x2, 0x2, 0x10d, 0x10e, 0x5, 0x38, + 0x1d, 0x2, 0x10e, 0x10f, 0x5, 0x16, 0xc, 0x2, 0x10f, 0x2f, 0x3, 0x2, + 0x2, 0x2, 0x110, 0x113, 0x7, 0x17, 0x2, 0x2, 0x111, 0x114, 0x5, 0xa, + 0x6, 0x2, 0x112, 0x114, 0x5, 0x34, 0x1b, 0x2, 0x113, 0x111, 0x3, + 0x2, 0x2, 0x2, 0x113, 0x112, 0x3, 0x2, 0x2, 0x2, 0x114, 0x115, 0x3, + 0x2, 0x2, 0x2, 0x115, 0x116, 0x7, 0xd, 0x2, 0x2, 0x116, 0x117, 0x5, + 0x38, 0x1d, 0x2, 0x117, 0x118, 0x7, 0xd, 0x2, 0x2, 0x118, 0x119, + 0x5, 0x38, 0x1d, 0x2, 0x119, 0x11a, 0x5, 0x16, 0xc, 0x2, 0x11a, 0x31, + 0x3, 0x2, 0x2, 0x2, 0x11b, 0x11c, 0x7, 0x18, 0x2, 0x2, 0x11c, 0x11d, + 0x5, 0x38, 0x1d, 0x2, 0x11d, 0x11e, 0x5, 0x16, 0xc, 0x2, 0x11e, 0x33, + 0x3, 0x2, 0x2, 0x2, 0x11f, 0x120, 0x5, 0x4a, 0x26, 0x2, 0x120, 0x121, + 0x7, 0x6, 0x2, 0x2, 0x121, 0x122, 0x5, 0x38, 0x1d, 0x2, 0x122, 0x35, + 0x3, 0x2, 0x2, 0x2, 0x123, 0x124, 0x7, 0x19, 0x2, 0x2, 0x124, 0x125, + 0x5, 0x38, 0x1d, 0x2, 0x125, 0x37, 0x3, 0x2, 0x2, 0x2, 0x126, 0x12d, + 0x5, 0x3e, 0x20, 0x2, 0x127, 0x12d, 0x5, 0x4c, 0x27, 0x2, 0x128, + 0x12d, 0x5, 0x4a, 0x26, 0x2, 0x129, 0x12d, 0x5, 0x56, 0x2c, 0x2, + 0x12a, 0x12d, 0x5, 0x4e, 0x28, 0x2, 0x12b, 0x12d, 0x5, 0x40, 0x21, + 0x2, 0x12c, 0x126, 0x3, 0x2, 0x2, 0x2, 0x12c, 0x127, 0x3, 0x2, 0x2, + 0x2, 0x12c, 0x128, 0x3, 0x2, 0x2, 0x2, 0x12c, 0x129, 0x3, 0x2, 0x2, + 0x2, 0x12c, 0x12a, 0x3, 0x2, 0x2, 0x2, 0x12c, 0x12b, 0x3, 0x2, 0x2, + 0x2, 0x12d, 0x39, 0x3, 0x2, 0x2, 0x2, 0x12e, 0x134, 0x5, 0x3e, 0x20, + 0x2, 0x12f, 0x134, 0x5, 0x4c, 0x27, 0x2, 0x130, 0x134, 0x5, 0x4a, + 0x26, 0x2, 0x131, 0x134, 0x5, 0x56, 0x2c, 0x2, 0x132, 0x134, 0x5, + 0x4e, 0x28, 0x2, 0x133, 0x12e, 0x3, 0x2, 0x2, 0x2, 0x133, 0x12f, + 0x3, 0x2, 0x2, 0x2, 0x133, 0x130, 0x3, 0x2, 0x2, 0x2, 0x133, 0x131, + 0x3, 0x2, 0x2, 0x2, 0x133, 0x132, 0x3, 0x2, 0x2, 0x2, 0x134, 0x3b, + 0x3, 0x2, 0x2, 0x2, 0x135, 0x139, 0x5, 0x3e, 0x20, 0x2, 0x136, 0x139, + 0x5, 0x4a, 0x26, 0x2, 0x137, 0x139, 0x5, 0x56, 0x2c, 0x2, 0x138, + 0x135, 0x3, 0x2, 0x2, 0x2, 0x138, 0x136, 0x3, 0x2, 0x2, 0x2, 0x138, + 0x137, 0x3, 0x2, 0x2, 0x2, 0x139, 0x3d, 0x3, 0x2, 0x2, 0x2, 0x13a, + 0x13b, 0x5, 0x58, 0x2d, 0x2, 0x13b, 0x144, 0x7, 0xb, 0x2, 0x2, 0x13c, + 0x141, 0x5, 0x38, 0x1d, 0x2, 0x13d, 0x13e, 0x7, 0xd, 0x2, 0x2, 0x13e, + 0x140, 0x5, 0x38, 0x1d, 0x2, 0x13f, 0x13d, 0x3, 0x2, 0x2, 0x2, 0x140, + 0x143, 0x3, 0x2, 0x2, 0x2, 0x141, 0x13f, 0x3, 0x2, 0x2, 0x2, 0x141, + 0x142, 0x3, 0x2, 0x2, 0x2, 0x142, 0x145, 0x3, 0x2, 0x2, 0x2, 0x143, + 0x141, 0x3, 0x2, 0x2, 0x2, 0x144, 0x13c, 0x3, 0x2, 0x2, 0x2, 0x144, + 0x145, 0x3, 0x2, 0x2, 0x2, 0x145, 0x146, 0x3, 0x2, 0x2, 0x2, 0x146, + 0x147, 0x7, 0xc, 0x2, 0x2, 0x147, 0x3f, 0x3, 0x2, 0x2, 0x2, 0x148, + 0x14d, 0x5, 0x42, 0x22, 0x2, 0x149, 0x14d, 0x5, 0x44, 0x23, 0x2, + 0x14a, 0x14d, 0x5, 0x46, 0x24, 0x2, 0x14b, 0x14d, 0x5, 0x48, 0x25, + 0x2, 0x14c, 0x148, 0x3, 0x2, 0x2, 0x2, 0x14c, 0x149, 0x3, 0x2, 0x2, + 0x2, 0x14c, 0x14a, 0x3, 0x2, 0x2, 0x2, 0x14c, 0x14b, 0x3, 0x2, 0x2, + 0x2, 0x14d, 0x41, 0x3, 0x2, 0x2, 0x2, 0x14e, 0x14f, 0x5, 0x3a, 0x1e, + 0x2, 0x14f, 0x150, 0x5, 0x64, 0x33, 0x2, 0x150, 0x156, 0x5, 0x3a, + 0x1e, 0x2, 0x151, 0x152, 0x5, 0x64, 0x33, 0x2, 0x152, 0x153, 0x5, + 0x3a, 0x1e, 0x2, 0x153, 0x155, 0x3, 0x2, 0x2, 0x2, 0x154, 0x151, + 0x3, 0x2, 0x2, 0x2, 0x155, 0x158, 0x3, 0x2, 0x2, 0x2, 0x156, 0x154, + 0x3, 0x2, 0x2, 0x2, 0x156, 0x157, 0x3, 0x2, 0x2, 0x2, 0x157, 0x43, + 0x3, 0x2, 0x2, 0x2, 0x158, 0x156, 0x3, 0x2, 0x2, 0x2, 0x159, 0x15a, + 0x5, 0x62, 0x32, 0x2, 0x15a, 0x15b, 0x5, 0x3a, 0x1e, 0x2, 0x15b, + 0x45, 0x3, 0x2, 0x2, 0x2, 0x15c, 0x15d, 0x5, 0x3a, 0x1e, 0x2, 0x15d, + 0x15e, 0x5, 0x60, 0x31, 0x2, 0x15e, 0x47, 0x3, 0x2, 0x2, 0x2, 0x15f, + 0x160, 0x5, 0x3a, 0x1e, 0x2, 0x160, 0x161, 0x7, 0x1a, 0x2, 0x2, 0x161, + 0x162, 0x5, 0x38, 0x1d, 0x2, 0x162, 0x163, 0x7, 0x5, 0x2, 0x2, 0x163, + 0x164, 0x5, 0x38, 0x1d, 0x2, 0x164, 0x49, 0x3, 0x2, 0x2, 0x2, 0x165, + 0x166, 0x5, 0x5a, 0x2e, 0x2, 0x166, 0x4b, 0x3, 0x2, 0x2, 0x2, 0x167, + 0x168, 0x9, 0x2, 0x2, 0x2, 0x168, 0x4d, 0x3, 0x2, 0x2, 0x2, 0x169, + 0x16b, 0x5, 0x3c, 0x1f, 0x2, 0x16a, 0x16c, 0x5, 0x50, 0x29, 0x2, + 0x16b, 0x16a, 0x3, 0x2, 0x2, 0x2, 0x16c, 0x16d, 0x3, 0x2, 0x2, 0x2, + 0x16d, 0x16b, 0x3, 0x2, 0x2, 0x2, 0x16d, 0x16e, 0x3, 0x2, 0x2, 0x2, + 0x16e, 0x4f, 0x3, 0x2, 0x2, 0x2, 0x16f, 0x172, 0x5, 0x52, 0x2a, 0x2, + 0x170, 0x172, 0x5, 0x54, 0x2b, 0x2, 0x171, 0x16f, 0x3, 0x2, 0x2, + 0x2, 0x171, 0x170, 0x3, 0x2, 0x2, 0x2, 0x172, 0x51, 0x3, 0x2, 0x2, + 0x2, 0x173, 0x174, 0x9, 0x3, 0x2, 0x2, 0x174, 0x175, 0x5, 0x4a, 0x26, + 0x2, 0x175, 0x53, 0x3, 0x2, 0x2, 0x2, 0x176, 0x177, 0x7, 0x8, 0x2, + 0x2, 0x177, 0x178, 0x5, 0x38, 0x1d, 0x2, 0x178, 0x179, 0x7, 0x9, + 0x2, 0x2, 0x179, 0x55, 0x3, 0x2, 0x2, 0x2, 0x17a, 0x17b, 0x7, 0xb, + 0x2, 0x2, 0x17b, 0x17c, 0x5, 0x38, 0x1d, 0x2, 0x17c, 0x17d, 0x7, + 0xc, 0x2, 0x2, 0x17d, 0x57, 0x3, 0x2, 0x2, 0x2, 0x17e, 0x17f, 0x7, + 0x3e, 0x2, 0x2, 0x17f, 0x59, 0x3, 0x2, 0x2, 0x2, 0x180, 0x181, 0x7, + 0x3e, 0x2, 0x2, 0x181, 0x5b, 0x3, 0x2, 0x2, 0x2, 0x182, 0x183, 0x7, + 0x3e, 0x2, 0x2, 0x183, 0x5d, 0x3, 0x2, 0x2, 0x2, 0x184, 0x185, 0x7, + 0x3e, 0x2, 0x2, 0x185, 0x5f, 0x3, 0x2, 0x2, 0x2, 0x186, 0x187, 0x9, + 0x4, 0x2, 0x2, 0x187, 0x61, 0x3, 0x2, 0x2, 0x2, 0x188, 0x190, 0x7, + 0x1f, 0x2, 0x2, 0x189, 0x190, 0x7, 0x20, 0x2, 0x2, 0x18a, 0x190, + 0x7, 0x21, 0x2, 0x2, 0x18b, 0x190, 0x7, 0x22, 0x2, 0x2, 0x18c, 0x190, + 0x7, 0x23, 0x2, 0x2, 0x18d, 0x190, 0x7, 0x7, 0x2, 0x2, 0x18e, 0x190, + 0x5, 0x60, 0x31, 0x2, 0x18f, 0x188, 0x3, 0x2, 0x2, 0x2, 0x18f, 0x189, + 0x3, 0x2, 0x2, 0x2, 0x18f, 0x18a, 0x3, 0x2, 0x2, 0x2, 0x18f, 0x18b, + 0x3, 0x2, 0x2, 0x2, 0x18f, 0x18c, 0x3, 0x2, 0x2, 0x2, 0x18f, 0x18d, + 0x3, 0x2, 0x2, 0x2, 0x18f, 0x18e, 0x3, 0x2, 0x2, 0x2, 0x190, 0x63, + 0x3, 0x2, 0x2, 0x2, 0x191, 0x192, 0x9, 0x5, 0x2, 0x2, 0x192, 0x65, + 0x3, 0x2, 0x2, 0x2, 0x1f, 0x69, 0x72, 0x7d, 0x8a, 0x90, 0x93, 0x9a, + 0xa9, 0xac, 0xb2, 0xba, 0xc0, 0xc7, 0xd4, 0xe9, 0xf1, 0xf5, 0x107, + 0x113, 0x12c, 0x133, 0x138, 0x141, 0x144, 0x14c, 0x156, 0x16d, 0x171, + 0x18f, }; _serializedATN.insert(_serializedATN.end(), serializedATNSegment0,