rosidl_cli.command.helpers module
- rosidl_cli.command.helpers.dependencies_from_include_paths(include_paths: List[str]) List[str]
Collect dependencies’ ROS interface definition files from include paths.
Interface definition file paths from dependencies are absolute paths prefixed by the name of package they belong to followed by a colon ‘:’.
- rosidl_cli.command.helpers.generate_visibility_control_file(*, package_name: str, template_path: str, output_path: str) None
Generate a visibility control file from a template.
- Parameters:
package_name – Name of the ROS package for which to generate the file.
template_path – Path to template visibility control file. May contain @PROJECT_NAME@ and @PROJECT_NAME_UPPER@ placeholders, to be substituted by the package name, accordingly.
output_path – Path to visibility control file after interpolation.
- rosidl_cli.command.helpers.idl_tuples_from_interface_files(interface_files: List[str]) List[str]
Express ROS interface definition file paths as IDL tuples.
An IDL tuple is a relative path prefixed by an absolute path against which to resolve it followed by a colon ‘:’. This function then applies the same logic as interface_path_as_tuple.
- rosidl_cli.command.helpers.interface_path_as_tuple(path: str) Tuple[Path, Path]
Express interface definition file path as an (absolute prefix, relative path) tuple.
An interface definition file path is a relative path, optionally prefixed by a path against which to resolve the former followed by a colon ‘:’. Thus, this function applies following logic:
If a given path follows this pattern, it is split at the colon ‘:’
- If a given path is prefixed by a relative path, it is resolved
relative to the current working directory.
- If a given path has no prefix, the current working directory is
used as prefix.
- rosidl_cli.command.helpers.legacy_generator_arguments_file(*, package_name: str, interface_files: List[str], include_paths: List[str], templates_path: str, output_path: str) Generator[str, None, None]
Generate a temporary rosidl generator arguments file.
- Parameters:
package_name – Name of the ROS package for which to generate code
interface_files – Relative paths to ROS interface definition files, optionally prefixed by another absolute or relative path followed by a colon ‘:’. The former relative paths will be used as a prototype to namespace generated code (if applicable).
include_paths – Paths where ROS package dependencies’ interface definition files may be found
templates_path – Path to the templates directory for the generator script this arguments are for
output_path – Path to the output directory for generated code
- rosidl_cli.command.helpers.package_name_from_interface_file_path(path: Path) str
Derive ROS package name from a ROS interface definition file path.
This function assumes ROS interface definition files follow the typical
rosidl
install space layout i.e. ‘package_name/subfolder/interface.idl’.