X-Git-Url: https://gitweb.ps.run/toc/blobdiff_plain/45409c781a9e35df68c43b1e2f028d30bf90c0a0..c2ba7425955ae538e220cec79d9124756d1b4c8b:/gen/TocParser.cpp?ds=sidebyside diff --git a/gen/TocParser.cpp b/gen/TocParser.cpp index 8c58634..ec0c2e8 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,21 @@ TocParser::ProgContext* TocParser::prog() { }); try { enterOuterAlt(_localctx, 1); - setState(75); + setState(79); _errHandler->sync(this); _la = _input->LA(1); do { - setState(74); + setState(78); decl(); - setState(77); + setState(81); _errHandler->sync(this); _la = _input->LA(1); } while ((((_la & ~ 0x3fULL) == 0) && - ((1ULL << _la) & ((1ULL << TocParser::T__0) - | (1ULL << TocParser::T__3) - | (1ULL << TocParser::T__9))) != 0)); - setState(79); + ((1ULL << _la) & ((1ULL << TocParser::T__1) + | (1ULL << TocParser::T__4) + | (1ULL << TocParser::T__11) + | (1ULL << TocParser::T__15))) != 0)); + setState(83); match(TocParser::EOF); } @@ -124,22 +113,15 @@ TocParser::StructDeclContext* TocParser::DeclContext::structDecl() { return getRuleContext(0); } +TocParser::NamespaceDeclContext* TocParser::DeclContext::namespaceDecl() { + return getRuleContext(0); +} + 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,30 +135,39 @@ TocParser::DeclContext* TocParser::decl() { exitRule(); }); try { - setState(84); + setState(91); _errHandler->sync(this); switch (_input->LA(1)) { - case TocParser::T__0: { + case TocParser::T__4: { enterOuterAlt(_localctx, 1); - setState(81); + setState(85); varDecl(); + setState(86); + match(TocParser::T__0); break; } - case TocParser::T__3: { + case TocParser::T__11: { enterOuterAlt(_localctx, 2); - setState(82); + setState(88); funcDecl(); break; } - case TocParser::T__9: { + case TocParser::T__15: { enterOuterAlt(_localctx, 3); - setState(83); + setState(89); structDecl(); break; } + case TocParser::T__1: { + enterOuterAlt(_localctx, 4); + setState(90); + namespaceDecl(); + break; + } + default: throw NoViableAltException(this); } @@ -191,36 +182,34 @@ TocParser::DeclContext* TocParser::decl() { return _localctx; } -//----------------- VarDeclContext ------------------------------------------------------------------ +//----------------- NamespaceDeclContext ------------------------------------------------------------------ -TocParser::VarDeclContext::VarDeclContext(ParserRuleContext *parent, size_t invokingState) +TocParser::NamespaceDeclContext::NamespaceDeclContext(ParserRuleContext *parent, size_t invokingState) : ParserRuleContext(parent, invokingState) { } -TocParser::VarContext* TocParser::VarDeclContext::var() { - return getRuleContext(0); +TocParser::TypeNameContext* TocParser::NamespaceDeclContext::typeName() { + return getRuleContext(0); } - -size_t TocParser::VarDeclContext::getRuleIndex() const { - return TocParser::RuleVarDecl; +std::vector TocParser::NamespaceDeclContext::decl() { + return getRuleContexts(); } -void TocParser::VarDeclContext::enterRule(tree::ParseTreeListener *listener) { - auto parserListener = dynamic_cast(listener); - if (parserListener != nullptr) - parserListener->enterVarDecl(this); +TocParser::DeclContext* TocParser::NamespaceDeclContext::decl(size_t i) { + return getRuleContext(i); } -void TocParser::VarDeclContext::exitRule(tree::ParseTreeListener *listener) { - auto parserListener = dynamic_cast(listener); - if (parserListener != nullptr) - parserListener->exitVarDecl(this); + +size_t TocParser::NamespaceDeclContext::getRuleIndex() const { + return TocParser::RuleNamespaceDecl; } -TocParser::VarDeclContext* TocParser::varDecl() { - VarDeclContext *_localctx = _tracker.createInstance(_ctx, getState()); - enterRule(_localctx, 4, TocParser::RuleVarDecl); + +TocParser::NamespaceDeclContext* TocParser::namespaceDecl() { + NamespaceDeclContext *_localctx = _tracker.createInstance(_ctx, getState()); + enterRule(_localctx, 4, TocParser::RuleNamespaceDecl); + size_t _la = 0; #if __cplusplus > 201703L auto onExit = finally([=, this] { @@ -231,10 +220,28 @@ TocParser::VarDeclContext* TocParser::varDecl() { }); try { enterOuterAlt(_localctx, 1); - setState(86); - match(TocParser::T__0); - setState(87); - var(); + setState(93); + match(TocParser::T__1); + setState(94); + typeName(); + setState(95); + match(TocParser::T__2); + setState(99); + _errHandler->sync(this); + _la = _input->LA(1); + while ((((_la & ~ 0x3fULL) == 0) && + ((1ULL << _la) & ((1ULL << TocParser::T__1) + | (1ULL << TocParser::T__4) + | (1ULL << TocParser::T__11) + | (1ULL << TocParser::T__15))) != 0)) { + setState(96); + decl(); + setState(101); + _errHandler->sync(this); + _la = _input->LA(1); + } + setState(102); + match(TocParser::T__3); } catch (RecognitionException &e) { @@ -246,45 +253,25 @@ TocParser::VarDeclContext* TocParser::varDecl() { return _localctx; } -//----------------- VarContext ------------------------------------------------------------------ +//----------------- VarDeclContext ------------------------------------------------------------------ -TocParser::VarContext::VarContext(ParserRuleContext *parent, size_t invokingState) +TocParser::VarDeclContext::VarDeclContext(ParserRuleContext *parent, size_t invokingState) : ParserRuleContext(parent, invokingState) { } -TocParser::VarNameContext* TocParser::VarContext::varName() { - return getRuleContext(0); -} - -TocParser::TypeContext* TocParser::VarContext::type() { - return getRuleContext(0); -} - -TocParser::ExprContext* TocParser::VarContext::expr() { - return getRuleContext(0); +TocParser::VarContext* TocParser::VarDeclContext::var() { + return getRuleContext(0); } -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); +size_t TocParser::VarDeclContext::getRuleIndex() const { + return TocParser::RuleVarDecl; } -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()); - enterRule(_localctx, 6, TocParser::RuleVar); - size_t _la = 0; +TocParser::VarDeclContext* TocParser::varDecl() { + VarDeclContext *_localctx = _tracker.createInstance(_ctx, getState()); + enterRule(_localctx, 6, TocParser::RuleVarDecl); #if __cplusplus > 201703L auto onExit = finally([=, this] { @@ -295,23 +282,10 @@ TocParser::VarContext* TocParser::var() { }); try { enterOuterAlt(_localctx, 1); - setState(89); - varName(); - - setState(90); - match(TocParser::T__1); - setState(91); - type(); - setState(95); - _errHandler->sync(this); - - _la = _input->LA(1); - if (_la == TocParser::T__2) { - setState(93); - match(TocParser::T__2); - setState(94); - expr(); - } + setState(104); + match(TocParser::T__4); + setState(105); + var(); } catch (RecognitionException &e) { @@ -323,36 +297,34 @@ TocParser::VarContext* TocParser::var() { return _localctx; } -//----------------- TypeContext ------------------------------------------------------------------ +//----------------- VarContext ------------------------------------------------------------------ -TocParser::TypeContext::TypeContext(ParserRuleContext *parent, size_t invokingState) +TocParser::VarContext::VarContext(ParserRuleContext *parent, size_t invokingState) : ParserRuleContext(parent, invokingState) { } -TocParser::TypeNameContext* TocParser::TypeContext::typeName() { - return getRuleContext(0); +TocParser::VarNameContext* TocParser::VarContext::varName() { + return getRuleContext(0); } - -size_t TocParser::TypeContext::getRuleIndex() const { - return TocParser::RuleType; +TocParser::TypeContext* TocParser::VarContext::type() { + return getRuleContext(0); } -void TocParser::TypeContext::enterRule(tree::ParseTreeListener *listener) { - auto parserListener = dynamic_cast(listener); - if (parserListener != nullptr) - parserListener->enterType(this); +TocParser::ExprContext* TocParser::VarContext::expr() { + return getRuleContext(0); } -void TocParser::TypeContext::exitRule(tree::ParseTreeListener *listener) { - auto parserListener = dynamic_cast(listener); - if (parserListener != nullptr) - parserListener->exitType(this); + +size_t TocParser::VarContext::getRuleIndex() const { + return TocParser::RuleVar; } -TocParser::TypeContext* TocParser::type() { - TypeContext *_localctx = _tracker.createInstance(_ctx, getState()); - enterRule(_localctx, 8, TocParser::RuleType); + +TocParser::VarContext* TocParser::var() { + VarContext *_localctx = _tracker.createInstance(_ctx, getState()); + enterRule(_localctx, 8, TocParser::RuleVar); + size_t _la = 0; #if __cplusplus > 201703L auto onExit = finally([=, this] { @@ -363,8 +335,23 @@ TocParser::TypeContext* TocParser::type() { }); try { enterOuterAlt(_localctx, 1); - setState(97); - typeName(); + setState(107); + varName(); + + setState(108); + match(TocParser::T__5); + setState(109); + type(); + setState(113); + _errHandler->sync(this); + + _la = _input->LA(1); + if (_la == TocParser::T__6) { + setState(111); + match(TocParser::T__6); + setState(112); + expr(0); + } } catch (RecognitionException &e) { @@ -376,36 +363,33 @@ TocParser::TypeContext* TocParser::type() { return _localctx; } -//----------------- FuncDeclContext ------------------------------------------------------------------ +//----------------- VarInitContext ------------------------------------------------------------------ -TocParser::FuncDeclContext::FuncDeclContext(ParserRuleContext *parent, size_t invokingState) +TocParser::VarInitContext::VarInitContext(ParserRuleContext *parent, size_t invokingState) : ParserRuleContext(parent, invokingState) { } -TocParser::FuncContext* TocParser::FuncDeclContext::func() { - return getRuleContext(0); +TocParser::VarNameContext* TocParser::VarInitContext::varName() { + return getRuleContext(0); } - -size_t TocParser::FuncDeclContext::getRuleIndex() const { - return TocParser::RuleFuncDecl; +TocParser::TypeContext* TocParser::VarInitContext::type() { + return getRuleContext(0); } -void TocParser::FuncDeclContext::enterRule(tree::ParseTreeListener *listener) { - auto parserListener = dynamic_cast(listener); - if (parserListener != nullptr) - parserListener->enterFuncDecl(this); +TocParser::ExprContext* TocParser::VarInitContext::expr() { + return getRuleContext(0); } -void TocParser::FuncDeclContext::exitRule(tree::ParseTreeListener *listener) { - auto parserListener = dynamic_cast(listener); - if (parserListener != nullptr) - parserListener->exitFuncDecl(this); + +size_t TocParser::VarInitContext::getRuleIndex() const { + return TocParser::RuleVarInit; } -TocParser::FuncDeclContext* TocParser::funcDecl() { - FuncDeclContext *_localctx = _tracker.createInstance(_ctx, getState()); - enterRule(_localctx, 10, TocParser::RuleFuncDecl); + +TocParser::VarInitContext* TocParser::varInit() { + VarInitContext *_localctx = _tracker.createInstance(_ctx, getState()); + enterRule(_localctx, 10, TocParser::RuleVarInit); #if __cplusplus > 201703L auto onExit = finally([=, this] { @@ -416,10 +400,18 @@ TocParser::FuncDeclContext* TocParser::funcDecl() { }); try { enterOuterAlt(_localctx, 1); - setState(99); - match(TocParser::T__3); - setState(100); - func(); + setState(115); + varName(); + + setState(116); + match(TocParser::T__5); + setState(117); + type(); + + setState(119); + match(TocParser::T__6); + setState(120); + expr(0); } catch (RecognitionException &e) { @@ -431,48 +423,42 @@ TocParser::FuncDeclContext* TocParser::funcDecl() { return _localctx; } -//----------------- FuncContext ------------------------------------------------------------------ +//----------------- TypeContext ------------------------------------------------------------------ -TocParser::FuncContext::FuncContext(ParserRuleContext *parent, size_t invokingState) +TocParser::TypeContext::TypeContext(ParserRuleContext *parent, size_t invokingState) : ParserRuleContext(parent, invokingState) { } -TocParser::FuncNameContext* TocParser::FuncContext::funcName() { - return getRuleContext(0); +TocParser::TypeNameContext* TocParser::TypeContext::typeName() { + return getRuleContext(0); } -TocParser::ParameterContext* TocParser::FuncContext::parameter() { - return getRuleContext(0); +std::vector TocParser::TypeContext::namespaceSpecifier() { + return getRuleContexts(); } -TocParser::BodyContext* TocParser::FuncContext::body() { - return getRuleContext(0); +TocParser::NamespaceSpecifierContext* TocParser::TypeContext::namespaceSpecifier(size_t i) { + return getRuleContext(i); } -TocParser::TypeContext* TocParser::FuncContext::type() { - return getRuleContext(0); +std::vector TocParser::TypeContext::typeModifier() { + return getRuleContexts(); } - -size_t TocParser::FuncContext::getRuleIndex() const { - return TocParser::RuleFunc; +TocParser::TypeModifierContext* TocParser::TypeContext::typeModifier(size_t i) { + return getRuleContext(i); } -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); +size_t TocParser::TypeContext::getRuleIndex() const { + return TocParser::RuleType; } -TocParser::FuncContext* TocParser::func() { - FuncContext *_localctx = _tracker.createInstance(_ctx, getState()); - enterRule(_localctx, 12, TocParser::RuleFunc); + +TocParser::TypeContext* TocParser::type() { + TypeContext *_localctx = _tracker.createInstance(_ctx, getState()); + enterRule(_localctx, 12, TocParser::RuleType); + size_t _la = 0; #if __cplusplus > 201703L auto onExit = finally([=, this] { @@ -482,22 +468,34 @@ TocParser::FuncContext* TocParser::func() { exitRule(); }); try { + size_t alt; enterOuterAlt(_localctx, 1); - setState(102); - funcName(); - setState(103); - match(TocParser::T__4); - setState(104); - parameter(); - setState(105); - match(TocParser::T__5); + setState(125); + _errHandler->sync(this); + alt = getInterpreter()->adaptivePredict(_input, 4, _ctx); + while (alt != 2 && alt != atn::ATN::INVALID_ALT_NUMBER) { + if (alt == 1) { + setState(122); + namespaceSpecifier(); + } + setState(127); + _errHandler->sync(this); + alt = getInterpreter()->adaptivePredict(_input, 4, _ctx); + } + setState(128); + typeName(); + setState(132); + _errHandler->sync(this); + _la = _input->LA(1); + while (_la == TocParser::T__7 - setState(106); - match(TocParser::T__1); - setState(107); - type(); - setState(109); - body(); + || _la == TocParser::T__8) { + setState(129); + typeModifier(); + setState(134); + _errHandler->sync(this); + _la = _input->LA(1); + } } catch (RecognitionException &e) { @@ -509,44 +507,25 @@ TocParser::FuncContext* TocParser::func() { return _localctx; } -//----------------- ParameterContext ------------------------------------------------------------------ +//----------------- TypeModifierContext ------------------------------------------------------------------ -TocParser::ParameterContext::ParameterContext(ParserRuleContext *parent, size_t invokingState) +TocParser::TypeModifierContext::TypeModifierContext(ParserRuleContext *parent, size_t invokingState) : ParserRuleContext(parent, invokingState) { } -TocParser::FirstParameterContext* TocParser::ParameterContext::firstParameter() { - return getRuleContext(0); -} - -std::vector TocParser::ParameterContext::additionalParameter() { - return getRuleContexts(); +tree::TerminalNode* TocParser::TypeModifierContext::INT_LIT() { + return getToken(TocParser::INT_LIT, 0); } -TocParser::AdditionalParameterContext* TocParser::ParameterContext::additionalParameter(size_t i) { - return getRuleContext(i); -} - - -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); +size_t TocParser::TypeModifierContext::getRuleIndex() const { + return TocParser::RuleTypeModifier; } -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()); - enterRule(_localctx, 14, TocParser::RuleParameter); +TocParser::TypeModifierContext* TocParser::typeModifier() { + TypeModifierContext *_localctx = _tracker.createInstance(_ctx, getState()); + enterRule(_localctx, 14, TocParser::RuleTypeModifier); size_t _la = 0; #if __cplusplus > 201703L @@ -557,24 +536,35 @@ TocParser::ParameterContext* TocParser::parameter() { exitRule(); }); try { - enterOuterAlt(_localctx, 1); - setState(118); + setState(141); _errHandler->sync(this); + switch (_input->LA(1)) { + case TocParser::T__7: { + enterOuterAlt(_localctx, 1); + setState(135); + match(TocParser::T__7); + break; + } - _la = _input->LA(1); - if (_la == TocParser::NAME) { - setState(111); - firstParameter(); - setState(115); - _errHandler->sync(this); - _la = _input->LA(1); - while (_la == TocParser::T__6) { - setState(112); - additionalParameter(); - setState(117); + case TocParser::T__8: { + enterOuterAlt(_localctx, 2); + setState(136); + match(TocParser::T__8); + setState(138); _errHandler->sync(this); + _la = _input->LA(1); + if (_la == TocParser::INT_LIT) { + setState(137); + match(TocParser::INT_LIT); + } + setState(140); + match(TocParser::T__9); + break; } + + default: + throw NoViableAltException(this); } } @@ -587,36 +577,25 @@ TocParser::ParameterContext* TocParser::parameter() { return _localctx; } -//----------------- FirstParameterContext ------------------------------------------------------------------ +//----------------- NamespaceSpecifierContext ------------------------------------------------------------------ -TocParser::FirstParameterContext::FirstParameterContext(ParserRuleContext *parent, size_t invokingState) +TocParser::NamespaceSpecifierContext::NamespaceSpecifierContext(ParserRuleContext *parent, size_t invokingState) : ParserRuleContext(parent, invokingState) { } -TocParser::VarContext* TocParser::FirstParameterContext::var() { - return getRuleContext(0); +TocParser::TypeNameContext* TocParser::NamespaceSpecifierContext::typeName() { + return getRuleContext(0); } -size_t TocParser::FirstParameterContext::getRuleIndex() const { - return TocParser::RuleFirstParameter; -} - -void TocParser::FirstParameterContext::enterRule(tree::ParseTreeListener *listener) { - auto parserListener = dynamic_cast(listener); - if (parserListener != nullptr) - parserListener->enterFirstParameter(this); +size_t TocParser::NamespaceSpecifierContext::getRuleIndex() const { + return TocParser::RuleNamespaceSpecifier; } -void TocParser::FirstParameterContext::exitRule(tree::ParseTreeListener *listener) { - auto parserListener = dynamic_cast(listener); - if (parserListener != nullptr) - parserListener->exitFirstParameter(this); -} -TocParser::FirstParameterContext* TocParser::firstParameter() { - FirstParameterContext *_localctx = _tracker.createInstance(_ctx, getState()); - enterRule(_localctx, 16, TocParser::RuleFirstParameter); +TocParser::NamespaceSpecifierContext* TocParser::namespaceSpecifier() { + NamespaceSpecifierContext *_localctx = _tracker.createInstance(_ctx, getState()); + enterRule(_localctx, 16, TocParser::RuleNamespaceSpecifier); #if __cplusplus > 201703L auto onExit = finally([=, this] { @@ -627,8 +606,10 @@ TocParser::FirstParameterContext* TocParser::firstParameter() { }); try { enterOuterAlt(_localctx, 1); - setState(120); - var(); + setState(143); + typeName(); + setState(144); + match(TocParser::T__10); } catch (RecognitionException &e) { @@ -640,36 +621,25 @@ TocParser::FirstParameterContext* TocParser::firstParameter() { return _localctx; } -//----------------- AdditionalParameterContext ------------------------------------------------------------------ +//----------------- FuncDeclContext ------------------------------------------------------------------ -TocParser::AdditionalParameterContext::AdditionalParameterContext(ParserRuleContext *parent, size_t invokingState) +TocParser::FuncDeclContext::FuncDeclContext(ParserRuleContext *parent, size_t invokingState) : ParserRuleContext(parent, invokingState) { } -TocParser::VarContext* TocParser::AdditionalParameterContext::var() { - return getRuleContext(0); +TocParser::FuncContext* TocParser::FuncDeclContext::func() { + return getRuleContext(0); } -size_t TocParser::AdditionalParameterContext::getRuleIndex() const { - return TocParser::RuleAdditionalParameter; -} - -void TocParser::AdditionalParameterContext::enterRule(tree::ParseTreeListener *listener) { - auto parserListener = dynamic_cast(listener); - if (parserListener != nullptr) - parserListener->enterAdditionalParameter(this); +size_t TocParser::FuncDeclContext::getRuleIndex() const { + return TocParser::RuleFuncDecl; } -void TocParser::AdditionalParameterContext::exitRule(tree::ParseTreeListener *listener) { - auto parserListener = dynamic_cast(listener); - if (parserListener != nullptr) - parserListener->exitAdditionalParameter(this); -} -TocParser::AdditionalParameterContext* TocParser::additionalParameter() { - AdditionalParameterContext *_localctx = _tracker.createInstance(_ctx, getState()); - enterRule(_localctx, 18, TocParser::RuleAdditionalParameter); +TocParser::FuncDeclContext* TocParser::funcDecl() { + FuncDeclContext *_localctx = _tracker.createInstance(_ctx, getState()); + enterRule(_localctx, 18, TocParser::RuleFuncDecl); #if __cplusplus > 201703L auto onExit = finally([=, this] { @@ -680,10 +650,171 @@ TocParser::AdditionalParameterContext* TocParser::additionalParameter() { }); try { enterOuterAlt(_localctx, 1); - setState(122); - match(TocParser::T__6); - setState(123); - var(); + setState(146); + match(TocParser::T__11); + setState(147); + func(); + + } + catch (RecognitionException &e) { + _errHandler->reportError(this, e); + _localctx->exception = std::current_exception(); + _errHandler->recover(this, _localctx->exception); + } + + return _localctx; +} + +//----------------- FuncContext ------------------------------------------------------------------ + +TocParser::FuncContext::FuncContext(ParserRuleContext *parent, size_t invokingState) + : ParserRuleContext(parent, invokingState) { +} + +TocParser::FuncNameContext* TocParser::FuncContext::funcName() { + return getRuleContext(0); +} + +TocParser::ParameterContext* TocParser::FuncContext::parameter() { + return getRuleContext(0); +} + +TocParser::TypeContext* TocParser::FuncContext::type() { + return getRuleContext(0); +} + +TocParser::BodyContext* TocParser::FuncContext::body() { + return getRuleContext(0); +} + +TocParser::GenericDeclContext* TocParser::FuncContext::genericDecl() { + return getRuleContext(0); +} + + +size_t TocParser::FuncContext::getRuleIndex() const { + return TocParser::RuleFunc; +} + + +TocParser::FuncContext* TocParser::func() { + FuncContext *_localctx = _tracker.createInstance(_ctx, getState()); + enterRule(_localctx, 20, TocParser::RuleFunc); + size_t _la = 0; + +#if __cplusplus > 201703L + auto onExit = finally([=, this] { +#else + auto onExit = finally([=] { +#endif + exitRule(); + }); + try { + enterOuterAlt(_localctx, 1); + setState(149); + funcName(); + setState(151); + _errHandler->sync(this); + + _la = _input->LA(1); + if (_la == TocParser::T__17) { + setState(150); + genericDecl(); + } + setState(153); + match(TocParser::T__12); + setState(154); + parameter(); + setState(155); + match(TocParser::T__13); + + setState(156); + match(TocParser::T__5); + setState(157); + type(); + setState(161); + _errHandler->sync(this); + switch (_input->LA(1)) { + case TocParser::T__2: { + setState(159); + body(); + break; + } + + case TocParser::T__0: { + setState(160); + match(TocParser::T__0); + break; + } + + default: + throw NoViableAltException(this); + } + + } + catch (RecognitionException &e) { + _errHandler->reportError(this, e); + _localctx->exception = std::current_exception(); + _errHandler->recover(this, _localctx->exception); + } + + return _localctx; +} + +//----------------- ParameterContext ------------------------------------------------------------------ + +TocParser::ParameterContext::ParameterContext(ParserRuleContext *parent, size_t invokingState) + : ParserRuleContext(parent, invokingState) { +} + +std::vector TocParser::ParameterContext::var() { + return getRuleContexts(); +} + +TocParser::VarContext* TocParser::ParameterContext::var(size_t i) { + return getRuleContext(i); +} + + +size_t TocParser::ParameterContext::getRuleIndex() const { + return TocParser::RuleParameter; +} + + +TocParser::ParameterContext* TocParser::parameter() { + ParameterContext *_localctx = _tracker.createInstance(_ctx, getState()); + enterRule(_localctx, 22, TocParser::RuleParameter); + size_t _la = 0; + +#if __cplusplus > 201703L + auto onExit = finally([=, this] { +#else + auto onExit = finally([=] { +#endif + exitRule(); + }); + try { + enterOuterAlt(_localctx, 1); + setState(171); + _errHandler->sync(this); + + _la = _input->LA(1); + if (_la == TocParser::NAME) { + setState(163); + var(); + setState(168); + _errHandler->sync(this); + _la = _input->LA(1); + while (_la == TocParser::T__14) { + setState(164); + match(TocParser::T__14); + setState(165); + var(); + setState(170); + _errHandler->sync(this); + _la = _input->LA(1); + } + } } catch (RecognitionException &e) { @@ -714,21 +845,10 @@ 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()); - enterRule(_localctx, 20, TocParser::RuleBody); + enterRule(_localctx, 24, TocParser::RuleBody); size_t _la = 0; #if __cplusplus > 201703L @@ -740,27 +860,40 @@ TocParser::BodyContext* TocParser::body() { }); try { enterOuterAlt(_localctx, 1); - setState(125); - match(TocParser::T__7); - setState(129); + setState(173); + match(TocParser::T__2); + setState(177); _errHandler->sync(this); _la = _input->LA(1); while ((((_la & ~ 0x3fULL) == 0) && - ((1ULL << _la) & ((1ULL << TocParser::T__0) - | (1ULL << TocParser::T__4) - | (1ULL << TocParser::T__10) - | (1ULL << TocParser::T__11) + ((1ULL << _la) & ((1ULL << TocParser::T__4) + | (1ULL << TocParser::T__7) | (1ULL << TocParser::T__12) - | (1ULL << TocParser::INTLIT) + | (1ULL << TocParser::T__19) + | (1ULL << TocParser::T__21) + | (1ULL << TocParser::T__23) + | (1ULL << TocParser::T__24) + | (1ULL << TocParser::T__25) + | (1ULL << TocParser::T__28) + | (1ULL << TocParser::T__29) + | (1ULL << TocParser::T__30) + | (1ULL << TocParser::T__31) + | (1ULL << TocParser::T__32) + | (1ULL << TocParser::T__33) + | (1ULL << TocParser::T__34) + | (1ULL << TocParser::INT_LIT) + | (1ULL << TocParser::DECIMAL_LIT) + | (1ULL << TocParser::BOOL_LIT) + | (1ULL << TocParser::StringLit) | (1ULL << TocParser::NAME))) != 0)) { - setState(126); + setState(174); stmt(); - setState(131); + setState(179); _errHandler->sync(this); _la = _input->LA(1); } - setState(132); - match(TocParser::T__8); + setState(180); + match(TocParser::T__3); } catch (RecognitionException &e) { @@ -782,6 +915,10 @@ TocParser::StructNameContext* TocParser::StructDeclContext::structName() { return getRuleContext(0); } +TocParser::GenericDeclContext* TocParser::StructDeclContext::genericDecl() { + return getRuleContext(0); +} + std::vector TocParser::StructDeclContext::structMember() { return getRuleContexts(); } @@ -795,21 +932,10 @@ 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()); - enterRule(_localctx, 22, TocParser::RuleStructDecl); + enterRule(_localctx, 26, TocParser::RuleStructDecl); size_t _la = 0; #if __cplusplus > 201703L @@ -821,24 +947,34 @@ TocParser::StructDeclContext* TocParser::structDecl() { }); try { enterOuterAlt(_localctx, 1); - setState(134); - match(TocParser::T__9); - setState(135); + setState(182); + match(TocParser::T__15); + setState(183); structName(); - setState(136); - match(TocParser::T__7); - setState(140); + setState(185); + _errHandler->sync(this); + + _la = _input->LA(1); + if (_la == TocParser::T__17) { + setState(184); + genericDecl(); + } + setState(187); + match(TocParser::T__2); + setState(191); _errHandler->sync(this); _la = _input->LA(1); - while (_la == TocParser::NAME) { - setState(137); + while (_la == TocParser::T__16 + + || _la == TocParser::NAME) { + setState(188); structMember(); - setState(142); + setState(193); _errHandler->sync(this); _la = _input->LA(1); } - setState(143); - match(TocParser::T__8); + setState(194); + match(TocParser::T__3); } catch (RecognitionException &e) { @@ -860,6 +996,10 @@ TocParser::StructVarContext* TocParser::StructMemberContext::structVar() { return getRuleContext(0); } +TocParser::PrivateDeclContext* TocParser::StructMemberContext::privateDecl() { + return getRuleContext(0); +} + TocParser::StructMethodContext* TocParser::StructMemberContext::structMethod() { return getRuleContext(0); } @@ -869,21 +1009,11 @@ 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()); - enterRule(_localctx, 24, TocParser::RuleStructMember); + enterRule(_localctx, 28, TocParser::RuleStructMember); + size_t _la = 0; #if __cplusplus > 201703L auto onExit = finally([=, this] { @@ -893,19 +1023,27 @@ TocParser::StructMemberContext* TocParser::structMember() { exitRule(); }); try { - setState(147); + setState(201); _errHandler->sync(this); - switch (getInterpreter()->adaptivePredict(_input, 7, _ctx)) { + switch (getInterpreter()->adaptivePredict(_input, 16, _ctx)) { case 1: { enterOuterAlt(_localctx, 1); - setState(145); + setState(197); + _errHandler->sync(this); + + _la = _input->LA(1); + if (_la == TocParser::T__16) { + setState(196); + privateDecl(); + } + setState(199); structVar(); break; } case 2: { enterOuterAlt(_localctx, 2); - setState(146); + setState(200); structMethod(); break; } @@ -939,21 +1077,10 @@ 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()); - enterRule(_localctx, 26, TocParser::RuleStructVar); + enterRule(_localctx, 30, TocParser::RuleStructVar); #if __cplusplus > 201703L auto onExit = finally([=, this] { @@ -964,8 +1091,10 @@ TocParser::StructVarContext* TocParser::structVar() { }); try { enterOuterAlt(_localctx, 1); - setState(149); + setState(203); var(); + setState(204); + match(TocParser::T__0); } catch (RecognitionException &e) { @@ -992,21 +1121,10 @@ 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()); - enterRule(_localctx, 28, TocParser::RuleStructMethod); + enterRule(_localctx, 32, TocParser::RuleStructMethod); #if __cplusplus > 201703L auto onExit = finally([=, this] { @@ -1017,7 +1135,7 @@ TocParser::StructMethodContext* TocParser::structMethod() { }); try { enterOuterAlt(_localctx, 1); - setState(151); + setState(206); func(); } @@ -1030,56 +1148,21 @@ TocParser::StructMethodContext* TocParser::structMethod() { return _localctx; } -//----------------- StmtContext ------------------------------------------------------------------ +//----------------- PrivateDeclContext ------------------------------------------------------------------ -TocParser::StmtContext::StmtContext(ParserRuleContext *parent, size_t invokingState) +TocParser::PrivateDeclContext::PrivateDeclContext(ParserRuleContext *parent, size_t invokingState) : ParserRuleContext(parent, invokingState) { } -TocParser::VarDeclContext* TocParser::StmtContext::varDecl() { - return getRuleContext(0); -} - -TocParser::ConditionalContext* TocParser::StmtContext::conditional() { - return getRuleContext(0); -} - -TocParser::LoopContext* TocParser::StmtContext::loop() { - return getRuleContext(0); -} - -TocParser::AssignmentContext* TocParser::StmtContext::assignment() { - return getRuleContext(0); -} - -TocParser::ReturnStmtContext* TocParser::StmtContext::returnStmt() { - return getRuleContext(0); -} - -TocParser::ExprContext* TocParser::StmtContext::expr() { - return getRuleContext(0); -} - - -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); +size_t TocParser::PrivateDeclContext::getRuleIndex() const { + return TocParser::RulePrivateDecl; } -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); +TocParser::PrivateDeclContext* TocParser::privateDecl() { + PrivateDeclContext *_localctx = _tracker.createInstance(_ctx, getState()); + enterRule(_localctx, 34, TocParser::RulePrivateDecl); #if __cplusplus > 201703L auto onExit = finally([=, this] { @@ -1090,48 +1173,8 @@ TocParser::StmtContext* TocParser::stmt() { }); try { enterOuterAlt(_localctx, 1); - setState(159); - _errHandler->sync(this); - switch (getInterpreter()->adaptivePredict(_input, 8, _ctx)) { - case 1: { - setState(153); - varDecl(); - break; - } - - case 2: { - setState(154); - conditional(); - break; - } - - case 3: { - setState(155); - loop(); - break; - } - - case 4: { - setState(156); - assignment(); - break; - } - - case 5: { - setState(157); - returnStmt(); - break; - } - - case 6: { - setState(158); - expr(); - break; - } - - default: - break; - } + setState(208); + match(TocParser::T__16); } catch (RecognitionException &e) { @@ -1143,36 +1186,30 @@ TocParser::StmtContext* TocParser::stmt() { return _localctx; } -//----------------- ConditionalContext ------------------------------------------------------------------ +//----------------- GenericDeclContext ------------------------------------------------------------------ -TocParser::ConditionalContext::ConditionalContext(ParserRuleContext *parent, size_t invokingState) +TocParser::GenericDeclContext::GenericDeclContext(ParserRuleContext *parent, size_t invokingState) : ParserRuleContext(parent, invokingState) { } -TocParser::IfCondContext* TocParser::ConditionalContext::ifCond() { - return getRuleContext(0); +std::vector TocParser::GenericDeclContext::typeName() { + return getRuleContexts(); } - -size_t TocParser::ConditionalContext::getRuleIndex() const { - return TocParser::RuleConditional; +TocParser::TypeNameContext* TocParser::GenericDeclContext::typeName(size_t i) { + return getRuleContext(i); } -void TocParser::ConditionalContext::enterRule(tree::ParseTreeListener *listener) { - auto parserListener = dynamic_cast(listener); - if (parserListener != nullptr) - parserListener->enterConditional(this); -} -void TocParser::ConditionalContext::exitRule(tree::ParseTreeListener *listener) { - auto parserListener = dynamic_cast(listener); - if (parserListener != nullptr) - parserListener->exitConditional(this); +size_t TocParser::GenericDeclContext::getRuleIndex() const { + return TocParser::RuleGenericDecl; } -TocParser::ConditionalContext* TocParser::conditional() { - ConditionalContext *_localctx = _tracker.createInstance(_ctx, getState()); - enterRule(_localctx, 32, TocParser::RuleConditional); + +TocParser::GenericDeclContext* TocParser::genericDecl() { + GenericDeclContext *_localctx = _tracker.createInstance(_ctx, getState()); + enterRule(_localctx, 36, TocParser::RuleGenericDecl); + size_t _la = 0; #if __cplusplus > 201703L auto onExit = finally([=, this] { @@ -1183,8 +1220,24 @@ TocParser::ConditionalContext* TocParser::conditional() { }); try { enterOuterAlt(_localctx, 1); - setState(161); - ifCond(); + setState(210); + match(TocParser::T__17); + setState(211); + typeName(); + setState(216); + _errHandler->sync(this); + _la = _input->LA(1); + while (_la == TocParser::T__14) { + setState(212); + match(TocParser::T__14); + setState(213); + typeName(); + setState(218); + _errHandler->sync(this); + _la = _input->LA(1); + } + setState(219); + match(TocParser::T__18); } catch (RecognitionException &e) { @@ -1196,40 +1249,53 @@ TocParser::ConditionalContext* TocParser::conditional() { return _localctx; } -//----------------- IfCondContext ------------------------------------------------------------------ +//----------------- StmtContext ------------------------------------------------------------------ -TocParser::IfCondContext::IfCondContext(ParserRuleContext *parent, size_t invokingState) +TocParser::StmtContext::StmtContext(ParserRuleContext *parent, size_t invokingState) : ParserRuleContext(parent, invokingState) { } -TocParser::ExprContext* TocParser::IfCondContext::expr() { - return getRuleContext(0); +TocParser::VarDeclContext* TocParser::StmtContext::varDecl() { + return getRuleContext(0); } -TocParser::BodyContext* TocParser::IfCondContext::body() { - return getRuleContext(0); +TocParser::IfStmtContext* TocParser::StmtContext::ifStmt() { + return getRuleContext(0); +} + +TocParser::SwitchStmtContext* TocParser::StmtContext::switchStmt() { + return getRuleContext(0); } +TocParser::ForStmtContext* TocParser::StmtContext::forStmt() { + return getRuleContext(0); +} -size_t TocParser::IfCondContext::getRuleIndex() const { - return TocParser::RuleIfCond; +TocParser::WhileStmtContext* TocParser::StmtContext::whileStmt() { + return getRuleContext(0); } -void TocParser::IfCondContext::enterRule(tree::ParseTreeListener *listener) { - auto parserListener = dynamic_cast(listener); - if (parserListener != nullptr) - parserListener->enterIfCond(this); +TocParser::AssignStmtContext* TocParser::StmtContext::assignStmt() { + return getRuleContext(0); } -void TocParser::IfCondContext::exitRule(tree::ParseTreeListener *listener) { - auto parserListener = dynamic_cast(listener); - if (parserListener != nullptr) - parserListener->exitIfCond(this); +TocParser::ReturnStmtContext* TocParser::StmtContext::returnStmt() { + return getRuleContext(0); +} + +TocParser::ExprContext* TocParser::StmtContext::expr() { + return getRuleContext(0); } -TocParser::IfCondContext* TocParser::ifCond() { - IfCondContext *_localctx = _tracker.createInstance(_ctx, getState()); - enterRule(_localctx, 34, TocParser::RuleIfCond); + +size_t TocParser::StmtContext::getRuleIndex() const { + return TocParser::RuleStmt; +} + + +TocParser::StmtContext* TocParser::stmt() { + StmtContext *_localctx = _tracker.createInstance(_ctx, getState()); + enterRule(_localctx, 38, TocParser::RuleStmt); #if __cplusplus > 201703L auto onExit = finally([=, this] { @@ -1239,13 +1305,76 @@ TocParser::IfCondContext* TocParser::ifCond() { exitRule(); }); try { - enterOuterAlt(_localctx, 1); - setState(163); - match(TocParser::T__10); - setState(164); - expr(); - setState(165); - body(); + setState(237); + _errHandler->sync(this); + switch (getInterpreter()->adaptivePredict(_input, 18, _ctx)) { + case 1: { + enterOuterAlt(_localctx, 1); + setState(221); + varDecl(); + setState(222); + match(TocParser::T__0); + break; + } + + case 2: { + enterOuterAlt(_localctx, 2); + setState(224); + ifStmt(); + break; + } + + case 3: { + enterOuterAlt(_localctx, 3); + setState(225); + switchStmt(); + break; + } + + case 4: { + enterOuterAlt(_localctx, 4); + setState(226); + forStmt(); + break; + } + + case 5: { + enterOuterAlt(_localctx, 5); + setState(227); + whileStmt(); + break; + } + + case 6: { + enterOuterAlt(_localctx, 6); + setState(228); + assignStmt(); + setState(229); + match(TocParser::T__0); + break; + } + + case 7: { + enterOuterAlt(_localctx, 7); + setState(231); + returnStmt(); + setState(232); + match(TocParser::T__0); + break; + } + + case 8: { + enterOuterAlt(_localctx, 8); + setState(234); + expr(0); + setState(235); + match(TocParser::T__0); + break; + } + + default: + break; + } } catch (RecognitionException &e) { @@ -1257,36 +1386,42 @@ TocParser::IfCondContext* TocParser::ifCond() { return _localctx; } -//----------------- LoopContext ------------------------------------------------------------------ +//----------------- IfStmtContext ------------------------------------------------------------------ -TocParser::LoopContext::LoopContext(ParserRuleContext *parent, size_t invokingState) +TocParser::IfStmtContext::IfStmtContext(ParserRuleContext *parent, size_t invokingState) : ParserRuleContext(parent, invokingState) { } -TocParser::WhileLoopContext* TocParser::LoopContext::whileLoop() { - return getRuleContext(0); +TocParser::ExprContext* TocParser::IfStmtContext::expr() { + return getRuleContext(0); } +TocParser::BodyContext* TocParser::IfStmtContext::body() { + return getRuleContext(0); +} -size_t TocParser::LoopContext::getRuleIndex() const { - return TocParser::RuleLoop; +std::vector TocParser::IfStmtContext::elseIfStmt() { + return getRuleContexts(); } -void TocParser::LoopContext::enterRule(tree::ParseTreeListener *listener) { - auto parserListener = dynamic_cast(listener); - if (parserListener != nullptr) - parserListener->enterLoop(this); +TocParser::ElseIfStmtContext* TocParser::IfStmtContext::elseIfStmt(size_t i) { + return getRuleContext(i); } -void TocParser::LoopContext::exitRule(tree::ParseTreeListener *listener) { - auto parserListener = dynamic_cast(listener); - if (parserListener != nullptr) - parserListener->exitLoop(this); +TocParser::ElseStmtContext* TocParser::IfStmtContext::elseStmt() { + return getRuleContext(0); } -TocParser::LoopContext* TocParser::loop() { - LoopContext *_localctx = _tracker.createInstance(_ctx, getState()); - enterRule(_localctx, 36, TocParser::RuleLoop); + +size_t TocParser::IfStmtContext::getRuleIndex() const { + return TocParser::RuleIfStmt; +} + + +TocParser::IfStmtContext* TocParser::ifStmt() { + IfStmtContext *_localctx = _tracker.createInstance(_ctx, getState()); + enterRule(_localctx, 40, TocParser::RuleIfStmt); + size_t _la = 0; #if __cplusplus > 201703L auto onExit = finally([=, this] { @@ -1296,9 +1431,34 @@ TocParser::LoopContext* TocParser::loop() { exitRule(); }); try { + size_t alt; enterOuterAlt(_localctx, 1); - setState(167); - whileLoop(); + setState(239); + match(TocParser::T__19); + setState(240); + expr(0); + setState(241); + body(); + setState(245); + _errHandler->sync(this); + alt = getInterpreter()->adaptivePredict(_input, 19, _ctx); + while (alt != 2 && alt != atn::ATN::INVALID_ALT_NUMBER) { + if (alt == 1) { + setState(242); + elseIfStmt(); + } + setState(247); + _errHandler->sync(this); + alt = getInterpreter()->adaptivePredict(_input, 19, _ctx); + } + setState(249); + _errHandler->sync(this); + + _la = _input->LA(1); + if (_la == TocParser::T__20) { + setState(248); + elseStmt(); + } } catch (RecognitionException &e) { @@ -1310,40 +1470,29 @@ TocParser::LoopContext* TocParser::loop() { return _localctx; } -//----------------- WhileLoopContext ------------------------------------------------------------------ +//----------------- ElseIfStmtContext ------------------------------------------------------------------ -TocParser::WhileLoopContext::WhileLoopContext(ParserRuleContext *parent, size_t invokingState) +TocParser::ElseIfStmtContext::ElseIfStmtContext(ParserRuleContext *parent, size_t invokingState) : ParserRuleContext(parent, invokingState) { } -TocParser::ExprContext* TocParser::WhileLoopContext::expr() { +TocParser::ExprContext* TocParser::ElseIfStmtContext::expr() { return getRuleContext(0); } -TocParser::BodyContext* TocParser::WhileLoopContext::body() { +TocParser::BodyContext* TocParser::ElseIfStmtContext::body() { return getRuleContext(0); } -size_t TocParser::WhileLoopContext::getRuleIndex() const { - return TocParser::RuleWhileLoop; -} - -void TocParser::WhileLoopContext::enterRule(tree::ParseTreeListener *listener) { - auto parserListener = dynamic_cast(listener); - if (parserListener != nullptr) - parserListener->enterWhileLoop(this); +size_t TocParser::ElseIfStmtContext::getRuleIndex() const { + return TocParser::RuleElseIfStmt; } -void TocParser::WhileLoopContext::exitRule(tree::ParseTreeListener *listener) { - auto parserListener = dynamic_cast(listener); - if (parserListener != nullptr) - parserListener->exitWhileLoop(this); -} -TocParser::WhileLoopContext* TocParser::whileLoop() { - WhileLoopContext *_localctx = _tracker.createInstance(_ctx, getState()); - enterRule(_localctx, 38, TocParser::RuleWhileLoop); +TocParser::ElseIfStmtContext* TocParser::elseIfStmt() { + ElseIfStmtContext *_localctx = _tracker.createInstance(_ctx, getState()); + enterRule(_localctx, 42, TocParser::RuleElseIfStmt); #if __cplusplus > 201703L auto onExit = finally([=, this] { @@ -1354,11 +1503,13 @@ TocParser::WhileLoopContext* TocParser::whileLoop() { }); try { enterOuterAlt(_localctx, 1); - setState(169); - match(TocParser::T__11); - setState(170); - expr(); - setState(171); + setState(251); + match(TocParser::T__20); + setState(252); + match(TocParser::T__19); + setState(253); + expr(0); + setState(254); body(); } @@ -1371,40 +1522,25 @@ TocParser::WhileLoopContext* TocParser::whileLoop() { return _localctx; } -//----------------- AssignmentContext ------------------------------------------------------------------ +//----------------- ElseStmtContext ------------------------------------------------------------------ -TocParser::AssignmentContext::AssignmentContext(ParserRuleContext *parent, size_t invokingState) +TocParser::ElseStmtContext::ElseStmtContext(ParserRuleContext *parent, size_t invokingState) : ParserRuleContext(parent, invokingState) { } -TocParser::IdentifierContext* TocParser::AssignmentContext::identifier() { - return getRuleContext(0); -} - -TocParser::ExprContext* TocParser::AssignmentContext::expr() { - return getRuleContext(0); +TocParser::BodyContext* TocParser::ElseStmtContext::body() { + return getRuleContext(0); } -size_t TocParser::AssignmentContext::getRuleIndex() const { - return TocParser::RuleAssignment; +size_t TocParser::ElseStmtContext::getRuleIndex() const { + return TocParser::RuleElseStmt; } -void TocParser::AssignmentContext::enterRule(tree::ParseTreeListener *listener) { - auto parserListener = dynamic_cast(listener); - if (parserListener != nullptr) - parserListener->enterAssignment(this); -} -void TocParser::AssignmentContext::exitRule(tree::ParseTreeListener *listener) { - auto parserListener = dynamic_cast(listener); - if (parserListener != nullptr) - parserListener->exitAssignment(this); -} - -TocParser::AssignmentContext* TocParser::assignment() { - AssignmentContext *_localctx = _tracker.createInstance(_ctx, getState()); - enterRule(_localctx, 40, TocParser::RuleAssignment); +TocParser::ElseStmtContext* TocParser::elseStmt() { + ElseStmtContext *_localctx = _tracker.createInstance(_ctx, getState()); + enterRule(_localctx, 44, TocParser::RuleElseStmt); #if __cplusplus > 201703L auto onExit = finally([=, this] { @@ -1415,12 +1551,10 @@ TocParser::AssignmentContext* TocParser::assignment() { }); try { enterOuterAlt(_localctx, 1); - setState(173); - identifier(); - setState(174); - match(TocParser::T__2); - setState(175); - expr(); + setState(256); + match(TocParser::T__20); + setState(257); + body(); } catch (RecognitionException &e) { @@ -1432,36 +1566,29 @@ TocParser::AssignmentContext* TocParser::assignment() { return _localctx; } -//----------------- ReturnStmtContext ------------------------------------------------------------------ +//----------------- SwitchStmtContext ------------------------------------------------------------------ -TocParser::ReturnStmtContext::ReturnStmtContext(ParserRuleContext *parent, size_t invokingState) +TocParser::SwitchStmtContext::SwitchStmtContext(ParserRuleContext *parent, size_t invokingState) : ParserRuleContext(parent, invokingState) { } -TocParser::ExprContext* TocParser::ReturnStmtContext::expr() { +TocParser::ExprContext* TocParser::SwitchStmtContext::expr() { return getRuleContext(0); } - -size_t TocParser::ReturnStmtContext::getRuleIndex() const { - return TocParser::RuleReturnStmt; +TocParser::SwitchBodyContext* TocParser::SwitchStmtContext::switchBody() { + return getRuleContext(0); } -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); +size_t TocParser::SwitchStmtContext::getRuleIndex() const { + return TocParser::RuleSwitchStmt; } -TocParser::ReturnStmtContext* TocParser::returnStmt() { - ReturnStmtContext *_localctx = _tracker.createInstance(_ctx, getState()); - enterRule(_localctx, 42, TocParser::RuleReturnStmt); + +TocParser::SwitchStmtContext* TocParser::switchStmt() { + SwitchStmtContext *_localctx = _tracker.createInstance(_ctx, getState()); + enterRule(_localctx, 46, TocParser::RuleSwitchStmt); #if __cplusplus > 201703L auto onExit = finally([=, this] { @@ -1472,10 +1599,12 @@ TocParser::ReturnStmtContext* TocParser::returnStmt() { }); try { enterOuterAlt(_localctx, 1); - setState(177); - match(TocParser::T__12); - setState(178); - expr(); + setState(259); + match(TocParser::T__21); + setState(260); + expr(0); + setState(261); + switchBody(); } catch (RecognitionException &e) { @@ -1487,60 +1616,88 @@ TocParser::ReturnStmtContext* TocParser::returnStmt() { return _localctx; } -//----------------- ExprContext ------------------------------------------------------------------ +//----------------- SwitchBodyContext ------------------------------------------------------------------ -TocParser::ExprContext::ExprContext(ParserRuleContext *parent, size_t invokingState) +TocParser::SwitchBodyContext::SwitchBodyContext(ParserRuleContext *parent, size_t invokingState) : ParserRuleContext(parent, invokingState) { } -TocParser::FuncCallContext* TocParser::ExprContext::funcCall() { - return getRuleContext(0); +std::vector TocParser::SwitchBodyContext::switchCase() { + return getRuleContexts(); } -TocParser::LiteralContext* TocParser::ExprContext::literal() { - return getRuleContext(0); +TocParser::SwitchCaseContext* TocParser::SwitchBodyContext::switchCase(size_t i) { + return getRuleContext(i); } -TocParser::IdentifierContext* TocParser::ExprContext::identifier() { - return getRuleContext(0); -} -TocParser::SubscriptContext* TocParser::ExprContext::subscript() { - return getRuleContext(0); +size_t TocParser::SwitchBodyContext::getRuleIndex() const { + return TocParser::RuleSwitchBody; } -TocParser::MemberAccessContext* TocParser::ExprContext::memberAccess() { - return getRuleContext(0); -} -TocParser::ParenExprContext* TocParser::ExprContext::parenExpr() { - return getRuleContext(0); -} +TocParser::SwitchBodyContext* TocParser::switchBody() { + SwitchBodyContext *_localctx = _tracker.createInstance(_ctx, getState()); + enterRule(_localctx, 48, TocParser::RuleSwitchBody); + size_t _la = 0; + +#if __cplusplus > 201703L + auto onExit = finally([=, this] { +#else + auto onExit = finally([=] { +#endif + exitRule(); + }); + try { + enterOuterAlt(_localctx, 1); + setState(263); + match(TocParser::T__2); + setState(267); + _errHandler->sync(this); + _la = _input->LA(1); + while (_la == TocParser::T__22) { + setState(264); + switchCase(); + setState(269); + _errHandler->sync(this); + _la = _input->LA(1); + } + setState(270); + match(TocParser::T__3); + + } + catch (RecognitionException &e) { + _errHandler->reportError(this, e); + _localctx->exception = std::current_exception(); + _errHandler->recover(this, _localctx->exception); + } -TocParser::OperatorExprContext* TocParser::ExprContext::operatorExpr() { - return getRuleContext(0); + return _localctx; } +//----------------- SwitchCaseContext ------------------------------------------------------------------ -size_t TocParser::ExprContext::getRuleIndex() const { - return TocParser::RuleExpr; +TocParser::SwitchCaseContext::SwitchCaseContext(ParserRuleContext *parent, size_t invokingState) + : ParserRuleContext(parent, invokingState) { } -void TocParser::ExprContext::enterRule(tree::ParseTreeListener *listener) { - auto parserListener = dynamic_cast(listener); - if (parserListener != nullptr) - parserListener->enterExpr(this); +TocParser::ExprContext* TocParser::SwitchCaseContext::expr() { + return getRuleContext(0); } -void TocParser::ExprContext::exitRule(tree::ParseTreeListener *listener) { - auto parserListener = dynamic_cast(listener); - if (parserListener != nullptr) - parserListener->exitExpr(this); +TocParser::BodyContext* TocParser::SwitchCaseContext::body() { + return getRuleContext(0); } -TocParser::ExprContext* TocParser::expr() { - ExprContext *_localctx = _tracker.createInstance(_ctx, getState()); - enterRule(_localctx, 44, TocParser::RuleExpr); + +size_t TocParser::SwitchCaseContext::getRuleIndex() const { + return TocParser::RuleSwitchCase; +} + + +TocParser::SwitchCaseContext* TocParser::switchCase() { + SwitchCaseContext *_localctx = _tracker.createInstance(_ctx, getState()); + enterRule(_localctx, 50, TocParser::RuleSwitchCase); #if __cplusplus > 201703L auto onExit = finally([=, this] { @@ -1550,61 +1707,13 @@ TocParser::ExprContext* TocParser::expr() { exitRule(); }); try { - setState(187); - _errHandler->sync(this); - switch (getInterpreter()->adaptivePredict(_input, 9, _ctx)) { - case 1: { - enterOuterAlt(_localctx, 1); - setState(180); - funcCall(); - break; - } - - case 2: { - enterOuterAlt(_localctx, 2); - setState(181); - literal(); - break; - } - - case 3: { - enterOuterAlt(_localctx, 3); - setState(182); - identifier(); - break; - } - - case 4: { - enterOuterAlt(_localctx, 4); - setState(183); - subscript(); - break; - } - - case 5: { - enterOuterAlt(_localctx, 5); - setState(184); - memberAccess(); - break; - } - - case 6: { - enterOuterAlt(_localctx, 6); - setState(185); - parenExpr(); - break; - } - - case 7: { - enterOuterAlt(_localctx, 7); - setState(186); - operatorExpr(); - break; - } - - default: - break; - } + enterOuterAlt(_localctx, 1); + setState(272); + match(TocParser::T__22); + setState(273); + expr(0); + setState(274); + body(); } catch (RecognitionException &e) { @@ -1616,56 +1725,37 @@ TocParser::ExprContext* TocParser::expr() { return _localctx; } -//----------------- NonOpExprContext ------------------------------------------------------------------ +//----------------- ForStmtContext ------------------------------------------------------------------ -TocParser::NonOpExprContext::NonOpExprContext(ParserRuleContext *parent, size_t invokingState) +TocParser::ForStmtContext::ForStmtContext(ParserRuleContext *parent, size_t invokingState) : ParserRuleContext(parent, invokingState) { } -TocParser::FuncCallContext* TocParser::NonOpExprContext::funcCall() { - return getRuleContext(0); +TocParser::VarInitContext* TocParser::ForStmtContext::varInit() { + return getRuleContext(0); } -TocParser::LiteralContext* TocParser::NonOpExprContext::literal() { - return getRuleContext(0); -} - -TocParser::IdentifierContext* TocParser::NonOpExprContext::identifier() { - return getRuleContext(0); -} - -TocParser::SubscriptContext* TocParser::NonOpExprContext::subscript() { - return getRuleContext(0); +std::vector TocParser::ForStmtContext::expr() { + return getRuleContexts(); } -TocParser::MemberAccessContext* TocParser::NonOpExprContext::memberAccess() { - return getRuleContext(0); +TocParser::ExprContext* TocParser::ForStmtContext::expr(size_t i) { + return getRuleContext(i); } -TocParser::ParenExprContext* TocParser::NonOpExprContext::parenExpr() { - return getRuleContext(0); +TocParser::BodyContext* TocParser::ForStmtContext::body() { + return getRuleContext(0); } -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); +size_t TocParser::ForStmtContext::getRuleIndex() const { + return TocParser::RuleForStmt; } -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, 46, TocParser::RuleNonOpExpr); +TocParser::ForStmtContext* TocParser::forStmt() { + ForStmtContext *_localctx = _tracker.createInstance(_ctx, getState()); + enterRule(_localctx, 52, TocParser::RuleForStmt); #if __cplusplus > 201703L auto onExit = finally([=, this] { @@ -1675,54 +1765,21 @@ TocParser::NonOpExprContext* TocParser::nonOpExpr() { exitRule(); }); try { - setState(195); - _errHandler->sync(this); - switch (getInterpreter()->adaptivePredict(_input, 10, _ctx)) { - case 1: { - enterOuterAlt(_localctx, 1); - setState(189); - funcCall(); - break; - } - - case 2: { - enterOuterAlt(_localctx, 2); - setState(190); - literal(); - break; - } - - case 3: { - enterOuterAlt(_localctx, 3); - setState(191); - identifier(); - break; - } - - case 4: { - enterOuterAlt(_localctx, 4); - setState(192); - subscript(); - break; - } - - case 5: { - enterOuterAlt(_localctx, 5); - setState(193); - memberAccess(); - break; - } - - case 6: { - enterOuterAlt(_localctx, 6); - setState(194); - parenExpr(); - break; - } - - default: - break; - } + enterOuterAlt(_localctx, 1); + setState(276); + match(TocParser::T__23); + setState(277); + varInit(); + setState(278); + match(TocParser::T__14); + setState(279); + expr(0); + setState(280); + match(TocParser::T__14); + setState(281); + expr(0); + setState(282); + body(); } catch (RecognitionException &e) { @@ -1734,48 +1791,29 @@ TocParser::NonOpExprContext* TocParser::nonOpExpr() { return _localctx; } -//----------------- NonSubscriptExprContext ------------------------------------------------------------------ +//----------------- WhileStmtContext ------------------------------------------------------------------ -TocParser::NonSubscriptExprContext::NonSubscriptExprContext(ParserRuleContext *parent, size_t invokingState) +TocParser::WhileStmtContext::WhileStmtContext(ParserRuleContext *parent, size_t invokingState) : ParserRuleContext(parent, invokingState) { } -TocParser::FuncCallContext* TocParser::NonSubscriptExprContext::funcCall() { - return getRuleContext(0); +TocParser::ExprContext* TocParser::WhileStmtContext::expr() { + return getRuleContext(0); } -TocParser::IdentifierContext* TocParser::NonSubscriptExprContext::identifier() { - return getRuleContext(0); +TocParser::BodyContext* TocParser::WhileStmtContext::body() { + return getRuleContext(0); } -TocParser::MemberAccessContext* TocParser::NonSubscriptExprContext::memberAccess() { - return getRuleContext(0); -} -TocParser::ParenExprContext* TocParser::NonSubscriptExprContext::parenExpr() { - return getRuleContext(0); +size_t TocParser::WhileStmtContext::getRuleIndex() const { + return TocParser::RuleWhileStmt; } -size_t TocParser::NonSubscriptExprContext::getRuleIndex() const { - return TocParser::RuleNonSubscriptExpr; -} - -void TocParser::NonSubscriptExprContext::enterRule(tree::ParseTreeListener *listener) { - auto parserListener = dynamic_cast(listener); - if (parserListener != nullptr) - parserListener->enterNonSubscriptExpr(this); -} - -void TocParser::NonSubscriptExprContext::exitRule(tree::ParseTreeListener *listener) { - auto parserListener = dynamic_cast(listener); - if (parserListener != nullptr) - parserListener->exitNonSubscriptExpr(this); -} - -TocParser::NonSubscriptExprContext* TocParser::nonSubscriptExpr() { - NonSubscriptExprContext *_localctx = _tracker.createInstance(_ctx, getState()); - enterRule(_localctx, 48, TocParser::RuleNonSubscriptExpr); +TocParser::WhileStmtContext* TocParser::whileStmt() { + WhileStmtContext *_localctx = _tracker.createInstance(_ctx, getState()); + enterRule(_localctx, 54, TocParser::RuleWhileStmt); #if __cplusplus > 201703L auto onExit = finally([=, this] { @@ -1785,40 +1823,13 @@ TocParser::NonSubscriptExprContext* TocParser::nonSubscriptExpr() { exitRule(); }); try { - setState(201); - _errHandler->sync(this); - switch (getInterpreter()->adaptivePredict(_input, 11, _ctx)) { - case 1: { - enterOuterAlt(_localctx, 1); - setState(197); - funcCall(); - break; - } - - case 2: { - enterOuterAlt(_localctx, 2); - setState(198); - identifier(); - break; - } - - case 3: { - enterOuterAlt(_localctx, 3); - setState(199); - memberAccess(); - break; - } - - case 4: { - enterOuterAlt(_localctx, 4); - setState(200); - parenExpr(); - break; - } - - default: - break; - } + enterOuterAlt(_localctx, 1); + setState(284); + match(TocParser::T__24); + setState(285); + expr(0); + setState(286); + body(); } catch (RecognitionException &e) { @@ -1830,45 +1841,29 @@ TocParser::NonSubscriptExprContext* TocParser::nonSubscriptExpr() { return _localctx; } -//----------------- FuncCallContext ------------------------------------------------------------------ +//----------------- AssignStmtContext ------------------------------------------------------------------ -TocParser::FuncCallContext::FuncCallContext(ParserRuleContext *parent, size_t invokingState) +TocParser::AssignStmtContext::AssignStmtContext(ParserRuleContext *parent, size_t invokingState) : ParserRuleContext(parent, invokingState) { } -TocParser::FuncNameContext* TocParser::FuncCallContext::funcName() { - return getRuleContext(0); -} - -std::vector TocParser::FuncCallContext::expr() { +std::vector TocParser::AssignStmtContext::expr() { return getRuleContexts(); } -TocParser::ExprContext* TocParser::FuncCallContext::expr(size_t i) { +TocParser::ExprContext* TocParser::AssignStmtContext::expr(size_t i) { return getRuleContext(i); } -size_t TocParser::FuncCallContext::getRuleIndex() const { - return TocParser::RuleFuncCall; +size_t TocParser::AssignStmtContext::getRuleIndex() const { + return TocParser::RuleAssignStmt; } -void TocParser::FuncCallContext::enterRule(tree::ParseTreeListener *listener) { - auto parserListener = dynamic_cast(listener); - if (parserListener != nullptr) - parserListener->enterFuncCall(this); -} -void TocParser::FuncCallContext::exitRule(tree::ParseTreeListener *listener) { - auto parserListener = dynamic_cast(listener); - if (parserListener != nullptr) - parserListener->exitFuncCall(this); -} - -TocParser::FuncCallContext* TocParser::funcCall() { - FuncCallContext *_localctx = _tracker.createInstance(_ctx, getState()); - enterRule(_localctx, 50, TocParser::RuleFuncCall); - size_t _la = 0; +TocParser::AssignStmtContext* TocParser::assignStmt() { + AssignStmtContext *_localctx = _tracker.createInstance(_ctx, getState()); + enterRule(_localctx, 56, TocParser::RuleAssignStmt); #if __cplusplus > 201703L auto onExit = finally([=, this] { @@ -1879,35 +1874,12 @@ TocParser::FuncCallContext* TocParser::funcCall() { }); try { enterOuterAlt(_localctx, 1); - setState(203); - funcName(); - setState(204); - match(TocParser::T__4); - setState(213); - _errHandler->sync(this); - - _la = _input->LA(1); - if ((((_la & ~ 0x3fULL) == 0) && - ((1ULL << _la) & ((1ULL << TocParser::T__4) - | (1ULL << TocParser::INTLIT) - | (1ULL << TocParser::NAME))) != 0)) { - setState(205); - expr(); - setState(210); - _errHandler->sync(this); - _la = _input->LA(1); - while (_la == TocParser::T__6) { - setState(206); - match(TocParser::T__6); - setState(207); - expr(); - setState(212); - _errHandler->sync(this); - _la = _input->LA(1); - } - } - setState(215); - match(TocParser::T__5); + setState(288); + expr(0); + setState(289); + match(TocParser::T__6); + setState(290); + expr(0); } catch (RecognitionException &e) { @@ -1919,36 +1891,25 @@ TocParser::FuncCallContext* TocParser::funcCall() { return _localctx; } -//----------------- OperatorExprContext ------------------------------------------------------------------ +//----------------- ReturnStmtContext ------------------------------------------------------------------ -TocParser::OperatorExprContext::OperatorExprContext(ParserRuleContext *parent, size_t invokingState) +TocParser::ReturnStmtContext::ReturnStmtContext(ParserRuleContext *parent, size_t invokingState) : ParserRuleContext(parent, invokingState) { } -TocParser::BinaryOperatorContext* TocParser::OperatorExprContext::binaryOperator() { - return getRuleContext(0); +TocParser::ExprContext* TocParser::ReturnStmtContext::expr() { + return getRuleContext(0); } -size_t TocParser::OperatorExprContext::getRuleIndex() const { - return TocParser::RuleOperatorExpr; -} - -void TocParser::OperatorExprContext::enterRule(tree::ParseTreeListener *listener) { - auto parserListener = dynamic_cast(listener); - if (parserListener != nullptr) - parserListener->enterOperatorExpr(this); +size_t TocParser::ReturnStmtContext::getRuleIndex() const { + return TocParser::RuleReturnStmt; } -void TocParser::OperatorExprContext::exitRule(tree::ParseTreeListener *listener) { - auto parserListener = dynamic_cast(listener); - if (parserListener != nullptr) - parserListener->exitOperatorExpr(this); -} -TocParser::OperatorExprContext* TocParser::operatorExpr() { - OperatorExprContext *_localctx = _tracker.createInstance(_ctx, getState()); - enterRule(_localctx, 52, TocParser::RuleOperatorExpr); +TocParser::ReturnStmtContext* TocParser::returnStmt() { + ReturnStmtContext *_localctx = _tracker.createInstance(_ctx, getState()); + enterRule(_localctx, 58, TocParser::RuleReturnStmt); #if __cplusplus > 201703L auto onExit = finally([=, this] { @@ -1959,8 +1920,10 @@ TocParser::OperatorExprContext* TocParser::operatorExpr() { }); try { enterOuterAlt(_localctx, 1); - setState(217); - binaryOperator(); + setState(292); + match(TocParser::T__25); + setState(293); + expr(0); } catch (RecognitionException &e) { @@ -1969,141 +1932,481 @@ TocParser::OperatorExprContext* TocParser::operatorExpr() { _errHandler->recover(this, _localctx->exception); } - return _localctx; + return _localctx; +} + +//----------------- ExprContext ------------------------------------------------------------------ + +TocParser::ExprContext::ExprContext(ParserRuleContext *parent, size_t invokingState) + : ParserRuleContext(parent, invokingState) { +} + + +size_t TocParser::ExprContext::getRuleIndex() const { + return TocParser::RuleExpr; +} + +void TocParser::ExprContext::copyFrom(ExprContext *ctx) { + ParserRuleContext::copyFrom(ctx); +} + +//----------------- DotExprContext ------------------------------------------------------------------ + +TocParser::ExprContext* TocParser::DotExprContext::expr() { + return getRuleContext(0); +} + +TocParser::VarNameContext* TocParser::DotExprContext::varName() { + return getRuleContext(0); +} + +TocParser::DotExprContext::DotExprContext(ExprContext *ctx) { copyFrom(ctx); } + + +//----------------- FuncExprContext ------------------------------------------------------------------ + +TocParser::FuncNameContext* TocParser::FuncExprContext::funcName() { + return getRuleContext(0); +} + +std::vector TocParser::FuncExprContext::namespaceSpecifier() { + return getRuleContexts(); +} + +TocParser::NamespaceSpecifierContext* TocParser::FuncExprContext::namespaceSpecifier(size_t i) { + return getRuleContext(i); +} + +std::vector TocParser::FuncExprContext::expr() { + return getRuleContexts(); +} + +TocParser::ExprContext* TocParser::FuncExprContext::expr(size_t i) { + return getRuleContext(i); +} + +TocParser::FuncExprContext::FuncExprContext(ExprContext *ctx) { copyFrom(ctx); } + + +//----------------- BracketExprContext ------------------------------------------------------------------ + +std::vector TocParser::BracketExprContext::expr() { + return getRuleContexts(); +} + +TocParser::ExprContext* TocParser::BracketExprContext::expr(size_t i) { + return getRuleContext(i); +} + +TocParser::BracketExprContext::BracketExprContext(ExprContext *ctx) { copyFrom(ctx); } + + +//----------------- PrefixOpExprContext ------------------------------------------------------------------ + +TocParser::Prefix_opContext* TocParser::PrefixOpExprContext::prefix_op() { + return getRuleContext(0); +} + +TocParser::ExprContext* TocParser::PrefixOpExprContext::expr() { + return getRuleContext(0); +} + +TocParser::PrefixOpExprContext::PrefixOpExprContext(ExprContext *ctx) { copyFrom(ctx); } + + +//----------------- MethodExprContext ------------------------------------------------------------------ + +std::vector TocParser::MethodExprContext::expr() { + return getRuleContexts(); +} + +TocParser::ExprContext* TocParser::MethodExprContext::expr(size_t i) { + return getRuleContext(i); +} + +TocParser::FuncNameContext* TocParser::MethodExprContext::funcName() { + return getRuleContext(0); +} + +TocParser::MethodExprContext::MethodExprContext(ExprContext *ctx) { copyFrom(ctx); } + + +//----------------- PostfixOpExprContext ------------------------------------------------------------------ + +TocParser::ExprContext* TocParser::PostfixOpExprContext::expr() { + return getRuleContext(0); +} + +TocParser::Postfix_opContext* TocParser::PostfixOpExprContext::postfix_op() { + return getRuleContext(0); +} + +TocParser::PostfixOpExprContext::PostfixOpExprContext(ExprContext *ctx) { copyFrom(ctx); } + + +//----------------- BinaryOpExprContext ------------------------------------------------------------------ + +std::vector TocParser::BinaryOpExprContext::expr() { + return getRuleContexts(); +} + +TocParser::ExprContext* TocParser::BinaryOpExprContext::expr(size_t i) { + return getRuleContext(i); +} + +TocParser::Binary_opContext* TocParser::BinaryOpExprContext::binary_op() { + return getRuleContext(0); +} + +TocParser::BinaryOpExprContext::BinaryOpExprContext(ExprContext *ctx) { copyFrom(ctx); } + + +//----------------- TernaryOpExprContext ------------------------------------------------------------------ + +std::vector TocParser::TernaryOpExprContext::expr() { + return getRuleContexts(); +} + +TocParser::ExprContext* TocParser::TernaryOpExprContext::expr(size_t i) { + return getRuleContext(i); +} + +TocParser::TernaryOpExprContext::TernaryOpExprContext(ExprContext *ctx) { copyFrom(ctx); } + + +//----------------- LitExprContext ------------------------------------------------------------------ + +TocParser::LiteralContext* TocParser::LitExprContext::literal() { + return getRuleContext(0); } -//----------------- BinaryOperatorContext ------------------------------------------------------------------ +TocParser::LitExprContext::LitExprContext(ExprContext *ctx) { copyFrom(ctx); } -TocParser::BinaryOperatorContext::BinaryOperatorContext(ParserRuleContext *parent, size_t invokingState) - : ParserRuleContext(parent, invokingState) { -} -std::vector TocParser::BinaryOperatorContext::nonOpExpr() { - return getRuleContexts(); +//----------------- ParenExprContext ------------------------------------------------------------------ + +TocParser::ExprContext* TocParser::ParenExprContext::expr() { + return getRuleContext(0); } -TocParser::NonOpExprContext* TocParser::BinaryOperatorContext::nonOpExpr(size_t i) { - return getRuleContext(i); +TocParser::ParenExprContext::ParenExprContext(ExprContext *ctx) { copyFrom(ctx); } + + +//----------------- IdentifierExprContext ------------------------------------------------------------------ + +TocParser::VarNameContext* TocParser::IdentifierExprContext::varName() { + return getRuleContext(0); } -std::vector TocParser::BinaryOperatorContext::BINARY_OPERATOR() { - return getTokens(TocParser::BINARY_OPERATOR); +std::vector TocParser::IdentifierExprContext::namespaceSpecifier() { + return getRuleContexts(); } -tree::TerminalNode* TocParser::BinaryOperatorContext::BINARY_OPERATOR(size_t i) { - return getToken(TocParser::BINARY_OPERATOR, i); +TocParser::NamespaceSpecifierContext* TocParser::IdentifierExprContext::namespaceSpecifier(size_t i) { + return getRuleContext(i); } +TocParser::IdentifierExprContext::IdentifierExprContext(ExprContext *ctx) { copyFrom(ctx); } -size_t TocParser::BinaryOperatorContext::getRuleIndex() const { - return TocParser::RuleBinaryOperator; -} -void TocParser::BinaryOperatorContext::enterRule(tree::ParseTreeListener *listener) { - auto parserListener = dynamic_cast(listener); - if (parserListener != nullptr) - parserListener->enterBinaryOperator(this); -} -void TocParser::BinaryOperatorContext::exitRule(tree::ParseTreeListener *listener) { - auto parserListener = dynamic_cast(listener); - if (parserListener != nullptr) - parserListener->exitBinaryOperator(this); +TocParser::ExprContext* TocParser::expr() { + return expr(0); } -TocParser::BinaryOperatorContext* TocParser::binaryOperator() { - BinaryOperatorContext *_localctx = _tracker.createInstance(_ctx, getState()); - enterRule(_localctx, 54, TocParser::RuleBinaryOperator); - size_t _la = 0; +TocParser::ExprContext* TocParser::expr(int precedence) { + ParserRuleContext *parentContext = _ctx; + size_t parentState = getState(); + TocParser::ExprContext *_localctx = _tracker.createInstance(_ctx, parentState); + TocParser::ExprContext *previousContext = _localctx; + (void)previousContext; // Silence compiler, in case the context is not used by generated code. + size_t startState = 60; + enterRecursionRule(_localctx, 60, TocParser::RuleExpr, precedence); + + size_t _la = 0; #if __cplusplus > 201703L auto onExit = finally([=, this] { #else auto onExit = finally([=] { #endif - exitRule(); + unrollRecursionContexts(parentContext); }); try { + size_t alt; enterOuterAlt(_localctx, 1); - setState(219); - nonOpExpr(); - setState(220); - match(TocParser::BINARY_OPERATOR); - setState(221); - nonOpExpr(); - setState(226); + setState(331); _errHandler->sync(this); - _la = _input->LA(1); - while (_la == TocParser::BINARY_OPERATOR) { - setState(222); - match(TocParser::BINARY_OPERATOR); - setState(223); - nonOpExpr(); - setState(228); + switch (getInterpreter()->adaptivePredict(_input, 26, _ctx)) { + case 1: { + _localctx = _tracker.createInstance(_localctx); + _ctx = _localctx; + previousContext = _localctx; + + setState(299); _errHandler->sync(this); + alt = getInterpreter()->adaptivePredict(_input, 22, _ctx); + while (alt != 2 && alt != atn::ATN::INVALID_ALT_NUMBER) { + if (alt == 1) { + setState(296); + namespaceSpecifier(); + } + setState(301); + _errHandler->sync(this); + alt = getInterpreter()->adaptivePredict(_input, 22, _ctx); + } + setState(302); + funcName(); + setState(303); + match(TocParser::T__12); + setState(312); + _errHandler->sync(this); + _la = _input->LA(1); + if ((((_la & ~ 0x3fULL) == 0) && + ((1ULL << _la) & ((1ULL << TocParser::T__7) + | (1ULL << TocParser::T__12) + | (1ULL << TocParser::T__28) + | (1ULL << TocParser::T__29) + | (1ULL << TocParser::T__30) + | (1ULL << TocParser::T__31) + | (1ULL << TocParser::T__32) + | (1ULL << TocParser::T__33) + | (1ULL << TocParser::T__34) + | (1ULL << TocParser::INT_LIT) + | (1ULL << TocParser::DECIMAL_LIT) + | (1ULL << TocParser::BOOL_LIT) + | (1ULL << TocParser::StringLit) + | (1ULL << TocParser::NAME))) != 0)) { + setState(304); + expr(0); + setState(309); + _errHandler->sync(this); + _la = _input->LA(1); + while (_la == TocParser::T__14) { + setState(305); + match(TocParser::T__14); + setState(306); + expr(0); + setState(311); + _errHandler->sync(this); + _la = _input->LA(1); + } + } + setState(314); + match(TocParser::T__13); + break; } - - } - catch (RecognitionException &e) { - _errHandler->reportError(this, e); - _localctx->exception = std::current_exception(); - _errHandler->recover(this, _localctx->exception); - } - - return _localctx; -} - -//----------------- IdentifierContext ------------------------------------------------------------------ - -TocParser::IdentifierContext::IdentifierContext(ParserRuleContext *parent, size_t invokingState) - : ParserRuleContext(parent, invokingState) { -} - -TocParser::VarNameContext* TocParser::IdentifierContext::varName() { - return getRuleContext(0); -} - -size_t TocParser::IdentifierContext::getRuleIndex() const { - return TocParser::RuleIdentifier; -} + case 2: { + _localctx = _tracker.createInstance(_localctx); + _ctx = _localctx; + previousContext = _localctx; + setState(316); + literal(); + break; + } -void TocParser::IdentifierContext::enterRule(tree::ParseTreeListener *listener) { - auto parserListener = dynamic_cast(listener); - if (parserListener != nullptr) - parserListener->enterIdentifier(this); -} + case 3: { + _localctx = _tracker.createInstance(_localctx); + _ctx = _localctx; + previousContext = _localctx; + setState(317); + match(TocParser::T__12); + setState(318); + expr(0); + setState(319); + match(TocParser::T__13); + break; + } -void TocParser::IdentifierContext::exitRule(tree::ParseTreeListener *listener) { - auto parserListener = dynamic_cast(listener); - if (parserListener != nullptr) - parserListener->exitIdentifier(this); -} + case 4: { + _localctx = _tracker.createInstance(_localctx); + _ctx = _localctx; + previousContext = _localctx; + setState(321); + prefix_op(); + setState(322); + expr(6); + break; + } -TocParser::IdentifierContext* TocParser::identifier() { - IdentifierContext *_localctx = _tracker.createInstance(_ctx, getState()); - enterRule(_localctx, 56, TocParser::RuleIdentifier); + case 5: { + _localctx = _tracker.createInstance(_localctx); + _ctx = _localctx; + previousContext = _localctx; + setState(327); + _errHandler->sync(this); + alt = getInterpreter()->adaptivePredict(_input, 25, _ctx); + while (alt != 2 && alt != atn::ATN::INVALID_ALT_NUMBER) { + if (alt == 1) { + setState(324); + namespaceSpecifier(); + } + setState(329); + _errHandler->sync(this); + alt = getInterpreter()->adaptivePredict(_input, 25, _ctx); + } + setState(330); + varName(); + break; + } -#if __cplusplus > 201703L - auto onExit = finally([=, this] { -#else - auto onExit = finally([=] { -#endif - exitRule(); - }); - try { - enterOuterAlt(_localctx, 1); - setState(229); - varName(); - + default: + break; + } + _ctx->stop = _input->LT(-1); + setState(371); + _errHandler->sync(this); + alt = getInterpreter()->adaptivePredict(_input, 30, _ctx); + while (alt != 2 && alt != atn::ATN::INVALID_ALT_NUMBER) { + if (alt == 1) { + if (!_parseListeners.empty()) + triggerExitRuleEvent(); + previousContext = _localctx; + setState(369); + _errHandler->sync(this); + switch (getInterpreter()->adaptivePredict(_input, 29, _ctx)) { + case 1: { + auto newContext = _tracker.createInstance(_tracker.createInstance(parentContext, parentState)); + _localctx = newContext; + pushNewRecursionContext(newContext, startState, RuleExpr); + setState(333); + + if (!(precpred(_ctx, 4))) throw FailedPredicateException(this, "precpred(_ctx, 4)"); + setState(334); + binary_op(); + setState(335); + expr(5); + break; + } + + case 2: { + auto newContext = _tracker.createInstance(_tracker.createInstance(parentContext, parentState)); + _localctx = newContext; + pushNewRecursionContext(newContext, startState, RuleExpr); + setState(337); + + if (!(precpred(_ctx, 3))) throw FailedPredicateException(this, "precpred(_ctx, 3)"); + setState(338); + match(TocParser::T__27); + setState(339); + expr(0); + setState(340); + match(TocParser::T__5); + setState(341); + expr(4); + break; + } + + case 3: { + auto newContext = _tracker.createInstance(_tracker.createInstance(parentContext, parentState)); + _localctx = newContext; + pushNewRecursionContext(newContext, startState, RuleExpr); + setState(343); + + if (!(precpred(_ctx, 10))) throw FailedPredicateException(this, "precpred(_ctx, 10)"); + setState(344); + match(TocParser::T__26); + setState(345); + funcName(); + setState(346); + match(TocParser::T__12); + setState(355); + _errHandler->sync(this); + + _la = _input->LA(1); + if ((((_la & ~ 0x3fULL) == 0) && + ((1ULL << _la) & ((1ULL << TocParser::T__7) + | (1ULL << TocParser::T__12) + | (1ULL << TocParser::T__28) + | (1ULL << TocParser::T__29) + | (1ULL << TocParser::T__30) + | (1ULL << TocParser::T__31) + | (1ULL << TocParser::T__32) + | (1ULL << TocParser::T__33) + | (1ULL << TocParser::T__34) + | (1ULL << TocParser::INT_LIT) + | (1ULL << TocParser::DECIMAL_LIT) + | (1ULL << TocParser::BOOL_LIT) + | (1ULL << TocParser::StringLit) + | (1ULL << TocParser::NAME))) != 0)) { + setState(347); + expr(0); + setState(352); + _errHandler->sync(this); + _la = _input->LA(1); + while (_la == TocParser::T__14) { + setState(348); + match(TocParser::T__14); + setState(349); + expr(0); + setState(354); + _errHandler->sync(this); + _la = _input->LA(1); + } + } + setState(357); + match(TocParser::T__13); + break; + } + + case 4: { + auto newContext = _tracker.createInstance(_tracker.createInstance(parentContext, parentState)); + _localctx = newContext; + pushNewRecursionContext(newContext, startState, RuleExpr); + setState(359); + + if (!(precpred(_ctx, 7))) throw FailedPredicateException(this, "precpred(_ctx, 7)"); + setState(360); + match(TocParser::T__26); + setState(361); + varName(); + break; + } + + case 5: { + auto newContext = _tracker.createInstance(_tracker.createInstance(parentContext, parentState)); + _localctx = newContext; + pushNewRecursionContext(newContext, startState, RuleExpr); + setState(362); + + if (!(precpred(_ctx, 5))) throw FailedPredicateException(this, "precpred(_ctx, 5)"); + setState(363); + postfix_op(); + break; + } + + case 6: { + auto newContext = _tracker.createInstance(_tracker.createInstance(parentContext, parentState)); + _localctx = newContext; + pushNewRecursionContext(newContext, startState, RuleExpr); + setState(364); + + if (!(precpred(_ctx, 2))) throw FailedPredicateException(this, "precpred(_ctx, 2)"); + setState(365); + match(TocParser::T__8); + setState(366); + expr(0); + setState(367); + match(TocParser::T__9); + break; + } + + default: + break; + } + } + setState(373); + _errHandler->sync(this); + alt = getInterpreter()->adaptivePredict(_input, 30, _ctx); + } } catch (RecognitionException &e) { _errHandler->reportError(this, e); _localctx->exception = std::current_exception(); _errHandler->recover(this, _localctx->exception); } - return _localctx; } @@ -2113,30 +2416,32 @@ TocParser::LiteralContext::LiteralContext(ParserRuleContext *parent, size_t invo : ParserRuleContext(parent, invokingState) { } -tree::TerminalNode* TocParser::LiteralContext::INTLIT() { - return getToken(TocParser::INTLIT, 0); +tree::TerminalNode* TocParser::LiteralContext::INT_LIT() { + return getToken(TocParser::INT_LIT, 0); } +tree::TerminalNode* TocParser::LiteralContext::DECIMAL_LIT() { + return getToken(TocParser::DECIMAL_LIT, 0); +} -size_t TocParser::LiteralContext::getRuleIndex() const { - return TocParser::RuleLiteral; +tree::TerminalNode* TocParser::LiteralContext::StringLit() { + return getToken(TocParser::StringLit, 0); } -void TocParser::LiteralContext::enterRule(tree::ParseTreeListener *listener) { - auto parserListener = dynamic_cast(listener); - if (parserListener != nullptr) - parserListener->enterLiteral(this); +tree::TerminalNode* TocParser::LiteralContext::BOOL_LIT() { + return getToken(TocParser::BOOL_LIT, 0); } -void TocParser::LiteralContext::exitRule(tree::ParseTreeListener *listener) { - auto parserListener = dynamic_cast(listener); - if (parserListener != nullptr) - parserListener->exitLiteral(this); + +size_t TocParser::LiteralContext::getRuleIndex() const { + return TocParser::RuleLiteral; } + TocParser::LiteralContext* TocParser::literal() { LiteralContext *_localctx = _tracker.createInstance(_ctx, getState()); - enterRule(_localctx, 58, TocParser::RuleLiteral); + enterRule(_localctx, 62, TocParser::RuleLiteral); + size_t _la = 0; #if __cplusplus > 201703L auto onExit = finally([=, this] { @@ -2147,8 +2452,19 @@ TocParser::LiteralContext* TocParser::literal() { }); try { enterOuterAlt(_localctx, 1); - setState(231); - match(TocParser::INTLIT); + setState(374); + _la = _input->LA(1); + if (!((((_la & ~ 0x3fULL) == 0) && + ((1ULL << _la) & ((1ULL << TocParser::INT_LIT) + | (1ULL << TocParser::DECIMAL_LIT) + | (1ULL << TocParser::BOOL_LIT) + | (1ULL << TocParser::StringLit))) != 0))) { + _errHandler->recoverInline(this); + } + else { + _errHandler->reportMatch(this); + consume(); + } } catch (RecognitionException &e) { @@ -2160,40 +2476,25 @@ TocParser::LiteralContext* TocParser::literal() { return _localctx; } -//----------------- SubscriptContext ------------------------------------------------------------------ +//----------------- FuncNameContext ------------------------------------------------------------------ -TocParser::SubscriptContext::SubscriptContext(ParserRuleContext *parent, size_t invokingState) +TocParser::FuncNameContext::FuncNameContext(ParserRuleContext *parent, size_t invokingState) : ParserRuleContext(parent, invokingState) { } -TocParser::NonSubscriptExprContext* TocParser::SubscriptContext::nonSubscriptExpr() { - return getRuleContext(0); -} - -TocParser::ExprContext* TocParser::SubscriptContext::expr() { - return getRuleContext(0); +tree::TerminalNode* TocParser::FuncNameContext::NAME() { + return getToken(TocParser::NAME, 0); } -size_t TocParser::SubscriptContext::getRuleIndex() const { - return TocParser::RuleSubscript; -} - -void TocParser::SubscriptContext::enterRule(tree::ParseTreeListener *listener) { - auto parserListener = dynamic_cast(listener); - if (parserListener != nullptr) - parserListener->enterSubscript(this); +size_t TocParser::FuncNameContext::getRuleIndex() const { + return TocParser::RuleFuncName; } -void TocParser::SubscriptContext::exitRule(tree::ParseTreeListener *listener) { - auto parserListener = dynamic_cast(listener); - if (parserListener != nullptr) - parserListener->exitSubscript(this); -} -TocParser::SubscriptContext* TocParser::subscript() { - SubscriptContext *_localctx = _tracker.createInstance(_ctx, getState()); - enterRule(_localctx, 60, TocParser::RuleSubscript); +TocParser::FuncNameContext* TocParser::funcName() { + FuncNameContext *_localctx = _tracker.createInstance(_ctx, getState()); + enterRule(_localctx, 64, TocParser::RuleFuncName); #if __cplusplus > 201703L auto onExit = finally([=, this] { @@ -2204,14 +2505,8 @@ TocParser::SubscriptContext* TocParser::subscript() { }); try { enterOuterAlt(_localctx, 1); - setState(233); - nonSubscriptExpr(); - setState(234); - match(TocParser::T__13); - setState(235); - expr(); - setState(236); - match(TocParser::T__14); + setState(376); + match(TocParser::NAME); } catch (RecognitionException &e) { @@ -2223,40 +2518,25 @@ TocParser::SubscriptContext* TocParser::subscript() { return _localctx; } -//----------------- MemberAccessContext ------------------------------------------------------------------ +//----------------- VarNameContext ------------------------------------------------------------------ -TocParser::MemberAccessContext::MemberAccessContext(ParserRuleContext *parent, size_t invokingState) +TocParser::VarNameContext::VarNameContext(ParserRuleContext *parent, size_t invokingState) : ParserRuleContext(parent, invokingState) { } -std::vector TocParser::MemberAccessContext::identifier() { - return getRuleContexts(); -} - -TocParser::IdentifierContext* TocParser::MemberAccessContext::identifier(size_t i) { - return getRuleContext(i); +tree::TerminalNode* TocParser::VarNameContext::NAME() { + return getToken(TocParser::NAME, 0); } -size_t TocParser::MemberAccessContext::getRuleIndex() const { - return TocParser::RuleMemberAccess; -} - -void TocParser::MemberAccessContext::enterRule(tree::ParseTreeListener *listener) { - auto parserListener = dynamic_cast(listener); - if (parserListener != nullptr) - parserListener->enterMemberAccess(this); +size_t TocParser::VarNameContext::getRuleIndex() const { + return TocParser::RuleVarName; } -void TocParser::MemberAccessContext::exitRule(tree::ParseTreeListener *listener) { - auto parserListener = dynamic_cast(listener); - if (parserListener != nullptr) - parserListener->exitMemberAccess(this); -} -TocParser::MemberAccessContext* TocParser::memberAccess() { - MemberAccessContext *_localctx = _tracker.createInstance(_ctx, getState()); - enterRule(_localctx, 62, TocParser::RuleMemberAccess); +TocParser::VarNameContext* TocParser::varName() { + VarNameContext *_localctx = _tracker.createInstance(_ctx, getState()); + enterRule(_localctx, 66, TocParser::RuleVarName); #if __cplusplus > 201703L auto onExit = finally([=, this] { @@ -2267,12 +2547,8 @@ TocParser::MemberAccessContext* TocParser::memberAccess() { }); try { enterOuterAlt(_localctx, 1); - setState(238); - identifier(); - setState(239); - match(TocParser::T__15); - setState(240); - identifier(); + setState(378); + match(TocParser::NAME); } catch (RecognitionException &e) { @@ -2284,36 +2560,25 @@ TocParser::MemberAccessContext* TocParser::memberAccess() { return _localctx; } -//----------------- ParenExprContext ------------------------------------------------------------------ +//----------------- TypeNameContext ------------------------------------------------------------------ -TocParser::ParenExprContext::ParenExprContext(ParserRuleContext *parent, size_t invokingState) +TocParser::TypeNameContext::TypeNameContext(ParserRuleContext *parent, size_t invokingState) : ParserRuleContext(parent, invokingState) { } -TocParser::ExprContext* TocParser::ParenExprContext::expr() { - return getRuleContext(0); +tree::TerminalNode* TocParser::TypeNameContext::NAME() { + return getToken(TocParser::NAME, 0); } -size_t TocParser::ParenExprContext::getRuleIndex() const { - return TocParser::RuleParenExpr; -} - -void TocParser::ParenExprContext::enterRule(tree::ParseTreeListener *listener) { - auto parserListener = dynamic_cast(listener); - if (parserListener != nullptr) - parserListener->enterParenExpr(this); +size_t TocParser::TypeNameContext::getRuleIndex() const { + return TocParser::RuleTypeName; } -void TocParser::ParenExprContext::exitRule(tree::ParseTreeListener *listener) { - auto parserListener = dynamic_cast(listener); - if (parserListener != nullptr) - parserListener->exitParenExpr(this); -} -TocParser::ParenExprContext* TocParser::parenExpr() { - ParenExprContext *_localctx = _tracker.createInstance(_ctx, getState()); - enterRule(_localctx, 64, TocParser::RuleParenExpr); +TocParser::TypeNameContext* TocParser::typeName() { + TypeNameContext *_localctx = _tracker.createInstance(_ctx, getState()); + enterRule(_localctx, 68, TocParser::RuleTypeName); #if __cplusplus > 201703L auto onExit = finally([=, this] { @@ -2324,12 +2589,8 @@ TocParser::ParenExprContext* TocParser::parenExpr() { }); try { enterOuterAlt(_localctx, 1); - setState(242); - match(TocParser::T__4); - setState(243); - expr(); - setState(244); - match(TocParser::T__5); + setState(380); + match(TocParser::NAME); } catch (RecognitionException &e) { @@ -2341,36 +2602,25 @@ TocParser::ParenExprContext* TocParser::parenExpr() { return _localctx; } -//----------------- FuncNameContext ------------------------------------------------------------------ +//----------------- StructNameContext ------------------------------------------------------------------ -TocParser::FuncNameContext::FuncNameContext(ParserRuleContext *parent, size_t invokingState) +TocParser::StructNameContext::StructNameContext(ParserRuleContext *parent, size_t invokingState) : ParserRuleContext(parent, invokingState) { } -tree::TerminalNode* TocParser::FuncNameContext::NAME() { +tree::TerminalNode* TocParser::StructNameContext::NAME() { return getToken(TocParser::NAME, 0); } -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); +size_t TocParser::StructNameContext::getRuleIndex() const { + return TocParser::RuleStructName; } -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, 66, TocParser::RuleFuncName); +TocParser::StructNameContext* TocParser::structName() { + StructNameContext *_localctx = _tracker.createInstance(_ctx, getState()); + enterRule(_localctx, 70, TocParser::RuleStructName); #if __cplusplus > 201703L auto onExit = finally([=, this] { @@ -2381,7 +2631,7 @@ TocParser::FuncNameContext* TocParser::funcName() { }); try { enterOuterAlt(_localctx, 1); - setState(246); + setState(382); match(TocParser::NAME); } @@ -2394,36 +2644,22 @@ TocParser::FuncNameContext* TocParser::funcName() { return _localctx; } -//----------------- VarNameContext ------------------------------------------------------------------ +//----------------- Postfix_opContext ------------------------------------------------------------------ -TocParser::VarNameContext::VarNameContext(ParserRuleContext *parent, size_t invokingState) +TocParser::Postfix_opContext::Postfix_opContext(ParserRuleContext *parent, size_t invokingState) : ParserRuleContext(parent, invokingState) { } -tree::TerminalNode* TocParser::VarNameContext::NAME() { - return getToken(TocParser::NAME, 0); -} - - -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); +size_t TocParser::Postfix_opContext::getRuleIndex() const { + return TocParser::RulePostfix_op; } -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, 68, TocParser::RuleVarName); +TocParser::Postfix_opContext* TocParser::postfix_op() { + Postfix_opContext *_localctx = _tracker.createInstance(_ctx, getState()); + enterRule(_localctx, 72, TocParser::RulePostfix_op); + size_t _la = 0; #if __cplusplus > 201703L auto onExit = finally([=, this] { @@ -2434,8 +2670,17 @@ TocParser::VarNameContext* TocParser::varName() { }); try { enterOuterAlt(_localctx, 1); - setState(248); - match(TocParser::NAME); + setState(384); + _la = _input->LA(1); + if (!(_la == TocParser::T__28 + + || _la == TocParser::T__29)) { + _errHandler->recoverInline(this); + } + else { + _errHandler->reportMatch(this); + consume(); + } } catch (RecognitionException &e) { @@ -2447,36 +2692,25 @@ TocParser::VarNameContext* TocParser::varName() { return _localctx; } -//----------------- TypeNameContext ------------------------------------------------------------------ +//----------------- Prefix_opContext ------------------------------------------------------------------ -TocParser::TypeNameContext::TypeNameContext(ParserRuleContext *parent, size_t invokingState) +TocParser::Prefix_opContext::Prefix_opContext(ParserRuleContext *parent, size_t invokingState) : ParserRuleContext(parent, invokingState) { } -tree::TerminalNode* TocParser::TypeNameContext::NAME() { - return getToken(TocParser::NAME, 0); +TocParser::Postfix_opContext* TocParser::Prefix_opContext::postfix_op() { + return getRuleContext(0); } -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); +size_t TocParser::Prefix_opContext::getRuleIndex() const { + return TocParser::RulePrefix_op; } -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, 70, TocParser::RuleTypeName); +TocParser::Prefix_opContext* TocParser::prefix_op() { + Prefix_opContext *_localctx = _tracker.createInstance(_ctx, getState()); + enterRule(_localctx, 74, TocParser::RulePrefix_op); #if __cplusplus > 201703L auto onExit = finally([=, this] { @@ -2486,9 +2720,62 @@ TocParser::TypeNameContext* TocParser::typeName() { exitRule(); }); try { - enterOuterAlt(_localctx, 1); - setState(250); - match(TocParser::NAME); + setState(393); + _errHandler->sync(this); + switch (_input->LA(1)) { + case TocParser::T__30: { + enterOuterAlt(_localctx, 1); + setState(386); + match(TocParser::T__30); + break; + } + + case TocParser::T__31: { + enterOuterAlt(_localctx, 2); + setState(387); + match(TocParser::T__31); + break; + } + + case TocParser::T__32: { + enterOuterAlt(_localctx, 3); + setState(388); + match(TocParser::T__32); + break; + } + + case TocParser::T__33: { + enterOuterAlt(_localctx, 4); + setState(389); + match(TocParser::T__33); + break; + } + + case TocParser::T__34: { + enterOuterAlt(_localctx, 5); + setState(390); + match(TocParser::T__34); + break; + } + + case TocParser::T__7: { + enterOuterAlt(_localctx, 6); + setState(391); + match(TocParser::T__7); + break; + } + + case TocParser::T__28: + case TocParser::T__29: { + enterOuterAlt(_localctx, 7); + setState(392); + postfix_op(); + break; + } + + default: + throw NoViableAltException(this); + } } catch (RecognitionException &e) { @@ -2500,36 +2787,22 @@ TocParser::TypeNameContext* TocParser::typeName() { return _localctx; } -//----------------- StructNameContext ------------------------------------------------------------------ +//----------------- Binary_opContext ------------------------------------------------------------------ -TocParser::StructNameContext::StructNameContext(ParserRuleContext *parent, size_t invokingState) +TocParser::Binary_opContext::Binary_opContext(ParserRuleContext *parent, size_t invokingState) : ParserRuleContext(parent, invokingState) { } -tree::TerminalNode* TocParser::StructNameContext::NAME() { - return getToken(TocParser::NAME, 0); -} - - -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); +size_t TocParser::Binary_opContext::getRuleIndex() const { + return TocParser::RuleBinary_op; } -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, 72, TocParser::RuleStructName); +TocParser::Binary_opContext* TocParser::binary_op() { + Binary_opContext *_localctx = _tracker.createInstance(_ctx, getState()); + enterRule(_localctx, 76, TocParser::RuleBinary_op); + size_t _la = 0; #if __cplusplus > 201703L auto onExit = finally([=, this] { @@ -2540,8 +2813,43 @@ TocParser::StructNameContext* TocParser::structName() { }); try { enterOuterAlt(_localctx, 1); - setState(252); - match(TocParser::NAME); + setState(395); + _la = _input->LA(1); + if (!((((_la & ~ 0x3fULL) == 0) && + ((1ULL << _la) & ((1ULL << TocParser::T__7) + | (1ULL << TocParser::T__17) + | (1ULL << TocParser::T__18) + | (1ULL << TocParser::T__30) + | (1ULL << TocParser::T__31) + | (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) + | (1ULL << TocParser::T__55) + | (1ULL << TocParser::T__56))) != 0))) { + _errHandler->recoverInline(this); + } + else { + _errHandler->reportMatch(this); + consume(); + } } catch (RecognitionException &e) { @@ -2553,6 +2861,31 @@ TocParser::StructNameContext* TocParser::structName() { return _localctx; } +bool TocParser::sempred(RuleContext *context, size_t ruleIndex, size_t predicateIndex) { + switch (ruleIndex) { + case 30: return exprSempred(dynamic_cast(context), predicateIndex); + + default: + break; + } + return true; +} + +bool TocParser::exprSempred(ExprContext *_localctx, size_t predicateIndex) { + switch (predicateIndex) { + case 0: return precpred(_ctx, 4); + case 1: return precpred(_ctx, 3); + case 2: return precpred(_ctx, 10); + case 3: return precpred(_ctx, 7); + case 4: return precpred(_ctx, 5); + case 5: return precpred(_ctx, 2); + + default: + break; + } + return true; +} + // Static vars and initialization. std::vector TocParser::_decisionToDFA; atn::PredictionContextCache TocParser::_sharedContextCache; @@ -2562,23 +2895,31 @@ atn::ATN TocParser::_atn; std::vector TocParser::_serializedATN; std::vector TocParser::_ruleNames = { - "prog", "decl", "varDecl", "var", "type", "funcDecl", "func", "parameter", - "firstParameter", "additionalParameter", "body", "structDecl", "structMember", - "structVar", "structMethod", "stmt", "conditional", "ifCond", "loop", - "whileLoop", "assignment", "returnStmt", "expr", "nonOpExpr", "nonSubscriptExpr", - "funcCall", "operatorExpr", "binaryOperator", "identifier", "literal", - "subscript", "memberAccess", "parenExpr", "funcName", "varName", "typeName", - "structName" + "prog", "decl", "namespaceDecl", "varDecl", "var", "varInit", "type", + "typeModifier", "namespaceSpecifier", "funcDecl", "func", "parameter", + "body", "structDecl", "structMember", "structVar", "structMethod", "privateDecl", + "genericDecl", "stmt", "ifStmt", "elseIfStmt", "elseStmt", "switchStmt", + "switchBody", "switchCase", "forStmt", "whileStmt", "assignStmt", "returnStmt", + "expr", "literal", "funcName", "varName", "typeName", "structName", "postfix_op", + "prefix_op", "binary_op" }; std::vector TocParser::_literalNames = { - "", "'var'", "':'", "'='", "'func'", "'('", "')'", "','", "'{'", "'}'", - "'struct'", "'if'", "'while'", "'return'", "'['", "']'", "'.'" + "", "';'", "'namespace'", "'{'", "'}'", "'var'", "':'", "'='", "'*'", + "'['", "']'", "'::'", "'func'", "'('", "')'", "','", "'struct'", "'private'", + "'<'", "'>'", "'if'", "'else'", "'switch'", "'case'", "'for'", "'while'", + "'return'", "'.'", "'\u003F'", "'++'", "'--'", "'+'", "'-'", "'!'", "'~'", + "'&'", "'/'", "'%'", "'|'", "'^'", "'=='", "'!='", "'<='", "'>='", "'<<'", + "'>>'", "'||'", "'&&'", "'&='", "'|='", "'^='", "'<<='", "'>>='", "'+='", + "'-='", "'*='", "'/='", "'%='" }; std::vector TocParser::_symbolicNames = { - "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "BINARY_OPERATOR", - "INTLIT", "NAME", "WS", "NEWLINE" + "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", + "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", + "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", + "", "", "", "", "INT_LIT", "DECIMAL_LIT", "BOOL_LIT", "StringLit", "NAME", + "WS", "NEWLINE" }; dfa::Vocabulary TocParser::_vocabulary(_literalNames, _symbolicNames); @@ -2601,7 +2942,7 @@ TocParser::Initializer::Initializer() { static const uint16_t serializedATNSegment0[] = { 0x3, 0x608b, 0xa72a, 0x8133, 0xb9ed, 0x417c, 0x3be7, 0x7786, 0x5964, - 0x3, 0x17, 0x101, 0x4, 0x2, 0x9, 0x2, 0x4, 0x3, 0x9, 0x3, 0x4, 0x4, + 0x3, 0x42, 0x190, 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, @@ -2613,161 +2954,271 @@ TocParser::Initializer::Initializer() { 0x9, 0x1d, 0x4, 0x1e, 0x9, 0x1e, 0x4, 0x1f, 0x9, 0x1f, 0x4, 0x20, 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, 0x3, 0x2, 0x6, 0x2, 0x4e, 0xa, 0x2, 0xd, 0x2, 0xe, 0x2, - 0x4f, 0x3, 0x2, 0x3, 0x2, 0x3, 0x3, 0x3, 0x3, 0x3, 0x3, 0x5, 0x3, - 0x57, 0xa, 0x3, 0x3, 0x4, 0x3, 0x4, 0x3, 0x4, 0x3, 0x5, 0x3, 0x5, - 0x3, 0x5, 0x3, 0x5, 0x3, 0x5, 0x3, 0x5, 0x5, 0x5, 0x62, 0xa, 0x5, - 0x3, 0x6, 0x3, 0x6, 0x3, 0x7, 0x3, 0x7, 0x3, 0x7, 0x3, 0x8, 0x3, - 0x8, 0x3, 0x8, 0x3, 0x8, 0x3, 0x8, 0x3, 0x8, 0x3, 0x8, 0x3, 0x8, - 0x3, 0x8, 0x3, 0x9, 0x3, 0x9, 0x7, 0x9, 0x74, 0xa, 0x9, 0xc, 0x9, - 0xe, 0x9, 0x77, 0xb, 0x9, 0x5, 0x9, 0x79, 0xa, 0x9, 0x3, 0xa, 0x3, - 0xa, 0x3, 0xb, 0x3, 0xb, 0x3, 0xb, 0x3, 0xc, 0x3, 0xc, 0x7, 0xc, - 0x82, 0xa, 0xc, 0xc, 0xc, 0xe, 0xc, 0x85, 0xb, 0xc, 0x3, 0xc, 0x3, - 0xc, 0x3, 0xd, 0x3, 0xd, 0x3, 0xd, 0x3, 0xd, 0x7, 0xd, 0x8d, 0xa, - 0xd, 0xc, 0xd, 0xe, 0xd, 0x90, 0xb, 0xd, 0x3, 0xd, 0x3, 0xd, 0x3, - 0xe, 0x3, 0xe, 0x5, 0xe, 0x96, 0xa, 0xe, 0x3, 0xf, 0x3, 0xf, 0x3, - 0x10, 0x3, 0x10, 0x3, 0x11, 0x3, 0x11, 0x3, 0x11, 0x3, 0x11, 0x3, - 0x11, 0x3, 0x11, 0x5, 0x11, 0xa2, 0xa, 0x11, 0x3, 0x12, 0x3, 0x12, - 0x3, 0x13, 0x3, 0x13, 0x3, 0x13, 0x3, 0x13, 0x3, 0x14, 0x3, 0x14, - 0x3, 0x15, 0x3, 0x15, 0x3, 0x15, 0x3, 0x15, 0x3, 0x16, 0x3, 0x16, - 0x3, 0x16, 0x3, 0x16, 0x3, 0x17, 0x3, 0x17, 0x3, 0x17, 0x3, 0x18, - 0x3, 0x18, 0x3, 0x18, 0x3, 0x18, 0x3, 0x18, 0x3, 0x18, 0x3, 0x18, - 0x5, 0x18, 0xbe, 0xa, 0x18, 0x3, 0x19, 0x3, 0x19, 0x3, 0x19, 0x3, - 0x19, 0x3, 0x19, 0x3, 0x19, 0x5, 0x19, 0xc6, 0xa, 0x19, 0x3, 0x1a, - 0x3, 0x1a, 0x3, 0x1a, 0x3, 0x1a, 0x5, 0x1a, 0xcc, 0xa, 0x1a, 0x3, - 0x1b, 0x3, 0x1b, 0x3, 0x1b, 0x3, 0x1b, 0x3, 0x1b, 0x7, 0x1b, 0xd3, - 0xa, 0x1b, 0xc, 0x1b, 0xe, 0x1b, 0xd6, 0xb, 0x1b, 0x5, 0x1b, 0xd8, - 0xa, 0x1b, 0x3, 0x1b, 0x3, 0x1b, 0x3, 0x1c, 0x3, 0x1c, 0x3, 0x1d, - 0x3, 0x1d, 0x3, 0x1d, 0x3, 0x1d, 0x3, 0x1d, 0x7, 0x1d, 0xe3, 0xa, - 0x1d, 0xc, 0x1d, 0xe, 0x1d, 0xe6, 0xb, 0x1d, 0x3, 0x1e, 0x3, 0x1e, - 0x3, 0x1f, 0x3, 0x1f, 0x3, 0x20, 0x3, 0x20, 0x3, 0x20, 0x3, 0x20, - 0x3, 0x20, 0x3, 0x21, 0x3, 0x21, 0x3, 0x21, 0x3, 0x21, 0x3, 0x22, - 0x3, 0x22, 0x3, 0x22, 0x3, 0x22, 0x3, 0x23, 0x3, 0x23, 0x3, 0x24, - 0x3, 0x24, 0x3, 0x25, 0x3, 0x25, 0x3, 0x26, 0x3, 0x26, 0x3, 0x26, - 0x2, 0x2, 0x27, 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, 0x2, 0x2, 0x2, 0xfa, 0x2, 0x4d, 0x3, - 0x2, 0x2, 0x2, 0x4, 0x56, 0x3, 0x2, 0x2, 0x2, 0x6, 0x58, 0x3, 0x2, - 0x2, 0x2, 0x8, 0x5b, 0x3, 0x2, 0x2, 0x2, 0xa, 0x63, 0x3, 0x2, 0x2, - 0x2, 0xc, 0x65, 0x3, 0x2, 0x2, 0x2, 0xe, 0x68, 0x3, 0x2, 0x2, 0x2, - 0x10, 0x78, 0x3, 0x2, 0x2, 0x2, 0x12, 0x7a, 0x3, 0x2, 0x2, 0x2, 0x14, - 0x7c, 0x3, 0x2, 0x2, 0x2, 0x16, 0x7f, 0x3, 0x2, 0x2, 0x2, 0x18, 0x88, - 0x3, 0x2, 0x2, 0x2, 0x1a, 0x95, 0x3, 0x2, 0x2, 0x2, 0x1c, 0x97, 0x3, - 0x2, 0x2, 0x2, 0x1e, 0x99, 0x3, 0x2, 0x2, 0x2, 0x20, 0xa1, 0x3, 0x2, - 0x2, 0x2, 0x22, 0xa3, 0x3, 0x2, 0x2, 0x2, 0x24, 0xa5, 0x3, 0x2, 0x2, - 0x2, 0x26, 0xa9, 0x3, 0x2, 0x2, 0x2, 0x28, 0xab, 0x3, 0x2, 0x2, 0x2, - 0x2a, 0xaf, 0x3, 0x2, 0x2, 0x2, 0x2c, 0xb3, 0x3, 0x2, 0x2, 0x2, 0x2e, - 0xbd, 0x3, 0x2, 0x2, 0x2, 0x30, 0xc5, 0x3, 0x2, 0x2, 0x2, 0x32, 0xcb, - 0x3, 0x2, 0x2, 0x2, 0x34, 0xcd, 0x3, 0x2, 0x2, 0x2, 0x36, 0xdb, 0x3, - 0x2, 0x2, 0x2, 0x38, 0xdd, 0x3, 0x2, 0x2, 0x2, 0x3a, 0xe7, 0x3, 0x2, - 0x2, 0x2, 0x3c, 0xe9, 0x3, 0x2, 0x2, 0x2, 0x3e, 0xeb, 0x3, 0x2, 0x2, - 0x2, 0x40, 0xf0, 0x3, 0x2, 0x2, 0x2, 0x42, 0xf4, 0x3, 0x2, 0x2, 0x2, - 0x44, 0xf8, 0x3, 0x2, 0x2, 0x2, 0x46, 0xfa, 0x3, 0x2, 0x2, 0x2, 0x48, - 0xfc, 0x3, 0x2, 0x2, 0x2, 0x4a, 0xfe, 0x3, 0x2, 0x2, 0x2, 0x4c, 0x4e, - 0x5, 0x4, 0x3, 0x2, 0x4d, 0x4c, 0x3, 0x2, 0x2, 0x2, 0x4e, 0x4f, 0x3, - 0x2, 0x2, 0x2, 0x4f, 0x4d, 0x3, 0x2, 0x2, 0x2, 0x4f, 0x50, 0x3, 0x2, - 0x2, 0x2, 0x50, 0x51, 0x3, 0x2, 0x2, 0x2, 0x51, 0x52, 0x7, 0x2, 0x2, - 0x3, 0x52, 0x3, 0x3, 0x2, 0x2, 0x2, 0x53, 0x57, 0x5, 0x6, 0x4, 0x2, - 0x54, 0x57, 0x5, 0xc, 0x7, 0x2, 0x55, 0x57, 0x5, 0x18, 0xd, 0x2, - 0x56, 0x53, 0x3, 0x2, 0x2, 0x2, 0x56, 0x54, 0x3, 0x2, 0x2, 0x2, 0x56, - 0x55, 0x3, 0x2, 0x2, 0x2, 0x57, 0x5, 0x3, 0x2, 0x2, 0x2, 0x58, 0x59, - 0x7, 0x3, 0x2, 0x2, 0x59, 0x5a, 0x5, 0x8, 0x5, 0x2, 0x5a, 0x7, 0x3, - 0x2, 0x2, 0x2, 0x5b, 0x5c, 0x5, 0x46, 0x24, 0x2, 0x5c, 0x5d, 0x7, - 0x4, 0x2, 0x2, 0x5d, 0x5e, 0x5, 0xa, 0x6, 0x2, 0x5e, 0x61, 0x3, 0x2, - 0x2, 0x2, 0x5f, 0x60, 0x7, 0x5, 0x2, 0x2, 0x60, 0x62, 0x5, 0x2e, - 0x18, 0x2, 0x61, 0x5f, 0x3, 0x2, 0x2, 0x2, 0x61, 0x62, 0x3, 0x2, - 0x2, 0x2, 0x62, 0x9, 0x3, 0x2, 0x2, 0x2, 0x63, 0x64, 0x5, 0x48, 0x25, - 0x2, 0x64, 0xb, 0x3, 0x2, 0x2, 0x2, 0x65, 0x66, 0x7, 0x6, 0x2, 0x2, - 0x66, 0x67, 0x5, 0xe, 0x8, 0x2, 0x67, 0xd, 0x3, 0x2, 0x2, 0x2, 0x68, - 0x69, 0x5, 0x44, 0x23, 0x2, 0x69, 0x6a, 0x7, 0x7, 0x2, 0x2, 0x6a, - 0x6b, 0x5, 0x10, 0x9, 0x2, 0x6b, 0x6c, 0x7, 0x8, 0x2, 0x2, 0x6c, - 0x6d, 0x7, 0x4, 0x2, 0x2, 0x6d, 0x6e, 0x5, 0xa, 0x6, 0x2, 0x6e, 0x6f, - 0x3, 0x2, 0x2, 0x2, 0x6f, 0x70, 0x5, 0x16, 0xc, 0x2, 0x70, 0xf, 0x3, - 0x2, 0x2, 0x2, 0x71, 0x75, 0x5, 0x12, 0xa, 0x2, 0x72, 0x74, 0x5, - 0x14, 0xb, 0x2, 0x73, 0x72, 0x3, 0x2, 0x2, 0x2, 0x74, 0x77, 0x3, - 0x2, 0x2, 0x2, 0x75, 0x73, 0x3, 0x2, 0x2, 0x2, 0x75, 0x76, 0x3, 0x2, - 0x2, 0x2, 0x76, 0x79, 0x3, 0x2, 0x2, 0x2, 0x77, 0x75, 0x3, 0x2, 0x2, - 0x2, 0x78, 0x71, 0x3, 0x2, 0x2, 0x2, 0x78, 0x79, 0x3, 0x2, 0x2, 0x2, - 0x79, 0x11, 0x3, 0x2, 0x2, 0x2, 0x7a, 0x7b, 0x5, 0x8, 0x5, 0x2, 0x7b, - 0x13, 0x3, 0x2, 0x2, 0x2, 0x7c, 0x7d, 0x7, 0x9, 0x2, 0x2, 0x7d, 0x7e, - 0x5, 0x8, 0x5, 0x2, 0x7e, 0x15, 0x3, 0x2, 0x2, 0x2, 0x7f, 0x83, 0x7, - 0xa, 0x2, 0x2, 0x80, 0x82, 0x5, 0x20, 0x11, 0x2, 0x81, 0x80, 0x3, - 0x2, 0x2, 0x2, 0x82, 0x85, 0x3, 0x2, 0x2, 0x2, 0x83, 0x81, 0x3, 0x2, - 0x2, 0x2, 0x83, 0x84, 0x3, 0x2, 0x2, 0x2, 0x84, 0x86, 0x3, 0x2, 0x2, - 0x2, 0x85, 0x83, 0x3, 0x2, 0x2, 0x2, 0x86, 0x87, 0x7, 0xb, 0x2, 0x2, - 0x87, 0x17, 0x3, 0x2, 0x2, 0x2, 0x88, 0x89, 0x7, 0xc, 0x2, 0x2, 0x89, - 0x8a, 0x5, 0x4a, 0x26, 0x2, 0x8a, 0x8e, 0x7, 0xa, 0x2, 0x2, 0x8b, - 0x8d, 0x5, 0x1a, 0xe, 0x2, 0x8c, 0x8b, 0x3, 0x2, 0x2, 0x2, 0x8d, - 0x90, 0x3, 0x2, 0x2, 0x2, 0x8e, 0x8c, 0x3, 0x2, 0x2, 0x2, 0x8e, 0x8f, - 0x3, 0x2, 0x2, 0x2, 0x8f, 0x91, 0x3, 0x2, 0x2, 0x2, 0x90, 0x8e, 0x3, - 0x2, 0x2, 0x2, 0x91, 0x92, 0x7, 0xb, 0x2, 0x2, 0x92, 0x19, 0x3, 0x2, - 0x2, 0x2, 0x93, 0x96, 0x5, 0x1c, 0xf, 0x2, 0x94, 0x96, 0x5, 0x1e, - 0x10, 0x2, 0x95, 0x93, 0x3, 0x2, 0x2, 0x2, 0x95, 0x94, 0x3, 0x2, - 0x2, 0x2, 0x96, 0x1b, 0x3, 0x2, 0x2, 0x2, 0x97, 0x98, 0x5, 0x8, 0x5, - 0x2, 0x98, 0x1d, 0x3, 0x2, 0x2, 0x2, 0x99, 0x9a, 0x5, 0xe, 0x8, 0x2, - 0x9a, 0x1f, 0x3, 0x2, 0x2, 0x2, 0x9b, 0xa2, 0x5, 0x6, 0x4, 0x2, 0x9c, - 0xa2, 0x5, 0x22, 0x12, 0x2, 0x9d, 0xa2, 0x5, 0x26, 0x14, 0x2, 0x9e, - 0xa2, 0x5, 0x2a, 0x16, 0x2, 0x9f, 0xa2, 0x5, 0x2c, 0x17, 0x2, 0xa0, - 0xa2, 0x5, 0x2e, 0x18, 0x2, 0xa1, 0x9b, 0x3, 0x2, 0x2, 0x2, 0xa1, - 0x9c, 0x3, 0x2, 0x2, 0x2, 0xa1, 0x9d, 0x3, 0x2, 0x2, 0x2, 0xa1, 0x9e, - 0x3, 0x2, 0x2, 0x2, 0xa1, 0x9f, 0x3, 0x2, 0x2, 0x2, 0xa1, 0xa0, 0x3, - 0x2, 0x2, 0x2, 0xa2, 0x21, 0x3, 0x2, 0x2, 0x2, 0xa3, 0xa4, 0x5, 0x24, - 0x13, 0x2, 0xa4, 0x23, 0x3, 0x2, 0x2, 0x2, 0xa5, 0xa6, 0x7, 0xd, - 0x2, 0x2, 0xa6, 0xa7, 0x5, 0x2e, 0x18, 0x2, 0xa7, 0xa8, 0x5, 0x16, - 0xc, 0x2, 0xa8, 0x25, 0x3, 0x2, 0x2, 0x2, 0xa9, 0xaa, 0x5, 0x28, - 0x15, 0x2, 0xaa, 0x27, 0x3, 0x2, 0x2, 0x2, 0xab, 0xac, 0x7, 0xe, - 0x2, 0x2, 0xac, 0xad, 0x5, 0x2e, 0x18, 0x2, 0xad, 0xae, 0x5, 0x16, - 0xc, 0x2, 0xae, 0x29, 0x3, 0x2, 0x2, 0x2, 0xaf, 0xb0, 0x5, 0x3a, - 0x1e, 0x2, 0xb0, 0xb1, 0x7, 0x5, 0x2, 0x2, 0xb1, 0xb2, 0x5, 0x2e, - 0x18, 0x2, 0xb2, 0x2b, 0x3, 0x2, 0x2, 0x2, 0xb3, 0xb4, 0x7, 0xf, - 0x2, 0x2, 0xb4, 0xb5, 0x5, 0x2e, 0x18, 0x2, 0xb5, 0x2d, 0x3, 0x2, - 0x2, 0x2, 0xb6, 0xbe, 0x5, 0x34, 0x1b, 0x2, 0xb7, 0xbe, 0x5, 0x3c, - 0x1f, 0x2, 0xb8, 0xbe, 0x5, 0x3a, 0x1e, 0x2, 0xb9, 0xbe, 0x5, 0x3e, - 0x20, 0x2, 0xba, 0xbe, 0x5, 0x40, 0x21, 0x2, 0xbb, 0xbe, 0x5, 0x42, - 0x22, 0x2, 0xbc, 0xbe, 0x5, 0x36, 0x1c, 0x2, 0xbd, 0xb6, 0x3, 0x2, - 0x2, 0x2, 0xbd, 0xb7, 0x3, 0x2, 0x2, 0x2, 0xbd, 0xb8, 0x3, 0x2, 0x2, - 0x2, 0xbd, 0xb9, 0x3, 0x2, 0x2, 0x2, 0xbd, 0xba, 0x3, 0x2, 0x2, 0x2, - 0xbd, 0xbb, 0x3, 0x2, 0x2, 0x2, 0xbd, 0xbc, 0x3, 0x2, 0x2, 0x2, 0xbe, - 0x2f, 0x3, 0x2, 0x2, 0x2, 0xbf, 0xc6, 0x5, 0x34, 0x1b, 0x2, 0xc0, - 0xc6, 0x5, 0x3c, 0x1f, 0x2, 0xc1, 0xc6, 0x5, 0x3a, 0x1e, 0x2, 0xc2, - 0xc6, 0x5, 0x3e, 0x20, 0x2, 0xc3, 0xc6, 0x5, 0x40, 0x21, 0x2, 0xc4, - 0xc6, 0x5, 0x42, 0x22, 0x2, 0xc5, 0xbf, 0x3, 0x2, 0x2, 0x2, 0xc5, - 0xc0, 0x3, 0x2, 0x2, 0x2, 0xc5, 0xc1, 0x3, 0x2, 0x2, 0x2, 0xc5, 0xc2, - 0x3, 0x2, 0x2, 0x2, 0xc5, 0xc3, 0x3, 0x2, 0x2, 0x2, 0xc5, 0xc4, 0x3, - 0x2, 0x2, 0x2, 0xc6, 0x31, 0x3, 0x2, 0x2, 0x2, 0xc7, 0xcc, 0x5, 0x34, - 0x1b, 0x2, 0xc8, 0xcc, 0x5, 0x3a, 0x1e, 0x2, 0xc9, 0xcc, 0x5, 0x40, - 0x21, 0x2, 0xca, 0xcc, 0x5, 0x42, 0x22, 0x2, 0xcb, 0xc7, 0x3, 0x2, - 0x2, 0x2, 0xcb, 0xc8, 0x3, 0x2, 0x2, 0x2, 0xcb, 0xc9, 0x3, 0x2, 0x2, - 0x2, 0xcb, 0xca, 0x3, 0x2, 0x2, 0x2, 0xcc, 0x33, 0x3, 0x2, 0x2, 0x2, - 0xcd, 0xce, 0x5, 0x44, 0x23, 0x2, 0xce, 0xd7, 0x7, 0x7, 0x2, 0x2, - 0xcf, 0xd4, 0x5, 0x2e, 0x18, 0x2, 0xd0, 0xd1, 0x7, 0x9, 0x2, 0x2, - 0xd1, 0xd3, 0x5, 0x2e, 0x18, 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, 0xd8, 0x3, 0x2, 0x2, 0x2, 0xd6, 0xd4, - 0x3, 0x2, 0x2, 0x2, 0xd7, 0xcf, 0x3, 0x2, 0x2, 0x2, 0xd7, 0xd8, 0x3, - 0x2, 0x2, 0x2, 0xd8, 0xd9, 0x3, 0x2, 0x2, 0x2, 0xd9, 0xda, 0x7, 0x8, - 0x2, 0x2, 0xda, 0x35, 0x3, 0x2, 0x2, 0x2, 0xdb, 0xdc, 0x5, 0x38, - 0x1d, 0x2, 0xdc, 0x37, 0x3, 0x2, 0x2, 0x2, 0xdd, 0xde, 0x5, 0x30, - 0x19, 0x2, 0xde, 0xdf, 0x7, 0x13, 0x2, 0x2, 0xdf, 0xe4, 0x5, 0x30, - 0x19, 0x2, 0xe0, 0xe1, 0x7, 0x13, 0x2, 0x2, 0xe1, 0xe3, 0x5, 0x30, - 0x19, 0x2, 0xe2, 0xe0, 0x3, 0x2, 0x2, 0x2, 0xe3, 0xe6, 0x3, 0x2, - 0x2, 0x2, 0xe4, 0xe2, 0x3, 0x2, 0x2, 0x2, 0xe4, 0xe5, 0x3, 0x2, 0x2, - 0x2, 0xe5, 0x39, 0x3, 0x2, 0x2, 0x2, 0xe6, 0xe4, 0x3, 0x2, 0x2, 0x2, - 0xe7, 0xe8, 0x5, 0x46, 0x24, 0x2, 0xe8, 0x3b, 0x3, 0x2, 0x2, 0x2, - 0xe9, 0xea, 0x7, 0x14, 0x2, 0x2, 0xea, 0x3d, 0x3, 0x2, 0x2, 0x2, - 0xeb, 0xec, 0x5, 0x32, 0x1a, 0x2, 0xec, 0xed, 0x7, 0x10, 0x2, 0x2, - 0xed, 0xee, 0x5, 0x2e, 0x18, 0x2, 0xee, 0xef, 0x7, 0x11, 0x2, 0x2, - 0xef, 0x3f, 0x3, 0x2, 0x2, 0x2, 0xf0, 0xf1, 0x5, 0x3a, 0x1e, 0x2, - 0xf1, 0xf2, 0x7, 0x12, 0x2, 0x2, 0xf2, 0xf3, 0x5, 0x3a, 0x1e, 0x2, - 0xf3, 0x41, 0x3, 0x2, 0x2, 0x2, 0xf4, 0xf5, 0x7, 0x7, 0x2, 0x2, 0xf5, - 0xf6, 0x5, 0x2e, 0x18, 0x2, 0xf6, 0xf7, 0x7, 0x8, 0x2, 0x2, 0xf7, - 0x43, 0x3, 0x2, 0x2, 0x2, 0xf8, 0xf9, 0x7, 0x15, 0x2, 0x2, 0xf9, - 0x45, 0x3, 0x2, 0x2, 0x2, 0xfa, 0xfb, 0x7, 0x15, 0x2, 0x2, 0xfb, - 0x47, 0x3, 0x2, 0x2, 0x2, 0xfc, 0xfd, 0x7, 0x15, 0x2, 0x2, 0xfd, - 0x49, 0x3, 0x2, 0x2, 0x2, 0xfe, 0xff, 0x7, 0x15, 0x2, 0x2, 0xff, - 0x4b, 0x3, 0x2, 0x2, 0x2, 0x11, 0x4f, 0x56, 0x61, 0x75, 0x78, 0x83, - 0x8e, 0x95, 0xa1, 0xbd, 0xc5, 0xcb, 0xd4, 0xd7, 0xe4, + 0x9, 0x26, 0x4, 0x27, 0x9, 0x27, 0x4, 0x28, 0x9, 0x28, 0x3, 0x2, + 0x6, 0x2, 0x52, 0xa, 0x2, 0xd, 0x2, 0xe, 0x2, 0x53, 0x3, 0x2, 0x3, + 0x2, 0x3, 0x3, 0x3, 0x3, 0x3, 0x3, 0x3, 0x3, 0x3, 0x3, 0x3, 0x3, + 0x5, 0x3, 0x5e, 0xa, 0x3, 0x3, 0x4, 0x3, 0x4, 0x3, 0x4, 0x3, 0x4, + 0x7, 0x4, 0x64, 0xa, 0x4, 0xc, 0x4, 0xe, 0x4, 0x67, 0xb, 0x4, 0x3, + 0x4, 0x3, 0x4, 0x3, 0x5, 0x3, 0x5, 0x3, 0x5, 0x3, 0x6, 0x3, 0x6, + 0x3, 0x6, 0x3, 0x6, 0x3, 0x6, 0x3, 0x6, 0x5, 0x6, 0x74, 0xa, 0x6, + 0x3, 0x7, 0x3, 0x7, 0x3, 0x7, 0x3, 0x7, 0x3, 0x7, 0x3, 0x7, 0x3, + 0x7, 0x3, 0x8, 0x7, 0x8, 0x7e, 0xa, 0x8, 0xc, 0x8, 0xe, 0x8, 0x81, + 0xb, 0x8, 0x3, 0x8, 0x3, 0x8, 0x7, 0x8, 0x85, 0xa, 0x8, 0xc, 0x8, + 0xe, 0x8, 0x88, 0xb, 0x8, 0x3, 0x9, 0x3, 0x9, 0x3, 0x9, 0x5, 0x9, + 0x8d, 0xa, 0x9, 0x3, 0x9, 0x5, 0x9, 0x90, 0xa, 0x9, 0x3, 0xa, 0x3, + 0xa, 0x3, 0xa, 0x3, 0xb, 0x3, 0xb, 0x3, 0xb, 0x3, 0xc, 0x3, 0xc, + 0x5, 0xc, 0x9a, 0xa, 0xc, 0x3, 0xc, 0x3, 0xc, 0x3, 0xc, 0x3, 0xc, + 0x3, 0xc, 0x3, 0xc, 0x3, 0xc, 0x3, 0xc, 0x5, 0xc, 0xa4, 0xa, 0xc, + 0x3, 0xd, 0x3, 0xd, 0x3, 0xd, 0x7, 0xd, 0xa9, 0xa, 0xd, 0xc, 0xd, + 0xe, 0xd, 0xac, 0xb, 0xd, 0x5, 0xd, 0xae, 0xa, 0xd, 0x3, 0xe, 0x3, + 0xe, 0x7, 0xe, 0xb2, 0xa, 0xe, 0xc, 0xe, 0xe, 0xe, 0xb5, 0xb, 0xe, + 0x3, 0xe, 0x3, 0xe, 0x3, 0xf, 0x3, 0xf, 0x3, 0xf, 0x5, 0xf, 0xbc, + 0xa, 0xf, 0x3, 0xf, 0x3, 0xf, 0x7, 0xf, 0xc0, 0xa, 0xf, 0xc, 0xf, + 0xe, 0xf, 0xc3, 0xb, 0xf, 0x3, 0xf, 0x3, 0xf, 0x3, 0x10, 0x5, 0x10, + 0xc8, 0xa, 0x10, 0x3, 0x10, 0x3, 0x10, 0x5, 0x10, 0xcc, 0xa, 0x10, + 0x3, 0x11, 0x3, 0x11, 0x3, 0x11, 0x3, 0x12, 0x3, 0x12, 0x3, 0x13, + 0x3, 0x13, 0x3, 0x14, 0x3, 0x14, 0x3, 0x14, 0x3, 0x14, 0x7, 0x14, + 0xd9, 0xa, 0x14, 0xc, 0x14, 0xe, 0x14, 0xdc, 0xb, 0x14, 0x3, 0x14, + 0x3, 0x14, 0x3, 0x15, 0x3, 0x15, 0x3, 0x15, 0x3, 0x15, 0x3, 0x15, + 0x3, 0x15, 0x3, 0x15, 0x3, 0x15, 0x3, 0x15, 0x3, 0x15, 0x3, 0x15, + 0x3, 0x15, 0x3, 0x15, 0x3, 0x15, 0x3, 0x15, 0x3, 0x15, 0x5, 0x15, + 0xf0, 0xa, 0x15, 0x3, 0x16, 0x3, 0x16, 0x3, 0x16, 0x3, 0x16, 0x7, + 0x16, 0xf6, 0xa, 0x16, 0xc, 0x16, 0xe, 0x16, 0xf9, 0xb, 0x16, 0x3, + 0x16, 0x5, 0x16, 0xfc, 0xa, 0x16, 0x3, 0x17, 0x3, 0x17, 0x3, 0x17, + 0x3, 0x17, 0x3, 0x17, 0x3, 0x18, 0x3, 0x18, 0x3, 0x18, 0x3, 0x19, + 0x3, 0x19, 0x3, 0x19, 0x3, 0x19, 0x3, 0x1a, 0x3, 0x1a, 0x7, 0x1a, + 0x10c, 0xa, 0x1a, 0xc, 0x1a, 0xe, 0x1a, 0x10f, 0xb, 0x1a, 0x3, 0x1a, + 0x3, 0x1a, 0x3, 0x1b, 0x3, 0x1b, 0x3, 0x1b, 0x3, 0x1b, 0x3, 0x1c, + 0x3, 0x1c, 0x3, 0x1c, 0x3, 0x1c, 0x3, 0x1c, 0x3, 0x1c, 0x3, 0x1c, + 0x3, 0x1c, 0x3, 0x1d, 0x3, 0x1d, 0x3, 0x1d, 0x3, 0x1d, 0x3, 0x1e, + 0x3, 0x1e, 0x3, 0x1e, 0x3, 0x1e, 0x3, 0x1f, 0x3, 0x1f, 0x3, 0x1f, + 0x3, 0x20, 0x3, 0x20, 0x7, 0x20, 0x12c, 0xa, 0x20, 0xc, 0x20, 0xe, + 0x20, 0x12f, 0xb, 0x20, 0x3, 0x20, 0x3, 0x20, 0x3, 0x20, 0x3, 0x20, + 0x3, 0x20, 0x7, 0x20, 0x136, 0xa, 0x20, 0xc, 0x20, 0xe, 0x20, 0x139, + 0xb, 0x20, 0x5, 0x20, 0x13b, 0xa, 0x20, 0x3, 0x20, 0x3, 0x20, 0x3, + 0x20, 0x3, 0x20, 0x3, 0x20, 0x3, 0x20, 0x3, 0x20, 0x3, 0x20, 0x3, + 0x20, 0x3, 0x20, 0x3, 0x20, 0x7, 0x20, 0x148, 0xa, 0x20, 0xc, 0x20, + 0xe, 0x20, 0x14b, 0xb, 0x20, 0x3, 0x20, 0x5, 0x20, 0x14e, 0xa, 0x20, + 0x3, 0x20, 0x3, 0x20, 0x3, 0x20, 0x3, 0x20, 0x3, 0x20, 0x3, 0x20, + 0x3, 0x20, 0x3, 0x20, 0x3, 0x20, 0x3, 0x20, 0x3, 0x20, 0x3, 0x20, + 0x3, 0x20, 0x3, 0x20, 0x3, 0x20, 0x3, 0x20, 0x3, 0x20, 0x7, 0x20, + 0x161, 0xa, 0x20, 0xc, 0x20, 0xe, 0x20, 0x164, 0xb, 0x20, 0x5, 0x20, + 0x166, 0xa, 0x20, 0x3, 0x20, 0x3, 0x20, 0x3, 0x20, 0x3, 0x20, 0x3, + 0x20, 0x3, 0x20, 0x3, 0x20, 0x3, 0x20, 0x3, 0x20, 0x3, 0x20, 0x3, + 0x20, 0x3, 0x20, 0x7, 0x20, 0x174, 0xa, 0x20, 0xc, 0x20, 0xe, 0x20, + 0x177, 0xb, 0x20, 0x3, 0x21, 0x3, 0x21, 0x3, 0x22, 0x3, 0x22, 0x3, + 0x23, 0x3, 0x23, 0x3, 0x24, 0x3, 0x24, 0x3, 0x25, 0x3, 0x25, 0x3, + 0x26, 0x3, 0x26, 0x3, 0x27, 0x3, 0x27, 0x3, 0x27, 0x3, 0x27, 0x3, + 0x27, 0x3, 0x27, 0x3, 0x27, 0x5, 0x27, 0x18c, 0xa, 0x27, 0x3, 0x28, + 0x3, 0x28, 0x3, 0x28, 0x2, 0x3, 0x3e, 0x29, 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, + 0x2, 0x5, 0x3, 0x2, 0x3c, 0x3f, 0x3, 0x2, 0x1f, 0x20, 0x6, 0x2, 0xa, + 0xa, 0x14, 0x15, 0x21, 0x22, 0x25, 0x3b, 0x2, 0x19c, 0x2, 0x51, 0x3, + 0x2, 0x2, 0x2, 0x4, 0x5d, 0x3, 0x2, 0x2, 0x2, 0x6, 0x5f, 0x3, 0x2, + 0x2, 0x2, 0x8, 0x6a, 0x3, 0x2, 0x2, 0x2, 0xa, 0x6d, 0x3, 0x2, 0x2, + 0x2, 0xc, 0x75, 0x3, 0x2, 0x2, 0x2, 0xe, 0x7f, 0x3, 0x2, 0x2, 0x2, + 0x10, 0x8f, 0x3, 0x2, 0x2, 0x2, 0x12, 0x91, 0x3, 0x2, 0x2, 0x2, 0x14, + 0x94, 0x3, 0x2, 0x2, 0x2, 0x16, 0x97, 0x3, 0x2, 0x2, 0x2, 0x18, 0xad, + 0x3, 0x2, 0x2, 0x2, 0x1a, 0xaf, 0x3, 0x2, 0x2, 0x2, 0x1c, 0xb8, 0x3, + 0x2, 0x2, 0x2, 0x1e, 0xcb, 0x3, 0x2, 0x2, 0x2, 0x20, 0xcd, 0x3, 0x2, + 0x2, 0x2, 0x22, 0xd0, 0x3, 0x2, 0x2, 0x2, 0x24, 0xd2, 0x3, 0x2, 0x2, + 0x2, 0x26, 0xd4, 0x3, 0x2, 0x2, 0x2, 0x28, 0xef, 0x3, 0x2, 0x2, 0x2, + 0x2a, 0xf1, 0x3, 0x2, 0x2, 0x2, 0x2c, 0xfd, 0x3, 0x2, 0x2, 0x2, 0x2e, + 0x102, 0x3, 0x2, 0x2, 0x2, 0x30, 0x105, 0x3, 0x2, 0x2, 0x2, 0x32, + 0x109, 0x3, 0x2, 0x2, 0x2, 0x34, 0x112, 0x3, 0x2, 0x2, 0x2, 0x36, + 0x116, 0x3, 0x2, 0x2, 0x2, 0x38, 0x11e, 0x3, 0x2, 0x2, 0x2, 0x3a, + 0x122, 0x3, 0x2, 0x2, 0x2, 0x3c, 0x126, 0x3, 0x2, 0x2, 0x2, 0x3e, + 0x14d, 0x3, 0x2, 0x2, 0x2, 0x40, 0x178, 0x3, 0x2, 0x2, 0x2, 0x42, + 0x17a, 0x3, 0x2, 0x2, 0x2, 0x44, 0x17c, 0x3, 0x2, 0x2, 0x2, 0x46, + 0x17e, 0x3, 0x2, 0x2, 0x2, 0x48, 0x180, 0x3, 0x2, 0x2, 0x2, 0x4a, + 0x182, 0x3, 0x2, 0x2, 0x2, 0x4c, 0x18b, 0x3, 0x2, 0x2, 0x2, 0x4e, + 0x18d, 0x3, 0x2, 0x2, 0x2, 0x50, 0x52, 0x5, 0x4, 0x3, 0x2, 0x51, + 0x50, 0x3, 0x2, 0x2, 0x2, 0x52, 0x53, 0x3, 0x2, 0x2, 0x2, 0x53, 0x51, + 0x3, 0x2, 0x2, 0x2, 0x53, 0x54, 0x3, 0x2, 0x2, 0x2, 0x54, 0x55, 0x3, + 0x2, 0x2, 0x2, 0x55, 0x56, 0x7, 0x2, 0x2, 0x3, 0x56, 0x3, 0x3, 0x2, + 0x2, 0x2, 0x57, 0x58, 0x5, 0x8, 0x5, 0x2, 0x58, 0x59, 0x7, 0x3, 0x2, + 0x2, 0x59, 0x5e, 0x3, 0x2, 0x2, 0x2, 0x5a, 0x5e, 0x5, 0x14, 0xb, + 0x2, 0x5b, 0x5e, 0x5, 0x1c, 0xf, 0x2, 0x5c, 0x5e, 0x5, 0x6, 0x4, + 0x2, 0x5d, 0x57, 0x3, 0x2, 0x2, 0x2, 0x5d, 0x5a, 0x3, 0x2, 0x2, 0x2, + 0x5d, 0x5b, 0x3, 0x2, 0x2, 0x2, 0x5d, 0x5c, 0x3, 0x2, 0x2, 0x2, 0x5e, + 0x5, 0x3, 0x2, 0x2, 0x2, 0x5f, 0x60, 0x7, 0x4, 0x2, 0x2, 0x60, 0x61, + 0x5, 0x46, 0x24, 0x2, 0x61, 0x65, 0x7, 0x5, 0x2, 0x2, 0x62, 0x64, + 0x5, 0x4, 0x3, 0x2, 0x63, 0x62, 0x3, 0x2, 0x2, 0x2, 0x64, 0x67, 0x3, + 0x2, 0x2, 0x2, 0x65, 0x63, 0x3, 0x2, 0x2, 0x2, 0x65, 0x66, 0x3, 0x2, + 0x2, 0x2, 0x66, 0x68, 0x3, 0x2, 0x2, 0x2, 0x67, 0x65, 0x3, 0x2, 0x2, + 0x2, 0x68, 0x69, 0x7, 0x6, 0x2, 0x2, 0x69, 0x7, 0x3, 0x2, 0x2, 0x2, + 0x6a, 0x6b, 0x7, 0x7, 0x2, 0x2, 0x6b, 0x6c, 0x5, 0xa, 0x6, 0x2, 0x6c, + 0x9, 0x3, 0x2, 0x2, 0x2, 0x6d, 0x6e, 0x5, 0x44, 0x23, 0x2, 0x6e, + 0x6f, 0x7, 0x8, 0x2, 0x2, 0x6f, 0x70, 0x5, 0xe, 0x8, 0x2, 0x70, 0x73, + 0x3, 0x2, 0x2, 0x2, 0x71, 0x72, 0x7, 0x9, 0x2, 0x2, 0x72, 0x74, 0x5, + 0x3e, 0x20, 0x2, 0x73, 0x71, 0x3, 0x2, 0x2, 0x2, 0x73, 0x74, 0x3, + 0x2, 0x2, 0x2, 0x74, 0xb, 0x3, 0x2, 0x2, 0x2, 0x75, 0x76, 0x5, 0x44, + 0x23, 0x2, 0x76, 0x77, 0x7, 0x8, 0x2, 0x2, 0x77, 0x78, 0x5, 0xe, + 0x8, 0x2, 0x78, 0x79, 0x3, 0x2, 0x2, 0x2, 0x79, 0x7a, 0x7, 0x9, 0x2, + 0x2, 0x7a, 0x7b, 0x5, 0x3e, 0x20, 0x2, 0x7b, 0xd, 0x3, 0x2, 0x2, + 0x2, 0x7c, 0x7e, 0x5, 0x12, 0xa, 0x2, 0x7d, 0x7c, 0x3, 0x2, 0x2, + 0x2, 0x7e, 0x81, 0x3, 0x2, 0x2, 0x2, 0x7f, 0x7d, 0x3, 0x2, 0x2, 0x2, + 0x7f, 0x80, 0x3, 0x2, 0x2, 0x2, 0x80, 0x82, 0x3, 0x2, 0x2, 0x2, 0x81, + 0x7f, 0x3, 0x2, 0x2, 0x2, 0x82, 0x86, 0x5, 0x46, 0x24, 0x2, 0x83, + 0x85, 0x5, 0x10, 0x9, 0x2, 0x84, 0x83, 0x3, 0x2, 0x2, 0x2, 0x85, + 0x88, 0x3, 0x2, 0x2, 0x2, 0x86, 0x84, 0x3, 0x2, 0x2, 0x2, 0x86, 0x87, + 0x3, 0x2, 0x2, 0x2, 0x87, 0xf, 0x3, 0x2, 0x2, 0x2, 0x88, 0x86, 0x3, + 0x2, 0x2, 0x2, 0x89, 0x90, 0x7, 0xa, 0x2, 0x2, 0x8a, 0x8c, 0x7, 0xb, + 0x2, 0x2, 0x8b, 0x8d, 0x7, 0x3c, 0x2, 0x2, 0x8c, 0x8b, 0x3, 0x2, + 0x2, 0x2, 0x8c, 0x8d, 0x3, 0x2, 0x2, 0x2, 0x8d, 0x8e, 0x3, 0x2, 0x2, + 0x2, 0x8e, 0x90, 0x7, 0xc, 0x2, 0x2, 0x8f, 0x89, 0x3, 0x2, 0x2, 0x2, + 0x8f, 0x8a, 0x3, 0x2, 0x2, 0x2, 0x90, 0x11, 0x3, 0x2, 0x2, 0x2, 0x91, + 0x92, 0x5, 0x46, 0x24, 0x2, 0x92, 0x93, 0x7, 0xd, 0x2, 0x2, 0x93, + 0x13, 0x3, 0x2, 0x2, 0x2, 0x94, 0x95, 0x7, 0xe, 0x2, 0x2, 0x95, 0x96, + 0x5, 0x16, 0xc, 0x2, 0x96, 0x15, 0x3, 0x2, 0x2, 0x2, 0x97, 0x99, + 0x5, 0x42, 0x22, 0x2, 0x98, 0x9a, 0x5, 0x26, 0x14, 0x2, 0x99, 0x98, + 0x3, 0x2, 0x2, 0x2, 0x99, 0x9a, 0x3, 0x2, 0x2, 0x2, 0x9a, 0x9b, 0x3, + 0x2, 0x2, 0x2, 0x9b, 0x9c, 0x7, 0xf, 0x2, 0x2, 0x9c, 0x9d, 0x5, 0x18, + 0xd, 0x2, 0x9d, 0x9e, 0x7, 0x10, 0x2, 0x2, 0x9e, 0x9f, 0x7, 0x8, + 0x2, 0x2, 0x9f, 0xa0, 0x5, 0xe, 0x8, 0x2, 0xa0, 0xa3, 0x3, 0x2, 0x2, + 0x2, 0xa1, 0xa4, 0x5, 0x1a, 0xe, 0x2, 0xa2, 0xa4, 0x7, 0x3, 0x2, + 0x2, 0xa3, 0xa1, 0x3, 0x2, 0x2, 0x2, 0xa3, 0xa2, 0x3, 0x2, 0x2, 0x2, + 0xa4, 0x17, 0x3, 0x2, 0x2, 0x2, 0xa5, 0xaa, 0x5, 0xa, 0x6, 0x2, 0xa6, + 0xa7, 0x7, 0x11, 0x2, 0x2, 0xa7, 0xa9, 0x5, 0xa, 0x6, 0x2, 0xa8, + 0xa6, 0x3, 0x2, 0x2, 0x2, 0xa9, 0xac, 0x3, 0x2, 0x2, 0x2, 0xaa, 0xa8, + 0x3, 0x2, 0x2, 0x2, 0xaa, 0xab, 0x3, 0x2, 0x2, 0x2, 0xab, 0xae, 0x3, + 0x2, 0x2, 0x2, 0xac, 0xaa, 0x3, 0x2, 0x2, 0x2, 0xad, 0xa5, 0x3, 0x2, + 0x2, 0x2, 0xad, 0xae, 0x3, 0x2, 0x2, 0x2, 0xae, 0x19, 0x3, 0x2, 0x2, + 0x2, 0xaf, 0xb3, 0x7, 0x5, 0x2, 0x2, 0xb0, 0xb2, 0x5, 0x28, 0x15, + 0x2, 0xb1, 0xb0, 0x3, 0x2, 0x2, 0x2, 0xb2, 0xb5, 0x3, 0x2, 0x2, 0x2, + 0xb3, 0xb1, 0x3, 0x2, 0x2, 0x2, 0xb3, 0xb4, 0x3, 0x2, 0x2, 0x2, 0xb4, + 0xb6, 0x3, 0x2, 0x2, 0x2, 0xb5, 0xb3, 0x3, 0x2, 0x2, 0x2, 0xb6, 0xb7, + 0x7, 0x6, 0x2, 0x2, 0xb7, 0x1b, 0x3, 0x2, 0x2, 0x2, 0xb8, 0xb9, 0x7, + 0x12, 0x2, 0x2, 0xb9, 0xbb, 0x5, 0x48, 0x25, 0x2, 0xba, 0xbc, 0x5, + 0x26, 0x14, 0x2, 0xbb, 0xba, 0x3, 0x2, 0x2, 0x2, 0xbb, 0xbc, 0x3, + 0x2, 0x2, 0x2, 0xbc, 0xbd, 0x3, 0x2, 0x2, 0x2, 0xbd, 0xc1, 0x7, 0x5, + 0x2, 0x2, 0xbe, 0xc0, 0x5, 0x1e, 0x10, 0x2, 0xbf, 0xbe, 0x3, 0x2, + 0x2, 0x2, 0xc0, 0xc3, 0x3, 0x2, 0x2, 0x2, 0xc1, 0xbf, 0x3, 0x2, 0x2, + 0x2, 0xc1, 0xc2, 0x3, 0x2, 0x2, 0x2, 0xc2, 0xc4, 0x3, 0x2, 0x2, 0x2, + 0xc3, 0xc1, 0x3, 0x2, 0x2, 0x2, 0xc4, 0xc5, 0x7, 0x6, 0x2, 0x2, 0xc5, + 0x1d, 0x3, 0x2, 0x2, 0x2, 0xc6, 0xc8, 0x5, 0x24, 0x13, 0x2, 0xc7, + 0xc6, 0x3, 0x2, 0x2, 0x2, 0xc7, 0xc8, 0x3, 0x2, 0x2, 0x2, 0xc8, 0xc9, + 0x3, 0x2, 0x2, 0x2, 0xc9, 0xcc, 0x5, 0x20, 0x11, 0x2, 0xca, 0xcc, + 0x5, 0x22, 0x12, 0x2, 0xcb, 0xc7, 0x3, 0x2, 0x2, 0x2, 0xcb, 0xca, + 0x3, 0x2, 0x2, 0x2, 0xcc, 0x1f, 0x3, 0x2, 0x2, 0x2, 0xcd, 0xce, 0x5, + 0xa, 0x6, 0x2, 0xce, 0xcf, 0x7, 0x3, 0x2, 0x2, 0xcf, 0x21, 0x3, 0x2, + 0x2, 0x2, 0xd0, 0xd1, 0x5, 0x16, 0xc, 0x2, 0xd1, 0x23, 0x3, 0x2, + 0x2, 0x2, 0xd2, 0xd3, 0x7, 0x13, 0x2, 0x2, 0xd3, 0x25, 0x3, 0x2, + 0x2, 0x2, 0xd4, 0xd5, 0x7, 0x14, 0x2, 0x2, 0xd5, 0xda, 0x5, 0x46, + 0x24, 0x2, 0xd6, 0xd7, 0x7, 0x11, 0x2, 0x2, 0xd7, 0xd9, 0x5, 0x46, + 0x24, 0x2, 0xd8, 0xd6, 0x3, 0x2, 0x2, 0x2, 0xd9, 0xdc, 0x3, 0x2, + 0x2, 0x2, 0xda, 0xd8, 0x3, 0x2, 0x2, 0x2, 0xda, 0xdb, 0x3, 0x2, 0x2, + 0x2, 0xdb, 0xdd, 0x3, 0x2, 0x2, 0x2, 0xdc, 0xda, 0x3, 0x2, 0x2, 0x2, + 0xdd, 0xde, 0x7, 0x15, 0x2, 0x2, 0xde, 0x27, 0x3, 0x2, 0x2, 0x2, + 0xdf, 0xe0, 0x5, 0x8, 0x5, 0x2, 0xe0, 0xe1, 0x7, 0x3, 0x2, 0x2, 0xe1, + 0xf0, 0x3, 0x2, 0x2, 0x2, 0xe2, 0xf0, 0x5, 0x2a, 0x16, 0x2, 0xe3, + 0xf0, 0x5, 0x30, 0x19, 0x2, 0xe4, 0xf0, 0x5, 0x36, 0x1c, 0x2, 0xe5, + 0xf0, 0x5, 0x38, 0x1d, 0x2, 0xe6, 0xe7, 0x5, 0x3a, 0x1e, 0x2, 0xe7, + 0xe8, 0x7, 0x3, 0x2, 0x2, 0xe8, 0xf0, 0x3, 0x2, 0x2, 0x2, 0xe9, 0xea, + 0x5, 0x3c, 0x1f, 0x2, 0xea, 0xeb, 0x7, 0x3, 0x2, 0x2, 0xeb, 0xf0, + 0x3, 0x2, 0x2, 0x2, 0xec, 0xed, 0x5, 0x3e, 0x20, 0x2, 0xed, 0xee, + 0x7, 0x3, 0x2, 0x2, 0xee, 0xf0, 0x3, 0x2, 0x2, 0x2, 0xef, 0xdf, 0x3, + 0x2, 0x2, 0x2, 0xef, 0xe2, 0x3, 0x2, 0x2, 0x2, 0xef, 0xe3, 0x3, 0x2, + 0x2, 0x2, 0xef, 0xe4, 0x3, 0x2, 0x2, 0x2, 0xef, 0xe5, 0x3, 0x2, 0x2, + 0x2, 0xef, 0xe6, 0x3, 0x2, 0x2, 0x2, 0xef, 0xe9, 0x3, 0x2, 0x2, 0x2, + 0xef, 0xec, 0x3, 0x2, 0x2, 0x2, 0xf0, 0x29, 0x3, 0x2, 0x2, 0x2, 0xf1, + 0xf2, 0x7, 0x16, 0x2, 0x2, 0xf2, 0xf3, 0x5, 0x3e, 0x20, 0x2, 0xf3, + 0xf7, 0x5, 0x1a, 0xe, 0x2, 0xf4, 0xf6, 0x5, 0x2c, 0x17, 0x2, 0xf5, + 0xf4, 0x3, 0x2, 0x2, 0x2, 0xf6, 0xf9, 0x3, 0x2, 0x2, 0x2, 0xf7, 0xf5, + 0x3, 0x2, 0x2, 0x2, 0xf7, 0xf8, 0x3, 0x2, 0x2, 0x2, 0xf8, 0xfb, 0x3, + 0x2, 0x2, 0x2, 0xf9, 0xf7, 0x3, 0x2, 0x2, 0x2, 0xfa, 0xfc, 0x5, 0x2e, + 0x18, 0x2, 0xfb, 0xfa, 0x3, 0x2, 0x2, 0x2, 0xfb, 0xfc, 0x3, 0x2, + 0x2, 0x2, 0xfc, 0x2b, 0x3, 0x2, 0x2, 0x2, 0xfd, 0xfe, 0x7, 0x17, + 0x2, 0x2, 0xfe, 0xff, 0x7, 0x16, 0x2, 0x2, 0xff, 0x100, 0x5, 0x3e, + 0x20, 0x2, 0x100, 0x101, 0x5, 0x1a, 0xe, 0x2, 0x101, 0x2d, 0x3, 0x2, + 0x2, 0x2, 0x102, 0x103, 0x7, 0x17, 0x2, 0x2, 0x103, 0x104, 0x5, 0x1a, + 0xe, 0x2, 0x104, 0x2f, 0x3, 0x2, 0x2, 0x2, 0x105, 0x106, 0x7, 0x18, + 0x2, 0x2, 0x106, 0x107, 0x5, 0x3e, 0x20, 0x2, 0x107, 0x108, 0x5, + 0x32, 0x1a, 0x2, 0x108, 0x31, 0x3, 0x2, 0x2, 0x2, 0x109, 0x10d, 0x7, + 0x5, 0x2, 0x2, 0x10a, 0x10c, 0x5, 0x34, 0x1b, 0x2, 0x10b, 0x10a, + 0x3, 0x2, 0x2, 0x2, 0x10c, 0x10f, 0x3, 0x2, 0x2, 0x2, 0x10d, 0x10b, + 0x3, 0x2, 0x2, 0x2, 0x10d, 0x10e, 0x3, 0x2, 0x2, 0x2, 0x10e, 0x110, + 0x3, 0x2, 0x2, 0x2, 0x10f, 0x10d, 0x3, 0x2, 0x2, 0x2, 0x110, 0x111, + 0x7, 0x6, 0x2, 0x2, 0x111, 0x33, 0x3, 0x2, 0x2, 0x2, 0x112, 0x113, + 0x7, 0x19, 0x2, 0x2, 0x113, 0x114, 0x5, 0x3e, 0x20, 0x2, 0x114, 0x115, + 0x5, 0x1a, 0xe, 0x2, 0x115, 0x35, 0x3, 0x2, 0x2, 0x2, 0x116, 0x117, + 0x7, 0x1a, 0x2, 0x2, 0x117, 0x118, 0x5, 0xc, 0x7, 0x2, 0x118, 0x119, + 0x7, 0x11, 0x2, 0x2, 0x119, 0x11a, 0x5, 0x3e, 0x20, 0x2, 0x11a, 0x11b, + 0x7, 0x11, 0x2, 0x2, 0x11b, 0x11c, 0x5, 0x3e, 0x20, 0x2, 0x11c, 0x11d, + 0x5, 0x1a, 0xe, 0x2, 0x11d, 0x37, 0x3, 0x2, 0x2, 0x2, 0x11e, 0x11f, + 0x7, 0x1b, 0x2, 0x2, 0x11f, 0x120, 0x5, 0x3e, 0x20, 0x2, 0x120, 0x121, + 0x5, 0x1a, 0xe, 0x2, 0x121, 0x39, 0x3, 0x2, 0x2, 0x2, 0x122, 0x123, + 0x5, 0x3e, 0x20, 0x2, 0x123, 0x124, 0x7, 0x9, 0x2, 0x2, 0x124, 0x125, + 0x5, 0x3e, 0x20, 0x2, 0x125, 0x3b, 0x3, 0x2, 0x2, 0x2, 0x126, 0x127, + 0x7, 0x1c, 0x2, 0x2, 0x127, 0x128, 0x5, 0x3e, 0x20, 0x2, 0x128, 0x3d, + 0x3, 0x2, 0x2, 0x2, 0x129, 0x12d, 0x8, 0x20, 0x1, 0x2, 0x12a, 0x12c, + 0x5, 0x12, 0xa, 0x2, 0x12b, 0x12a, 0x3, 0x2, 0x2, 0x2, 0x12c, 0x12f, + 0x3, 0x2, 0x2, 0x2, 0x12d, 0x12b, 0x3, 0x2, 0x2, 0x2, 0x12d, 0x12e, + 0x3, 0x2, 0x2, 0x2, 0x12e, 0x130, 0x3, 0x2, 0x2, 0x2, 0x12f, 0x12d, + 0x3, 0x2, 0x2, 0x2, 0x130, 0x131, 0x5, 0x42, 0x22, 0x2, 0x131, 0x13a, + 0x7, 0xf, 0x2, 0x2, 0x132, 0x137, 0x5, 0x3e, 0x20, 0x2, 0x133, 0x134, + 0x7, 0x11, 0x2, 0x2, 0x134, 0x136, 0x5, 0x3e, 0x20, 0x2, 0x135, 0x133, + 0x3, 0x2, 0x2, 0x2, 0x136, 0x139, 0x3, 0x2, 0x2, 0x2, 0x137, 0x135, + 0x3, 0x2, 0x2, 0x2, 0x137, 0x138, 0x3, 0x2, 0x2, 0x2, 0x138, 0x13b, + 0x3, 0x2, 0x2, 0x2, 0x139, 0x137, 0x3, 0x2, 0x2, 0x2, 0x13a, 0x132, + 0x3, 0x2, 0x2, 0x2, 0x13a, 0x13b, 0x3, 0x2, 0x2, 0x2, 0x13b, 0x13c, + 0x3, 0x2, 0x2, 0x2, 0x13c, 0x13d, 0x7, 0x10, 0x2, 0x2, 0x13d, 0x14e, + 0x3, 0x2, 0x2, 0x2, 0x13e, 0x14e, 0x5, 0x40, 0x21, 0x2, 0x13f, 0x140, + 0x7, 0xf, 0x2, 0x2, 0x140, 0x141, 0x5, 0x3e, 0x20, 0x2, 0x141, 0x142, + 0x7, 0x10, 0x2, 0x2, 0x142, 0x14e, 0x3, 0x2, 0x2, 0x2, 0x143, 0x144, + 0x5, 0x4c, 0x27, 0x2, 0x144, 0x145, 0x5, 0x3e, 0x20, 0x8, 0x145, + 0x14e, 0x3, 0x2, 0x2, 0x2, 0x146, 0x148, 0x5, 0x12, 0xa, 0x2, 0x147, + 0x146, 0x3, 0x2, 0x2, 0x2, 0x148, 0x14b, 0x3, 0x2, 0x2, 0x2, 0x149, + 0x147, 0x3, 0x2, 0x2, 0x2, 0x149, 0x14a, 0x3, 0x2, 0x2, 0x2, 0x14a, + 0x14c, 0x3, 0x2, 0x2, 0x2, 0x14b, 0x149, 0x3, 0x2, 0x2, 0x2, 0x14c, + 0x14e, 0x5, 0x44, 0x23, 0x2, 0x14d, 0x129, 0x3, 0x2, 0x2, 0x2, 0x14d, + 0x13e, 0x3, 0x2, 0x2, 0x2, 0x14d, 0x13f, 0x3, 0x2, 0x2, 0x2, 0x14d, + 0x143, 0x3, 0x2, 0x2, 0x2, 0x14d, 0x149, 0x3, 0x2, 0x2, 0x2, 0x14e, + 0x175, 0x3, 0x2, 0x2, 0x2, 0x14f, 0x150, 0xc, 0x6, 0x2, 0x2, 0x150, + 0x151, 0x5, 0x4e, 0x28, 0x2, 0x151, 0x152, 0x5, 0x3e, 0x20, 0x7, + 0x152, 0x174, 0x3, 0x2, 0x2, 0x2, 0x153, 0x154, 0xc, 0x5, 0x2, 0x2, + 0x154, 0x155, 0x7, 0x1e, 0x2, 0x2, 0x155, 0x156, 0x5, 0x3e, 0x20, + 0x2, 0x156, 0x157, 0x7, 0x8, 0x2, 0x2, 0x157, 0x158, 0x5, 0x3e, 0x20, + 0x6, 0x158, 0x174, 0x3, 0x2, 0x2, 0x2, 0x159, 0x15a, 0xc, 0xc, 0x2, + 0x2, 0x15a, 0x15b, 0x7, 0x1d, 0x2, 0x2, 0x15b, 0x15c, 0x5, 0x42, + 0x22, 0x2, 0x15c, 0x165, 0x7, 0xf, 0x2, 0x2, 0x15d, 0x162, 0x5, 0x3e, + 0x20, 0x2, 0x15e, 0x15f, 0x7, 0x11, 0x2, 0x2, 0x15f, 0x161, 0x5, + 0x3e, 0x20, 0x2, 0x160, 0x15e, 0x3, 0x2, 0x2, 0x2, 0x161, 0x164, + 0x3, 0x2, 0x2, 0x2, 0x162, 0x160, 0x3, 0x2, 0x2, 0x2, 0x162, 0x163, + 0x3, 0x2, 0x2, 0x2, 0x163, 0x166, 0x3, 0x2, 0x2, 0x2, 0x164, 0x162, + 0x3, 0x2, 0x2, 0x2, 0x165, 0x15d, 0x3, 0x2, 0x2, 0x2, 0x165, 0x166, + 0x3, 0x2, 0x2, 0x2, 0x166, 0x167, 0x3, 0x2, 0x2, 0x2, 0x167, 0x168, + 0x7, 0x10, 0x2, 0x2, 0x168, 0x174, 0x3, 0x2, 0x2, 0x2, 0x169, 0x16a, + 0xc, 0x9, 0x2, 0x2, 0x16a, 0x16b, 0x7, 0x1d, 0x2, 0x2, 0x16b, 0x174, + 0x5, 0x44, 0x23, 0x2, 0x16c, 0x16d, 0xc, 0x7, 0x2, 0x2, 0x16d, 0x174, + 0x5, 0x4a, 0x26, 0x2, 0x16e, 0x16f, 0xc, 0x4, 0x2, 0x2, 0x16f, 0x170, + 0x7, 0xb, 0x2, 0x2, 0x170, 0x171, 0x5, 0x3e, 0x20, 0x2, 0x171, 0x172, + 0x7, 0xc, 0x2, 0x2, 0x172, 0x174, 0x3, 0x2, 0x2, 0x2, 0x173, 0x14f, + 0x3, 0x2, 0x2, 0x2, 0x173, 0x153, 0x3, 0x2, 0x2, 0x2, 0x173, 0x159, + 0x3, 0x2, 0x2, 0x2, 0x173, 0x169, 0x3, 0x2, 0x2, 0x2, 0x173, 0x16c, + 0x3, 0x2, 0x2, 0x2, 0x173, 0x16e, 0x3, 0x2, 0x2, 0x2, 0x174, 0x177, + 0x3, 0x2, 0x2, 0x2, 0x175, 0x173, 0x3, 0x2, 0x2, 0x2, 0x175, 0x176, + 0x3, 0x2, 0x2, 0x2, 0x176, 0x3f, 0x3, 0x2, 0x2, 0x2, 0x177, 0x175, + 0x3, 0x2, 0x2, 0x2, 0x178, 0x179, 0x9, 0x2, 0x2, 0x2, 0x179, 0x41, + 0x3, 0x2, 0x2, 0x2, 0x17a, 0x17b, 0x7, 0x40, 0x2, 0x2, 0x17b, 0x43, + 0x3, 0x2, 0x2, 0x2, 0x17c, 0x17d, 0x7, 0x40, 0x2, 0x2, 0x17d, 0x45, + 0x3, 0x2, 0x2, 0x2, 0x17e, 0x17f, 0x7, 0x40, 0x2, 0x2, 0x17f, 0x47, + 0x3, 0x2, 0x2, 0x2, 0x180, 0x181, 0x7, 0x40, 0x2, 0x2, 0x181, 0x49, + 0x3, 0x2, 0x2, 0x2, 0x182, 0x183, 0x9, 0x3, 0x2, 0x2, 0x183, 0x4b, + 0x3, 0x2, 0x2, 0x2, 0x184, 0x18c, 0x7, 0x21, 0x2, 0x2, 0x185, 0x18c, + 0x7, 0x22, 0x2, 0x2, 0x186, 0x18c, 0x7, 0x23, 0x2, 0x2, 0x187, 0x18c, + 0x7, 0x24, 0x2, 0x2, 0x188, 0x18c, 0x7, 0x25, 0x2, 0x2, 0x189, 0x18c, + 0x7, 0xa, 0x2, 0x2, 0x18a, 0x18c, 0x5, 0x4a, 0x26, 0x2, 0x18b, 0x184, + 0x3, 0x2, 0x2, 0x2, 0x18b, 0x185, 0x3, 0x2, 0x2, 0x2, 0x18b, 0x186, + 0x3, 0x2, 0x2, 0x2, 0x18b, 0x187, 0x3, 0x2, 0x2, 0x2, 0x18b, 0x188, + 0x3, 0x2, 0x2, 0x2, 0x18b, 0x189, 0x3, 0x2, 0x2, 0x2, 0x18b, 0x18a, + 0x3, 0x2, 0x2, 0x2, 0x18c, 0x4d, 0x3, 0x2, 0x2, 0x2, 0x18d, 0x18e, + 0x9, 0x4, 0x2, 0x2, 0x18e, 0x4f, 0x3, 0x2, 0x2, 0x2, 0x22, 0x53, + 0x5d, 0x65, 0x73, 0x7f, 0x86, 0x8c, 0x8f, 0x99, 0xa3, 0xaa, 0xad, + 0xb3, 0xbb, 0xc1, 0xc7, 0xcb, 0xda, 0xef, 0xf7, 0xfb, 0x10d, 0x12d, + 0x137, 0x13a, 0x149, 0x14d, 0x162, 0x165, 0x173, 0x175, 0x18b, }; _serializedATN.insert(_serializedATN.end(), serializedATNSegment0,