AutoAPMS
Resilient Robot Mission Management
Loading...
Searching...
No Matches
node_manifest.hpp
1// Copyright 2024 Robin Müller
2//
3// Licensed under the Apache License, Version 2.0 (the "License");
4// you may not use this file except in compliance with the License.
5// You may obtain a copy of the License at
6//
7// https://www.apache.org/licenses/LICENSE-2.0
8//
9// Unless required by applicable law or agreed to in writing, software
10// distributed under the License is distributed on an "AS IS" BASIS,
11// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12// See the License for the specific language governing permissions and
13// limitations under the License.
14
15#pragma once
16
17#include <map>
18#include <vector>
19
20#include "auto_apms_behavior_tree_core/node/node_registration_options.hpp"
21#include "auto_apms_util/exceptions.hpp"
22#include "auto_apms_util/yaml.hpp"
23
25{
26class NodeManifest;
27}
28
30namespace YAML
31{
32template <>
33struct convert<auto_apms_behavior_tree::core::NodeManifest>
34{
35 using Manifest = auto_apms_behavior_tree::core::NodeManifest;
36 static Node encode(const Manifest & rhs);
37 static bool decode(const Node & node, Manifest & lhs);
38};
39} // namespace YAML
41
43{
44
109{
110public:
111 using RegistrationOptions = NodeRegistrationOptions;
112
114 using Map = std::map<std::string, NodeRegistrationOptions>;
115
122 NodeManifest(const Map & map = {});
123
125
126
131 static NodeManifest fromFiles(const std::vector<std::string> & paths);
132
142 static NodeManifest fromResourceIdentity(const std::string & identity);
143
149 void toFile(const std::string & file_path) const;
150
156 bool contains(const std::string & node_name) const;
157
164 RegistrationOptions & operator[](const std::string & node_name);
165
167 const RegistrationOptions & operator[](const std::string & node_name) const;
168
177 NodeManifest & add(const std::string & node_name, const RegistrationOptions & opt);
178
185 NodeManifest & remove(const std::string & node_name);
186
195 NodeManifest & merge(const NodeManifest & other, bool replace = false);
196
201 std::vector<std::string> getNodeNames();
202
207 size_t size() const;
208
213 bool empty() const;
214
219 const Map & map() const;
220
221private:
222 Map map_;
223};
224
225} // namespace auto_apms_behavior_tree::core
226
227// #####################################################################################################################
228// ################################ DEFINITIONS ##############################################
229// #####################################################################################################################
230
232namespace YAML
233{
234inline Node convert<auto_apms_behavior_tree::core::NodeManifest>::encode(const Manifest & rhs)
235{
236 Node node(NodeType::Map);
237 for (const auto & [name, params] : rhs.map()) node[name] = params;
238 return node;
239}
240inline bool convert<auto_apms_behavior_tree::core::NodeManifest>::decode(const Node & node, Manifest & rhs)
241{
242 if (!node.IsMap())
243 throw auto_apms_util::exceptions::YAMLFormatError(
244 "YAML::Node for auto_apms_behavior_tree::core::NodeManifest must be map but is type " +
245 std::to_string(node.Type()) + " (0: Undefined - 1: Null - 2: Scalar - 3: Sequence - 4: Map).");
246
247 for (auto it = node.begin(); it != node.end(); ++it) {
248 const auto & name = it->first.as<std::string>();
249 try {
250 rhs.add(name, it->second.as<Manifest::RegistrationOptions>());
251 } catch (const std::exception & e) {
252 throw auto_apms_util::exceptions::YAMLFormatError(
253 "Node registration parameters for node '" + name + "' are invalid: " + e.what());
254 }
255 }
256 return true;
257}
258} // namespace YAML
Data structure for information about which behavior tree node plugin to load and how to configure the...
std::map< std::string, NodeRegistrationOptions > Map
Mapping of a node's name and its registration parameters.
static NodeManifest fromFiles(const std::vector< std::string > &paths)
Create a node plugin manifest from multiple files. They are loaded in the given order.
size_t size() const
Get the number of behavior tree nodes this manifest holds registration options for.
NodeManifest & add(const std::string &node_name, const RegistrationOptions &opt)
Add registration options for a behavior tree node to the manifest.
bool contains(const std::string &node_name) const
Determine if a behavior tree node has been added to the manifest.
bool empty() const
Determine whether any node registration options have been added to the manifest.
NodeManifest & merge(const NodeManifest &other, bool replace=false)
Merges another NodeManifest with this one.
static NodeManifest fromResourceIdentity(const std::string &identity)
Create a node manifest from an installed resource.
const Map & map() const
Get a view of the internal map.
std::vector< std::string > getNodeNames()
Get all names of the behavior tree nodes specified by the manifest.
RegistrationOptions & operator[](const std::string &node_name)
Access the node manifest and retrieve registration options for a specific behavior tree node.
void toFile(const std::string &file_path) const
Write the node manifest to a file.
NodeManifest(const Map &map={})
Constructor of a NodeManifest data structure.
NodeManifest & remove(const std::string &node_name)
Remove registration options for a behavior tree node.
#define AUTO_APMS_UTIL_DEFINE_YAML_CONVERSION_METHODS(ClassType)
Macro for defining YAML encode/decode methods for a class.
Definition yaml.hpp:33
Core API for AutoAPMS's behavior tree implementation.
Definition builder.hpp:30
Parameters for loading and registering a behavior tree node class from a shared library using e....