HikoGUI
A low latency retained GUI
Loading...
Searching...
No Matches
skeleton_if_node.hpp
1// Copyright Take Vos 2020-2021.
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 hi::inline v1 {
10
12 std::vector<statement_vector> children_groups;
14 std::vector<parse_location> formula_locations;
15
16 skeleton_if_node(parse_location location, std::unique_ptr<formula_node> expression) noexcept : skeleton_node(location)
17 {
18 expressions.push_back(std::move(expression));
19 formula_locations.push_back(location);
20 children_groups.emplace_back();
21 }
22
23 bool found_elif(parse_location _location, std::unique_ptr<formula_node> expression) noexcept override
24 {
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 {
37 if (children_groups.size() != expressions.size()) {
38 return false;
39 }
40
41 children_groups.emplace_back();
42 return true;
43 }
44
47 bool append(std::unique_ptr<skeleton_node> x) noexcept override
48 {
49 append_child(children_groups.back(), std::move(x));
50 return true;
51 }
52
53 void post_process(formula_post_process_context &context) override
54 {
55 hi_assert(ssize(expressions) == ssize(formula_locations));
56 for (ssize_t i = 0; i != ssize(expressions); ++i) {
57 post_process_expression(context, *expressions[i], formula_locations[i]);
58 }
59
60 for (hilet &children : children_groups) {
61 if (ssize(children) > 0) {
62 children.back()->left_align();
63 }
64
65 for (hilet &child : children) {
66 child->post_process(context);
67 }
68 }
69 }
70
72 {
73 hi_assert(ssize(expressions) == ssize(formula_locations));
74 for (ssize_t i = 0; i != ssize(expressions); ++i) {
75 if (evaluate_formula_without_output(context, *expressions[i], formula_locations[i])) {
76 return evaluate_children(context, children_groups[i]);
77 }
78 }
79 if (ssize(children_groups) > ssize(expressions)) {
80 return evaluate_children(context, children_groups[ssize(expressions)]);
81 }
82 return {};
83 }
84
85 std::string string() const noexcept override
86 {
87 hi_assert(expressions.size() > 0);
88 std::string s = "<if ";
89 s += to_string(*expressions[0]);
90 s += join(transform<std::vector<std::string>>(children_groups[0], [](auto &x) {
91 return to_string(*x);
92 }));
93
94 for (std::size_t i = 1; i != expressions.size(); ++i) {
95 s += "elif ";
96 s += to_string(*expressions[i]);
97 s += join(transform<std::vector<std::string>>(children_groups[i], [](auto &x) {
98 return to_string(*x);
99 }));
100 }
101
102 if (children_groups.size() != expressions.size()) {
103 s += "else ";
104 s += join(transform<std::vector<std::string>>(children_groups.back(), [](auto &x) {
105 return to_string(*x);
106 }));
107 }
108
109 s += ">";
110 return s;
111 }
112};
113
114} // namespace hi::inline v1
#define hi_assert(expression,...)
Assert if expression is true.
Definition assert.hpp:199
#define hilet
Invariant should be the default for variables.
Definition utility.hpp:23
DOXYGEN BUG.
Definition algorithm.hpp:13
A dynamic data type.
Definition datum.hpp:223
Definition formula_evaluation_context.hpp:15
Definition formula_post_process_context.hpp:19
Definition parse_location.hpp:18
Definition skeleton_if_node.hpp:11
datum evaluate(formula_evaluation_context &context) override
Evaluate the template.
Definition skeleton_if_node.hpp:71
bool append(std::unique_ptr< skeleton_node > x) noexcept override
Append a template-piece to the current template.
Definition skeleton_if_node.hpp:47
Definition skeleton_node.hpp:16
T move(T... args)
T push_back(T... args)
T size(T... args)