- Sponsor
-
Notifications
You must be signed in to change notification settings - Fork 98
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Create xacro Bazel module #350
base: ros2
Are you sure you want to change the base?
Conversation
Signed-off-by: Michael Carroll <[email protected]>
@rhaschke I talked with @codebot about this addition, and he seemed generally inclined to take it. For context, we use the bazel build system and xacro together currently, but would like to land it in the bazel central registry (https://github.com/bazelbuild/bazel-central-registry) so that people can quickly add xacro to their bazel projects. This is also currently being done in drake (https://github.com/RobotLocomotion/drake/tree/master/tools/workspace/ros_xacro_internal), so maybe an opportunity to condense to a single set of rules (@jwnimmer-tri) |
Note that this is still wip as I haven't gotten the tests running under bazel yet, but wanted to start the conversation. |
Thanks for the ping! Yes, if xacro were published in the bazel central registry then Drake would probably switch to using that module definition (assuming it works equally well to our current solution). If I can help out (e.g., if there are questions about how bazel works), just let me know. |
I never used bazel before. Are there plans to bazalize a large set of ROS2 packages or is this only for xacro? |
Signed-off-by: Michael Carroll <[email protected]>
I don't have any plans to do more than There is recurring interest in the broader ROS community for bazel and some community supported repos (https://github.com/mvukov/rules_ros, https://github.com/ApexAI/rules_ros) as well as Bazel users in adjacent projects like Drake and Gazebo. I'm happy to find a reviewer who is familiar and I will add CI as well. |
Signed-off-by: Michael Carroll <[email protected]>
Signed-off-by: Michael Carroll <[email protected]>
Signed-off-by: Michael Carroll <[email protected]>
Following up to add CI: #351 |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Can we avoid cluttering the root folder with all those bazel files?
Is it possible to move them into a subfolder?
Signed-off-by: Michael Carroll <[email protected]>
Signed-off-by: Michael Carroll <[email protected]>
Signed-off-by: Michael Carroll <[email protected]>
I moved all of the ones possible into a subdirectory. MODULE.bazel and BUILD.bazel files have to appear at the root, much like a CMakeLists.txt, so they aren't possible to move. The .bazelversion file helps with automatic version tooling like https://github.com/bazelbuild/bazelisk and the CI workflow that I'm using here. It must also appear in the root, but since it's a dotfile, I'm hoping is less of an inconvenience? |
Signed-off-by: Michael Carroll <[email protected]>
1b815f6
to
ad38049
Compare
Signed-off-by: Michael Carroll <[email protected]>
Signed-off-by: Michael Carroll <[email protected]>
Signed-off-by: Michael Carroll <[email protected]>
Signed-off-by: Michael Carroll <[email protected]>
Signed-off-by: Michael Carroll <[email protected]>
Signed-off-by: Michael Carroll <[email protected]>
@jwnimmer-tri I think I'm pretty happy with the rules and tests that I have created here, mind to take a look from a bazel perspective? I have also attempted to replace the drake impl here: RobotLocomotion/drake#22341 |
* Remove src glob * Add provides * Trim extension based on string length * Directly expose xacro_file rule Signed-off-by: Michael Carroll <[email protected]>
Co-authored-by: Marcel <[email protected]>
Signed-off-by: Michael Carroll <[email protected]>
Signed-off-by: Michael Carroll <[email protected]>
Signed-off-by: Michael Carroll <[email protected]>
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I don't yet understand the purpose of open_bazel
. Is that to replace $(find pkg)
with a search in the XACRO_INPUTS
environment variable? If so, why not make it more explicit and introduce a new find directive, e.g. $(find bazel)
.
In any case, this feature needs to be better documented.
Since bazel does all builds in a hermetically-sealed workspace (essentially chroot), you can't refer to the files with their absolute filesystem paths. Instead, you have to pre-declare in the build the data files you intend to use and then refer to them via their bazel paths (prefixed with I wouldn't be opposed to adding a bazel-specific directive, though. |
Does the absolute path of the input files end up baked into the output? If not, we could make the invoking rule copy or symlink the inputs into a single directory and invoke (I think in the gRPC logic https://github.com/grpc/grpc/pull/27275/files we're doing something ~ similar to handle x-repo Python codegen.) |
No, the absolute path shouldn't show up anywhere in the output, I'll give this approach a shot. |
Signed-off-by: Michael Carroll <[email protected]>
Signed-off-by: Michael Carroll <[email protected]>
Signed-off-by: Michael Carroll <[email protected]>
Signed-off-by: Michael Carroll <[email protected]>
Signed-off-by: Michael Carroll <[email protected]>
Signed-off-by: Michael Carroll <[email protected]>
@rhaschke I have updated my implementation here to remove any bazel-specific semantics that were there before. The small change I did need to make was an optional |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Thanks for cleaning this up.
Why do you need so many integration-test files? What exactly are they testing?
As I understand, the unit tests in test_xacro.py
are run as well, aren't they?
Co-authored-by: Robert Haschke <[email protected]>
They are testing that the bazel rules correctly can find/expand xacro files as part of a build. It likely looks like more files because it's an entirely separate bazel project. The validates that there isn't anything "leaking" between the root bazel module implementation.
That is correct, the stuff in the integration test only tests the bazel rules, similar to the cmake variant in the |
Add the infrastructure necessary to use xacro as a bazel module. This gives users the ability to either use xacro as a standalone executable in their bazel projects, but also adds rules to allow for bazel to run xacro at build-time.
This also adds bazel-based CI to validate that the workflows continue to work.