CMakeLists.txt.em: Reduce boilerplate in install(TARGETS for library #1056
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
Description
Since CMake 3.14, the install(TARGETS signature had default install destination that work well, without requiring for the user the need to set any boilerplate (see https://cmake.org/cmake/help/v3.14/command/install.html#installing-targets). As since #969 the minimum version of CMake is 3.16, we can remove all the
DESTINATIONarguments from the libraryinstall(TARGETScall, and the libraries will still be installed in the correct location.Note that the
install(TARGETScall that install the node executable will still keep itsDESTINATIONarguments, as in that case theDESTINATIONis non-standard.Is this user-facing behavior change?
The generated CMakeLists.txt will change from containing:
to:
while keeping the same behavior, reducing the generated boilerplate.
Did you use Generative AI?
No.
Additional Information
Triggered by ros-misc-utilities/apriltag_detector#7 .