From 3e1237f5ee74675c0297cbd430a2ee5464c0ef61 Mon Sep 17 00:00:00 2001 From: Pablo Garrido Date: Wed, 4 Nov 2020 07:29:33 +0100 Subject: [PATCH] Release micro-ROS Foxy (#9) * Avoid logging on build time based on RCutils flags (#6) * Add RCL_YAML_PARSER and RCL_LOGGING CMake options. * Replace RCL_YAML_PARSER by RCL_COMMAND_LINE_ENABLED and RCL_LOGGING by RCL_LOGGING_ENABLED. * Disabled logging fix * Fix remapping (#7) Co-authored-by: Pablo Garrido Co-authored-by: julibert --- rcl/CMakeLists.txt | 53 +++++++++++++++++++++++++++------- rcl/include/rcl/context.h | 4 +++ rcl/include/rcl/node.h | 2 ++ rcl/include/rcl/node_options.h | 5 ++++ rcl/src/rcl/client.c | 7 +++++ rcl/src/rcl/context.c | 4 +++ rcl/src/rcl/event.c | 2 ++ rcl/src/rcl/init.c | 12 ++++++++ rcl/src/rcl/logging.c | 10 +++++-- rcl/src/rcl/node.c | 19 ++++++++++++ rcl/src/rcl/node_options.c | 10 +++++++ rcl/src/rcl/publisher.c | 7 +++++ rcl/src/rcl/service.c | 7 +++++ rcl/src/rcl/subscription.c | 7 +++++ 14 files changed, 135 insertions(+), 14 deletions(-) diff --git a/rcl/CMakeLists.txt b/rcl/CMakeLists.txt index 934ef4ae1f..38aeed1390 100644 --- a/rcl/CMakeLists.txt +++ b/rcl/CMakeLists.txt @@ -2,19 +2,28 @@ cmake_minimum_required(VERSION 3.5) project(rcl) +option(RCL_COMMAND_LINE_ENABLED "Enable/disable the rcl_yaml_param_parser tool" OFF) +option(RCL_LOGGING_ENABLED "Enable/disable logging" OFF) + find_package(ament_cmake_ros REQUIRED) find_package(rcl_interfaces REQUIRED) -find_package(rcl_yaml_param_parser REQUIRED) find_package(rcutils REQUIRED) find_package(rmw REQUIRED) find_package(rmw_implementation REQUIRED) find_package(rosidl_runtime_c REQUIRED) find_package(tracetools REQUIRED) +if(RCL_COMMAND_LINE_ENABLED) + find_package(rcl_yaml_param_parser REQUIRED) +endif() + include(cmake/rcl_set_symbol_visibility_hidden.cmake) -include(cmake/get_default_rcl_logging_implementation.cmake) -get_default_rcl_logging_implementation(RCL_LOGGING_IMPL) + +if(RCL_LOGGING_ENABLED) + include(cmake/get_default_rcl_logging_implementation.cmake) + get_default_rcl_logging_implementation(RCL_LOGGING_IMPL) +endif() # Default to C11 if(NOT CMAKE_C_STANDARD) @@ -31,7 +40,7 @@ if(CMAKE_COMPILER_IS_GNUCXX OR CMAKE_CXX_COMPILER_ID MATCHES "Clang") endif() set(${PROJECT_NAME}_sources - src/rcl/arguments.c + $<$:src/rcl/arguments.c> src/rcl/client.c src/rcl/common.c src/rcl/context.c @@ -45,12 +54,12 @@ set(${PROJECT_NAME}_sources src/rcl/lexer.c src/rcl/lexer_lookahead.c src/rcl/localhost.c - src/rcl/logging_rosout.c - src/rcl/logging.c + $<$:src/rcl/logging_rosout.c> + $<$:src/rcl/logging.c> src/rcl/node.c src/rcl/node_options.c src/rcl/publisher.c - src/rcl/remap.c + $<$:src/rcl/remap.c> src/rcl/rmw_implementation_identifier_check.c src/rcl/security.c src/rcl/service.c @@ -69,15 +78,31 @@ target_include_directories(${PROJECT_NAME} PUBLIC # specific order: dependents before dependencies ament_target_dependencies(${PROJECT_NAME} "rcl_interfaces" - "rcl_yaml_param_parser" "rcutils" "rmw" "rmw_implementation" - ${RCL_LOGGING_IMPL} "rosidl_runtime_c" "tracetools" ) +if(RCL_COMMAND_LINE_ENABLED) + ament_target_dependencies(${PROJECT_NAME} + "rcl_yaml_param_parser" + ) +endif() + +if(RCL_LOGGING_ENABLED) + ament_target_dependencies(${PROJECT_NAME} + ${RCL_LOGGING_IMPL} + ) +endif() + +target_compile_definitions(${PROJECT_NAME} + PRIVATE + $<$:RCL_COMMAND_LINE_ENABLED> + $<$:RCL_LOGGING_ENABLED> + ) + # Causes the visibility macros to use dllexport rather than dllimport, # which is appropriate when building the dll but not consuming it. target_compile_definitions(${PROJECT_NAME} PRIVATE "RCL_BUILDING_DLL") @@ -106,14 +131,20 @@ ament_export_targets(${PROJECT_NAME}) ament_export_dependencies(ament_cmake) ament_export_dependencies(rcl_interfaces) -ament_export_dependencies(rcl_yaml_param_parser) ament_export_dependencies(rmw_implementation) ament_export_dependencies(rmw) ament_export_dependencies(rcutils) -ament_export_dependencies(${RCL_LOGGING_IMPL}) ament_export_dependencies(rosidl_runtime_c) ament_export_dependencies(tracetools) +if(RCL_COMMAND_LINE_ENABLED) + ament_export_dependencies(rcl_yaml_param_parser) +endif() + +if(RCL_LOGGING_ENABLED) + ament_export_dependencies(${RCL_LOGGING_IMPL}) +endif() + if(BUILD_TESTING) find_package(ament_lint_auto REQUIRED) ament_lint_auto_find_test_dependencies() diff --git a/rcl/include/rcl/context.h b/rcl/include/rcl/context.h index 89995a9f90..efb6bd71f4 100644 --- a/rcl/include/rcl/context.h +++ b/rcl/include/rcl/context.h @@ -23,7 +23,9 @@ extern "C" #include "rmw/init.h" #include "rcl/allocator.h" +#ifdef RCL_COMMAND_LINE_ENABLED #include "rcl/arguments.h" +#endif // RCL_COMMAND_LINE_ENABLED #include "rcl/init_options.h" #include "rcl/macros.h" #include "rcl/types.h" @@ -107,9 +109,11 @@ struct rcl_context_impl_t; */ typedef struct rcl_context_t { +#ifdef RCL_COMMAND_LINE_ENABLED /// Global arguments for all nodes which share this context. /** Typically generated by the parsing of argc/argv in `rcl_init()`. */ rcl_arguments_t global_arguments; +#endif // RCL_COMMAND_LINE_ENABLED /// Implementation specific pointer. struct rcl_context_impl_t * impl; diff --git a/rcl/include/rcl/node.h b/rcl/include/rcl/node.h index 0d5de91dfc..9f0fcd4bf3 100644 --- a/rcl/include/rcl/node.h +++ b/rcl/include/rcl/node.h @@ -23,7 +23,9 @@ extern "C" #include #include "rcl/allocator.h" +#ifdef RCL_COMMAND_LINE_ENABLED #include "rcl/arguments.h" +#endif // RCL_COMMAND_LINE_ENABLED #include "rcl/context.h" #include "rcl/macros.h" #include "rcl/node_options.h" diff --git a/rcl/include/rcl/node_options.h b/rcl/include/rcl/node_options.h index c9c0edfb08..9238c0317c 100644 --- a/rcl/include/rcl/node_options.h +++ b/rcl/include/rcl/node_options.h @@ -21,7 +21,10 @@ extern "C" #endif #include "rcl/allocator.h" +#ifdef RCL_COMMAND_LINE_ENABLED #include "rcl/arguments.h" +#endif // RCL_COMMAND_LINE_ENABLED +#include "rcl/macros.h" #include "rcl/domain_id.h" @@ -57,8 +60,10 @@ typedef struct rcl_node_options_t /// If false then only use arguments in this struct, otherwise use global arguments also. bool use_global_arguments; +#ifdef RCL_COMMAND_LINE_ENABLED /// Command line arguments that apply only to this node. rcl_arguments_t arguments; +#endif // RCL_COMMAND_LINE_ENABLED /// Flag to enable rosout for this node bool enable_rosout; diff --git a/rcl/src/rcl/client.c b/rcl/src/rcl/client.c index 8752363908..10b88bf117 100644 --- a/rcl/src/rcl/client.c +++ b/rcl/src/rcl/client.c @@ -24,7 +24,9 @@ extern "C" #include "rcl/error_handling.h" #include "rcl/expand_topic_name.h" +#ifdef RCL_COMMAND_LINE_ENABLED #include "rcl/remap.h" +#endif // RCL_COMMAND_LINE_ENABLED #include "rcutils/logging_macros.h" #include "rcutils/macros.h" #include "rcutils/stdatomic_helper.h" @@ -131,6 +133,7 @@ rcl_client_init( ret = RCL_RET_ERROR; goto cleanup; } +#ifdef RCL_COMMAND_LINE_ENABLED rcl_arguments_t * global_args = NULL; if (node_options->use_global_arguments) { global_args = &(node->context->global_arguments); @@ -144,6 +147,10 @@ rcl_client_init( remapped_service_name = expanded_service_name; expanded_service_name = NULL; } +#else + remapped_service_name = (char *)allocator->allocate(strlen(expanded_service_name) + 1, allocator->state); + memcpy(remapped_service_name, expanded_service_name, strlen(expanded_service_name) + 1); +#endif // RCL_COMMAND_LINE_ENABLED // Validate the expanded service name. int validation_result; diff --git a/rcl/src/rcl/context.c b/rcl/src/rcl/context.c index 3eb40b2397..9db7c90bd5 100644 --- a/rcl/src/rcl/context.c +++ b/rcl/src/rcl/context.c @@ -33,7 +33,9 @@ rcl_get_zero_initialized_context(void) .instance_id_storage = {0}, }; // this is not constexpr so it cannot be in the struct initialization +#ifdef RCL_COMMAND_LINE_ENABLED context.global_arguments = rcl_get_zero_initialized_arguments(); +#endif // RCL_COMMAND_LINE_ENABLED // ensure assumption about static storage static_assert( sizeof(context.instance_id_storage) >= sizeof(atomic_uint_least64_t), @@ -101,6 +103,7 @@ __cleanup_context(rcl_context_t * context) // reset the instance id to 0 to indicate "invalid" (should already be 0, but this is defensive) rcutils_atomic_store((atomic_uint_least64_t *)(&context->instance_id_storage), 0); +#ifdef RCL_COMMAND_LINE_ENABLED // clean up global_arguments if initialized if (NULL != context->global_arguments.impl) { ret = rcl_arguments_fini(&(context->global_arguments)); @@ -113,6 +116,7 @@ __cleanup_context(rcl_context_t * context) rcl_reset_error(); } } +#endif // RCL_COMMAND_LINE_ENABLED // if impl is null, nothing else can be cleaned up if (NULL != context->impl) { diff --git a/rcl/src/rcl/event.c b/rcl/src/rcl/event.c index c441019f33..76ea630c57 100644 --- a/rcl/src/rcl/event.c +++ b/rcl/src/rcl/event.c @@ -23,7 +23,9 @@ extern "C" #include "rcl/error_handling.h" #include "rcl/expand_topic_name.h" +#ifdef RCL_COMMAND_LINE_ENABLED #include "rcl/remap.h" +#endif // RCL_COMMAND_LINE_ENABLED #include "rcutils/logging_macros.h" #include "rmw/error_handling.h" #include "rmw/validate_full_topic_name.h" diff --git a/rcl/src/rcl/init.c b/rcl/src/rcl/init.c index 0025bdda81..d3f4c8d349 100644 --- a/rcl/src/rcl/init.c +++ b/rcl/src/rcl/init.c @@ -27,15 +27,21 @@ extern "C" #include "tracetools/tracetools.h" +#ifdef RCL_COMMAND_LINE_ENABLED #include "rcl/arguments.h" +#endif // RCL_COMMAND_LINE_ENABLED #include "rcl/domain_id.h" #include "rcl/error_handling.h" #include "rcl/localhost.h" +#ifdef RCL_LOGGING_ENABLED #include "rcl/logging.h" +#endif // RCL_LOGGING_ENABLED #include "rcl/security.h" #include "rcl/validate_enclave_name.h" +#ifdef RCL_COMMAND_LINE_ENABLED #include "./arguments_impl.h" +#endif // RCL_COMMAND_LINE_ENABLED #include "./common.h" #include "./context_impl.h" #include "./init_options_impl.h" @@ -80,8 +86,10 @@ rcl_init( return RCL_RET_ALREADY_INIT; } +#ifdef RCL_COMMAND_LINE_ENABLED // Zero initialize global arguments. context->global_arguments = rcl_get_zero_initialized_arguments(); +#endif // RCL_COMMAND_LINE_ENABLED // Setup impl for context. // use zero_allocate so the cleanup function will not try to clean up uninitialized parts later @@ -123,6 +131,7 @@ rcl_init( } } +#ifdef RCL_COMMAND_LINE_ENABLED // Parse the ROS specific arguments. ret = rcl_parse_arguments(argc, argv, allocator, &context->global_arguments); if (RCL_RET_OK != ret) { @@ -130,6 +139,7 @@ rcl_init( RCUTILS_LOG_ERROR_NAMED(ROS_PACKAGE_NAME, "Failed to parse global arguments"); goto fail; } +#endif // RCL_COMMAND_LINE_ENABLED // Set the instance id. uint64_t next_instance_id = rcutils_atomic_fetch_add_uint64_t(&__rcl_next_unique_id, 1); @@ -167,6 +177,7 @@ rcl_init( } } +#ifdef RCL_COMMAND_LINE_ENABLED if (context->global_arguments.impl->enclave) { context->impl->init_options.impl->rmw_init_options.enclave = rcutils_strdup( context->global_arguments.impl->enclave, @@ -181,6 +192,7 @@ rcl_init( fail_ret = RCL_RET_BAD_ALLOC; goto fail; } +#endif RCL_COMMAND_LINE_ENABLED int validation_result; size_t invalid_index; diff --git a/rcl/src/rcl/logging.c b/rcl/src/rcl/logging.c index 381a852391..1a5f28a32e 100644 --- a/rcl/src/rcl/logging.c +++ b/rcl/src/rcl/logging.c @@ -66,9 +66,13 @@ rcl_logging_configure_with_output_handler( g_logging_allocator = *allocator; int default_level = global_args->impl->log_level; const char * config_file = global_args->impl->external_log_config_file; - g_rcl_logging_stdout_enabled = !global_args->impl->log_stdout_disabled; - g_rcl_logging_rosout_enabled = !global_args->impl->log_rosout_disabled; - g_rcl_logging_ext_lib_enabled = !global_args->impl->log_ext_lib_disabled; + bool global_disable = false; + #ifdef RCUTILS_NO_LOGGING + global_disable = true; + #endif + g_rcl_logging_stdout_enabled = !global_args->impl->log_stdout_disabled && !global_disable; + g_rcl_logging_rosout_enabled = !global_args->impl->log_rosout_disabled && !global_disable; + g_rcl_logging_ext_lib_enabled = !global_args->impl->log_ext_lib_disabled && !global_disable; rcl_ret_t status = RCL_RET_OK; g_rcl_logging_num_out_handlers = 0; diff --git a/rcl/src/rcl/node.c b/rcl/src/rcl/node.c index 42ec35d9fe..b3c5a49124 100644 --- a/rcl/src/rcl/node.c +++ b/rcl/src/rcl/node.c @@ -24,14 +24,20 @@ extern "C" #include #include +#ifdef RCL_COMMAND_LINE_ENABLED #include "rcl/arguments.h" +#endif // RCL_COMMAND_LINE_ENABLED #include "rcl/error_handling.h" #include "rcl/domain_id.h" #include "rcl/localhost.h" +#ifdef RCL_LOGGING_ENABLED #include "rcl/logging.h" #include "rcl/logging_rosout.h" +#endif // RCL_LOGGING_ENABLED #include "rcl/rcl.h" +#ifdef RCL_COMMAND_LINE_ENABLED #include "rcl/remap.h" +#endif // RCL_COMMAND_LINE_ENABLED #include "rcl/security.h" #include "rcutils/filesystem.h" @@ -215,6 +221,7 @@ rcl_node_init( goto fail; } +#ifdef RCL_COMMAND_LINE_ENABLED // Remap the node name and namespace if remap rules are given rcl_arguments_t * global_args = NULL; if (node->impl->options.use_global_arguments) { @@ -241,6 +248,7 @@ rcl_node_init( should_free_local_namespace_ = true; local_namespace_ = remapped_namespace; } +#endif // RCL_COMMAND_LINE_ENABLED // compute fully qualfied name of the node. if ('/' == local_namespace_[strlen(local_namespace_) - 1]) { @@ -297,6 +305,7 @@ rcl_node_init( // error message already set goto fail; } +#ifdef RCL_LOGGING_ENABLED // The initialization for the rosout publisher requires the node to be in initialized to a point // that it can create new topic publishers if (rcl_logging_rosout_enabled() && node->impl->options.enable_rosout) { @@ -306,6 +315,7 @@ rcl_node_init( goto fail; } } +#endif // RCL_LOGGING_ENABLED RCUTILS_LOG_DEBUG_NAMED(ROS_PACKAGE_NAME, "Node initialized"); ret = RCL_RET_OK; TRACEPOINT( @@ -317,6 +327,7 @@ rcl_node_init( goto cleanup; fail: if (node->impl) { +#ifdef RCL_LOGGING_ENABLED if (rcl_logging_rosout_enabled() && node->impl->options.enable_rosout && node->impl->logger_name) @@ -327,6 +338,7 @@ rcl_node_init( ROS_PACKAGE_NAME, "Failed to fini publisher for node: %i", ret); allocator->deallocate((char *)node->impl->logger_name, allocator->state); } +#endif // RCL_LOGGING_ENABLED if (node->impl->fq_name) { allocator->deallocate((char *)node->impl->fq_name, allocator->state); } @@ -349,6 +361,8 @@ rcl_node_init( } allocator->deallocate(node->impl->graph_guard_condition, allocator->state); } + +#ifdef RCL_COMMAND_LINE_ENABLED if (NULL != node->impl->options.arguments.impl) { ret = rcl_arguments_fini(&(node->impl->options.arguments)); if (ret != RCL_RET_OK) { @@ -358,6 +372,7 @@ rcl_node_init( ); } } +#endif // RCL_COMMAND_LINE_ENABLED allocator->deallocate(node->impl, allocator->state); } *node = rcl_get_zero_initialized_node(); @@ -387,6 +402,7 @@ rcl_node_fini(rcl_node_t * node) rcl_allocator_t allocator = node->impl->options.allocator; rcl_ret_t result = RCL_RET_OK; rcl_ret_t rcl_ret = RCL_RET_OK; +#ifdef RCL_LOGGING_ENABLED if (rcl_logging_rosout_enabled() && node->impl->options.enable_rosout) { rcl_ret = rcl_logging_rosout_fini_publisher_for_node(node); if (rcl_ret != RCL_RET_OK && rcl_ret != RCL_RET_NOT_INIT) { @@ -394,6 +410,7 @@ rcl_node_fini(rcl_node_t * node) result = RCL_RET_ERROR; } } +#endif // RCL_LOGGING_ENABLED rmw_ret_t rmw_ret = rmw_destroy_node(node->impl->rmw_node_handle); if (rmw_ret != RMW_RET_OK) { RCL_SET_ERROR_MSG(rmw_get_error_string().str); @@ -408,12 +425,14 @@ rcl_node_fini(rcl_node_t * node) // assuming that allocate and deallocate are ok since they are checked in init allocator.deallocate((char *)node->impl->logger_name, allocator.state); allocator.deallocate((char *)node->impl->fq_name, allocator.state); +#ifdef RCL_COMMAND_LINE_ENABLED if (NULL != node->impl->options.arguments.impl) { rcl_ret_t ret = rcl_arguments_fini(&(node->impl->options.arguments)); if (ret != RCL_RET_OK) { return ret; } } +#endif // RCL_COMMAND_LINE_ENABLED allocator.deallocate(node->impl, allocator.state); node->impl = NULL; RCUTILS_LOG_DEBUG_NAMED(ROS_PACKAGE_NAME, "Node finalized"); diff --git a/rcl/src/rcl/node_options.c b/rcl/src/rcl/node_options.c index cb6d47f215..b4bdaa497d 100644 --- a/rcl/src/rcl/node_options.c +++ b/rcl/src/rcl/node_options.c @@ -21,10 +21,14 @@ extern "C" #include "rcl/node_options.h" +#ifdef RCL_COMMAND_LINE_ENABLED #include "rcl/arguments.h" +#endif // RCL_COMMAND_LINE_ENABLED #include "rcl/domain_id.h" #include "rcl/error_handling.h" +#ifdef RCL_LOGGING_ENABLED #include "rcl/logging_rosout.h" +#endif // RCL_LOGGING_ENABLED rcl_node_options_t rcl_node_get_default_options() @@ -37,7 +41,9 @@ rcl_node_get_default_options() }; // Must set the allocator after because it is not a compile time constant. default_options.allocator = rcl_get_default_allocator(); +#ifdef RCL_COMMAND_LINE_ENABLED default_options.arguments = rcl_get_zero_initialized_arguments(); +#endif // RCL_COMMAND_LINE_ENABLED return default_options; } @@ -62,9 +68,11 @@ rcl_node_options_copy( options_out->allocator = options->allocator; options_out->use_global_arguments = options->use_global_arguments; options_out->enable_rosout = options->enable_rosout; +#ifdef RCL_COMMAND_LINE_ENABLED if (NULL != options->arguments.impl) { return rcl_arguments_copy(&(options->arguments), &(options_out->arguments)); } +#endif // RCL_COMMAND_LINE_ENABLED return RCL_RET_OK; } @@ -76,6 +84,7 @@ rcl_node_options_fini( rcl_allocator_t allocator = options->allocator; RCL_CHECK_ALLOCATOR(&allocator, return RCL_RET_INVALID_ARGUMENT); +#ifdef RCL_COMMAND_LINE_ENABLED if (options->arguments.impl) { rcl_ret_t ret = rcl_arguments_fini(&options->arguments); if (RCL_RET_OK != ret) { @@ -83,6 +92,7 @@ rcl_node_options_fini( return ret; } } +#endif // RCL_COMMAND_LINE_ENABLED return RCL_RET_OK; } diff --git a/rcl/src/rcl/publisher.c b/rcl/src/rcl/publisher.c index 59da94d945..1fbecd9e15 100644 --- a/rcl/src/rcl/publisher.c +++ b/rcl/src/rcl/publisher.c @@ -25,7 +25,9 @@ extern "C" #include "rcl/allocator.h" #include "rcl/error_handling.h" #include "rcl/expand_topic_name.h" +#ifdef RCL_COMMAND_LINE_ENABLED #include "rcl/remap.h" +#endif // RCL_COMMAND_LINE_ENABLED #include "rcutils/logging_macros.h" #include "rcutils/macros.h" #include "rmw/error_handling.h" @@ -135,6 +137,7 @@ rcl_publisher_init( ret = RCL_RET_ERROR; goto cleanup; } +#ifdef RCL_COMMAND_LINE_ENABLED rcl_arguments_t * global_args = NULL; if (node_options->use_global_arguments) { global_args = &(node->context->global_arguments); @@ -148,6 +151,10 @@ rcl_publisher_init( remapped_topic_name = expanded_topic_name; expanded_topic_name = NULL; } +#else + remapped_topic_name = (char *)allocator->allocate(strlen(expanded_topic_name) + 1, allocator->state); + memcpy(remapped_topic_name, expanded_topic_name, strlen(expanded_topic_name) + 1); +#endif // RCL_COMMAND_LINE_ENABLED // Validate the expanded topic name. int validation_result; diff --git a/rcl/src/rcl/service.c b/rcl/src/rcl/service.c index 196e4aab34..33a5ccdcb7 100644 --- a/rcl/src/rcl/service.c +++ b/rcl/src/rcl/service.c @@ -24,7 +24,9 @@ extern "C" #include "rcl/error_handling.h" #include "rcl/expand_topic_name.h" +#ifdef RCL_COMMAND_LINE_ENABLED #include "rcl/remap.h" +#endif // RCL_COMMAND_LINE_ENABLED #include "rcutils/logging_macros.h" #include "rcutils/macros.h" #include "rmw/error_handling.h" @@ -135,6 +137,7 @@ rcl_service_init( ret = RCL_RET_ERROR; goto cleanup; } +#ifdef RCL_COMMAND_LINE_ENABLED rcl_arguments_t * global_args = NULL; if (node_options->use_global_arguments) { global_args = &(node->context->global_arguments); @@ -148,6 +151,10 @@ rcl_service_init( remapped_service_name = expanded_service_name; expanded_service_name = NULL; } +#else + remapped_service_name = (char *)allocator->allocate(strlen(expanded_service_name) + 1, allocator->state); + memcpy(remapped_service_name, expanded_service_name, strlen(expanded_service_name) + 1); +#endif // RCL_COMMAND_LINE_ENABLED // Validate the expanded service name. int validation_result; diff --git a/rcl/src/rcl/subscription.c b/rcl/src/rcl/subscription.c index f3628b828f..0eb2d92c23 100644 --- a/rcl/src/rcl/subscription.c +++ b/rcl/src/rcl/subscription.c @@ -23,7 +23,9 @@ extern "C" #include "rcl/error_handling.h" #include "rcl/expand_topic_name.h" +#ifdef RCL_COMMAND_LINE_ENABLED #include "rcl/remap.h" +#endif // RCL_COMMAND_LINE_ENABLED #include "rcutils/logging_macros.h" #include "rmw/error_handling.h" #include "rmw/validate_full_topic_name.h" @@ -123,6 +125,7 @@ rcl_subscription_init( ret = RCL_RET_ERROR; goto cleanup; } +#ifdef RCL_COMMAND_LINE_ENABLED rcl_arguments_t * global_args = NULL; if (node_options->use_global_arguments) { global_args = &(node->context->global_arguments); @@ -136,6 +139,10 @@ rcl_subscription_init( remapped_topic_name = expanded_topic_name; expanded_topic_name = NULL; } +#else + remapped_topic_name = (char *)allocator->allocate(strlen(expanded_topic_name) + 1, allocator->state); + memcpy(remapped_topic_name, expanded_topic_name, strlen(expanded_topic_name) + 1); +#endif // RCL_COMMAND_LINE_ENABLED // Validate the expanded topic name. int validation_result;