summaryrefslogtreecommitdiff
path: root/libbindgen/src/codegen/mod.rs
diff options
context:
space:
mode:
authorEmilio Cobos Álvarez <emilio@crisal.io>2017-01-06 10:38:03 +0100
committerEmilio Cobos Álvarez <emilio@crisal.io>2017-01-06 10:38:03 +0100
commit9798d92212a590fff0d6f5a55d582e1b45781172 (patch)
tree39983ad5ee939905ab4d615101fb1f8716a047f9 /libbindgen/src/codegen/mod.rs
parent6720a9930a28d5daf8303d5cf6a957f86765b988 (diff)
codegen: Properly handle virtual bases.
Diffstat (limited to 'libbindgen/src/codegen/mod.rs')
-rw-r--r--libbindgen/src/codegen/mod.rs12
1 files changed, 8 insertions, 4 deletions
diff --git a/libbindgen/src/codegen/mod.rs b/libbindgen/src/codegen/mod.rs
index c4dc9644..c6d5fd39 100644
--- a/libbindgen/src/codegen/mod.rs
+++ b/libbindgen/src/codegen/mod.rs
@@ -835,14 +835,18 @@ impl CodeGenerator for CompInfo {
}
for (i, base) in self.base_members().iter().enumerate() {
+ // Virtual bases are already taken into account by the vtable
+ // pointer.
+ //
+ // FIXME(emilio): Is this always right?
+ if base.is_virtual() {
+ continue;
+ }
+
let base_ty = ctx.resolve_type(base.ty);
// NB: We won't include unsized types in our base chain because they
// would contribute to our size given the dummy field we insert for
// unsized types.
- //
- // NB: Canonical type is here because it could be inheriting from a
- // typedef, for example, and the lack of `unwrap()` is because we
- // can inherit from a template parameter, yes.
if base_ty.is_unsized(ctx) {
continue;
}