Skip to content

Commit

Permalink
Work around destructuring bug
Browse files Browse the repository at this point in the history
  • Loading branch information
marijnh committed Sep 7, 2011
1 parent f3edf8d commit 1339d05
Showing 1 changed file with 21 additions and 13 deletions.
34 changes: 21 additions & 13 deletions src/comp/middle/typeck.rs
Original file line number Diff line number Diff line change
Expand Up @@ -2055,19 +2055,27 @@ fn check_expr_with_unifier(fcx: &@fn_ctxt, expr: &@ast::expr, unify: &unifier,
bot = check_call_or_bind(fcx, expr.span, f, args, kind_bind);

// Pull the argument and return types out.
let (proto, arg_tys, rt, cf, constrs) =
alt structure_of(fcx, expr.span, expr_ty(tcx, f)) {
// FIXME:
// probably need to munge the constrs to drop constraints
// for any bound args
ty::ty_fn(proto, arg_tys, rt, cf, constrs) {
(proto, arg_tys, rt, cf, constrs)
}
ty::ty_native_fn(_, arg_tys, rt) {
(ast::proto_fn, arg_tys, rt, ast::return, [])
}
_ { fail "LHS of bind expr didn't have a function type?!"; }
};
let proto, arg_tys, rt, cf, constrs;
alt structure_of(fcx, expr.span, expr_ty(tcx, f)) {
// FIXME:
// probably need to munge the constrs to drop constraints
// for any bound args
ty::ty_fn(proto_, arg_tys_, rt_, cf_, constrs_) {
proto = proto_;
arg_tys = arg_tys_;
rt = rt_;
cf = cf_;
constrs = constrs_;
}
ty::ty_native_fn(_, arg_tys_, rt_) {
proto = ast::proto_fn;
arg_tys = arg_tys_;
rt = rt_;
cf = ast::return;
constrs = [];
}
_ { fail "LHS of bind expr didn't have a function type?!"; }
};

// For each blank argument, add the type of that argument
// to the resulting function type.
Expand Down

0 comments on commit 1339d05

Please sign in to comment.