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 
28 GroundedFormula::GroundedFormula(const std::string &json)
29 {
30  from_json(json);
31 }
32 
33 GroundedFormula::GroundedFormula(const rapidjson::Value &v)
34 {
35  from_json_value(v);
36 }
37 
39 {
40 }
41 
42 std::string
43 GroundedFormula::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 
61 void
62 GroundedFormula::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 
128 void
129 GroundedFormula::from_json(const std::string &json)
130 {
131  rapidjson::Document d;
132  d.Parse(json);
133 
134  from_json_value(d);
135 }
136 
137 void
138 GroundedFormula::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 
195 void
196 GroundedFormula::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.