Skip to content
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

add meson support #691

Open
wants to merge 4 commits into
base: master
Choose a base branch
from

Conversation

christianrauch
Copy link
Contributor

@christianrauch christianrauch commented Nov 18, 2022

This adds a new rosdebian and rosrpm template for meson. Fixes #690.

The templates are copied from the cmake templates and the rules.em was adapted for meson.

Requires: #700

@christianrauch
Copy link
Contributor Author

@wjwwood @nuclearsandwich Can you have a look at this?

@christianrauch
Copy link
Contributor Author

@wjwwood @nuclearsandwich @cottsay Can you please have a look at this and let me know what is missing?

@nuclearsandwich
Copy link
Contributor

@christianrauch thank you for patiently maintaining this branch pending review.

Unrelated to the quality of the proposed changes, one of the things that has been delaying my review is trying to process my thoughts on how we ought to be handling the introduction of new build types in bloom. Specifically, should we have new build types like this one for meson start out in some kind of "preview" state or give some other indication that they are relatively new and thus has different stability standards compared to the other bloom build types. I do want to stress that I'm considering a disclaimer like this around the potential for change not an expectation or assumption and around stability not quality.

What I want for the meson build type and those that follow it is to decouple the overall bloom stability requirements from the ones for individual build types in order to give build type contributors/maintainers increased latitude. I would like the bloom team to be able to review the integration with bloom and trust that the build type maintainers are the subject matter experts with their tools, then just "click merge" to allow iterating in subsequent releases.
Right now, the thing that would help me feel comfortable moving towards that method of working would be some kind of disclaimer around the newly introduced build type.

What are your thoughts about something along those lines?

@christianrauch
Copy link
Contributor Author

It makes sense to document and/or inform users that some build types are experimental and may fail. bloom could maintain a list of experimental build types and simply show a warning "<build type> support is experimental. Please report errors to https://github.com/ros-infrastructure/bloom." when someone runs bloom to release a package.

However, I also expect users of bloom to know that meson is a new build type. ROS has always been using CMake for most of its packages and now regular python processes for python packages in ROS 2. I think that someone releasing a meson package will be aware of this novelty.

@christianrauch
Copy link
Contributor Author

FYI, this PR was used to release libcamera as deb and rpm package into humble.

@nuclearsandwich
Copy link
Contributor

FYI, this PR was used to release libcamera as deb and rpm package into humble.

I am significantly troubled that a custom branch of bloom was used to deploy to an official rosdistro without any indication. Especially because bloom reports that the released 0.11.2 version was used for ros/rosdistro#37104

I found that ros/rosdistro#36388 (comment) references this fact.
If in the future, you're using a non-standard version of bloom please call attention to it (although you do not need to cc me specifically in each case) on every review.

All the more reason to get this merged and released with an experimental tag.

@christianrauch
Copy link
Contributor Author

I am significantly troubled that a custom branch of bloom was used to deploy to an official rosdistro without any indication. Especially because bloom reports that the released 0.11.2 version was used for ros/rosdistro#37104

