-
-
Notifications
You must be signed in to change notification settings - Fork 108
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
Basic types #1363
base: main
Are you sure you want to change the base?
Basic types #1363
Conversation
A next step would be to address the Vulkan specific hack. We need a cleaner way to trigger the "special" handling of Vulkan records: |
src/parser.rs
Outdated
@@ -264,6 +265,13 @@ impl Library { | |||
) -> Result<(), String> { | |||
if let Some(typ) = self.read_record(parser, ns_id, elem, None, None)? { | |||
let name = typ.get_name(); | |||
// TODO: Don't hardcode to "Vulkan" | |||
let typ = if self.namespace(ns_id).name.eq("Vulkan") { | |||
assert!(typ.is_incomplete(self)); |
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.
We probably won't keep this assert but it shows that Vulkan records are incomplete.
Unfortunately, non Vulkan records can be incomplete too so we can't use is_incomplete
as the trigger for the new behavior.
And then there is the problem of the "ash::vk::{}"
format string: where should it be specified if we want to externalize it (to make gir
Vulkan agnostic 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.
An alternative approach to mapping the names with "ash::vk::{}"
would be to not do it and, instead, generate rust type aliases in a post process step.
pub type vulkan::Bool32 = VkBool32;
Advantage is that the Vulkan namespace will not be erased anymore (less "magic").
Disadvantage is that a bit more rust code will be generated.
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.
Likewise, instead of tweaking the Vulkan namespace on the fly, we could introduce a postprocess hook that tweaks/transforms the namespace after it was parsed.
7746d63
to
e4bc4ca
Compare
I went with post processing the Vulkan namespace. |
also rename the new Basic::Vulkan enum value to Basic::Typedef
What is the status of this one? |
@bilelmoussaoui I don't think we ever continued the discussion how to best map |
This PR is a follow up of #1134. Not sure what is the accepted way of contributing to someone else's PR.
Changes include:
Basic::Vulkan
enum toBasic::Typedef
.Vulkan-1.0.gir currently contains only what can be considered as
typedef
records.See https://gitlab.gnome.org/GNOME/gobject-introspection/-/blob/main/misc/update-vulkan-gir.py#L17
Basic::Typedef
s when parsing theVulkan
namespace.So a bit more generic and the
const VULKAN: &[&str] = &[...]
is gone. :)