From 4d3d19c6a7252e7a54c19e665bc69fdf2214fd4d Mon Sep 17 00:00:00 2001 From: codeboss <2422523675@qq.com> Date: Fri, 26 Jul 2024 16:22:34 +0800 Subject: [PATCH] =?UTF-8?q?=E7=B2=BE=E7=AE=80=E5=92=8C=E6=94=B9=E8=BF=9B?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- libSyntax/libsyntax.cpp | 2 +- libSyntax/syntax_novel.cpp | 31 ++++++++++++++++--------------- 2 files changed, 17 insertions(+), 16 deletions(-) diff --git a/libSyntax/libsyntax.cpp b/libSyntax/libsyntax.cpp index f720e5e..1c1f17f 100644 --- a/libSyntax/libsyntax.cpp +++ b/libSyntax/libsyntax.cpp @@ -23,7 +23,7 @@ std::tuple> TokenMatch } else { rt_inst->appendParseErrors(rt_inst->currentFile(), head->position(), - QString(u8"Syntax[0x00001]语法匹配错误,无法识别\"%1\"(应该为:%4)\n\t目标语法:'%5'。\n") + QString(u8"Syntax[0x00001]语法匹配错误,无法识别\"%1\"(应该为:%4)\n\t目标语法:%5。\n") .arg(head->content()).arg(head->row()).arg(head->column()).arg(this->define_peer->reviseWords()) .arg(rt_inst->currentExprRule()->token_present())); return std::make_tuple(IBasicRule::MatchResult::Part, head); diff --git a/libSyntax/syntax_novel.cpp b/libSyntax/syntax_novel.cpp index 7615a00..a349427 100644 --- a/libSyntax/syntax_novel.cpp +++ b/libSyntax/syntax_novel.cpp @@ -12,6 +12,7 @@ auto leftb = std::make_shared(); // { auto rightb = std::make_shared(); // } auto refers = std::make_shared(); // @ auto declare = std::make_shared(); // # +auto split_mark = std::make_shared(); // & auto rank_key = std::make_shared(u8"排序", 0xAEu); // 排序 auto story_key = std::make_shared(u8"故事", 0xAAu); // 故事 @@ -19,7 +20,6 @@ auto numbers = std::make_shared(); // [0-9 auto frag_key = std::make_shared(u8"情节", 0xABu); // 情节 auto volume_key = std::make_shared(u8"分卷", 0xACu); // 分卷 auto article_key = std::make_shared(u8"章节", 0xADu); // 章节 -auto split_mark = std::make_shared(); // & auto vtext = std::make_shared(); // ^([^\\{\\}\@&]+) auto name_text = std::make_shared(); // ^([^\\{\\}@&]+) @@ -35,32 +35,33 @@ auto name_text = std::make_shared(); // ^ #define OptMulR(rule) std::make_shared(rule, 0, INT_MAX) // multi+ #define MultiR(rule) std::make_shared(rule, 1, INT_MAX) +// opt? +#define OptR(rule) std::make_shared(rule, 0, 1) -auto decl_comp = std::make_shared(Rules{ MR(numbers), MR(vtext), MR(name_text), MR(split_mark) }); auto decl_expr = ElementRule(u8"decl_section", (int)NovelExprs::DESC_SECTION).reloadRule( - MultiR(decl_comp)); + MultiR(std::make_shared(Rules{ MR(numbers), MR(vtext), MR(refers), MR(split_mark)})) +); auto fragment_decl = ElementRule(u8"fragment_define", (int)NovelExprs::FRAG_DEFINES).reloadRule( - std::make_shared( - Rules{ MR(leftb), MR(frag_key), MR(name_text) } << - OptMulR(decl_expr) << + std::make_shared(Rules{ + MR(leftb), MR(frag_key), MR(name_text) } << + OptR(decl_expr) << MR(rightb) )); auto fragment_refer = ElementRule(u8"fragment_refer", (int)NovelExprs::FRAG_REFERS).reloadRule( - std::make_shared( - Rules{ MR(leftb), MR(refers), MR(frag_key), MR(name_text), MR(split_mark), MR(name_text) } << - OptMulR(decl_expr) << + std::make_shared(Rules{ + MR(leftb), MR(refers), MR(frag_key), MR(name_text), MR(split_mark), MR(name_text) } << + OptR(decl_expr) << MR(rightb) )); -auto fragment_comp = std::make_shared(Rules{ fragment_decl, fragment_refer, decl_expr }); auto story_define = ElementRule(u8"story_define", (int)NovelExprs::STORY_DEFINES).reloadRule( - std::make_shared( - Rules{ MR(leftb), MR(story_key), MR(name_text) } << - OptMulR(fragment_comp) << + std::make_shared(Rules{ + MR(leftb), MR(story_key), MR(name_text) } << + OptMulR(std::make_shared(Rules{ fragment_decl, fragment_refer, decl_expr })) << MR(rightb) )); // =================================================================== @@ -79,8 +80,8 @@ auto volume_decl = ElementRule(u8"volume_define", (int)NovelExprs: )); auto rank_define = ElementRule(u8"rank_define", (int)NovelNode::RankDeclaration).reloadRule( - std::make_shared( - Rules{ MR(declare), MR(rank_key), MR(numbers) } + std::make_shared(Rules{ + MR(declare), MR(rank_key), MR(numbers) } )); auto document_define = ElementRule(u8"decls-doc", (int)NovelExprs::DOC_DEFINES).reloadRule(