Fawkes API Fawkes Development Version
GroundedFormula.cpp
1
2/****************************************************************************
3 * GroundedFormula
4 * (auto-generated, do not modify directly)
5 *
6 * CLIPS Executive REST API.
7 * Enables access to goals, plans, and all items in the domain model.
8 *
9 * API Contact: Tim Niemueller <niemueller@kbsg.rwth-aachen.de>
10 * API Version: v1beta1
11 * API License: Apache 2.0
12 ****************************************************************************/
13
14#include "GroundedFormula.h"
15
16#include <rapidjson/document.h>
17#include <rapidjson/prettywriter.h>
18#include <rapidjson/stringbuffer.h>
19#include <rapidjson/writer.h>
20
21#include <numeric>
22#include <sstream>
23
25{
26}
27
28GroundedFormula::GroundedFormula(const std::string &json)
29{
30 from_json(json);
31}
32
33GroundedFormula::GroundedFormula(const rapidjson::Value &v)
34{
36}
37
39{
40}
41
42std::string
43GroundedFormula::to_json(bool pretty) const
44{
45 rapidjson::Document d;
46
47 to_json_value(d, d);
48
49 rapidjson::StringBuffer buffer;
50 if (pretty) {
51 rapidjson::PrettyWriter<rapidjson::StringBuffer> writer(buffer);
52 d.Accept(writer);
53 } else {
54 rapidjson::Writer<rapidjson::StringBuffer> writer(buffer);
55 d.Accept(writer);
56 }
57
58 return buffer.GetString();
59}
60
61void
62GroundedFormula::to_json_value(rapidjson::Document &d, rapidjson::Value &v) const
63{
64 rapidjson::Document::AllocatorType &allocator = d.GetAllocator();
65 v.SetObject();
66 // Avoid unused variable warnings
67 (void)allocator;
68
69 if (kind_) {
70 rapidjson::Value v_kind;
71 v_kind.SetString(*kind_, allocator);
72 v.AddMember("kind", v_kind, allocator);
73 }
74 if (apiVersion_) {
75 rapidjson::Value v_apiVersion;
76 v_apiVersion.SetString(*apiVersion_, allocator);
77 v.AddMember("apiVersion", v_apiVersion, allocator);
78 }
79 if (name_) {
80 rapidjson::Value v_name;
81 v_name.SetString(*name_, allocator);
82 v.AddMember("name", v_name, allocator);
83 }
84 if (type_) {
85 rapidjson::Value v_type;
86 v_type.SetString(*type_, allocator);
87 v.AddMember("type", v_type, allocator);
88 }
89 if (is_satisfied_) {
90 rapidjson::Value v_is_satisfied;
91 v_is_satisfied.SetBool(*is_satisfied_);
92 v.AddMember("is-satisfied", v_is_satisfied, allocator);
93 }
94 rapidjson::Value v_param_names(rapidjson::kArrayType);
95 v_param_names.Reserve(param_names_.size(), allocator);
96 for (const auto &e : param_names_) {
97 rapidjson::Value v;
98 v.SetString(e, allocator);
99 v_param_names.PushBack(v, allocator);
100 }
101 v.AddMember("param-names", v_param_names, allocator);
102 rapidjson::Value v_param_values(rapidjson::kArrayType);
103 v_param_values.Reserve(param_values_.size(), allocator);
104 for (const auto &e : param_values_) {
105 rapidjson::Value v;
106 v.SetString(e, allocator);
107 v_param_values.PushBack(v, allocator);
108 }
109 v.AddMember("param-values", v_param_values, allocator);
110 rapidjson::Value v_param_constants(rapidjson::kArrayType);
111 v_param_constants.Reserve(param_constants_.size(), allocator);
112 for (const auto &e : param_constants_) {
113 rapidjson::Value v;
114 v.SetString(e, allocator);
115 v_param_constants.PushBack(v, allocator);
116 }
117 v.AddMember("param-constants", v_param_constants, allocator);
118 rapidjson::Value v_child(rapidjson::kArrayType);
119 v_child.Reserve(child_.size(), allocator);
120 for (const auto &e : child_) {
121 rapidjson::Value v(rapidjson::kObjectType);
122 e->to_json_value(d, v);
123 v_child.PushBack(v, allocator);
124 }
125 v.AddMember("child", v_child, allocator);
126}
127
128void
129GroundedFormula::from_json(const std::string &json)
130{
131 rapidjson::Document d;
132 d.Parse(json);
133
135}
136
137void
138GroundedFormula::from_json_value(const rapidjson::Value &d)
139{
140 if (d.HasMember("kind") && d["kind"].IsString()) {
141 kind_ = d["kind"].GetString();
142 }
143 if (d.HasMember("apiVersion") && d["apiVersion"].IsString()) {
144 apiVersion_ = d["apiVersion"].GetString();
145 }
146 if (d.HasMember("name") && d["name"].IsString()) {
147 name_ = d["name"].GetString();
148 }
149 if (d.HasMember("type") && d["type"].IsString()) {
150 type_ = d["type"].GetString();
151 }
152 if (d.HasMember("is-satisfied") && d["is-satisfied"].IsBool()) {
153 is_satisfied_ = d["is-satisfied"].GetBool();
154 }
155 if (d.HasMember("param-names") && d["param-names"].IsArray()) {
156 const rapidjson::Value &a = d["param-names"];
157 param_names_ = std::vector<std::string>{};
158
159 param_names_.reserve(a.Size());
160 for (auto &v : a.GetArray()) {
161 param_names_.push_back(v.GetString());
162 }
163 }
164 if (d.HasMember("param-values") && d["param-values"].IsArray()) {
165 const rapidjson::Value &a = d["param-values"];
166 param_values_ = std::vector<std::string>{};
167
168 param_values_.reserve(a.Size());
169 for (auto &v : a.GetArray()) {
170 param_values_.push_back(v.GetString());
171 }
172 }
173 if (d.HasMember("param-constants") && d["param-constants"].IsArray()) {
174 const rapidjson::Value &a = d["param-constants"];
175 param_constants_ = std::vector<std::string>{};
176
177 param_constants_.reserve(a.Size());
178 for (auto &v : a.GetArray()) {
179 param_constants_.push_back(v.GetString());
180 }
181 }
182 if (d.HasMember("child") && d["child"].IsArray()) {
183 const rapidjson::Value &a = d["child"];
184 child_ = std::vector<std::shared_ptr<GroundedFormula>>{};
185
186 child_.reserve(a.Size());
187 for (auto &v : a.GetArray()) {
188 std::shared_ptr<GroundedFormula> nv{new GroundedFormula()};
189 nv->from_json_value(v);
190 child_.push_back(std::move(nv));
191 }
192 }
193}
194
195void
196GroundedFormula::validate(bool subcall) const
197{
198 std::vector<std::string> missing;
199 if (!kind_) {
200 missing.push_back("kind");
201 }
202 if (!apiVersion_) {
203 missing.push_back("apiVersion");
204 }
205 if (!name_) {
206 missing.push_back("name");
207 }
208 if (!type_) {
209 missing.push_back("type");
210 }
211 if (!is_satisfied_) {
212 missing.push_back("is-satisfied");
213 }
214
215 if (!missing.empty()) {
216 if (subcall) {
217 throw missing;
218 } else {
219 std::string s =
220 std::accumulate(std::next(missing.begin()),
221 missing.end(),
222 missing.front(),
223 [](std::string &s, const std::string &n) { return s + ", " + n; });
224 throw std::runtime_error("GroundedFormula is missing " + s);
225 }
226 }
227}
virtual void from_json_value(const rapidjson::Value &v)
Retrieve data from JSON string.
virtual std::string to_json(bool pretty=false) const
Render object to JSON.
GroundedFormula()
Constructor.
virtual ~GroundedFormula()
Destructor.
virtual void to_json_value(rapidjson::Document &d, rapidjson::Value &v) const
Render object to JSON.
virtual void from_json(const std::string &json)
Retrieve data from JSON string.
virtual void validate(bool subcall=false) const
Validate if all required fields have been set.