Skip to content

Commit

Permalink
address review feedback part 1
Browse files Browse the repository at this point in the history
  • Loading branch information
bpwilcox committed Nov 22, 2019
1 parent e425971 commit fb190e6
Showing 1 changed file with 17 additions and 15 deletions.
32 changes: 17 additions & 15 deletions rcl_yaml_param_parser/src/parser.c
Original file line number Diff line number Diff line change
Expand Up @@ -1149,9 +1149,7 @@ void rcl_yaml_node_struct_print(
for (size_t parameter_idx = 0U; parameter_idx < node_descriptors_st->num_params;
parameter_idx++)
{
if (
(NULL != node_descriptors_st->parameter_names))
{
if (NULL != node_descriptors_st->parameter_names) {
char * param_name = node_descriptors_st->parameter_names[parameter_idx];
if (NULL != param_name) {
printf("%*s:", param_col, param_name);
Expand Down Expand Up @@ -1669,6 +1667,9 @@ static rcutils_ret_t parse_descriptor(
{
RCUTILS_CHECK_ARGUMENT_FOR_NULL(params_st, RCUTILS_RET_INVALID_ARGUMENT);

assert(node_idx < params_st->num_nodes);
assert(parameter_idx < params_st->descriptors[node_idx].num_params);

rcutils_allocator_t allocator = params_st->allocator;
RCUTILS_CHECK_ALLOCATOR_WITH_MSG(
&allocator, "invalid allocator", return RCUTILS_RET_INVALID_ARGUMENT);
Expand All @@ -1686,6 +1687,12 @@ static rcutils_ret_t parse_descriptor(
RCUTILS_CHECK_FOR_NULL_WITH_MSG(
value, "event argument has no value", return RCUTILS_RET_INVALID_ARGUMENT);

if (is_seq) {
RCUTILS_SET_ERROR_MSG_WITH_FORMAT_STRING(
"Sequences not supported for parameter descriptors at line %d", line_num);
return RCUTILS_RET_ERROR;
}

if (style != YAML_SINGLE_QUOTED_SCALAR_STYLE &&
style != YAML_DOUBLE_QUOTED_SCALAR_STYLE &&
0U == val_size)
Expand Down Expand Up @@ -1714,24 +1721,19 @@ static rcutils_ret_t parse_descriptor(
RCUTILS_SET_ERROR_MSG_WITH_FORMAT_STRING(
"Parameter assignment at line %d unallowed in parameter__descriptors", line_num);
return RCUTILS_RET_ERROR;
} else {
// If parsing a yaml value, then current parameter namespace must be parameter name
allocator.deallocate(params_st->descriptors[node_idx].parameter_names[parameter_idx],
allocator.state);
params_st->descriptors[node_idx].parameter_names[parameter_idx] =
rcutils_strdup(ns_tracker->parameter_ns, allocator);
}
// If parsing a yaml value, then current parameter namespace must be parameter name
allocator.deallocate(params_st->descriptors[node_idx].parameter_names[parameter_idx],
allocator.state);
params_st->descriptors[node_idx].parameter_names[parameter_idx] =
rcutils_strdup(ns_tracker->parameter_ns, allocator);

if (NULL == param_descriptor->name) {
param_descriptor->name =
rcutils_strdup(params_st->descriptors[node_idx].parameter_names[parameter_idx], allocator);
rcl_node_params_descriptors_t * node_descriptors_st = &(params_st->descriptors[node_idx]);
node_descriptors_st->num_params++;
}
if (true == is_seq) {
RCUTILS_SET_ERROR_MSG_WITH_FORMAT_STRING(
"Sequences not supported for parameter descriptors at line %d", line_num);
return RCUTILS_RET_ERROR;
}

if (0 == strncmp("additional_constraints", ns_tracker->descriptor_key_ns,
strlen("additional_constraints")))
Expand Down Expand Up @@ -2037,7 +2039,7 @@ static rcutils_ret_t parse_key(
break;
}

/// Add a parameter name into the node parameters
/// Add a parameter name into the node parameter descriptors
parameter_ns = ns_tracker->parameter_ns;
if (NULL == parameter_ns) {
ret = find_descriptor(*node_idx, value, params_st, parameter_idx);
Expand Down

0 comments on commit fb190e6

Please sign in to comment.