Sorry that this comes as a surprise to you now. Since this PR is open for more than 5 months now without getting feedback after nagging people and also since my comment on the rosdep PR (ros/rosdistro#36388 (comment)) went unnoticed, I assumed that there are no issues with the process. I am really not sure what I could have done more to notify people about this.

Copy link
Contributor

@nuclearsandwich nuclearsandwich left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I've completed a review of the general and debian-specific changes. There aren't any serious blockers but there are a few open questions.

@cottsay would you be willing to review the RPM changes, in particular the spec file?

Comment on lines 31 to 36
dh_auto_configure -- \
--prefix="@(InstallationPrefix)" \
--cmake-prefix-path="@(InstallationPrefix)" \
--libdir=lib \
--libexecdir=lib \
--strip
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Does meson have an equivalent to CMake's BUILD_TESTING? #649 will exclude test dependencies conditionally based on the nocheck debian build option. The CMake-derived build types test for this as such to specifically disable BUILD_TESTING.

ifneq ($(filter nocheck,$(DEB_BUILD_OPTIONS)),)
BUILD_TESTING_ARG=-DBUILD_TESTING=OFF
endif

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I don't see such a flag. You can directly add unit tests and run them with meson test (https://mesonbuild.com/Unit-tests.html) but I don't see an integrated flag that could handle test dependencies. I don't know the details but I would assume that the tests are only built when you actually run meson test.

Other than that, the test option is commonly used which is then checked with if get_option('test') inside the meson file. We could set that parameter here but it is not guaranteed that every meson project will use the same option for tests.

bloom/commands/generate.py Outdated Show resolved Hide resolved
@@ -12,4 +12,4 @@ Bloom now supports different build types by inspecting the `build_type` tag in p
Templates for a build type are stored in subdirectories of the platform's templates directory named for the build type.
As an example the templates for the `ament_cmake` build type for debian packages is stored in [bloom/generators/debian/templates/ament_cmake](debian/templates/ament_cmake).

To add support for a new build type create a new templates subdirectory for it in your target platform's `templates` directory, and add any necessary supporting code to the generator for build type specific substitutions.For examples search for "Build-type specific substitutions" in [bloom/generators/debian/generator.py](debian/generator.py).
To add support for a new build type create a new templates subdirectory for it in your target platform's `templates` directory, and add any necessary supporting code to the generator for build type specific substitutions. For examples search for "Build-type specific substitutions" in [bloom/generators/debian/generator.py](debian/generator.py).
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Thanks for this correction. Markdown and RST files in ros-infrastructure projects use "semantic line breaks" with one sentence per line.

So the preferred fix would be:

Suggested change
To add support for a new build type create a new templates subdirectory for it in your target platform's `templates` directory, and add any necessary supporting code to the generator for build type specific substitutions. For examples search for "Build-type specific substitutions" in [bloom/generators/debian/generator.py](debian/generator.py).
To add support for a new build type create a new templates subdirectory for it in your target platform's `templates` directory, and add any necessary supporting code to the generator for build type specific substitutions.
For examples search for "Build-type specific substitutions" in [bloom/generators/debian/generator.py](debian/generator.py).

However in #702 I've expanded and rephrased this section so if this PR merges first then I'll correct it there after resolving any potential conflicts so this does not block.

bloom/generators/debian/templates/meson/rules.em Outdated Show resolved Hide resolved
bloom/generators/rosrpm.py Show resolved Hide resolved
@nuclearsandwich
Copy link
Contributor

I am really not sure what I could have done more to notify people about this.

I concur that you did everything in your power. It's presumptive of me to assume that you would wait indefinitely.

@christianrauch
Copy link
Contributor Author

ping @nuclearsandwich

Copy link
Contributor Author

@christianrauch christianrauch left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I addressed your open questions and added more information to the commit messages.

bloom/generators/debian/templates/meson/rules.em Outdated Show resolved Hide resolved
bloom/generators/rosrpm.py Show resolved Hide resolved
@christianrauch
Copy link
Contributor Author

@nuclearsandwich @cottsay Can either of you have a look at this again, please?

The default 'installation_prefix' is '/usr'. This is wrong for 'rosrpm'
and has to be prefixed correctly with the default ROS installation.
@codecov-commenter
Copy link

codecov-commenter commented Sep 1, 2024

Codecov Report

Attention: Patch coverage is 0% with 4 lines in your changes missing coverage. Please review.

Please upload report for BASE (master@b42a1dd). Learn more about missing BASE report.

Files with missing lines Patch % Lines
bloom/generators/debian/generator.py 0.00% 2 Missing ⚠️
bloom/generators/rpm/generator.py 0.00% 2 Missing ⚠️
Additional details and impacted files
@@            Coverage Diff            @@
##             master     #691   +/-   ##
=========================================
  Coverage          ?   54.59%           
=========================================
  Files             ?       52           
  Lines             ?     6367           
  Branches          ?     1276           
=========================================
  Hits              ?     3476           
  Misses            ?     2534           
  Partials          ?      357           

☔ View full report in Codecov by Sentry.
📢 Have feedback on the report? Share it here.

@christianrauch
Copy link
Contributor Author

@nuclearsandwich @cottsay This PR for meson support is now more than 2y old. Can you please take a look at this and let me know which critical issues are left? There is only one comment related to "experimental" build types which refers to another unmerged PR.

I am using this PR to release the libcamera package for a while for DEB and RPM systems and this seems to work as expected.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

support meson
3 participants