forked from robotology/yarp-devices-ros2
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Added ParamsParser to MultipleAnalogSensors_nws_ros2
Signed-off-by: Ettore Landini <[email protected]>
- Loading branch information
1 parent
5c0aaf5
commit 07ca1a7
Showing
7 changed files
with
239 additions
and
60 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
139 changes: 139 additions & 0 deletions
139
src/devices/multipleAnalogSensors_nws_ros2/GenericSensor_nws_ros2_ParamsParser.cpp
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,139 @@ | ||
/* | ||
* SPDX-FileCopyrightText: 2023-2023 Istituto Italiano di Tecnologia (IIT) | ||
* SPDX-License-Identifier: LGPL-2.1-or-later | ||
*/ | ||
|
||
|
||
// Generated by yarpDeviceParamParserGenerator (1.0) | ||
// This is an automatically generated file. Please do not edit it. | ||
// It will be re-generated if the cmake flag ALLOW_DEVICE_PARAM_PARSER_GERNERATION is ON. | ||
|
||
// Generated on: Mon Aug 5 16:25:52 2024 | ||
|
||
|
||
#include "GenericSensor_nws_ros2_ParamsParser.h" | ||
#include <yarp/os/LogStream.h> | ||
#include <yarp/os/Value.h> | ||
|
||
namespace { | ||
YARP_LOG_COMPONENT(GenericSensor_nws_ros2ParamsCOMPONENT, "yarp.device.GenericSensor_nws_ros2") | ||
} | ||
|
||
|
||
GenericSensor_nws_ros2_ParamsParser::GenericSensor_nws_ros2_ParamsParser() | ||
{ | ||
} | ||
|
||
|
||
std::vector<std::string> GenericSensor_nws_ros2_ParamsParser::getListOfParams() const | ||
{ | ||
std::vector<std::string> params; | ||
params.push_back("period"); | ||
params.push_back("node_name"); | ||
params.push_back("topic_name"); | ||
return params; | ||
} | ||
|
||
|
||
bool GenericSensor_nws_ros2_ParamsParser::parseParams(const yarp::os::Searchable & config) | ||
{ | ||
//Check for --help option | ||
if (config.check("help")) | ||
{ | ||
yCInfo(GenericSensor_nws_ros2ParamsCOMPONENT) << getDocumentationOfDeviceParams(); | ||
} | ||
|
||
std::string config_string = config.toString(); | ||
yarp::os::Property prop_check(config_string.c_str()); | ||
//Parser of parameter period | ||
{ | ||
if (config.check("period")) | ||
{ | ||
m_period = config.find("period").asFloat64(); | ||
yCInfo(GenericSensor_nws_ros2ParamsCOMPONENT) << "Parameter 'period' using value:" << m_period; | ||
} | ||
else | ||
{ | ||
yCInfo(GenericSensor_nws_ros2ParamsCOMPONENT) << "Parameter 'period' using DEFAULT value:" << m_period; | ||
} | ||
prop_check.unput("period"); | ||
} | ||
|
||
//Parser of parameter node_name | ||
{ | ||
if (config.check("node_name")) | ||
{ | ||
m_node_name = config.find("node_name").asString(); | ||
yCInfo(GenericSensor_nws_ros2ParamsCOMPONENT) << "Parameter 'node_name' using value:" << m_node_name; | ||
} | ||
else | ||
{ | ||
yCError(GenericSensor_nws_ros2ParamsCOMPONENT) << "Mandatory parameter 'node_name' not found!"; | ||
yCError(GenericSensor_nws_ros2ParamsCOMPONENT) << "Description of the parameter: name of the ros2 node"; | ||
return false; | ||
} | ||
prop_check.unput("node_name"); | ||
} | ||
|
||
//Parser of parameter topic_name | ||
{ | ||
if (config.check("topic_name")) | ||
{ | ||
m_topic_name = config.find("topic_name").asString(); | ||
yCInfo(GenericSensor_nws_ros2ParamsCOMPONENT) << "Parameter 'topic_name' using value:" << m_topic_name; | ||
} | ||
else | ||
{ | ||
yCError(GenericSensor_nws_ros2ParamsCOMPONENT) << "Mandatory parameter 'topic_name' not found!"; | ||
yCError(GenericSensor_nws_ros2ParamsCOMPONENT) << "Description of the parameter: name of the topic where the device must publish the data"; | ||
return false; | ||
} | ||
prop_check.unput("topic_name"); | ||
} | ||
|
||
/* | ||
//This code check if the user set some parameter which are not check by the parser | ||
//If the parser is set in strict mode, this will generate an error | ||
if (prop_check.size() > 0) | ||
{ | ||
bool extra_params_found = false; | ||
for (auto it=prop_check.begin(); it!=prop_check.end(); it++) | ||
{ | ||
if (m_parser_is_strict) | ||
{ | ||
yCError(GenericSensor_nws_ros2ParamsCOMPONENT) << "User asking for parameter: "<<it->name <<" which is unknown to this parser!"; | ||
extra_params_found = true; | ||
} | ||
else | ||
{ | ||
yCWarning(GenericSensor_nws_ros2ParamsCOMPONENT) << "User asking for parameter: "<< it->name <<" which is unknown to this parser!"; | ||
} | ||
} | ||
if (m_parser_is_strict && extra_params_found) | ||
{ | ||
return false; | ||
} | ||
} | ||
*/ | ||
return true; | ||
} | ||
|
||
|
||
std::string GenericSensor_nws_ros2_ParamsParser::getDocumentationOfDeviceParams() const | ||
{ | ||
std::string doc; | ||
doc = doc + std::string("\n=============================================\n"); | ||
doc = doc + std::string("This is the help for device: GenericSensor_nws_ros2\n"); | ||
doc = doc + std::string("\n"); | ||
doc = doc + std::string("This is the list of the parameters accepted by the device:\n"); | ||
doc = doc + std::string("'period': refresh period of the broadcasted values in s\n"); | ||
doc = doc + std::string("'node_name': name of the ros2 node\n"); | ||
doc = doc + std::string("'topic_name': name of the topic where the device must publish the data\n"); | ||
doc = doc + std::string("\n"); | ||
doc = doc + std::string("Here are some examples of invocation command with yarpdev, with all params:\n"); | ||
doc = doc + " yarpdev --device genericSensor_nws_ros2 --period 0.02 --node_name <mandatory_value> --topic_name <mandatory_value>\n"; | ||
doc = doc + std::string("Using only mandatory params:\n"); | ||
doc = doc + " yarpdev --device genericSensor_nws_ros2 --node_name <mandatory_value> --topic_name <mandatory_value>\n"; | ||
doc = doc + std::string("=============================================\n\n"); return doc; | ||
} |
75 changes: 75 additions & 0 deletions
75
src/devices/multipleAnalogSensors_nws_ros2/GenericSensor_nws_ros2_ParamsParser.h
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,75 @@ | ||
/* | ||
* SPDX-FileCopyrightText: 2023-2023 Istituto Italiano di Tecnologia (IIT) | ||
* SPDX-License-Identifier: LGPL-2.1-or-later | ||
*/ | ||
|
||
|
||
// Generated by yarpDeviceParamParserGenerator (1.0) | ||
// This is an automatically generated file. Please do not edit it. | ||
// It will be re-generated if the cmake flag ALLOW_DEVICE_PARAM_PARSER_GERNERATION is ON. | ||
|
||
// Generated on: Mon Aug 5 16:25:52 2024 | ||
|
||
|
||
#ifndef GENERICSENSOR_NWS_ROS2_PARAMSPARSER_H | ||
#define GENERICSENSOR_NWS_ROS2_PARAMSPARSER_H | ||
|
||
#include <yarp/os/Searchable.h> | ||
#include <yarp/dev/IDeviceDriverParams.h> | ||
#include <string> | ||
#include <cmath> | ||
|
||
/** | ||
* This class is the parameters parser for class GenericSensor_nws_ros2. | ||
* | ||
* These are the used parameters: | ||
* | Group name | Parameter name | Type | Units | Default Value | Required | Description | Notes | | ||
* |:----------:|:--------------:|:------:|:-----:|:-------------:|:--------:|:--------------------------------------------------------:|:------------------------------:| | ||
* | - | period | double | s | 0.02 | 0 | refresh period of the broadcasted values in s | default 0.02s | | ||
* | - | node_name | string | - | - | 1 | name of the ros2 node | - | | ||
* | - | topic_name | string | - | - | 1 | name of the topic where the device must publish the data | must begin with an initial '/' | | ||
* | ||
* The device can be launched by yarpdev using one of the following examples (with and without all optional parameters): | ||
* \code{.unparsed} | ||
* yarpdev --device genericSensor_nws_ros2 --period 0.02 --node_name <mandatory_value> --topic_name <mandatory_value> | ||
* \endcode | ||
* | ||
* \code{.unparsed} | ||
* yarpdev --device genericSensor_nws_ros2 --node_name <mandatory_value> --topic_name <mandatory_value> | ||
* \endcode | ||
* | ||
*/ | ||
|
||
class GenericSensor_nws_ros2_ParamsParser : public yarp::dev::IDeviceDriverParams | ||
{ | ||
public: | ||
GenericSensor_nws_ros2_ParamsParser(); | ||
~GenericSensor_nws_ros2_ParamsParser() override = default; | ||
|
||
public: | ||
const std::string m_device_classname = {"GenericSensor_nws_ros2"}; | ||
const std::string m_device_name = {"genericSensor_nws_ros2"}; | ||
bool m_parser_is_strict = false; | ||
struct parser_version_type | ||
{ | ||
int major = 1; | ||
int minor = 0; | ||
}; | ||
const parser_version_type m_parser_version = {}; | ||
|
||
const std::string m_period_defaultValue = {"0.02"}; | ||
const std::string m_node_name_defaultValue = {""}; | ||
const std::string m_topic_name_defaultValue = {""}; | ||
|
||
double m_period = {0.02}; | ||
std::string m_node_name = {}; //This default value is autogenerated. It is highly recommended to provide a suggested value also for mandatory parameters. | ||
std::string m_topic_name = {}; //This default value is autogenerated. It is highly recommended to provide a suggested value also for mandatory parameters. | ||
|
||
bool parseParams(const yarp::os::Searchable & config) override; | ||
std::string getDeviceClassName() const override { return m_device_classname; } | ||
std::string getDeviceName() const override { return m_device_name; } | ||
std::string getDocumentationOfDeviceParams() const override; | ||
std::vector<std::string> getListOfParams() const override; | ||
}; | ||
|
||
#endif |
3 changes: 3 additions & 0 deletions
3
src/devices/multipleAnalogSensors_nws_ros2/GenericSensor_nws_ros2_params.md
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,3 @@ | ||
| | period | double | s | 0.02 | No | refresh period of the broadcasted values in s | default 0.02s | | ||
| | node_name | string | - | - | Yes | name of the ros2 node | | | ||
| | topic_name | string | - | - | Yes | name of the topic where the device must publish the data| must begin with an initial '/' | |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters