From f1431adb404973f2f9dbce91b3c56893935df83b Mon Sep 17 00:00:00 2001 From: Patrick Walton Date: Fri, 10 Jun 2011 13:49:22 -0700 Subject: [PATCH] rustc: Add a generic struct_elt() function to trans --- src/comp/middle/trans.rs | 14 ++++++++++---- 1 file changed, 10 insertions(+), 4 deletions(-) diff --git a/src/comp/middle/trans.rs b/src/comp/middle/trans.rs index d700611ac4a..32bd47dc0c9 100644 --- a/src/comp/middle/trans.rs +++ b/src/comp/middle/trans.rs @@ -347,6 +347,15 @@ fn val_str(type_names tn, ValueRef v) -> str { ret ty_str(tn, val_ty(v)); } +// Returns the nth element of the given LLVM structure type. +fn struct_elt(TypeRef llstructty, uint n) -> TypeRef { + auto elt_count = llvm::LLVMCountStructElementTypes(llstructty); + assert (n < elt_count); + auto elt_tys = vec::init_elt(T_nil(), elt_count); + llvm::LLVMGetStructElementTypes(llstructty, vec::buf(elt_tys)); + ret llvm::LLVMGetElementType(elt_tys.(n)); +} + // LLVM type constructors. @@ -7686,10 +7695,7 @@ fn trans_mod(@local_ctxt cx, &ast::_mod m) { fn get_pair_fn_ty(TypeRef llpairty) -> TypeRef { // Bit of a kludge: pick the fn typeref out of the pair. - let vec[TypeRef] pair_tys = [T_nil(), T_nil()]; - llvm::LLVMGetStructElementTypes(llpairty, - vec::buf[TypeRef](pair_tys)); - ret llvm::LLVMGetElementType(pair_tys.(0)); + ret struct_elt(llpairty, 0u); } fn decl_fn_and_pair(&@crate_ctxt ccx, &span sp,