ROS 2 rclcpp + rcl - rolling  rolling-a919a6e5
ROS 2 C++ Client Library with ROS Client Library
arguments.h
Go to the documentation of this file.
1 // Copyright 2018 Open Source Robotics Foundation, Inc.
2 //
3 // Licensed under the Apache License, Version 2.0 (the "License");
4 // you may not use this file except in compliance with the License.
5 // You may obtain a copy of the License at
6 //
7 // http://www.apache.org/licenses/LICENSE-2.0
8 //
9 // Unless required by applicable law or agreed to in writing, software
10 // distributed under the License is distributed on an "AS IS" BASIS,
11 // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12 // See the License for the specific language governing permissions and
13 // limitations under the License.
14 
16 
17 #ifndef RCL__ARGUMENTS_H_
18 #define RCL__ARGUMENTS_H_
19 
20 #include "rcl/allocator.h"
21 #include "rcl/log_level.h"
22 #include "rcl/macros.h"
23 #include "rcl/types.h"
24 #include "rcl/visibility_control.h"
25 #include "rcl_yaml_param_parser/types.h"
26 
27 #ifdef __cplusplus
28 extern "C"
29 {
30 #endif
31 
33 
35 typedef struct rcl_arguments_s
36 {
40 
42 #define RCL_ROS_ARGS_FLAG "--ros-args"
43 
45 #define RCL_ROS_ARGS_EXPLICIT_END_TOKEN "--"
46 
48 #define RCL_PARAM_FLAG "--param"
49 
51 #define RCL_SHORT_PARAM_FLAG "-p"
52 
54 #define RCL_PARAM_FILE_FLAG "--params-file"
55 
57 #define RCL_REMAP_FLAG "--remap"
58 
60 #define RCL_SHORT_REMAP_FLAG "-r"
61 
63 #define RCL_ENCLAVE_FLAG "--enclave"
64 
66 #define RCL_SHORT_ENCLAVE_FLAG "-e"
67 
69 #define RCL_LOG_LEVEL_FLAG "--log-level"
70 
72 #define RCL_EXTERNAL_LOG_FILE_NAME_PREFIX "--log-file-name"
73 
75 #define RCL_EXTERNAL_LOG_CONFIG_FLAG "--log-config-file"
76 
79 #define RCL_LOG_STDOUT_FLAG_SUFFIX "stdout-logs"
80 
83 #define RCL_LOG_ROSOUT_FLAG_SUFFIX "rosout-logs"
84 
87 #define RCL_LOG_EXT_LIB_FLAG_SUFFIX "external-lib-logs"
88 
90 RCL_PUBLIC
91 RCL_WARN_UNUSED
94 
96 
152 RCL_PUBLIC
153 RCL_WARN_UNUSED
154 rcl_ret_t
156  int argc,
157  const char * const * argv,
158  rcl_allocator_t allocator,
159  rcl_arguments_t * args_output);
160 
162 
175 RCL_PUBLIC
176 RCL_WARN_UNUSED
177 int
179  const rcl_arguments_t * args);
180 
182 
206 RCL_PUBLIC
207 RCL_WARN_UNUSED
208 rcl_ret_t
210  const rcl_arguments_t * args,
211  rcl_allocator_t allocator,
212  int ** output_unparsed_indices);
213 
215 
228 RCL_PUBLIC
229 RCL_WARN_UNUSED
230 int
232  const rcl_arguments_t * args);
233 
235 
258 RCL_PUBLIC
259 RCL_WARN_UNUSED
260 rcl_ret_t
262  const rcl_arguments_t * args,
263  rcl_allocator_t allocator,
264  int ** output_unparsed_ros_indices);
265 
267 
280 RCL_PUBLIC
281 RCL_WARN_UNUSED
282 int
284  const rcl_arguments_t * args);
285 
286 
288 
307 RCL_PUBLIC
308 RCL_WARN_UNUSED
309 rcl_ret_t
311  const rcl_arguments_t * arguments,
312  rcl_allocator_t allocator,
313  char *** parameter_files);
314 
316 
337 RCL_PUBLIC
338 RCL_WARN_UNUSED
339 rcl_ret_t
341  const rcl_arguments_t * arguments,
342  rcl_params_t ** parameter_overrides);
343 
345 
371 RCL_PUBLIC
372 RCL_WARN_UNUSED
373 rcl_ret_t
375  const char * const * argv,
376  const rcl_arguments_t * args,
377  rcl_allocator_t allocator,
378  int * nonros_argc,
379  const char *** nonros_argv);
380 
382 
400 RCL_PUBLIC
401 RCL_WARN_UNUSED
402 rcl_ret_t
404  const rcl_arguments_t * arguments,
405  rcl_log_levels_t * log_levels);
406 
408 
425 RCL_PUBLIC
426 RCL_WARN_UNUSED
427 rcl_ret_t
429  const rcl_arguments_t * args,
430  rcl_arguments_t * args_out);
431 
433 
447 RCL_PUBLIC
448 RCL_WARN_UNUSED
449 rcl_ret_t
451  rcl_arguments_t * args);
452 
453 #ifdef __cplusplus
454 }
455 #endif
456 
457 #endif // RCL__ARGUMENTS_H_
rcutils_allocator_t rcl_allocator_t
Encapsulation of an allocator.
Definition: allocator.h:31
RCL_PUBLIC RCL_WARN_UNUSED rcl_ret_t rcl_arguments_get_unparsed_ros(const rcl_arguments_t *args, rcl_allocator_t allocator, int **output_unparsed_ros_indices)
Return a list of indices to unknown ROS specific arguments that were left unparsed.
struct rcl_arguments_s rcl_arguments_t
Hold output of parsing command line arguments.
RCL_PUBLIC RCL_WARN_UNUSED int rcl_arguments_get_count_unparsed(const rcl_arguments_t *args)
Return the number of arguments that were not ROS specific arguments.
RCL_PUBLIC RCL_WARN_UNUSED rcl_ret_t rcl_arguments_get_param_files(const rcl_arguments_t *arguments, rcl_allocator_t allocator, char ***parameter_files)
Return a list of yaml parameter file paths specified on the command line.
RCL_PUBLIC RCL_WARN_UNUSED rcl_ret_t rcl_arguments_copy(const rcl_arguments_t *args, rcl_arguments_t *args_out)
Copy one arguments structure into another.
RCL_PUBLIC RCL_WARN_UNUSED rcl_ret_t rcl_arguments_get_param_overrides(const rcl_arguments_t *arguments, rcl_params_t **parameter_overrides)
Return all parameter overrides parsed from the command line.
RCL_PUBLIC RCL_WARN_UNUSED rcl_ret_t rcl_arguments_get_log_levels(const rcl_arguments_t *arguments, rcl_log_levels_t *log_levels)
Return log levels parsed from the command line.
RCL_PUBLIC RCL_WARN_UNUSED rcl_ret_t rcl_parse_arguments(int argc, const char *const *argv, rcl_allocator_t allocator, rcl_arguments_t *args_output)
Parse command line arguments into a structure usable by code.
RCL_PUBLIC RCL_WARN_UNUSED rcl_ret_t rcl_arguments_fini(rcl_arguments_t *args)
Reclaim resources held inside rcl_arguments_t structure.
RCL_PUBLIC RCL_WARN_UNUSED int rcl_arguments_get_param_files_count(const rcl_arguments_t *args)
Return the number of parameter yaml files given in the arguments.
RCL_PUBLIC RCL_WARN_UNUSED rcl_ret_t rcl_arguments_get_unparsed(const rcl_arguments_t *args, rcl_allocator_t allocator, int **output_unparsed_indices)
Return a list of indices to non ROS specific arguments.
RCL_PUBLIC RCL_WARN_UNUSED int rcl_arguments_get_count_unparsed_ros(const rcl_arguments_t *args)
Return the number of ROS specific arguments that were not successfully parsed.
RCL_PUBLIC RCL_WARN_UNUSED rcl_arguments_t rcl_get_zero_initialized_arguments(void)
Return a rcl_arguments_t struct with members initialized to NULL.
RCL_PUBLIC RCL_WARN_UNUSED rcl_ret_t rcl_remove_ros_arguments(const char *const *argv, const rcl_arguments_t *args, rcl_allocator_t allocator, int *nonros_argc, const char ***nonros_argv)
Return a list of arguments with ROS-specific arguments removed.
Hold output of parsing command line arguments.
Definition: arguments.h:36
rcl_arguments_impl_t * impl
Private implementation pointer.
Definition: arguments.h:38
Hold default logger level and other logger setting.
Definition: log_level.h:44
rmw_ret_t rcl_ret_t
The type that holds an rcl return code.
Definition: types.h:24