aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorGraydon Hoare <[email protected]>2011-04-28 14:30:31 -0700
committerGraydon Hoare <[email protected]>2011-04-28 14:35:12 -0700
commitc9e601b31d6ad3961587d829db4472d314e7e606 (patch)
tree028573e92e1af5cdd2e55f42cf9bc01bd2a919b4 /src
parentstdlib: Add getenv(3) to win32_os. (diff)
downloadrust-c9e601b31d6ad3961587d829db4472d314e7e606.tar.xz
rust-c9e601b31d6ad3961587d829db4472d314e7e606.zip
Drop args in native stubs too.
Diffstat (limited to 'src')
-rw-r--r--src/comp/middle/trans.rs11
1 files changed, 11 insertions, 0 deletions
diff --git a/src/comp/middle/trans.rs b/src/comp/middle/trans.rs
index a37308dd..bf96da8b 100644
--- a/src/comp/middle/trans.rs
+++ b/src/comp/middle/trans.rs
@@ -6622,6 +6622,7 @@ fn decl_native_fn_and_pair(@crate_ctxt ccx,
call_args += vec(lltaskptr);
for each (uint i in _uint.range(0u, num_ty_param)) {
auto llarg = llvm.LLVMGetParam(fcx.llfn, arg_n);
+ fcx.lltydescs += vec(llarg);
check (llarg as int != 0);
call_args += vec(vp2i(bcx, llarg));
arg_n += 1u;
@@ -6677,16 +6678,26 @@ fn decl_native_fn_and_pair(@crate_ctxt ccx,
r = bcx.build.Call(llnativefn, call_args);
rptr = fcx.llretptr;
} else {
+
+ let vec[tup(ValueRef, ty.t)] drop_args = vec();
+
for (ty.arg arg in args) {
auto llarg = llvm.LLVMGetParam(fcx.llfn, arg_n);
check (llarg as int != 0);
push_arg(bcx, call_args, llarg, arg.ty);
+ if (arg.mode == ast.val) {
+ drop_args += vec(tup(llarg, arg.ty));
+ }
arg_n += 1u;
}
r = trans_native_call(bcx.build, ccx.glues, lltaskptr, ccx.externs,
ccx.tn, ccx.llmod, name, pass_task, call_args);
rptr = bcx.build.BitCast(fcx.llretptr, T_ptr(T_i32()));
+
+ for (tup(ValueRef, ty.t) d in drop_args) {
+ bcx = drop_ty(bcx, d._0, d._1).bcx;
+ }
}
// We don't store the return value if it's nil, to avoid stomping on a nil