diff options
author | Nick Fitzgerald <fitzgen@gmail.com> | 2017-11-01 14:36:08 -0700 |
---|---|---|
committer | Nick Fitzgerald <fitzgen@gmail.com> | 2017-11-02 09:51:09 -0700 |
commit | 79dbe8b8062076f8ac3f76c0eaf4846dcb8c4638 (patch) | |
tree | c7fbf6bbb0134e13a1ebaea38c342f02daaaa69c /src/codegen/mod.rs | |
parent | f059edee4a6b165323623af0c993d3c3889ed2c1 (diff) |
Detect `#pragma pack(...)` and make `pack(n)` where `n > 1` opaque
This is a bandaid for #537. It does *not* fix the underlying issue, which
requires `#[repr(packed = "N")]` support in Rust. However, it does make sure
that we don't generate type definitions with the wrong layout, or fail our
generated layout tests.
Diffstat (limited to 'src/codegen/mod.rs')
-rw-r--r-- | src/codegen/mod.rs | 8 |
1 files changed, 5 insertions, 3 deletions
diff --git a/src/codegen/mod.rs b/src/codegen/mod.rs index 2cbde732..50de296e 100644 --- a/src/codegen/mod.rs +++ b/src/codegen/mod.rs @@ -1394,7 +1394,9 @@ impl CodeGenerator for CompInfo { let used_template_params = item.used_template_params(ctx); - let mut packed = self.packed(); + let ty = item.expect_type(); + let layout = ty.layout(ctx); + let mut packed = self.is_packed(ctx, &layout); // generate tuple struct if struct or union is a forward declaration, // skip for now if template parameters are needed. @@ -1431,7 +1433,7 @@ impl CodeGenerator for CompInfo { let is_opaque = item.is_opaque(ctx, &()); let mut fields = vec![]; let mut struct_layout = - StructLayoutTracker::new(ctx, self, &canonical_name); + StructLayoutTracker::new(ctx, self, ty, &canonical_name); if !is_opaque { if item.has_vtable_ptr(ctx) { @@ -1618,7 +1620,7 @@ impl CodeGenerator for CompInfo { if let Some(comment) = item.comment(ctx) { attributes.push(attributes::doc(comment)); } - if packed { + if packed && !is_opaque { attributes.push(attributes::repr_list(&["C", "packed"])); } else { attributes.push(attributes::repr("C")); |