diff options
author | bors-servo <lbergstrom+bors@mozilla.com> | 2016-12-22 00:38:12 -0800 |
---|---|---|
committer | GitHub <noreply@github.com> | 2016-12-22 00:38:12 -0800 |
commit | 4472e0a5e60765611e980795de7c3c3a7e244ad5 (patch) | |
tree | 2abc5dea5cdf1bc9e1d25c201632e0940f20c675 /libbindgen/src | |
parent | 7615250f5d85688f0a4601c91c4984458961c54a (diff) | |
parent | a336b01ec19045a7ea89dcfee588967df506a033 (diff) |
Auto merge of #354 - Nashenas88:master, r=emilio
Followed Resolved Type Ref instead of panicking
This could fix #353, but I would really want everyone to review in case I'm missing something important. The compilation continues for the code I'm working with. Also, should I add a regression test for this? I could simply use the code in the referenced issue.
Diffstat (limited to 'libbindgen/src')
-rw-r--r-- | libbindgen/src/codegen/mod.rs | 6 |
1 files changed, 5 insertions, 1 deletions
diff --git a/libbindgen/src/codegen/mod.rs b/libbindgen/src/codegen/mod.rs index 9734a520..192eb674 100644 --- a/libbindgen/src/codegen/mod.rs +++ b/libbindgen/src/codegen/mod.rs @@ -2013,7 +2013,11 @@ impl CodeGenerator for Function { let signature = signature_item.kind().expect_type(); let signature = match *signature.kind() { TypeKind::Function(ref sig) => sig, - _ => panic!("How?"), + TypeKind::ResolvedTypeRef(ref item_id) => { + let item = ctx.resolve_item(*item_id); + return self.codegen(ctx, result, _whitelisted_items, item); + }, + _ => panic!("How?") }; let fndecl = utils::rust_fndecl_from_signature(ctx, signature_item); |