YARP
Yet Another Robot Platform
 
Loading...
Searching...
No Matches
Rangefinder2DTransformer_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: Thu May 22 11:32:47 2025
12
13
15#include <yarp/os/LogStream.h>
16#include <yarp/os/Value.h>
17
18namespace {
19 YARP_LOG_COMPONENT(Rangefinder2DTransformerParamsCOMPONENT, "yarp.device.Rangefinder2DTransformer")
20}
21
22
26
27
29{
30 std::vector<std::string> params;
31 params.push_back("device_position_x");
32 params.push_back("device_position_y");
33 params.push_back("device_position_theta");
34 params.push_back("laser_frame_name");
35 params.push_back("robot_frame_name");
36 return params;
37}
38
39
40bool Rangefinder2DTransformer_ParamsParser::getParamValue(const std::string& paramName, std::string& paramValue) const
41{
42 if (paramName =="device_position_x")
43 {
44 paramValue = std::to_string(m_device_position_x);
45 return true;
46 }
47 if (paramName =="device_position_y")
48 {
49 paramValue = std::to_string(m_device_position_y);
50 return true;
51 }
52 if (paramName =="device_position_theta")
53 {
54 paramValue = std::to_string(m_device_position_theta);
55 return true;
56 }
57 if (paramName =="laser_frame_name")
58 {
59 paramValue = m_laser_frame_name;
60 return true;
61 }
62 if (paramName =="robot_frame_name")
63 {
64 paramValue = m_robot_frame_name;
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(Rangefinder2DTransformerParamsCOMPONENT) << getDocumentationOfDeviceParams();
90 }
91
94 //Parser of parameter device_position_x
95 {
96 if (config.check("device_position_x"))
97 {
98 m_device_position_x = config.find("device_position_x").asFloat64();
99 yCInfo(Rangefinder2DTransformerParamsCOMPONENT) << "Parameter 'device_position_x' using value:" << m_device_position_x;
100 }
101 else
102 {
103 yCInfo(Rangefinder2DTransformerParamsCOMPONENT) << "Parameter 'device_position_x' using DEFAULT value:" << m_device_position_x;
104 }
105 prop_check.unput("device_position_x");
106 }
107
108 //Parser of parameter device_position_y
109 {
110 if (config.check("device_position_y"))
111 {
112 m_device_position_y = config.find("device_position_y").asFloat64();
113 yCInfo(Rangefinder2DTransformerParamsCOMPONENT) << "Parameter 'device_position_y' using value:" << m_device_position_y;
114 }
115 else
116 {
117 yCInfo(Rangefinder2DTransformerParamsCOMPONENT) << "Parameter 'device_position_y' using DEFAULT value:" << m_device_position_y;
118 }
119 prop_check.unput("device_position_y");
120 }
121
122 //Parser of parameter device_position_theta
123 {
124 if (config.check("device_position_theta"))
125 {
126 m_device_position_theta = config.find("device_position_theta").asFloat64();
127 yCInfo(Rangefinder2DTransformerParamsCOMPONENT) << "Parameter 'device_position_theta' using value:" << m_device_position_theta;
128 }
129 else
130 {
131 yCInfo(Rangefinder2DTransformerParamsCOMPONENT) << "Parameter 'device_position_theta' using DEFAULT value:" << m_device_position_theta;
132 }
133 prop_check.unput("device_position_theta");
134 }
135
136 //Parser of parameter laser_frame_name
137 {
138 if (config.check("laser_frame_name"))
139 {
140 m_laser_frame_name = config.find("laser_frame_name").asString();
141 yCInfo(Rangefinder2DTransformerParamsCOMPONENT) << "Parameter 'laser_frame_name' using value:" << m_laser_frame_name;
142 }
143 else
144 {
145 yCInfo(Rangefinder2DTransformerParamsCOMPONENT) << "Parameter 'laser_frame_name' using DEFAULT value:" << m_laser_frame_name;
146 }
147 prop_check.unput("laser_frame_name");
148 }
149
150 //Parser of parameter robot_frame_name
151 {
152 if (config.check("robot_frame_name"))
153 {
154 m_robot_frame_name = config.find("robot_frame_name").asString();
155 yCInfo(Rangefinder2DTransformerParamsCOMPONENT) << "Parameter 'robot_frame_name' using value:" << m_robot_frame_name;
156 }
157 else
158 {
159 yCInfo(Rangefinder2DTransformerParamsCOMPONENT) << "Parameter 'robot_frame_name' using DEFAULT value:" << m_robot_frame_name;
160 }
161 prop_check.unput("robot_frame_name");
162 }
163
164 /*
165 //This code check if the user set some parameter which are not check by the parser
166 //If the parser is set in strict mode, this will generate an error
167 if (prop_check.size() > 0)
168 {
169 bool extra_params_found = false;
170 for (auto it=prop_check.begin(); it!=prop_check.end(); it++)
171 {
172 if (m_parser_is_strict)
173 {
174 yCError(Rangefinder2DTransformerParamsCOMPONENT) << "User asking for parameter: "<<it->name <<" which is unknown to this parser!";
175 extra_params_found = true;
176 }
177 else
178 {
179 yCWarning(Rangefinder2DTransformerParamsCOMPONENT) << "User asking for parameter: "<< it->name <<" which is unknown to this parser!";
180 }
181 }
182
183 if (m_parser_is_strict && extra_params_found)
184 {
185 return false;
186 }
187 }
188 */
189 return true;
190}
191
192
194{
195 std::string doc;
196 doc = doc + std::string("\n=============================================\n");
197 doc = doc + std::string("This is the help for device: Rangefinder2DTransformer\n");
198 doc = doc + std::string("\n");
199 doc = doc + std::string("This is the list of the parameters accepted by the device:\n");
200 doc = doc + std::string("'device_position_x': X coordinate of the virtual lidar\n");
201 doc = doc + std::string("'device_position_y': Y coordinate of the virtual lidar\n");
202 doc = doc + std::string("'device_position_theta': Theta coordinate of the virtual lidar\n");
203 doc = doc + std::string("'laser_frame_name': If present, open a frameTranformClient to get the robot->laser transform\n");
204 doc = doc + std::string("'robot_frame_name': If present, open a frameTranformClient to get the robot->laser transform\n");
205 doc = doc + std::string("\n");
206 doc = doc + std::string("Here are some examples of invocation command with yarpdev, with all params:\n");
207 doc = doc + " yarpdev --device rangefinder2DTransformer --device_position_x 0 --device_position_y 0 --device_position_theta 0 --laser_frame_name <optional_value> --robot_frame_name <optional_value>\n";
208 doc = doc + std::string("Using only mandatory params:\n");
209 doc = doc + " yarpdev --device rangefinder2DTransformer\n";
210 doc = doc + std::string("=============================================\n\n"); return doc;
211}
#define yError(...)
Definition Log.h:361
bool parseParams(const yarp::os::Searchable &config) override
Parse the DeviceDriver parameters.
bool getParamValue(const std::string &paramName, std::string &paramValue) const override
Return the value (represented as a string) of the requested parameter.
std::vector< std::string > getListOfParams() const override
Return a list of all params used by the device.
std::string getDocumentationOfDeviceParams() const override
Get the documentation of the DeviceDriver's parameters.
std::string getConfiguration() const override
Return the configuration of 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 YARP_LOG_COMPONENT(name,...)