rcl  master
C API providing common ROS client library functionality.
remap.h
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 
15 #ifndef RCL__REMAP_H_
16 #define RCL__REMAP_H_
17 
18 #include "rcl/allocator.h"
19 #include "rcl/arguments.h"
20 #include "rcl/macros.h"
21 #include "rcl/types.h"
22 #include "rcl/visibility_control.h"
23 
24 #ifdef __cplusplus
25 extern "C"
26 {
27 #endif
28 
29 struct rcl_remap_impl_t;
30 
32 typedef struct rcl_remap_t
33 {
35  struct rcl_remap_impl_t * impl;
36 } rcl_remap_t;
37 
39 RCL_PUBLIC
40 RCL_WARN_UNUSED
42 rcl_get_zero_initialized_remap(void);
43 
44 // TODO(sloretz) add documentation about rostopic:// when it is supported
46 
107 RCL_PUBLIC
108 RCL_WARN_UNUSED
109 rcl_ret_t
110 rcl_remap_topic_name(
111  const rcl_arguments_t * local_arguments,
112  const rcl_arguments_t * global_arguments,
113  const char * topic_name,
114  const char * node_name,
115  const char * node_namespace,
116  rcl_allocator_t allocator,
117  char ** output_name);
118 
119 // TODO(sloretz) add documentation about rosservice:// when it is supported
121 
152 RCL_PUBLIC
153 RCL_WARN_UNUSED
154 rcl_ret_t
155 rcl_remap_service_name(
156  const rcl_arguments_t * local_arguments,
157  const rcl_arguments_t * global_arguments,
158  const char * service_name,
159  const char * node_name,
160  const char * node_namespace,
161  rcl_allocator_t allocator,
162  char ** output_name);
163 
165 
199 RCL_PUBLIC
200 RCL_WARN_UNUSED
201 rcl_ret_t
202 rcl_remap_node_name(
203  const rcl_arguments_t * local_arguments,
204  const rcl_arguments_t * global_arguments,
205  const char * node_name,
206  rcl_allocator_t allocator,
207  char ** output_name);
208 
210 
240 RCL_PUBLIC
241 RCL_WARN_UNUSED
242 rcl_ret_t
243 rcl_remap_node_namespace(
244  const rcl_arguments_t * local_arguments,
245  const rcl_arguments_t * global_arguments,
246  const char * node_name,
247  rcl_allocator_t allocator,
248  char ** output_namespace);
249 
251 
265 RCL_PUBLIC
266 RCL_WARN_UNUSED
267 rcl_ret_t
268 rcl_remap_fini(
269  rcl_remap_t * remap);
270 
271 #ifdef __cplusplus
272 }
273 #endif
274 
275 #endif // RCL__REMAP_H_
rcl_arguments_t
Hold output of parsing command line arguments.
Definition: arguments.h:32
rcl_remap_t
Hold remapping rules.
Definition: remap.h:32
rcutils_allocator_t
rcl_remap_t::impl
struct rcl_remap_impl_t * impl
Private implementation pointer.
Definition: remap.h:35