-
Notifications
You must be signed in to change notification settings - Fork 712
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
extend parse callbacks to expose discovered composite types and aliases #2658
Conversation
9aba819
to
e1aa4bf
Compare
75188da
to
e1aa4bf
Compare
Hey! Thanks for the PR and sorry for the delay on feedback. I think this feature is reasonable but there are some things I'd like to discuss first:
Thanks again 👍 |
Hey!
The goal of the ID in these callbacks is to find links aliases to discovered types. Without that, the aliases are way less useful as we don't know which type they are an alias of... My use case heavily relies on the IDs, but does not assume stable IDs. I basically build a map that uses the IDs as a key and that records the types discovered and their associated aliases. I could add in the documentation of the callbacks that IDs may be unstable and that the user should not expect them to be consistent across different bindgen runs. This would avoid people checking for hardcoded values of the IDs while still allowing us to find aliases and their aliased type. What do you think?
Do you mean something that would look like this: pub enum DiscoveredItem {
Struct {
original_name: Option<&str>,
final_ident: &str
// + whatever people want to expose here
},
Union {
original_name: Option<&str>,
final_ident: &str,
// + whatever people want to expose here
},
Alias {
alias_name: &str,
alias_for: usize // if we decide to keep IDs
}
// functions, modules, etc.
}
// The actual callback
fn new_item_found(
&self,
id: usize, // if we decide to keep it
item: DiscoveredItem
) I could do that although I am a bit scared that the DiscoveredItem enum becomes really large as people add more and more information into it.
Sure, I will change this :)
Agreed, will look into it when we agree on the final code :) |
But you still have the original C/C++ name of the type, right? Although name-based logic is usually easy to break, specially when some types don't even have a name 🤔
I'm not a big fan of policies as they are prone to the spacebar heating problem where someone doesn't read the policy and comes back with an angry issue complaning that we broke their workflow because we changed the way IDs are generated. Maybe we can meet halfway and add an opaque type that wraps the raw integer ID, something like: // FIXME: name is a work-in-progress
#[derive(PartialEq, Eq, Hash)]
pub struct DiscoveredItemId(usize); In that way, we only expose the bare minimum that we should guarantee: "two IDs are the same if they point back to the same C/C++ type"
Yeah that's an issue but if at some point one of the variants become way larger than the rest, we could add the extra fields for that variant into a What I want to avoid is creating several methods with the same functionality and having to keep their naming and documentation consistent. |
Right, not a fan of name based as well. Also I never tried with C++ but I imagine the namespace is included in the struct name ?
Works for me 🙂
Okay let's do that. I'll work on it tomorrow and push an update. |
e073105
to
68bcced
Compare
Hi @pvdrz Now, for the testing, I'm not really sure how to proceed. The testing system for callbacks seems to be based on comments at the top of the tests cases that are parsed to apply the callbacks. Here the callback does not impact the generated code but rather exports information about it. Using this system would require to hard code the expected result in the comments and quite a lot of parsing to make it work with this specific callback. As the enum get extended with more fields for each variant, it will quickly become a nightmare for people working on / maintaining it. Should I just make a standalone test in bindgen-tests/tests/parse_callbacks/test_item_discovery_callback.rs that works on a single sample header file and that ensures the discovery works? |
251cac7
to
bf34530
Compare
I added an example of what I think tests for this feature could look like. I am not sure if the names like I'm not sure if the test is good enough since it is a small feature. We could probably add this check to all the other header comparison tests if we generate the expected result for all of them but I'd need a bit of help on how to integrate that in your testing system since I'm not accustomed to it. |
cfab753
to
ebfcb44
Compare
this is my attempt at #2657
example use case:
this allowed me to build a library that discovers the bindings (for composite type) generated by bindgen (https://github.com/mxyns/bindgen-bridge)
i tried to expose as little hidden internal structs as possible (like passing
ItemId
as ausize
) but I did not feel like duplicating the definition ofCompType
was a good idea so I just made it public