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 (2.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: Mon May 26 22:00:40 2025
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
38bool Battery_nws_ros2_ParamsParser::getParamValue(const std::string& paramName, std::string& paramValue) const
39{
40 if (paramName =="period")
41 {
42 paramValue = std::to_string(m_period);
43 return true;
44 }
45 if (paramName =="node_name")
46 {
47 paramValue = m_node_name;
48 return true;
49 }
50 if (paramName =="topic_name")
51 {
52 paramValue = m_topic_name;
53 return true;
54 }
55
56 yError() <<"parameter '" << paramName << "' was not found";
57 return false;
58
59}
60
61
63{
64 //This is a sub-optimal solution.
65 //Ideally getConfiguration() should return all parameters but it is currently
66 //returning only user provided parameters (excluding default values)
67 //This behaviour will be fixed in the near future.
68 std::string s_cfg = m_provided_configuration;
69 return s_cfg;
70}
71
73{
74 //Check for --help option
75 if (config.check("help"))
76 {
77 yCInfo(Battery_nws_ros2ParamsCOMPONENT) << getDocumentationOfDeviceParams();
78 }
79
82 //Parser of parameter period
83 {
84 if (config.check("period"))
85 {
86 m_period = config.find("period").asFloat64();
87 yCInfo(Battery_nws_ros2ParamsCOMPONENT) << "Parameter 'period' using value:" << m_period;
88 }
89 else
90 {
91 yCInfo(Battery_nws_ros2ParamsCOMPONENT) << "Parameter 'period' using DEFAULT value:" << m_period;
92 }
93 prop_check.unput("period");
94 }
95
96 //Parser of parameter node_name
97 {
98 if (config.check("node_name"))
99 {
100 m_node_name = config.find("node_name").asString();
101 yCInfo(Battery_nws_ros2ParamsCOMPONENT) << "Parameter 'node_name' using value:" << m_node_name;
102 }
103 else
104 {
105 yCError(Battery_nws_ros2ParamsCOMPONENT) << "Mandatory parameter 'node_name' not found!";
106 yCError(Battery_nws_ros2ParamsCOMPONENT) << "Description of the parameter: name of the ros2 node";
107 return false;
108 }
109 prop_check.unput("node_name");
110 }
111
112 //Parser of parameter topic_name
113 {
114 if (config.check("topic_name"))
115 {
116 m_topic_name = config.find("topic_name").asString();
117 yCInfo(Battery_nws_ros2ParamsCOMPONENT) << "Parameter 'topic_name' using value:" << m_topic_name;
118 }
119 else
120 {
121 yCError(Battery_nws_ros2ParamsCOMPONENT) << "Mandatory parameter 'topic_name' not found!";
122 yCError(Battery_nws_ros2ParamsCOMPONENT) << "Description of the parameter: name of the topic where the device must publish the data";
123 return false;
124 }
125 prop_check.unput("topic_name");
126 }
127
128 /*
129 //This code check if the user set some parameter which are not check by the parser
130 //If the parser is set in strict mode, this will generate an error
131 if (prop_check.size() > 0)
132 {
133 bool extra_params_found = false;
134 for (auto it=prop_check.begin(); it!=prop_check.end(); it++)
135 {
136 if (m_parser_is_strict)
137 {
138 yCError(Battery_nws_ros2ParamsCOMPONENT) << "User asking for parameter: "<<it->name <<" which is unknown to this parser!";
139 extra_params_found = true;
140 }
141 else
142 {
143 yCWarning(Battery_nws_ros2ParamsCOMPONENT) << "User asking for parameter: "<< it->name <<" which is unknown to this parser!";
144 }
145 }
146
147 if (m_parser_is_strict && extra_params_found)
148 {
149 return false;
150 }
151 }
152 */
153 return true;
154}
155
156
158{
159 std::string doc;
160 doc = doc + std::string("\n=============================================\n");
161 doc = doc + std::string("This is the help for device: Battery_nws_ros2\n");
162 doc = doc + std::string("\n");
163 doc = doc + std::string("This is the list of the parameters accepted by the device:\n");
164 doc = doc + std::string("'period': refresh period of the broadcasted values in s\n");
165 doc = doc + std::string("'node_name': name of the ros2 node\n");
166 doc = doc + std::string("'topic_name': name of the topic where the device must publish the data\n");
167 doc = doc + std::string("\n");
168 doc = doc + std::string("Here are some examples of invocation command with yarpdev, with all params:\n");
169 doc = doc + " yarpdev --device battery_nws_ros2 --period 0.02 --node_name <mandatory_value> --topic_name <mandatory_value>\n";
170 doc = doc + std::string("Using only mandatory params:\n");
171 doc = doc + " yarpdev --device battery_nws_ros2 --node_name <mandatory_value> --topic_name <mandatory_value>\n";
172 doc = doc + std::string("=============================================\n\n"); return doc;
173}
#define yError(...)
Definition Log.h:361
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.
std::string getConfiguration() const override
Return the configuration of the device.
bool getParamValue(const std::string &paramName, std::string &paramValue) const override
Return the value (represented as a string) of the requested parameter.
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,...)