YARP
Yet Another Robot Platform
 
Loading...
Searching...
No Matches
Battery_nws_ros2_ParamsParser.cpp
Go to the documentation of this file.
1/*
2 * SPDX-FileCopyrightText: 2023-2023 Istituto Italiano di Tecnologia (IIT)
3 * SPDX-License-Identifier: LGPL-2.1-or-later
4 */
5
6
7// Generated by yarpDeviceParamParserGenerator (1.0)
8// This is an automatically generated file. Please do not edit it.
9// It will be re-generated if the cmake flag ALLOW_DEVICE_PARAM_PARSER_GERNERATION is ON.
10
11// Generated on: Thu Aug 1 16:19:38 2024
12
13
15#include <yarp/os/LogStream.h>
16#include <yarp/os/Value.h>
17
18namespace {
19 YARP_LOG_COMPONENT(Battery_nws_ros2ParamsCOMPONENT, "yarp.device.Battery_nws_ros2")
20}
21
22
26
27
28std::vector<std::string> Battery_nws_ros2_ParamsParser::getListOfParams() const
29{
30 std::vector<std::string> params;
31 params.push_back("period");
32 params.push_back("node_name");
33 params.push_back("topic_name");
34 return params;
35}
36
37
39{
40 //Check for --help option
41 if (config.check("help"))
42 {
43 yCInfo(Battery_nws_ros2ParamsCOMPONENT) << getDocumentationOfDeviceParams();
44 }
45
46 std::string config_string = config.toString();
47 yarp::os::Property prop_check(config_string.c_str());
48 //Parser of parameter period
49 {
50 if (config.check("period"))
51 {
52 m_period = config.find("period").asFloat64();
53 yCInfo(Battery_nws_ros2ParamsCOMPONENT) << "Parameter 'period' using value:" << m_period;
54 }
55 else
56 {
57 yCInfo(Battery_nws_ros2ParamsCOMPONENT) << "Parameter 'period' using DEFAULT value:" << m_period;
58 }
59 prop_check.unput("period");
60 }
61
62 //Parser of parameter node_name
63 {
64 if (config.check("node_name"))
65 {
66 m_node_name = config.find("node_name").asString();
67 yCInfo(Battery_nws_ros2ParamsCOMPONENT) << "Parameter 'node_name' using value:" << m_node_name;
68 }
69 else
70 {
71 yCError(Battery_nws_ros2ParamsCOMPONENT) << "Mandatory parameter 'node_name' not found!";
72 yCError(Battery_nws_ros2ParamsCOMPONENT) << "Description of the parameter: name of the ros2 node";
73 return false;
74 }
75 prop_check.unput("node_name");
76 }
77
78 //Parser of parameter topic_name
79 {
80 if (config.check("topic_name"))
81 {
82 m_topic_name = config.find("topic_name").asString();
83 yCInfo(Battery_nws_ros2ParamsCOMPONENT) << "Parameter 'topic_name' using value:" << m_topic_name;
84 }
85 else
86 {
87 yCError(Battery_nws_ros2ParamsCOMPONENT) << "Mandatory parameter 'topic_name' not found!";
88 yCError(Battery_nws_ros2ParamsCOMPONENT) << "Description of the parameter: name of the topic where the device must publish the data";
89 return false;
90 }
91 prop_check.unput("topic_name");
92 }
93
94 /*
95 //This code check if the user set some parameter which are not check by the parser
96 //If the parser is set in strict mode, this will generate an error
97 if (prop_check.size() > 0)
98 {
99 bool extra_params_found = false;
100 for (auto it=prop_check.begin(); it!=prop_check.end(); it++)
101 {
102 if (m_parser_is_strict)
103 {
104 yCError(Battery_nws_ros2ParamsCOMPONENT) << "User asking for parameter: "<<it->name <<" which is unknown to this parser!";
105 extra_params_found = true;
106 }
107 else
108 {
109 yCWarning(Battery_nws_ros2ParamsCOMPONENT) << "User asking for parameter: "<< it->name <<" which is unknown to this parser!";
110 }
111 }
112
113 if (m_parser_is_strict && extra_params_found)
114 {
115 return false;
116 }
117 }
118 */
119 return true;
120}
121
122
124{
125 std::string doc;
126 doc = doc + std::string("\n=============================================\n");
127 doc = doc + std::string("This is the help for device: Battery_nws_ros2\n");
128 doc = doc + std::string("\n");
129 doc = doc + std::string("This is the list of the parameters accepted by the device:\n");
130 doc = doc + std::string("'period': refresh period of the broadcasted values in s\n");
131 doc = doc + std::string("'node_name': name of the ros2 node\n");
132 doc = doc + std::string("'topic_name': name of the topic where the device must publish the data\n");
133 doc = doc + std::string("\n");
134 doc = doc + std::string("Here are some examples of invocation command with yarpdev, with all params:\n");
135 doc = doc + " yarpdev --device battery_nws_ros2 --period 0.02 --node_name <mandatory_value> --topic_name <mandatory_value>\n";
136 doc = doc + std::string("Using only mandatory params:\n");
137 doc = doc + " yarpdev --device battery_nws_ros2 --node_name <mandatory_value> --topic_name <mandatory_value>\n";
138 doc = doc + std::string("=============================================\n\n"); return doc;
139}
std::string getDocumentationOfDeviceParams() const override
Get the documentation of the DeviceDriver's parameters.
std::vector< std::string > getListOfParams() const override
Return a list of all params used by the device.
bool parseParams(const yarp::os::Searchable &config) override
Parse the DeviceDriver parameters.
A class for storing options and configuration information.
Definition Property.h:33
void unput(const std::string &key)
Remove the association from the given key to a value, if present.
A base class for nested structures that can be searched.
Definition Searchable.h:31
virtual bool check(const std::string &key) const =0
Check if there exists a property of the given name.
virtual std::string toString() const =0
Return a standard text representation of the content of the object.
virtual Value & find(const std::string &key) const =0
Gets a value corresponding to a given keyword.
#define yCInfo(component,...)
#define yCError(component,...)
#define YARP_LOG_COMPONENT(name,...)