about summary refs log tree commit diff
diff options
context:
space:
mode:
authorLuqman Aden <laden@csclub.uwaterloo.ca>2014-06-17 15:21:28 -0400
committerAlex Crichton <alex@alexcrichton.com>2014-06-18 17:01:41 -0700
commit8e9e17d188c2b59813b5a7d8f6ebb0c22e26ce93 (patch)
treed446d47b349a2834d2469af4e7bf21a31dbfb009
parentae7006e373e458eaf0464761a6b492181c47100e (diff)
downloadrust-8e9e17d188c2b59813b5a7d8f6ebb0c22e26ce93.tar.gz
rust-8e9e17d188c2b59813b5a7d8f6ebb0c22e26ce93.zip
librustc: Use expr_ty_adjusted in trans_overloaded_call.
-rw-r--r--src/librustc/middle/trans/expr.rs2
-rw-r--r--src/test/run-pass/issue-14958.rs29
2 files changed, 30 insertions, 1 deletions
diff --git a/src/librustc/middle/trans/expr.rs b/src/librustc/middle/trans/expr.rs
index 42c7a71bab8..599b45aafe2 100644
--- a/src/librustc/middle/trans/expr.rs
+++ b/src/librustc/middle/trans/expr.rs
@@ -1463,7 +1463,7 @@ fn trans_overloaded_call<'a>(
     // Evaluate and tuple the arguments.
     let tuple_type = ty::mk_tup(bcx.tcx(),
                                 args.iter()
-                                    .map(|e| expr_ty(bcx, &**e))
+                                    .map(|e| ty::expr_ty_adjusted(bcx.tcx(), &**e))
                                     .collect());
     let repr = adt::represent_type(bcx.ccx(), tuple_type);
     let numbered_fields: Vec<(uint, Gc<ast::Expr>)> =
diff --git a/src/test/run-pass/issue-14958.rs b/src/test/run-pass/issue-14958.rs
new file mode 100644
index 00000000000..045d3cc0458
--- /dev/null
+++ b/src/test/run-pass/issue-14958.rs
@@ -0,0 +1,29 @@
+// 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)]
+
+trait Foo {}
+
+struct Bar;
+
+impl<'a> std::ops::Fn<(&'a Foo,), ()> for Bar {
+    fn call(&self, _: (&'a Foo,)) {}
+}
+
+struct Baz;
+
+impl Foo for Baz {}
+
+fn main() {
+    let bar = Bar;
+    let baz = &Baz;
+    bar(baz);
+}