Skip to content

dbruggner/rules_ros2

 
 

Repository files navigation

CI

Bazel rules for ROS2

This repo provides functionality to build and use ROS2 with Bazel.

Prerequisites

You will need to install Bazel, see here. Besides Bazel, you will need a C++ compiler and a Python 3 interpreter.

And no, you don't have to install any ROS2 packages via apt.

The code is developed and tested on Ubuntu 20.04 with Python 3.8.

What works?

Available features:

  • Building of C++ and Python nodes (rclcpp and rclpy work).
  • C/C++/Python code generation for interfaces (messages, services and actions).
  • Defining ROS2 deployments with ros2_launch Bazel macro.
  • Defining ROS2 tests with ros2_test Bazel macro.
  • Only CycloneDDS middleware can be used at the moment.
    • Zero copy transport via shared memory backend (iceoryx) for CycloneDDS.
  • Utilities:
    • ros2_bag for handling rosbags
    • ros2_param for handling parameters
    • ros2_topic for handling topics

ROS2 packages are by default locked to versions from release-humble-20230127.

NOTE: Unlike ROS1 genmsg which refuses to generate code if the deps between interface targets are not set correctly, code generation for ROS2 seems to not care about this. If the deps are not correctly set, you'll only see failures during compilation of the generated code. It could be that I missed setting some flags to the code generation of ROS2 interfaces.

Please take a look at the examples folder to get started.

Alternatives

For alternative approaches, see:

About

Build ROS2 with Bazel

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Starlark 69.8%
  • Python 17.4%
  • C++ 9.3%
  • Smarty 3.5%