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#include "../macros.hpp"
9
10namespace hi::inline v1 {
11
13 std::vector<statement_vector> children_groups;
15 std::vector<parse_location> formula_locations;
16
17 skeleton_if_node(parse_location location, std::unique_ptr<formula_node> expression) noexcept : 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 {
26 if (children_groups.size() != expressions.size()) {
27 return false;
28 }
29
30 expressions.push_back(std::move(expression));
31 formula_locations.push_back(std::move(_location));
32 children_groups.emplace_back();
33 return true;
34 }
35
36 bool found_else(parse_location _location) noexcept override
37 {
38 if (children_groups.size() != expressions.size()) {
39 return false;
40 }
41
42 children_groups.emplace_back();
43 return true;
44 }
45
48 bool append(std::unique_ptr<skeleton_node> x) noexcept override
49 {
50 append_child(children_groups.back(), std::move(x));
51 return true;
52 }
53
54 void post_process(formula_post_process_context &context) override
55 {
56 hi_assert(ssize(expressions) == ssize(formula_locations));
57 for (ssize_t i = 0; i != ssize(expressions); ++i) {
58 post_process_expression(context, *expressions[i], formula_locations[i]);
59 }
60
61 for (hilet &children : children_groups) {
62 if (ssize(children) > 0) {
63 children.back()->left_align();
64 }
65
66 for (hilet &child : children) {
67 child->post_process(context);
68 }
69 }
70 }
71
72 datum evaluate(formula_evaluation_context &context) override
73 {
74 hi_assert(ssize(expressions) == ssize(formula_locations));
75 for (ssize_t i = 0; i != ssize(expressions); ++i) {
76 if (evaluate_formula_without_output(context, *expressions[i], formula_locations[i])) {
77 return evaluate_children(context, children_groups[i]);
78 }
79 }
80 if (ssize(children_groups) > ssize(expressions)) {
81 return evaluate_children(context, children_groups[ssize(expressions)]);
82 }
83 return {};
84 }
85
86 std::string string() const noexcept override
87 {
88 hi_assert(expressions.size() > 0);
89 std::string s = "<if ";
90 s += to_string(*expressions[0]);
91 s += join(transform<std::vector<std::string>>(children_groups[0], [](auto &x) {
92 return to_string(*x);
93 }));
94
95 for (std::size_t i = 1; i != expressions.size(); ++i) {
96 s += "elif ";
97 s += to_string(*expressions[i]);
98 s += join(transform<std::vector<std::string>>(children_groups[i], [](auto &x) {
99 return to_string(*x);
100 }));
101 }
102
103 if (children_groups.size() != expressions.size()) {
104 s += "else ";
105 s += join(transform<std::vector<std::string>>(children_groups.back(), [](auto &x) {
106 return to_string(*x);
107 }));
108 }
109
110 s += ">";
111 return s;
112 }
113};
114
115} // namespace hi::inline v1
DOXYGEN BUG.
Definition algorithm.hpp:16
constexpr Out narrow_cast(In const &rhs) noexcept
Cast numeric values without loss of precision.
Definition cast.hpp:377
Definition parse_location.hpp:18
Definition skeleton_if_node.hpp:12
datum evaluate(formula_evaluation_context &context) override
Evaluate the template.
Definition skeleton_if_node.hpp:72
bool append(std::unique_ptr< skeleton_node > x) noexcept override
Append a template-piece to the current template.
Definition skeleton_if_node.hpp:48
Definition skeleton_node.hpp:16
T move(T... args)
T push_back(T... args)
T size(T... args)