#include "syntax_novel.h" #include #include "ast_novel.h" using namespace lib_syntax; using namespace example_novel; using namespace lib_token; using namespace ast_basic; using namespace std; // rule-parts =============================================================================== #include "syntax_templets.h" using namespace lib_composit; void ref_story_set(std::shared_ptr inst, std::shared_ptr token) { inst->addToken(token); inst->setStoryRefer(token->content()); } void ref_slice_set(std::shared_ptr inst, std::shared_ptr token) { inst->addToken(token); inst->setSliceRefer(token->content()); } void slice_nm_set(std::shared_ptr inst, std::shared_ptr token) { inst->addToken(token); inst->setName(token->content()); } void story_nm_set(std::shared_ptr inst, std::shared_ptr token) { inst->addToken(token); inst->setName(token->content()); } void article_nm_set(std::shared_ptrinst, std::shared_ptr token) { inst->addToken(token); inst->setName(token->content()); } void volume_nm_set(std::shared_ptr inst, std::shared_ptr token) { inst->addToken(token); inst->setName(token->content()); } void rank_set(std::shared_ptr inst, std::shared_ptr token) { inst->addToken(token); inst->setRank(token->content().toInt()); } //auto content_extract = [](std::shared_ptr token) { // QString content; // while (token) { // if (token->defines()) // content.prepend(token->content() + " "); // token = token->prevToken(); // } // return content; // }; using TextDeclsSyntaxDef = Any, Match>; class DeclSyntax : public ElementRule { public: DeclSyntax() : ElementRule("decl_section") { } // 通过 ElementRule 继承 QList> expr_rule_parse(std::shared_ptr cursor) const override { //// 如果提前结束,记录错误并返回 //if (!cursor->words()) { // // 只有在表达式的起始点遇到nullptr,才是正常结束。 // if (cursor->token()->tokenType() != lib_token::IActionToken::Type::ElementBegin) { // auto ncurs = std::make_shared(cursor); // ncurs->logExprsError(QString("Syntax[0x00001]输入错误,程序提前结束:%1。").arg(cursor->filePath())); // ncurs->setFailure(); // return QList>() << ncurs; // } // while (cursor->token()->tokenType() == lib_token::IActionToken::Type::ElementBegin) // cursor = cursor->previous(); // auto ncurs = std::make_shared(cursor); // ncurs->setComplete(); // return QList>() << ncurs; //} //auto content = content_extract(cursor->token()); //// 绑定文字行 //auto bind_row = cursor->words()->row(); //QList> bridge_list{ cursor }; //decltype(bridge_list) final_result; //for (; bridge_list.size();) { // // 一次匹配 // decltype(bridge_list) current_result; // for (auto branch : bridge_list) { // if (branch->words()->row() == bind_row) { // auto mrst = _children_store->parse(branch); // // 本次解析无法通过,全错 // if (!std::count_if(mrst.begin(), mrst.end(), // [&](std::shared_ptr v) { // return !v->exprsErrorCount();// 没错 // })) { // final_result.append(branch); // continue; // } // // // for (auto m : mrst) { // if (m->exprsErrorCount()) { // std::const_pointer_cast(m)->setFailure(true); // final_result.append(m); // } // else { // current_result.append(m); // } // } // } // } // bridge_list = current_result; //} //for (auto x : bridge_list) // if (!final_result.contains(x)) // final_result.append(x); //return final_result; auto results = _children_store->parse(cursor); std::for_each(results.begin(), results.end(), [](std::shared_ptr ins) { std::const_pointer_cast(ins)->setFailure(ins->exprsErrorCount()); }); return results; } }; using ReferSyntaxDef = lib_composit::Seqs, Match, Match, Action, Match, Action, OptMulti, Match>; class ReferSyntax : public ElementRule { public: ReferSyntax() : ElementRule("fragment_refer") { } // 通过 ElementRule 继承 QList> expr_rule_parse(std::shared_ptr cursor) const override { return _children_store->parse(cursor); } }; using SliceSyntaxDef = lib_composit::Seqs, Match, Action, lib_composit::OptMulti>, Match>; class SliceSyntax : public ElementRule { public: SliceSyntax() : ElementRule("fragment_define") { } // 通过 ElementRule 继承 QList> expr_rule_parse(std::shared_ptr cursor) const override { return _children_store->parse(cursor); } }; using StorySyntaxDef = lib_composit::Seqs, Match, Action, lib_composit::OptMulti>, Match>; class StorySyntax : public ElementRule { public: StorySyntax() : ElementRule("story_define") { } // 通过 ElementRule 继承 QList> expr_rule_parse(std::shared_ptr cursor) const override { auto syntax = this->present(); //auto current_rst = content_extract(cursor->token()); auto rst = _children_store->parse(cursor); /* QString result_list; for (auto c : rst) { result_list += content_extract(c->token()) += "\n"; }*/ return rst; } }; using ArticleSyntaxDef = lib_composit::Seqs, Match, Action, lib_composit::OptMulti>, Match>; class ArticleSyntax : public ElementRule { public: ArticleSyntax() : ElementRule("article_define") { } // 通过 ElementRule 继承 QList> expr_rule_parse(std::shared_ptr cursor) const override { return _children_store->parse(cursor); } }; using VolumeSyntaxDef = lib_composit::Seqs, Match, Action, lib_composit::OptMulti>, Match>; class VolumeSyntax : public ElementRule { public: VolumeSyntax() : ElementRule("volume_define") { } // 通过 ElementRule 继承 QList> expr_rule_parse(std::shared_ptr cursor) const override { return _children_store->parse(cursor); } }; using RankSyntaxDef = lib_composit::Seqs, Match, Action>; class RankSyntax : public ElementRule { public: RankSyntax() : ElementRule("rank_define") { } // 通过 ElementRule 继承 QList> expr_rule_parse(std::shared_ptr cursor) const override { return _children_store->parse(cursor); } }; using DocSyntaxDef = lib_composit::Seqs, lib_composit::OptMulti>>; class DocumentSyntax : public ElementRule { public: DocumentSyntax() : ElementRule("decls-doc") { } // 通过 ElementRule 继承 QList> expr_rule_parse(std::shared_ptr cursor) const override { auto text = _children_store->present(); return _children_store->parse(cursor); } }; std::shared_ptr example_novel::NovalSyntax::getSyntaxTree() { return std::make_shared(); } //std::shared_ptr NovalSyntax::tidy(std::shared_ptr root, QList> children) //{ // build_objecttree(root, children); // node_register(root, children); // return root; //} //void NovalSyntax::build_objecttree(std::shared_ptr root, QList> children) //{ // for (auto& cinst : children) { // cinst->setParent(root); // // QList> child_items; // for (auto& it : cinst->bindExpression()->children()) { // auto const_it = std::dynamic_pointer_cast(it); // child_items.append(std::const_pointer_cast(const_it)); // } // // build_objecttree(cinst, child_items); // } //} //void NovalSyntax::node_register(std::shared_ptr root, QList> children) //{ // for (auto& child : children) { // if (!child->isAnonymous()) { // auto check_result = ast_gen::GlobalElement::UniquePtr->appendToCache(child); // if (check_result) // throw new SyntaxException(QString("SyntaxError[0x0004]系统中包含同类型重名命名节点:%1(%3,%4)") // .arg(child->signature()).arg(child->typeMark()).arg(child->path()).arg(check_result->path())); // } // // QList> next_child_items; // for (auto& it : child->bindExpression()->children()) { // auto const_it = std::dynamic_pointer_cast(it); // next_child_items.append(std::const_pointer_cast(const_it)); // } // // node_register(child, next_child_items); // } //}