Skip to content

Commit 2fd618e

Browse files
committedJun 17, 2014
auto merge of #14976 : luqmana/rust/focwtc, r=pcwalton
Fixes #14959.
2 parents db29814 + 8827395 commit 2fd618e

File tree

2 files changed

+52
-1
lines changed

2 files changed

+52
-1
lines changed
 

‎src/librustc/middle/typeck/check/regionck.rs

+4-1
Original file line numberDiff line numberDiff line change
@@ -443,7 +443,10 @@ fn visit_expr(rcx: &mut Rcx, expr: &ast::Expr) {
443443

444444
match expr.node {
445445
ast::ExprCall(ref callee, ref args) => {
446-
if !has_method_map {
446+
if has_method_map {
447+
constrain_call(rcx, None, expr, Some(*callee),
448+
args.as_slice(), false);
449+
} else {
447450
constrain_callee(rcx, callee.id, expr, &**callee);
448451
constrain_call(rcx,
449452
Some(callee.id),

‎src/test/run-pass/issue-14959.rs

+48
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,48 @@
1+
// Copyright 2014 The Rust Project Developers. See the COPYRIGHT
2+
// file at the top-level directory of this distribution and at
3+
// http://rust-lang.org/COPYRIGHT.
4+
//
5+
// Licensed under the Apache License, Version 2.0 <LICENSE-APACHE or
6+
// http://www.apache.org/licenses/LICENSE-2.0> or the MIT license
7+
// <LICENSE-MIT or http://opensource.org/licenses/MIT>, at your
8+
// option. This file may not be copied, modified, or distributed
9+
// except according to those terms.
10+
11+
#![feature(overloaded_calls)]
12+
13+
use std::ops::Fn;
14+
15+
trait Response {}
16+
trait Request {}
17+
trait Ingot<R, S> {
18+
fn enter(&mut self, _: &mut R, _: &mut S, a: &mut Alloy) -> Status;
19+
}
20+
21+
#[allow(dead_code)]
22+
struct HelloWorld;
23+
24+
struct SendFile<'a>;
25+
struct Alloy;
26+
enum Status {
27+
Continue
28+
}
29+
30+
impl Alloy {
31+
fn find<T>(&self) -> Option<T> {
32+
None
33+
}
34+
}
35+
36+
impl<'a, 'b> Fn<(&'b mut Response,),()> for SendFile<'a> {
37+
fn call(&self, (_res,): (&'b mut Response,)) {}
38+
}
39+
40+
impl<Rq: Request, Rs: Response> Ingot<Rq, Rs> for HelloWorld {
41+
fn enter(&mut self, _req: &mut Rq, res: &mut Rs, alloy: &mut Alloy) -> Status {
42+
let send_file = alloy.find::<SendFile>().unwrap();
43+
send_file(res);
44+
Continue
45+
}
46+
}
47+
48+
fn main() {}

0 commit comments

Comments
 (0)
Please sign in to comment.