Default trait: set pointers to std::ptr::null()/null_mut() instead of zeroed
This commit is contained in:
parent
3e812896ff
commit
7e505347f4
778
ash/src/vk.rs
778
ash/src/vk.rs
File diff suppressed because it is too large
Load diff
|
@ -1156,8 +1156,37 @@ pub fn derive_default(_struct: &vkxml::Struct) -> Option<Tokens> {
|
||||||
#param_ident: unsafe { ::std::mem::zeroed() }
|
#param_ident: unsafe { ::std::mem::zeroed() }
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else if field.reference.is_some()
|
} else if let Some(ref reference) = field.reference {
|
||||||
|| is_static_array(field)
|
match reference {
|
||||||
|
vkxml::ReferenceType::Pointer => {
|
||||||
|
if field.is_const {
|
||||||
|
quote!{
|
||||||
|
#param_ident: ::std::ptr::null()
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
quote!{
|
||||||
|
#param_ident: ::std::ptr::null_mut()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
vkxml::ReferenceType::PointerToPointer => {
|
||||||
|
quote!{
|
||||||
|
#param_ident: ::std::ptr::null_mut()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
vkxml::ReferenceType::PointerToConstPointer => {
|
||||||
|
if field.is_const {
|
||||||
|
quote!{
|
||||||
|
#param_ident: ::std::ptr::null()
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
quote!{
|
||||||
|
#param_ident: ::std::ptr::null_mut()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} else if is_static_array(field)
|
||||||
|| is_pfn(field)
|
|| is_pfn(field)
|
||||||
|| handles.contains(&field.basetype.as_str())
|
|| handles.contains(&field.basetype.as_str())
|
||||||
{
|
{
|
||||||
|
@ -1610,7 +1639,7 @@ pub fn write_source_code(path: &Path) {
|
||||||
};
|
};
|
||||||
acc
|
acc
|
||||||
});
|
});
|
||||||
|
|
||||||
let constants_code: Vec<_> = constants
|
let constants_code: Vec<_> = constants
|
||||||
.iter()
|
.iter()
|
||||||
.map(|constant| generate_constant(constant, &mut const_cache))
|
.map(|constant| generate_constant(constant, &mut const_cache))
|
||||||
|
|
Loading…
Reference in a new issue