about summary refs log tree commit diff
path: root/src
diff options
context:
space:
mode:
authorbors <bors@rust-lang.org>2016-09-30 04:24:38 -0700
committerGitHub <noreply@github.com>2016-09-30 04:24:38 -0700
commit1d64acdceb6f0eebbc5e8774972b86e4cf192a0f (patch)
treede8b45e4fd0f47abc75aa67ac0e284a0aa66aa22 /src
parentc88ed2a1a7c5e11932f2f2b315e527933d3f7ebf (diff)
parentec2e05194f02fea51ad19de3498b9f6818166f1c (diff)
downloadrust-1d64acdceb6f0eebbc5e8774972b86e4cf192a0f.tar.gz
rust-1d64acdceb6f0eebbc5e8774972b86e4cf192a0f.zip
Auto merge of #36822 - Aatch:resolve-callee-expr, r=luqmana
Resolve the callee type in check_call before autoderef

If the callee type is an associated type, then it needs to be normalized
before trying to deref it. This matches the behaviour of
`check_method_call` for autoderef behaviour in calls.

Fixes #36786
Diffstat (limited to 'src')
-rw-r--r--src/librustc_typeck/check/callee.rs3
-rw-r--r--src/test/run-pass/issue-36786-resolve-call.rs17
2 files changed, 19 insertions, 1 deletions
diff --git a/src/librustc_typeck/check/callee.rs b/src/librustc_typeck/check/callee.rs
index d1fb0736d21..75c1d28f7d8 100644
--- a/src/librustc_typeck/check/callee.rs
+++ b/src/librustc_typeck/check/callee.rs
@@ -47,8 +47,9 @@ impl<'a, 'gcx, 'tcx> FnCtxt<'a, 'gcx, 'tcx> {
                       expected: Expectation<'tcx>) -> Ty<'tcx>
     {
         let original_callee_ty = self.check_expr(callee_expr);
+        let expr_ty = self.structurally_resolved_type(call_expr.span, original_callee_ty);
 
-        let mut autoderef = self.autoderef(callee_expr.span, original_callee_ty);
+        let mut autoderef = self.autoderef(callee_expr.span, expr_ty);
         let result = autoderef.by_ref().flat_map(|(adj_ty, idx)| {
             self.try_overloaded_call_step(call_expr, callee_expr, adj_ty, idx)
         }).next();
diff --git a/src/test/run-pass/issue-36786-resolve-call.rs b/src/test/run-pass/issue-36786-resolve-call.rs
new file mode 100644
index 00000000000..0d718c7ba46
--- /dev/null
+++ b/src/test/run-pass/issue-36786-resolve-call.rs
@@ -0,0 +1,17 @@
+// Copyright 2016 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.
+
+// Ensure that types that rely on obligations are autoderefed
+// correctly
+
+fn main() {
+    let x : Vec<Box<Fn()>> = vec![Box::new(|| ())];
+    x[0]()
+}