HikoGUI
A low latency retained GUI
Loading...
Searching...
No Matches
formula_call_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 "formula_node.hpp"
8
9namespace hi::inline v1 {
10
13 formula_vector args;
14
16 formula_node(std::move(location)), lhs(std::move(lhs))
17 {
18 auto rhs_ = dynamic_cast<formula_arguments *>(rhs.get());
19 hi_assert(rhs_ != nullptr);
20 args = std::move(rhs_->args);
21 }
22
24 {
25 lhs->resolve_function_pointer(context);
26 for (auto &arg : args) {
27 arg->post_process(context);
28 }
29 }
30
31 datum evaluate(formula_evaluation_context &context) const override
32 {
33 hilet args_ = transform<datum::vector_type>(args, [&](hilet &x) {
34 return x->evaluate(context);
35 });
36
37 return lhs->call(context, args_);
38 }
39
41 {
43
44 try {
45 r.push_back(lhs->get_name());
46 } catch (parse_error const &e) {
47 throw parse_error(std::format("Function definition does not have a name, got {}\n{}", *lhs, e.what()));
48 }
49
50 for (hilet &arg : args) {
51 try {
52 r.push_back(arg->get_name());
53 } catch (parse_error const &e) {
54 throw parse_error(std::format("Definition of function {}() has a non-name argument {}\n{}", *lhs, *arg, e.what()));
55 }
56 }
57
58 return r;
59 }
60
61 std::string string() const noexcept override
62 {
63 auto s = std::format("({}(", *lhs);
64 int i = 0;
65 for (hilet &arg : args) {
66 if (i++ > 0) {
67 s += ',';
68 s += ' ';
69 }
70 s += to_string(*arg);
71 }
72 return s + "))";
73 }
74};
75
76} // namespace hi::inline v1
#define hilet
Invariant should be the default for variables.
Definition required.hpp:23
A dynamic data type.
Definition datum.hpp:225
Exception thrown during parsing on an error.
Definition exception.hpp:25
A temporary node used during parsing.
Definition formula_arguments.hpp:13
Definition formula_call_node.hpp:11
void post_process(formula_post_process_context &context) override
Resolve function and method pointers.
Definition formula_call_node.hpp:23
datum evaluate(formula_evaluation_context &context) const override
Evaluate an rvalue.
Definition formula_call_node.hpp:31
std::vector< std::string > get_name_and_argument_names() const override
Get name and argument names from a function declaration.
Definition formula_call_node.hpp:40
Definition formula_evaluation_context.hpp:16
Definition formula_node.hpp:29
Definition formula_post_process_context.hpp:19
Definition parse_location.hpp:17
T get(T... args)
T move(T... args)
T push_back(T... args)
T what(T... args)