19 YARP_LOG_COMPONENT(JoypadControlServerParamsCOMPONENT,
"yarp.device.JoypadControlServer")
30 std::vector<std::string> params;
31 params.push_back(
"period");
32 params.push_back(
"name");
33 params.push_back(
"use_separate_ports");
34 params.push_back(
"profile");
42 if (config.
check(
"help"))
47 std::string config_string = config.
toString();
51 if (config.
check(
"period"))
54 yCInfo(JoypadControlServerParamsCOMPONENT) <<
"Parameter 'period' using value:" <<
m_period;
58 yCInfo(JoypadControlServerParamsCOMPONENT) <<
"Parameter 'period' using DEFAULT value:" <<
m_period;
60 prop_check.
unput(
"period");
65 if (config.
check(
"name"))
68 yCInfo(JoypadControlServerParamsCOMPONENT) <<
"Parameter 'name' using value:" <<
m_name;
72 yCError(JoypadControlServerParamsCOMPONENT) <<
"Mandatory parameter 'name' not found!";
73 yCError(JoypadControlServerParamsCOMPONENT) <<
"Description of the parameter: Prefix name of the ports opened by the JoypadControlServer";
76 prop_check.
unput(
"name");
81 if (config.
check(
"use_separate_ports"))
90 prop_check.
unput(
"use_separate_ports");
95 if (config.
check(
"profile"))
98 yCInfo(JoypadControlServerParamsCOMPONENT) <<
"Parameter 'profile' using value:" <<
m_profile;
102 yCInfo(JoypadControlServerParamsCOMPONENT) <<
"Parameter 'profile' using DEFAULT value:" <<
m_profile;
104 prop_check.
unput(
"profile");
139 doc = doc + std::string(
"\n=============================================\n");
140 doc = doc + std::string(
"This is the help for device: JoypadControlServer\n");
141 doc = doc + std::string(
"\n");
142 doc = doc + std::string(
"This is the list of the parameters accepted by the device:\n");
143 doc = doc + std::string(
"'period': Refresh period (in s) of the broadcasted values through yarp ports\n");
144 doc = doc + std::string(
"'name': Prefix name of the ports opened by the JoypadControlServer\n");
145 doc = doc + std::string(
"'use_separate_ports': set it to 1 to use separate ports (buttons, axes, trackballs, hats) and 0 to stream all in one single port\n");
146 doc = doc + std::string(
"'profile': print the joypad data for debugging purpose\n");
147 doc = doc + std::string(
"\n");
148 doc = doc + std::string(
"Here are some examples of invocation command with yarpdev, with all params:\n");
149 doc = doc +
" yarpdev --device JoypadControlServer --period 0.01 --name /robotName/joypad --use_separate_ports true --profile false\n";
150 doc = doc + std::string(
"Using only mandatory params:\n");
151 doc = doc +
" yarpdev --device JoypadControlServer --name /robotName/joypad\n";
152 doc = doc + std::string(
"=============================================\n\n");
return doc;
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.
bool m_use_separate_ports
JoypadControlServer_ParamsParser()
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.
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.
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,...)