auto merge of #14976 : luqmana/rust/focwtc, r=pcwalton

Fixes #14959.
This commit is contained in:
bors 2014-06-17 18:56:35 +00:00
commit 2fd618e77a
2 changed files with 52 additions and 1 deletions

View File

@ -443,7 +443,10 @@ fn visit_expr(rcx: &mut Rcx, expr: &ast::Expr) {
match expr.node {
ast::ExprCall(ref callee, ref args) => {
if !has_method_map {
if has_method_map {
constrain_call(rcx, None, expr, Some(*callee),
args.as_slice(), false);
} else {
constrain_callee(rcx, callee.id, expr, &**callee);
constrain_call(rcx,
Some(callee.id),

View File

@ -0,0 +1,48 @@
// Copyright 2014 The Rust Project Developers. See the COPYRIGHT
// file at the top-level directory of this distribution and at
// http://rust-lang.org/COPYRIGHT.
//
// Licensed under the Apache License, Version 2.0 <LICENSE-APACHE or
// http://www.apache.org/licenses/LICENSE-2.0> or the MIT license
// <LICENSE-MIT or http://opensource.org/licenses/MIT>, at your
// option. This file may not be copied, modified, or distributed
// except according to those terms.
#![feature(overloaded_calls)]
use std::ops::Fn;
trait Response {}
trait Request {}
trait Ingot<R, S> {
fn enter(&mut self, _: &mut R, _: &mut S, a: &mut Alloy) -> Status;
}
#[allow(dead_code)]
struct HelloWorld;
struct SendFile<'a>;
struct Alloy;
enum Status {
Continue
}
impl Alloy {
fn find<T>(&self) -> Option<T> {
None
}
}
impl<'a, 'b> Fn<(&'b mut Response,),()> for SendFile<'a> {
fn call(&self, (_res,): (&'b mut Response,)) {}
}
impl<Rq: Request, Rs: Response> Ingot<Rq, Rs> for HelloWorld {
fn enter(&mut self, _req: &mut Rq, res: &mut Rs, alloy: &mut Alloy) -> Status {
let send_file = alloy.find::<SendFile>().unwrap();
send_file(res);
Continue
}
}
fn main() {}