aboutsummaryrefslogtreecommitdiff
path: root/lib/mstch/src/state/in_section.cpp
diff options
context:
space:
mode:
authorMistivia <i@mistivia.com>2025-01-16 15:43:04 +0800
committerMistivia <i@mistivia.com>2025-01-16 15:53:58 +0800
commit8689a7c78c50676ea739f52fbcee9f091709f5c0 (patch)
treebbb72c68e5e1753f751133941a402caa43e29a16 /lib/mstch/src/state/in_section.cpp
parent00afb767ae37488d99f78363d031b898b1932354 (diff)
add mstch
Diffstat (limited to 'lib/mstch/src/state/in_section.cpp')
-rw-r--r--lib/mstch/src/state/in_section.cpp34
1 files changed, 34 insertions, 0 deletions
diff --git a/lib/mstch/src/state/in_section.cpp b/lib/mstch/src/state/in_section.cpp
new file mode 100644
index 0000000..a139913
--- /dev/null
+++ b/lib/mstch/src/state/in_section.cpp
@@ -0,0 +1,34 @@
+#include "in_section.hpp"
+#include "outside_section.hpp"
+#include "visitor/is_node_empty.hpp"
+#include "visitor/render_section.hpp"
+
+using namespace mstch;
+
+in_section::in_section(type type, const token& start_token):
+ m_type(type), m_start_token(start_token), m_skipped_openings(0)
+{
+}
+
+std::string in_section::render(render_context& ctx, const token& token) {
+ if (token.token_type() == token::type::section_close)
+ if (token.name() == m_start_token.name() && m_skipped_openings == 0) {
+ auto& node = ctx.get_node(m_start_token.name());
+ std::string out;
+
+ if (m_type == type::normal && !visit(is_node_empty(), node))
+ out = visit(render_section(ctx, m_section, m_start_token.delims()), node);
+ else if (m_type == type::inverted && visit(is_node_empty(), node))
+ out = render_context::push(ctx).render(m_section);
+
+ ctx.set_state<outside_section>();
+ return out;
+ } else
+ m_skipped_openings--;
+ else if (token.token_type() == token::type::inverted_section_open ||
+ token.token_type() == token::type::section_open)
+ m_skipped_openings++;
+
+ m_section << token;
+ return "";
+}