YARP
Yet Another Robot Platform
 
Loading...
Searching...
No Matches
Odometry2D_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(Odometry2D_nws_ros2ParamsCOMPONENT, "yarp.device.Odometry2D_nws_ros2")
20}
21
22
26
27
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 params.push_back("odom_frame");
35 params.push_back("base_frame");
36 return params;
37}
38
39
40bool Odometry2D_nws_ros2_ParamsParser::getParamValue(const std::string& paramName, std::string& paramValue) const
41{
42 if (paramName =="period")
43 {
44 paramValue = std::to_string(m_period);
45 return true;
46 }
47 if (paramName =="node_name")
48 {
49 paramValue = m_node_name;
50 return true;
51 }
52 if (paramName =="topic_name")
53 {
54 paramValue = m_topic_name;
55 return true;
56 }
57 if (paramName =="odom_frame")
58 {
59 paramValue = m_odom_frame;
60 return true;
61 }
62 if (paramName =="base_frame")
63 {
64 paramValue = m_base_frame;
65 return true;
66 }
67
68 yError() <<"parameter '" << paramName << "' was not found";
69 return false;
70
71}
72
73
75{
76 //This is a sub-optimal solution.
77 //Ideally getConfiguration() should return all parameters but it is currently
78 //returning only user provided parameters (excluding default values)
79 //This behaviour will be fixed in the near future.
80 std::string s_cfg = m_provided_configuration;
81 return s_cfg;
82}
83
85{
86 //Check for --help option
87 if (config.check("help"))
88 {
89 yCInfo(Odometry2D_nws_ros2ParamsCOMPONENT) << getDocumentationOfDeviceParams();
90 }
91
94 //Parser of parameter period
95 {
96 if (config.check("period"))
97 {
98 m_period = config.find("period").asFloat64();
99 yCInfo(Odometry2D_nws_ros2ParamsCOMPONENT) << "Parameter 'period' using value:" << m_period;
100 }
101 else
102 {
103 yCInfo(Odometry2D_nws_ros2ParamsCOMPONENT) << "Parameter 'period' using DEFAULT value:" << m_period;
104 }
105 prop_check.unput("period");
106 }
107
108 //Parser of parameter node_name
109 {
110 if (config.check("node_name"))
111 {
112 m_node_name = config.find("node_name").asString();
113 yCInfo(Odometry2D_nws_ros2ParamsCOMPONENT) << "Parameter 'node_name' using value:" << m_node_name;
114 }
115 else
116 {
117 yCError(Odometry2D_nws_ros2ParamsCOMPONENT) << "Mandatory parameter 'node_name' not found!";
118 yCError(Odometry2D_nws_ros2ParamsCOMPONENT) << "Description of the parameter: name of the ros2 node";
119 return false;
120 }
121 prop_check.unput("node_name");
122 }
123
124 //Parser of parameter topic_name
125 {
126 if (config.check("topic_name"))
127 {
128 m_topic_name = config.find("topic_name").asString();
129 yCInfo(Odometry2D_nws_ros2ParamsCOMPONENT) << "Parameter 'topic_name' using value:" << m_topic_name;
130 }
131 else
132 {
133 yCError(Odometry2D_nws_ros2ParamsCOMPONENT) << "Mandatory parameter 'topic_name' not found!";
134 yCError(Odometry2D_nws_ros2ParamsCOMPONENT) << "Description of the parameter: name of the topic where the device must publish the data";
135 return false;
136 }
137 prop_check.unput("topic_name");
138 }
139
140 //Parser of parameter odom_frame
141 {
142 if (config.check("odom_frame"))
143 {
144 m_odom_frame = config.find("odom_frame").asString();
145 yCInfo(Odometry2D_nws_ros2ParamsCOMPONENT) << "Parameter 'odom_frame' using value:" << m_odom_frame;
146 }
147 else
148 {
149 yCError(Odometry2D_nws_ros2ParamsCOMPONENT) << "Mandatory parameter 'odom_frame' not found!";
150 yCError(Odometry2D_nws_ros2ParamsCOMPONENT) << "Description of the parameter: name of the reference frame for odometry";
151 return false;
152 }
153 prop_check.unput("odom_frame");
154 }
155
156 //Parser of parameter base_frame
157 {
158 if (config.check("base_frame"))
159 {
160 m_base_frame = config.find("base_frame").asString();
161 yCInfo(Odometry2D_nws_ros2ParamsCOMPONENT) << "Parameter 'base_frame' using value:" << m_base_frame;
162 }
163 else
164 {
165 yCError(Odometry2D_nws_ros2ParamsCOMPONENT) << "Mandatory parameter 'base_frame' not found!";
166 yCError(Odometry2D_nws_ros2ParamsCOMPONENT) << "Description of the parameter: name of the base frame for odometry";
167 return false;
168 }
169 prop_check.unput("base_frame");
170 }
171
172 /*
173 //This code check if the user set some parameter which are not check by the parser
174 //If the parser is set in strict mode, this will generate an error
175 if (prop_check.size() > 0)
176 {
177 bool extra_params_found = false;
178 for (auto it=prop_check.begin(); it!=prop_check.end(); it++)
179 {
180 if (m_parser_is_strict)
181 {
182 yCError(Odometry2D_nws_ros2ParamsCOMPONENT) << "User asking for parameter: "<<it->name <<" which is unknown to this parser!";
183 extra_params_found = true;
184 }
185 else
186 {
187 yCWarning(Odometry2D_nws_ros2ParamsCOMPONENT) << "User asking for parameter: "<< it->name <<" which is unknown to this parser!";
188 }
189 }
190
191 if (m_parser_is_strict && extra_params_found)
192 {
193 return false;
194 }
195 }
196 */
197 return true;
198}
199
200
202{
203 std::string doc;
204 doc = doc + std::string("\n=============================================\n");
205 doc = doc + std::string("This is the help for device: Odometry2D_nws_ros2\n");
206 doc = doc + std::string("\n");
207 doc = doc + std::string("This is the list of the parameters accepted by the device:\n");
208 doc = doc + std::string("'period': refresh period of the broadcasted values in s\n");
209 doc = doc + std::string("'node_name': name of the ros2 node\n");
210 doc = doc + std::string("'topic_name': name of the topic where the device must publish the data\n");
211 doc = doc + std::string("'odom_frame': name of the reference frame for odometry\n");
212 doc = doc + std::string("'base_frame': name of the base frame for odometry\n");
213 doc = doc + std::string("\n");
214 doc = doc + std::string("Here are some examples of invocation command with yarpdev, with all params:\n");
215 doc = doc + " yarpdev --device odometry2D_nws_ros2 --period 0.02 --node_name <mandatory_value> --topic_name <mandatory_value> --odom_frame <mandatory_value> --base_frame <mandatory_value>\n";
216 doc = doc + std::string("Using only mandatory params:\n");
217 doc = doc + " yarpdev --device odometry2D_nws_ros2 --node_name <mandatory_value> --topic_name <mandatory_value> --odom_frame <mandatory_value> --base_frame <mandatory_value>\n";
218 doc = doc + std::string("=============================================\n\n"); return doc;
219}
#define yError(...)
Definition Log.h:361
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.
std::string getDocumentationOfDeviceParams() const override
Get the documentation of the DeviceDriver's parameters.
std::string getConfiguration() const override
Return the configuration of the device.
std::vector< std::string > getListOfParams() const override
Return a list of all params used by the device.
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,...)