YARP
Yet Another Robot Platform
 
Loading...
Searching...
No Matches
AudioRecorder_nwc_yarp_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:40 2025
12
13
15#include <yarp/os/LogStream.h>
16#include <yarp/os/Value.h>
17
18namespace {
19 YARP_LOG_COMPONENT(AudioRecorder_nwc_yarpParamsCOMPONENT, "yarp.device.AudioRecorder_nwc_yarp")
20}
21
22
26
27
29{
30 std::vector<std::string> params;
31 params.push_back("local");
32 params.push_back("remote");
33 params.push_back("carrier");
34 params.push_back("useStream");
35 return params;
36}
37
38
39bool AudioRecorder_nwc_yarp_ParamsParser::getParamValue(const std::string& paramName, std::string& paramValue) const
40{
41 if (paramName =="local")
42 {
43 paramValue = m_local;
44 return true;
45 }
46 if (paramName =="remote")
47 {
48 paramValue = m_remote;
49 return true;
50 }
51 if (paramName =="carrier")
52 {
53 paramValue = m_carrier;
54 return true;
55 }
56 if (paramName =="useStream")
57 {
58 if (m_useStream==true) paramValue = "true";
59 else paramValue = "false";
60 return true;
61 }
62
63 yError() <<"parameter '" << paramName << "' was not found";
64 return false;
65
66}
67
68
70{
71 //This is a sub-optimal solution.
72 //Ideally getConfiguration() should return all parameters but it is currently
73 //returning only user provided parameters (excluding default values)
74 //This behaviour will be fixed in the near future.
75 std::string s_cfg = m_provided_configuration;
76 return s_cfg;
77}
78
80{
81 //Check for --help option
82 if (config.check("help"))
83 {
84 yCInfo(AudioRecorder_nwc_yarpParamsCOMPONENT) << getDocumentationOfDeviceParams();
85 }
86
89 //Parser of parameter local
90 {
91 if (config.check("local"))
92 {
93 m_local = config.find("local").asString();
94 yCInfo(AudioRecorder_nwc_yarpParamsCOMPONENT) << "Parameter 'local' using value:" << m_local;
95 }
96 else
97 {
98 yCError(AudioRecorder_nwc_yarpParamsCOMPONENT) << "Mandatory parameter 'local' not found!";
99 yCError(AudioRecorder_nwc_yarpParamsCOMPONENT) << "Description of the parameter: Full port name opened by the audioRecoder_nwc_yarp device.";
100 return false;
101 }
102 prop_check.unput("local");
103 }
104
105 //Parser of parameter remote
106 {
107 if (config.check("remote"))
108 {
109 m_remote = config.find("remote").asString();
110 yCInfo(AudioRecorder_nwc_yarpParamsCOMPONENT) << "Parameter 'remote' using value:" << m_remote;
111 }
112 else
113 {
114 yCError(AudioRecorder_nwc_yarpParamsCOMPONENT) << "Mandatory parameter 'remote' not found!";
115 yCError(AudioRecorder_nwc_yarpParamsCOMPONENT) << "Description of the parameter: Full port name of the port opened on the server side, to which the audioRecoder_nwc_yarp connects to.";
116 return false;
117 }
118 prop_check.unput("remote");
119 }
120
121 //Parser of parameter carrier
122 {
123 if (config.check("carrier"))
124 {
125 m_carrier = config.find("carrier").asString();
126 yCInfo(AudioRecorder_nwc_yarpParamsCOMPONENT) << "Parameter 'carrier' using value:" << m_carrier;
127 }
128 else
129 {
130 yCInfo(AudioRecorder_nwc_yarpParamsCOMPONENT) << "Parameter 'carrier' using DEFAULT value:" << m_carrier;
131 }
132 prop_check.unput("carrier");
133 }
134
135 //Parser of parameter useStream
136 {
137 if (config.check("useStream"))
138 {
139 m_useStream = config.find("useStream").asBool();
140 yCInfo(AudioRecorder_nwc_yarpParamsCOMPONENT) << "Parameter 'useStream' using value:" << m_useStream;
141 }
142 else
143 {
144 yCInfo(AudioRecorder_nwc_yarpParamsCOMPONENT) << "Parameter 'useStream' using DEFAULT value:" << m_useStream;
145 }
146 prop_check.unput("useStream");
147 }
148
149 /*
150 //This code check if the user set some parameter which are not check by the parser
151 //If the parser is set in strict mode, this will generate an error
152 if (prop_check.size() > 0)
153 {
154 bool extra_params_found = false;
155 for (auto it=prop_check.begin(); it!=prop_check.end(); it++)
156 {
157 if (m_parser_is_strict)
158 {
159 yCError(AudioRecorder_nwc_yarpParamsCOMPONENT) << "User asking for parameter: "<<it->name <<" which is unknown to this parser!";
160 extra_params_found = true;
161 }
162 else
163 {
164 yCWarning(AudioRecorder_nwc_yarpParamsCOMPONENT) << "User asking for parameter: "<< it->name <<" which is unknown to this parser!";
165 }
166 }
167
168 if (m_parser_is_strict && extra_params_found)
169 {
170 return false;
171 }
172 }
173 */
174 return true;
175}
176
177
179{
180 std::string doc;
181 doc = doc + std::string("\n=============================================\n");
182 doc = doc + std::string("This is the help for device: AudioRecorder_nwc_yarp\n");
183 doc = doc + std::string("\n");
184 doc = doc + std::string("This is the list of the parameters accepted by the device:\n");
185 doc = doc + std::string("'local': Full port name opened by the audioRecoder_nwc_yarp device.\n");
186 doc = doc + std::string("'remote': Full port name of the port opened on the server side, to which the audioRecoder_nwc_yarp connects to.\n");
187 doc = doc + std::string("'carrier': The carrier used for the streaming connection with the server.\n");
188 doc = doc + std::string("'useStream': If true, enables a streaming connection with the server. Otherwise only rpc is used\n");
189 doc = doc + std::string("\n");
190 doc = doc + std::string("Here are some examples of invocation command with yarpdev, with all params:\n");
191 doc = doc + " yarpdev --device audioRecorder_nwc_yarp --local <mandatory_value> --remote <mandatory_value> --carrier fast_tcp --useStream false\n";
192 doc = doc + std::string("Using only mandatory params:\n");
193 doc = doc + " yarpdev --device audioRecorder_nwc_yarp --local <mandatory_value> --remote <mandatory_value>\n";
194 doc = doc + std::string("=============================================\n\n"); return doc;
195}
#define yError(...)
Definition Log.h:361
bool parseParams(const yarp::os::Searchable &config) override
Parse the DeviceDriver 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.
std::string getDocumentationOfDeviceParams() const override
Get the documentation of the DeviceDriver's parameters.
bool getParamValue(const std::string &paramName, std::string &paramValue) const override
Return the value (represented as a string) of the requested parameter.
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,...)