YARP
Yet Another Robot Platform
 
Loading...
Searching...
No Matches
GenericSensor_nwc_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(GenericSensor_nwc_ros2ParamsCOMPONENT, "yarp.device.GenericSensor_nwc_ros2")
20}
21
22
26
27
29{
30 std::vector<std::string> params;
31 params.push_back("node_name");
32 params.push_back("topic_name");
33 params.push_back("sensor_name");
34 return params;
35}
36
37
38bool GenericSensor_nwc_ros2_ParamsParser::getParamValue(const std::string& paramName, std::string& paramValue) const
39{
40 if (paramName =="node_name")
41 {
42 paramValue = m_node_name;
43 return true;
44 }
45 if (paramName =="topic_name")
46 {
47 paramValue = m_topic_name;
48 return true;
49 }
50 if (paramName =="sensor_name")
51 {
52 paramValue = m_sensor_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(GenericSensor_nwc_ros2ParamsCOMPONENT) << getDocumentationOfDeviceParams();
78 }
79
82 //Parser of parameter node_name
83 {
84 if (config.check("node_name"))
85 {
86 m_node_name = config.find("node_name").asString();
87 yCInfo(GenericSensor_nwc_ros2ParamsCOMPONENT) << "Parameter 'node_name' using value:" << m_node_name;
88 }
89 else
90 {
91 yCError(GenericSensor_nwc_ros2ParamsCOMPONENT) << "Mandatory parameter 'node_name' not found!";
92 yCError(GenericSensor_nwc_ros2ParamsCOMPONENT) << "Description of the parameter: name of the ros2 node";
93 return false;
94 }
95 prop_check.unput("node_name");
96 }
97
98 //Parser of parameter topic_name
99 {
100 if (config.check("topic_name"))
101 {
102 m_topic_name = config.find("topic_name").asString();
103 yCInfo(GenericSensor_nwc_ros2ParamsCOMPONENT) << "Parameter 'topic_name' using value:" << m_topic_name;
104 }
105 else
106 {
107 yCError(GenericSensor_nwc_ros2ParamsCOMPONENT) << "Mandatory parameter 'topic_name' not found!";
108 yCError(GenericSensor_nwc_ros2ParamsCOMPONENT) << "Description of the parameter: name of the topic where the device must publish the data";
109 return false;
110 }
111 prop_check.unput("topic_name");
112 }
113
114 //Parser of parameter sensor_name
115 {
116 if (config.check("sensor_name"))
117 {
118 m_sensor_name = config.find("sensor_name").asString();
119 yCInfo(GenericSensor_nwc_ros2ParamsCOMPONENT) << "Parameter 'sensor_name' using value:" << m_sensor_name;
120 }
121 else
122 {
123 yCError(GenericSensor_nwc_ros2ParamsCOMPONENT) << "Mandatory parameter 'sensor_name' not found!";
124 yCError(GenericSensor_nwc_ros2ParamsCOMPONENT) << "Description of the parameter: The name of the sensor the data are coming from";
125 return false;
126 }
127 prop_check.unput("sensor_name");
128 }
129
130 /*
131 //This code check if the user set some parameter which are not check by the parser
132 //If the parser is set in strict mode, this will generate an error
133 if (prop_check.size() > 0)
134 {
135 bool extra_params_found = false;
136 for (auto it=prop_check.begin(); it!=prop_check.end(); it++)
137 {
138 if (m_parser_is_strict)
139 {
140 yCError(GenericSensor_nwc_ros2ParamsCOMPONENT) << "User asking for parameter: "<<it->name <<" which is unknown to this parser!";
141 extra_params_found = true;
142 }
143 else
144 {
145 yCWarning(GenericSensor_nwc_ros2ParamsCOMPONENT) << "User asking for parameter: "<< it->name <<" which is unknown to this parser!";
146 }
147 }
148
149 if (m_parser_is_strict && extra_params_found)
150 {
151 return false;
152 }
153 }
154 */
155 return true;
156}
157
158
160{
161 std::string doc;
162 doc = doc + std::string("\n=============================================\n");
163 doc = doc + std::string("This is the help for device: GenericSensor_nwc_ros2\n");
164 doc = doc + std::string("\n");
165 doc = doc + std::string("This is the list of the parameters accepted by the device:\n");
166 doc = doc + std::string("'node_name': name of the ros2 node\n");
167 doc = doc + std::string("'topic_name': name of the topic where the device must publish the data\n");
168 doc = doc + std::string("'sensor_name': The name of the sensor the data are coming from\n");
169 doc = doc + std::string("\n");
170 doc = doc + std::string("Here are some examples of invocation command with yarpdev, with all params:\n");
171 doc = doc + " yarpdev --device genericSensor_nwc_ros2 --node_name <mandatory_value> --topic_name <mandatory_value> --sensor_name <mandatory_value>\n";
172 doc = doc + std::string("Using only mandatory params:\n");
173 doc = doc + " yarpdev --device genericSensor_nwc_ros2 --node_name <mandatory_value> --topic_name <mandatory_value> --sensor_name <mandatory_value>\n";
174 doc = doc + std::string("=============================================\n\n"); return doc;
175}
#define yError(...)
Definition Log.h:361
bool parseParams(const yarp::os::Searchable &config) override
Parse the DeviceDriver 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.
std::string getDocumentationOfDeviceParams() const override
Get the documentation of the DeviceDriver's 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,...)