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_nwc_ros2
Signed-off-by: Ettore Landini <[email protected]>
- Loading branch information
1 parent
d0cffc7
commit 5c0aaf5
Showing
7 changed files
with
240 additions
and
44 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
141 changes: 141 additions & 0 deletions
141
src/devices/multipleAnalogSensors_nwc_ros2/GenericSensor_nwc_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,141 @@ | ||
/* | ||
* 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_nwc_ros2_ParamsParser.h" | ||
#include <yarp/os/LogStream.h> | ||
#include <yarp/os/Value.h> | ||
|
||
namespace { | ||
YARP_LOG_COMPONENT(GenericSensor_nwc_ros2ParamsCOMPONENT, "yarp.device.GenericSensor_nwc_ros2") | ||
} | ||
|
||
|
||
GenericSensor_nwc_ros2_ParamsParser::GenericSensor_nwc_ros2_ParamsParser() | ||
{ | ||
} | ||
|
||
|
||
std::vector<std::string> GenericSensor_nwc_ros2_ParamsParser::getListOfParams() const | ||
{ | ||
std::vector<std::string> params; | ||
params.push_back("node_name"); | ||
params.push_back("topic_name"); | ||
params.push_back("sensor_name"); | ||
return params; | ||
} | ||
|
||
|
||
bool GenericSensor_nwc_ros2_ParamsParser::parseParams(const yarp::os::Searchable & config) | ||
{ | ||
//Check for --help option | ||
if (config.check("help")) | ||
{ | ||
yCInfo(GenericSensor_nwc_ros2ParamsCOMPONENT) << getDocumentationOfDeviceParams(); | ||
} | ||
|
||
std::string config_string = config.toString(); | ||
yarp::os::Property prop_check(config_string.c_str()); | ||
//Parser of parameter node_name | ||
{ | ||
if (config.check("node_name")) | ||
{ | ||
m_node_name = config.find("node_name").asString(); | ||
yCInfo(GenericSensor_nwc_ros2ParamsCOMPONENT) << "Parameter 'node_name' using value:" << m_node_name; | ||
} | ||
else | ||
{ | ||
yCError(GenericSensor_nwc_ros2ParamsCOMPONENT) << "Mandatory parameter 'node_name' not found!"; | ||
yCError(GenericSensor_nwc_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_nwc_ros2ParamsCOMPONENT) << "Parameter 'topic_name' using value:" << m_topic_name; | ||
} | ||
else | ||
{ | ||
yCError(GenericSensor_nwc_ros2ParamsCOMPONENT) << "Mandatory parameter 'topic_name' not found!"; | ||
yCError(GenericSensor_nwc_ros2ParamsCOMPONENT) << "Description of the parameter: name of the topic where the device must publish the data"; | ||
return false; | ||
} | ||
prop_check.unput("topic_name"); | ||
} | ||
|
||
//Parser of parameter sensor_name | ||
{ | ||
if (config.check("sensor_name")) | ||
{ | ||
m_sensor_name = config.find("sensor_name").asString(); | ||
yCInfo(GenericSensor_nwc_ros2ParamsCOMPONENT) << "Parameter 'sensor_name' using value:" << m_sensor_name; | ||
} | ||
else | ||
{ | ||
yCError(GenericSensor_nwc_ros2ParamsCOMPONENT) << "Mandatory parameter 'sensor_name' not found!"; | ||
yCError(GenericSensor_nwc_ros2ParamsCOMPONENT) << "Description of the parameter: The name of the sensor the data are coming from"; | ||
return false; | ||
} | ||
prop_check.unput("sensor_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_nwc_ros2ParamsCOMPONENT) << "User asking for parameter: "<<it->name <<" which is unknown to this parser!"; | ||
extra_params_found = true; | ||
} | ||
else | ||
{ | ||
yCWarning(GenericSensor_nwc_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_nwc_ros2_ParamsParser::getDocumentationOfDeviceParams() const | ||
{ | ||
std::string doc; | ||
doc = doc + std::string("\n=============================================\n"); | ||
doc = doc + std::string("This is the help for device: GenericSensor_nwc_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("'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("'sensor_name': The name of the sensor the data are coming from\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_nwc_ros2 --node_name <mandatory_value> --topic_name <mandatory_value> --sensor_name <mandatory_value>\n"; | ||
doc = doc + std::string("Using only mandatory params:\n"); | ||
doc = doc + " yarpdev --device genericSensor_nwc_ros2 --node_name <mandatory_value> --topic_name <mandatory_value> --sensor_name <mandatory_value>\n"; | ||
doc = doc + std::string("=============================================\n\n"); return doc; | ||
} |
75 changes: 75 additions & 0 deletions
75
src/devices/multipleAnalogSensors_nwc_ros2/GenericSensor_nwc_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_NWC_ROS2_PARAMSPARSER_H | ||
#define GENERICSENSOR_NWC_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_nwc_ros2. | ||
* | ||
* These are the used parameters: | ||
* | Group name | Parameter name | Type | Units | Default Value | Required | Description | Notes | | ||
* |:----------:|:--------------:|:------:|:-----:|:-------------:|:--------:|:--------------------------------------------------------:|:----------------------------------:| | ||
* | - | node_name | string | - | - | 1 | name of the ros2 node | must not start with an initial '/' | | ||
* | - | topic_name | string | - | - | 1 | name of the topic where the device must publish the data | must begin with an initial '/' | | ||
* | - | sensor_name | string | - | - | 1 | The name of the sensor the data are coming from | - | | ||
* | ||
* The device can be launched by yarpdev using one of the following examples (with and without all optional parameters): | ||
* \code{.unparsed} | ||
* yarpdev --device genericSensor_nwc_ros2 --node_name <mandatory_value> --topic_name <mandatory_value> --sensor_name <mandatory_value> | ||
* \endcode | ||
* | ||
* \code{.unparsed} | ||
* yarpdev --device genericSensor_nwc_ros2 --node_name <mandatory_value> --topic_name <mandatory_value> --sensor_name <mandatory_value> | ||
* \endcode | ||
* | ||
*/ | ||
|
||
class GenericSensor_nwc_ros2_ParamsParser : public yarp::dev::IDeviceDriverParams | ||
{ | ||
public: | ||
GenericSensor_nwc_ros2_ParamsParser(); | ||
~GenericSensor_nwc_ros2_ParamsParser() override = default; | ||
|
||
public: | ||
const std::string m_device_classname = {"GenericSensor_nwc_ros2"}; | ||
const std::string m_device_name = {"genericSensor_nwc_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_node_name_defaultValue = {""}; | ||
const std::string m_topic_name_defaultValue = {""}; | ||
const std::string m_sensor_name_defaultValue = {""}; | ||
|
||
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. | ||
std::string m_sensor_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_nwc_ros2/GenericSensor_nwc_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 @@ | ||
| | node_name | string | - | - | Yes | name of the ros2 node | must not start with an initial '/' | | ||
| | topic_name | string | - | - | Yes | name of the topic where the device must publish the data | must begin with an initial '/' | | ||
| | sensor_name | string | - | - | Yes | The name of the sensor the data are coming from | | |
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