YARP
Yet Another Robot Platform
 
Loading...
Searching...
No Matches
FrameTransformServer_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:46 2025
12
13
15#include <yarp/os/LogStream.h>
16#include <yarp/os/Value.h>
17
18namespace {
19 YARP_LOG_COMPONENT(FrameTransformServerParamsCOMPONENT, "yarp.device.FrameTransformServer")
20}
21
22
26
27
29{
30 std::vector<std::string> params;
31 params.push_back("testxml_from");
32 params.push_back("testxml_context");
33 params.push_back("filexml_option");
34 params.push_back("local_rpc");
35 params.push_back("FrameTransform_verbose_debug");
36 params.push_back("period");
37 return params;
38}
39
40
41bool FrameTransformServer_ParamsParser::getParamValue(const std::string& paramName, std::string& paramValue) const
42{
43 if (paramName =="testxml_from")
44 {
45 paramValue = m_testxml_from;
46 return true;
47 }
48 if (paramName =="testxml_context")
49 {
50 paramValue = m_testxml_context;
51 return true;
52 }
53 if (paramName =="filexml_option")
54 {
55 paramValue = m_filexml_option;
56 return true;
57 }
58 if (paramName =="local_rpc")
59 {
60 paramValue = m_local_rpc;
61 return true;
62 }
63 if (paramName =="FrameTransform_verbose_debug")
64 {
65 if (m_FrameTransform_verbose_debug==true) paramValue = "true";
66 else paramValue = "false";
67 return true;
68 }
69 if (paramName =="period")
70 {
71 paramValue = std::to_string(m_period);
72 return true;
73 }
74
75 yError() <<"parameter '" << paramName << "' was not found";
76 return false;
77
78}
79
80
82{
83 //This is a sub-optimal solution.
84 //Ideally getConfiguration() should return all parameters but it is currently
85 //returning only user provided parameters (excluding default values)
86 //This behaviour will be fixed in the near future.
87 std::string s_cfg = m_provided_configuration;
88 return s_cfg;
89}
90
92{
93 //Check for --help option
94 if (config.check("help"))
95 {
96 yCInfo(FrameTransformServerParamsCOMPONENT) << getDocumentationOfDeviceParams();
97 }
98
101 //Parser of parameter testxml_from
102 {
103 if (config.check("testxml_from"))
104 {
105 m_testxml_from = config.find("testxml_from").asString();
106 yCInfo(FrameTransformServerParamsCOMPONENT) << "Parameter 'testxml_from' using value:" << m_testxml_from;
107 }
108 else
109 {
110 yCInfo(FrameTransformServerParamsCOMPONENT) << "Parameter 'testxml_from' using DEFAULT value:" << m_testxml_from;
111 }
112 prop_check.unput("testxml_from");
113 }
114
115 //Parser of parameter testxml_context
116 {
117 if (config.check("testxml_context"))
118 {
119 m_testxml_context = config.find("testxml_context").asString();
120 yCInfo(FrameTransformServerParamsCOMPONENT) << "Parameter 'testxml_context' using value:" << m_testxml_context;
121 }
122 else
123 {
124 yCInfo(FrameTransformServerParamsCOMPONENT) << "Parameter 'testxml_context' using DEFAULT value:" << m_testxml_context;
125 }
126 prop_check.unput("testxml_context");
127 }
128
129 //Parser of parameter filexml_option
130 {
131 if (config.check("filexml_option"))
132 {
133 m_filexml_option = config.find("filexml_option").asString();
134 yCInfo(FrameTransformServerParamsCOMPONENT) << "Parameter 'filexml_option' using value:" << m_filexml_option;
135 }
136 else
137 {
138 yCInfo(FrameTransformServerParamsCOMPONENT) << "Parameter 'filexml_option' using DEFAULT value:" << m_filexml_option;
139 }
140 prop_check.unput("filexml_option");
141 }
142
143 //Parser of parameter local_rpc
144 {
145 if (config.check("local_rpc"))
146 {
147 m_local_rpc = config.find("local_rpc").asString();
148 yCInfo(FrameTransformServerParamsCOMPONENT) << "Parameter 'local_rpc' using value:" << m_local_rpc;
149 }
150 else
151 {
152 yCInfo(FrameTransformServerParamsCOMPONENT) << "Parameter 'local_rpc' using DEFAULT value:" << m_local_rpc;
153 }
154 prop_check.unput("local_rpc");
155 }
156
157 //Parser of parameter FrameTransform_verbose_debug
158 {
159 if (config.check("FrameTransform_verbose_debug"))
160 {
161 m_FrameTransform_verbose_debug = config.find("FrameTransform_verbose_debug").asBool();
162 yCInfo(FrameTransformServerParamsCOMPONENT) << "Parameter 'FrameTransform_verbose_debug' using value:" << m_FrameTransform_verbose_debug;
163 }
164 else
165 {
166 yCInfo(FrameTransformServerParamsCOMPONENT) << "Parameter 'FrameTransform_verbose_debug' using DEFAULT value:" << m_FrameTransform_verbose_debug;
167 }
168 prop_check.unput("FrameTransform_verbose_debug");
169 }
170
171 //Parser of parameter period
172 {
173 if (config.check("period"))
174 {
175 m_period = config.find("period").asFloat64();
176 yCInfo(FrameTransformServerParamsCOMPONENT) << "Parameter 'period' using value:" << m_period;
177 }
178 else
179 {
180 yCInfo(FrameTransformServerParamsCOMPONENT) << "Parameter 'period' using DEFAULT value:" << m_period;
181 }
182 prop_check.unput("period");
183 }
184
185 /*
186 //This code check if the user set some parameter which are not check by the parser
187 //If the parser is set in strict mode, this will generate an error
188 if (prop_check.size() > 0)
189 {
190 bool extra_params_found = false;
191 for (auto it=prop_check.begin(); it!=prop_check.end(); it++)
192 {
193 if (m_parser_is_strict)
194 {
195 yCError(FrameTransformServerParamsCOMPONENT) << "User asking for parameter: "<<it->name <<" which is unknown to this parser!";
196 extra_params_found = true;
197 }
198 else
199 {
200 yCWarning(FrameTransformServerParamsCOMPONENT) << "User asking for parameter: "<< it->name <<" which is unknown to this parser!";
201 }
202 }
203
204 if (m_parser_is_strict && extra_params_found)
205 {
206 return false;
207 }
208 }
209 */
210 return true;
211}
212
213
215{
216 std::string doc;
217 doc = doc + std::string("\n=============================================\n");
218 doc = doc + std::string("This is the help for device: FrameTransformServer\n");
219 doc = doc + std::string("\n");
220 doc = doc + std::string("This is the list of the parameters accepted by the device:\n");
221 doc = doc + std::string("'testxml_from': xml configuration file name\n");
222 doc = doc + std::string("'testxml_context': xml configuration file context\n");
223 doc = doc + std::string("'filexml_option': The name of the xml file containing the needed configuration. if used, the name will be appended to config_xml/\n");
224 doc = doc + std::string("'local_rpc': Full name of the rpc port\n");
225 doc = doc + std::string("'FrameTransform_verbose_debug': Enable debug prints\n");
226 doc = doc + std::string("'period': thread period\n");
227 doc = doc + std::string("\n");
228 doc = doc + std::string("Here are some examples of invocation command with yarpdev, with all params:\n");
229 doc = doc + " yarpdev --device frameTransformServer --testxml_from <optional_value> --testxml_context <optional_value> --filexml_option fts_yarp_only.xml --local_rpc /ftServer/rpc --FrameTransform_verbose_debug false --period 0.10\n";
230 doc = doc + std::string("Using only mandatory params:\n");
231 doc = doc + " yarpdev --device frameTransformServer\n";
232 doc = doc + std::string("=============================================\n\n"); return doc;
233}
#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 YARP_LOG_COMPONENT(name,...)