HikoGUI
A low latency retained GUI
Loading...
Searching...
No Matches
skeleton_if_node.hpp
1// Copyright Take Vos 2020.
2// Distributed under the Boost Software License, Version 1.0.
3// (See accompanying file LICENSE_1_0.txt or copy at https://www.boost.org/LICENSE_1_0.txt)
4
5#pragma once
6
7#include "skeleton_node.hpp"
8
9namespace tt {
10
12 std::vector<statement_vector> children_groups;
14 std::vector<parse_location> formula_locations;
15
17 skeleton_node(location)
18 {
19 expressions.push_back(std::move(expression));
20 formula_locations.push_back(location);
21 children_groups.emplace_back();
22 }
23
24 bool found_elif(parse_location _location, std::unique_ptr<formula_node> expression) noexcept override {
25 if (children_groups.size() != expressions.size()) {
26 return false;
27 }
28
29 expressions.push_back(std::move(expression));
30 formula_locations.push_back(std::move(_location));
31 children_groups.emplace_back();
32 return true;
33 }
34
35 bool found_else(parse_location _location) noexcept override {
36 if (children_groups.size() != expressions.size()) {
37 return false;
38 }
39
40 children_groups.emplace_back();
41 return true;
42 }
43
46 bool append(std::unique_ptr<skeleton_node> x) noexcept override {
47 append_child(children_groups.back(), std::move(x));
48 return true;
49 }
50
51 void post_process(formula_post_process_context &context) override {
52 tt_assert(std::ssize(expressions) == std::ssize(formula_locations));
53 for (ssize_t i = 0; i != std::ssize(expressions); ++i) {
54 post_process_expression(context, *expressions[i], formula_locations[i]);
55 }
56
57 for (ttlet &children: children_groups) {
58 if (std::ssize(children) > 0) {
59 children.back()->left_align();
60 }
61
62 for (ttlet &child: children) {
63 child->post_process(context);
64 }
65 }
66 }
67
69 tt_axiom(std::ssize(expressions) == std::ssize(formula_locations));
70 for (ssize_t i = 0; i != std::ssize(expressions); ++i) {
71 if (evaluate_formula_without_output(context, *expressions[i], formula_locations[i])) {
72 return evaluate_children(context, children_groups[i]);
73 }
74 }
75 if (std::ssize(children_groups) > std::ssize(expressions)) {
76 return evaluate_children(context, children_groups[std::ssize(expressions)]);
77 }
78 return {};
79 }
80
81 std::string string() const noexcept override {
82 tt_assert(expressions.size() > 0);
83 std::string s = "<if ";
84 s += to_string(*expressions[0]);
85 s += join(transform<std::vector<std::string>>(children_groups[0], [](auto &x) { return to_string(*x); }));
86
87 for (size_t i = 1; i != expressions.size(); ++i) {
88 s += "elif ";
89 s += to_string(*expressions[i]);
90 s += join(transform<std::vector<std::string>>(children_groups[i], [](auto &x) { return to_string(*x); }));
91 }
92
93 if (children_groups.size() != expressions.size()) {
94 s += "else ";
95 s += join(transform<std::vector<std::string>>(children_groups.back(), [](auto &x) { return to_string(*x); }));
96 }
97
98 s += ">";
99 return s;
100 }
101};
102
103}
A dynamic data type.
Definition datum.hpp:213
Definition formula_evaluation_context.hpp:16
Definition formula_post_process_context.hpp:19
Definition parse_location.hpp:17
Definition skeleton_if_node.hpp:11
datum evaluate(formula_evaluation_context &context) override
Evaluate the template.
Definition skeleton_if_node.hpp:68
bool append(std::unique_ptr< skeleton_node > x) noexcept override
Append a template-piece to the current template.
Definition skeleton_if_node.hpp:46
Definition skeleton_node.hpp:16
T move(T... args)
T push_back(T... args)
T size(T... args)