-
-
Notifications
You must be signed in to change notification settings - Fork 110
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
Added ability to import a crate containing lib and bin targets with the same name #394
base: master
Are you sure you want to change the base?
Conversation
I probably won't have time to review this until one week from now. |
So, a decent chunk of this code is just plumbing that would be needed for #58. In fact, I could do up a follow up that implements that issue using a very small amount of code. Since it is shared work, my opinion is that the maintenance burden isn't too bad. Personally, I could rename my targets in my Rust project, but it really doesn't make sense to. If I have a binary named |
One question: is |
Well, previously the crate name was the same as the target name (a single rust Cargo.toml package manifest contains zero or one library crates, and 0-n bin crates). I'm conservative regarding deprecating / renaming things - I think it should be sufficient to document that the variable will contain a list of CMake targets, representing the crates that were imported.
I would document that the transformation is |
Just to be clear, do you want me to replace my existing |
Yes, please |
Are you sure this has the correct semantics? It converts e.g. |
Ah, I see. No that is not intended. In that case lets stick with the |
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.
Looks good besides the two comments.
Also it would be good if you could document the two new flags, by adding it to the documentation comment here:
corrosion/cmake/Corrosion.cmake
Line 938 in 4a134df
corrosion_import_crate( |
The documentation will automatically be included into the usage documentation here: https://corrosion-rs.github.io/corrosion/usage.html
Edit: Also my apologies for the long delay until reviewing
@@ -111,6 +119,7 @@ function(_generator_add_package_targets) | |||
_corrosion_add_library_target( | |||
WORKSPACE_MANIFEST_PATH "${workspace_manifest_path}" | |||
TARGET_NAME "${target_name}" |
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'm wondering: Is the original target_name
even still used after we defined target_name_cmake
? Is there a reason why we would need both target_name and target_name_cmake?
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.
Yes, it is used to form the lib file names.
Whoo boy, sorry for not getting back to this for so long. I redid the entire MR since it was so far behind and I had forgotten exactly what I had done in the first place. I can close this and open up a new MR if you would prefer. |
I'll be travelling a lot in the next 3 weeks, so it might take a while till I can review this PR (again). |
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.
Left some minor comments. Also for this PR it would be nice if you could add a short description to the release notes (RELEASES.md)
|
||
set(archive_byproducts "") | ||
set(shared_lib_byproduct "") | ||
set(pdb_byproduct "") | ||
|
||
add_library(${target_name} INTERFACE) | ||
_corrosion_initialize_properties(${target_name}) | ||
add_library(${target_name_cmake} INTERFACE IMPORTED GLOBAL) |
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.
Whats the reason to make the interface library IMPORTED
and GLOBAL
? It doesn't seem directly related to this PR.
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.
The target name "lib::mycrate" is reserved or not valid for certain CMake
features, such as generator expressions, and may result in undefined
behavior.
is what I get without this.
We do this by adding the ability to put the bin and lib targets into separate CMake namespaces. This also takes some initial steps towards breaking the connection between Rust target names and CMake target names. This structure could be useful for #58 eventually
I currently use
__
when::
is not valid in a target name. This can be easily changed if something else is desirable. This feature is entirely invisible unless you opt into it.