AutoAPMS
Streamlining behaviors in ROS 2
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/definitions.hpp"
21#include "auto_apms_behavior_tree_core/node/node_registration_options.hpp"
22#include "auto_apms_util/exceptions.hpp"
23#include "auto_apms_util/yaml.hpp"
24
26{
27
32{
40 NodeManifestResourceIdentity(const std::string & identity);
41
49 NodeManifestResourceIdentity(const char * identity);
50
57
58 virtual ~NodeManifestResourceIdentity() = default;
59
60 bool operator==(const NodeManifestResourceIdentity & other) const;
61
62 bool operator<(const NodeManifestResourceIdentity & other) const;
63
68 std::string str() const;
69
74 bool empty() const;
75
77 std::string package_name;
79 std::string metadata_id;
80};
81
89std::set<NodeManifestResourceIdentity> getNodeManifestResourceIdentities(
90 const std::set<std::string> & exclude_packages = {});
91
133{
134public:
135 using RegistrationOptions = NodeRegistrationOptions;
136
138 using Map = std::map<std::string, NodeRegistrationOptions>;
139
146 NodeManifest(const Map & map = {});
147
149
150
155 static NodeManifest fromFiles(const std::vector<std::string> & paths);
156
164 static NodeManifest fromResource(const NodeManifestResourceIdentity & search_identity);
165
171 void toFile(const std::string & file_path) const;
172
178 bool contains(const std::string & node_name) const;
179
186 RegistrationOptions & operator[](const std::string & node_name);
187
189 const RegistrationOptions & operator[](const std::string & node_name) const;
190
199 NodeManifest & add(const std::string & node_name, const RegistrationOptions & opt);
200
207 NodeManifest & remove(const std::string & node_name);
208
217 NodeManifest & merge(const NodeManifest & other, bool replace = false);
218
223 std::vector<std::string> getNodeNames();
224
229 size_t size() const;
230
235 bool empty() const;
236
241 const Map & map() const;
242
243private:
244 Map map_;
245};
246
251{
252public:
253 using Identity = NodeManifestResourceIdentity;
254
262 NodeManifestResource(const Identity & search_identity);
263
271 NodeManifestResource(const std::string & search_identity);
272
281 NodeManifestResource(const char * search_identity);
282
287 const Identity & getIdentity() const;
288
293 const NodeManifest & getNodeManifest() const;
294
299 const NodeModelMap & getNodeModel() const;
300
301private:
302 Identity unique_identity_;
303 std::string node_manifest_file_path_;
304 NodeManifest node_manifest_;
305 std::string node_model_file_path_;
306 NodeModelMap node_model_;
307};
308
309} // namespace auto_apms_behavior_tree::core
310
311// #####################################################################################################################
312// ################################ DEFINITIONS ##############################################
313// #####################################################################################################################
314
316namespace YAML
317{
318template <>
320{
322 static Node encode(const Identity & rhs)
323 {
324 Node node;
325 node = rhs.str();
326 return node;
327 }
328 static bool decode(const Node & node, Identity & rhs)
329 {
330 if (!node.IsScalar()) return false;
331 rhs = Identity(node.Scalar());
332 return true;
333 }
334};
335template <>
336struct convert<auto_apms_behavior_tree::core::NodeManifest>
337{
338 using Manifest = auto_apms_behavior_tree::core::NodeManifest;
339 inline static Node encode(const Manifest & rhs)
340 {
341 Node node(NodeType::Map);
342 for (const auto & [name, params] : rhs.map()) node[name] = params;
343 return node;
344 }
345 inline static bool decode(const Node & node, Manifest & rhs)
346 {
347 if (!node.IsMap())
348 throw auto_apms_util::exceptions::YAMLFormatError(
349 "YAML::Node for auto_apms_behavior_tree::core::NodeManifest must be map but is type " +
350 std::to_string(node.Type()) + " (0: Undefined - 1: Null - 2: Scalar - 3: Sequence - 4: Map).");
351
352 for (auto it = node.begin(); it != node.end(); ++it) {
353 const auto & name = it->first.as<std::string>();
354 try {
355 rhs.add(name, it->second.as<Manifest::RegistrationOptions>());
356 } catch (const std::exception & e) {
357 throw auto_apms_util::exceptions::YAMLFormatError(
358 "Node registration options for node '" + name + "' are invalid: " + e.what());
359 }
360 }
361 return true;
362 }
363};
364} // namespace YAML
NodeManifestResource(const Identity &search_identity)
Constructor of a node manifest resource object.
const NodeModelMap & getNodeModel() const
Get the node model object associated with this resource.
const Identity & getIdentity() const
Get the unique identity for this resource.
const NodeManifest & getNodeManifest() const
Get the node manifest object associated with this resource.
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.
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.
static NodeManifest fromResource(const NodeManifestResourceIdentity &search_identity)
Create a node manifest from an installed resource.
NodeManifest & remove(const std::string &node_name)
Remove registration options for a behavior tree node.
std::set< NodeManifestResourceIdentity > getNodeManifestResourceIdentities(const std::set< std::string > &exclude_packages={})
Get all registered behavior tree node manifest resource identities.
#define AUTO_APMS_UTIL_DEFINE_YAML_CONVERSION_METHODS(ClassType)
Macro for defining YAML encode/decode methods for a class.
Definition yaml.hpp:32
Core API for AutoAPMS's behavior tree implementation.
Definition behavior.hpp:32
Powerful tooling for incorporating behavior trees for task development.
Definition behavior.hpp:32
std::map< std::string, NodeModel > NodeModelMap
Mapping of node registration names and their implementation details.
Struct that encapsulates the identity string for a registered behavior tree node manifest.
bool empty() const
Determine whether this node manifest resource identity object is considered empty.
NodeManifestResourceIdentity(const std::string &identity)
Constructor of a node manifest resource identity object.
NodeManifestResourceIdentity()=default
Constructor of an empty node manifest resource identity object.
std::string package_name
Name of the package that registers the behavior resource.
std::string metadata_id
Metadata ID determined when regitering the corresponding node manifest resource.
std::string str() const
Create the corresponding identity string.
Parameters for loading and registering a behavior tree node class from a shared library using e....