Merge pull request #129 from Ralith/array-debug

Fix nonsense Debug impl on non-char static arrays
This commit is contained in:
Maik Klein 2018-10-08 10:59:12 +02:00 committed by GitHub
commit c2baf4f1f2
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
2 changed files with 1579 additions and 1948 deletions

File diff suppressed because it is too large Load diff

View file

@ -1248,7 +1248,7 @@ pub fn derive_debug(_struct: &vkxml::Struct, union_types: &HashSet<&str>) -> Opt
.map(|n| n.contains("pfn")) .map(|n| n.contains("pfn"))
.unwrap_or(false) .unwrap_or(false)
}); });
let contains_static_array = members.clone().any(is_static_array); let contains_static_array = members.clone().any(|x| is_static_array(x) && x.basetype == "char");
let contains_union = members let contains_union = members
.clone() .clone()
.any(|field| union_types.contains(field.basetype.as_str())); .any(|field| union_types.contains(field.basetype.as_str()));
@ -1258,7 +1258,7 @@ pub fn derive_debug(_struct: &vkxml::Struct, union_types: &HashSet<&str>) -> Opt
let debug_fields = members.clone().map(|field| { let debug_fields = members.clone().map(|field| {
let param_ident = field.param_ident(); let param_ident = field.param_ident();
let param_str = param_ident.as_ref(); let param_str = param_ident.as_ref();
let debug_value = if is_static_array(field) { let debug_value = if is_static_array(field) && field.basetype == "char" {
quote!{ quote!{
&unsafe { &unsafe {
::std::ffi::CStr::from_ptr(self.#param_ident.as_ptr() as *const i8) ::std::ffi::CStr::from_ptr(self.#param_ident.as_ptr() as *const i8)