fix-ast-struct

This commit is contained in:
codeboss 2025-03-01 21:15:15 +08:00
parent 3166c1b0c7
commit 647f41aa80
5 changed files with 60 additions and 38 deletions

View File

@ -3,7 +3,7 @@
<PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">
<LocalDebuggerWorkingDirectory>$(SolutionDir)$(Platform)\$(Configuration)\</LocalDebuggerWorkingDirectory>
<DebuggerFlavor>WindowsLocalDebugger</DebuggerFlavor>
<LocalDebuggerCommandArguments>--path "D:\Projects\Cpp\WsNovelParser\x64\test_file" --dest E:\</LocalDebuggerCommandArguments>
<LocalDebuggerCommandArguments>--path "D:\CustomNovels\科学+修仙+创造世界X" --dest E:\</LocalDebuggerCommandArguments>
</PropertyGroup>
<PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release|x64'">
<LocalDebuggerCommandArguments>--path "D:\Projects\Cpp\WsNovelParser\x64\test_file" --dest E:\</LocalDebuggerCommandArguments>

View File

@ -40,6 +40,7 @@ VisitMode printer::AstGenerate::mode() const {
#include <QDateTime>
bool printer::AstGenerate::visit(std::shared_ptr<const ast_gen::ElementAccess> syntax_element) {
auto depth = syntax_element->element()->depth();
switch ((NovelNode) syntax_element->element()->typeMark()) {
case NovelNode::GlobalElement:
{
@ -47,20 +48,21 @@ bool printer::AstGenerate::visit(std::shared_ptr<const ast_gen::ElementAccess> s
doc.appendChild(body);
body.setAttribute("time", QDateTime::currentDateTime().toString("yyyyMMdd_hhmmss"));
body.setAttribute("dir_src", src_root.absolutePath());
element_stack.append(body);
element_stack.append(std::make_pair(depth, body));
}break;
case NovelNode::Document: break;
case NovelNode::StoryDefine:
{
while (element_stack.last().tagName() != "ast") {
element_stack.takeLast();
}
decltype(this->element_stack) temp_stack;
std::copy_if(element_stack.begin(), element_stack.end(),
std::back_inserter(temp_stack), [=](std::pair<int, QDomElement> ep){ return ep.first < depth; });
this->element_stack = temp_stack;
auto current_ast = element_stack.last();
auto story_node = std::dynamic_pointer_cast<const example_novel::StoryDefine>(syntax_element->element());
auto dom_story = doc.createElement("story");
current_ast.appendChild(dom_story);
element_stack.append(dom_story);
current_ast.second.appendChild(dom_story);
element_stack.append(std::make_pair(depth, dom_story));
dom_story.setAttribute("name", story_node->name());
dom_story.setAttribute("address", (qulonglong) story_node.get());
@ -71,30 +73,32 @@ bool printer::AstGenerate::visit(std::shared_ptr<const ast_gen::ElementAccess> s
}break;
case NovelNode::FragmentSlice:
{
while (element_stack.last().tagName() != "story") {
element_stack.takeLast();
}
decltype(this->element_stack) temp_stack;
std::copy_if(element_stack.begin(), element_stack.end(),
std::back_inserter(temp_stack), [=](std::pair<int, QDomElement> ep) { return ep.first < depth; });
this->element_stack = temp_stack;
auto current_story = element_stack.last();
auto slice_node = std::dynamic_pointer_cast<const example_novel::FragmentSlice>(syntax_element->element());
auto dom_slice = doc.createElement("slice");
current_story.appendChild(dom_slice);
element_stack.append(dom_slice);
current_story.second.appendChild(dom_slice);
element_stack.append(std::make_pair(depth, dom_slice));
dom_slice.setAttribute("name", slice_node->name());
dom_slice.setAttribute("address", (qulonglong) slice_node.get());
}break;
case NovelNode::PointDefines:
{
while (element_stack.last().tagName() != "slice") {
element_stack.takeLast();
}
decltype(this->element_stack) temp_stack;
std::copy_if(element_stack.begin(), element_stack.end(),
std::back_inserter(temp_stack), [=](std::pair<int, QDomElement> ep) { return ep.first < depth; });
this->element_stack = temp_stack;
auto current_slice = element_stack.last();
auto point_node = std::dynamic_pointer_cast<const example_novel::PointDefines>(syntax_element->element());
auto dom_point = doc.createElement("point");
current_slice.appendChild(dom_point);
element_stack.append(dom_point);
current_slice.second.appendChild(dom_point);
element_stack.append(std::make_pair(depth, dom_point));
dom_point.setAttribute("name", point_node->name());
dom_point.setAttribute("address", (qulonglong) point_node.get());
@ -104,14 +108,15 @@ bool printer::AstGenerate::visit(std::shared_ptr<const ast_gen::ElementAccess> s
}break;
case NovelNode::TextSection:
{
while (element_stack.last().tagName() == "text") {
element_stack.takeLast();
}
decltype(this->element_stack) temp_stack;
std::copy_if(element_stack.begin(), element_stack.end(),
std::back_inserter(temp_stack), [=](std::pair<int, QDomElement> ep) { return ep.first < depth; });
this->element_stack = temp_stack;
auto current_pnode = element_stack.last();
auto text_node = std::dynamic_pointer_cast<const example_novel::TextSection>(syntax_element->element());
auto dom_text = doc.createElement("text-section");
current_pnode.appendChild(dom_text);
current_pnode.second.appendChild(dom_text);
dom_text.setAttribute("text", text_node->content());
dom_text.setAttribute("file-path", src_root.relativeFilePath(text_node->filePath()));
@ -120,15 +125,16 @@ bool printer::AstGenerate::visit(std::shared_ptr<const ast_gen::ElementAccess> s
}break;
case NovelNode::PointRefers:
{
while (element_stack.last().tagName() != "article" && element_stack.last().tagName() != "slice") {
element_stack.takeLast();
}
decltype(this->element_stack) temp_stack;
std::copy_if(element_stack.begin(), element_stack.end(),
std::back_inserter(temp_stack), [=](std::pair<int, QDomElement> ep) { return ep.first < depth; });
this->element_stack = temp_stack;
auto current_pnode = element_stack.last();
auto refer_node = std::dynamic_pointer_cast<const example_novel::PointRefers>(syntax_element->element());
auto dom_refer = doc.createElement("refer");
element_stack.append(dom_refer);
current_pnode.appendChild(dom_refer);
current_pnode.second.appendChild(dom_refer);
element_stack.append(std::make_pair(depth, dom_refer));
dom_refer.setAttribute("story", refer_node->storyRefer());
dom_refer.setAttribute("slice", refer_node->sliceRefer());
@ -139,15 +145,16 @@ bool printer::AstGenerate::visit(std::shared_ptr<const ast_gen::ElementAccess> s
}break;
case NovelNode::VolumeDefine:
{
while (element_stack.last().tagName() != "ast") {
element_stack.takeLast();
}
decltype(this->element_stack) temp_stack;
std::copy_if(element_stack.begin(), element_stack.end(),
std::back_inserter(temp_stack), [=](std::pair<int, QDomElement> ep) { return ep.first < depth; });
this->element_stack = temp_stack;
auto current_ast = element_stack.last();
auto volume_node = std::dynamic_pointer_cast<const example_novel::VolumeDefine>(syntax_element->element());
auto dom_volume = doc.createElement("volume");
current_ast.appendChild(dom_volume);
element_stack.append(dom_volume);
current_ast.second.appendChild(dom_volume);
element_stack.append(std::make_pair(depth, dom_volume));
dom_volume.setAttribute("name", volume_node->name());
dom_volume.setAttribute("address", (qulonglong) volume_node.get());
@ -157,15 +164,16 @@ bool printer::AstGenerate::visit(std::shared_ptr<const ast_gen::ElementAccess> s
}break;
case NovelNode::ArticleDefine:
{
while (element_stack.last().tagName() != "volume") {
element_stack.takeLast();
}
decltype(this->element_stack) temp_stack;
std::copy_if(element_stack.begin(), element_stack.end(),
std::back_inserter(temp_stack), [=](std::pair<int, QDomElement> ep) { return ep.first < depth; });
this->element_stack = temp_stack;
auto current_volume = element_stack.last();
auto article_node = std::dynamic_pointer_cast<const example_novel::ArticleDefine>(syntax_element->element());
auto dom_article = doc.createElement("article");
current_volume.appendChild(dom_article);
element_stack.append(dom_article);
current_volume.second.appendChild(dom_article);
element_stack.append(std::make_pair(depth, dom_article));
dom_article.setAttribute("name", article_node->name());
dom_article.setAttribute("address", (qulonglong) article_node.get());
@ -178,7 +186,7 @@ bool printer::AstGenerate::visit(std::shared_ptr<const ast_gen::ElementAccess> s
auto ast_element = element_stack.first();
auto rank_node = std::dynamic_pointer_cast<const example_novel::RankDeclare>(syntax_element->element());
auto dom_rank = doc.createElement("rank");
ast_element.appendChild(dom_rank);
ast_element.second.appendChild(dom_rank);
dom_rank.setAttribute("rank", rank_node->rankNumber());
dom_rank.setAttribute("doc-path", src_root.relativeFilePath(rank_node->filePath()));

View File

@ -15,7 +15,7 @@ namespace printer {
private:
QDir src_root;
QDomDocument doc;
QList<QDomElement> element_stack;
QList<std::pair<int, QDomElement>> element_stack;
void append_tokens(QDomElement _elm, std::shared_ptr<const ast_gen::SyntaxElement> inst);

View File

@ -188,6 +188,10 @@ QString NGlobalElement::signature() const {
return "::program";
}
int example_novel::NGlobalElement::depth() const {
return 1;
}
std::weak_ptr<const SyntaxElement> NGlobalElement::parent() const {
return std::weak_ptr<const SyntaxElement>();
}

View File

@ -46,6 +46,12 @@ namespace ast_gen {
*/
virtual QString signature() const = 0;
/**
* @brief Ast深度
* @return depth
*/
virtual int depth() const = 0;
/**
* @brief
* @return parentnullptr
@ -149,6 +155,9 @@ namespace example_novel {
QString path() const override {
return ExprInstance::filePath();
}
int depth() const {
return parent().lock()->depth() + 1;
}
virtual std::weak_ptr<const ast_gen::SyntaxElement> parent() const override {
return std::dynamic_pointer_cast<const ast_gen::SyntaxElement>(ExprInstance::parentExpr().lock());
}
@ -339,6 +348,7 @@ namespace example_novel {
bool isAnonymous() const override;
QString path() const override;
QString signature() const override;
int depth() const override;
std::weak_ptr<const SyntaxElement> parent() const override;
QList<std::shared_ptr<const ast_gen::TokenAccess>> selfTokens() const override;
};