generator: Use PFN_
types for struct members instead of repeating sig (#438)
Following the fixes in #437 this actually puts those function pointer typedefs to use, slimming down the code by a large margin at the same time.
This commit is contained in:
parent
82ca24663f
commit
9d6bf63b4e
3 changed files with 525 additions and 2522 deletions
File diff suppressed because it is too large
Load diff
File diff suppressed because it is too large
Load diff
|
@ -933,13 +933,16 @@ fn generate_function_pointers<'a>(
|
|||
struct CommandToMember<'a>(&'a Command);
|
||||
impl<'a> quote::ToTokens for CommandToMember<'a> {
|
||||
fn to_tokens(&self, tokens: &mut TokenStream) {
|
||||
let type_name = &self.0.type_name;
|
||||
let type_name = if self.0.type_needs_defining {
|
||||
// Type is defined in local scope
|
||||
quote!(#type_name)
|
||||
} else {
|
||||
// Type is usually defined in another module
|
||||
quote!(crate::vk::#type_name)
|
||||
};
|
||||
let function_name_rust = &self.0.function_name_rust;
|
||||
let parameters = &self.0.parameters;
|
||||
let returns = &self.0.returns;
|
||||
quote!(
|
||||
pub #function_name_rust: unsafe extern "system" fn(#parameters) #returns
|
||||
)
|
||||
.to_tokens(tokens)
|
||||
quote!(pub #function_name_rust: #type_name).to_tokens(tokens)
|
||||
}
|
||||
}
|
||||
|
||||
|
|
Loading…
Add table
Reference in a new issue