about summary refs log tree commit diff
diff options
context:
space:
mode:
authorbors <bors@rust-lang.org>2017-12-10 04:01:00 +0000
committerbors <bors@rust-lang.org>2017-12-10 04:01:00 +0000
commit02b4d3ddfb7cd9f1caf8ed90f18f8e798a1f4b05 (patch)
tree1222bd0c64470f5627d6a27200968b6352da978d
parentc89e206eedee079c4620eacbfb4e3bc6cf392fc8 (diff)
parent484729478b65443447516ba2d0cfb44fe8f8e430 (diff)
downloadrust-02b4d3ddfb7cd9f1caf8ed90f18f8e798a1f4b05.tar.gz
rust-02b4d3ddfb7cd9f1caf8ed90f18f8e798a1f4b05.zip
Auto merge of #46611 - GuillaumeGomez:type-mismatch, r=petrochenkov
Fix switched types in type mismatch

Fixes #46609.
-rw-r--r--src/librustc_typeck/check/mod.rs2
-rw-r--r--src/test/ui/switched-expectations.rs14
-rw-r--r--src/test/ui/switched-expectations.stderr11
3 files changed, 26 insertions, 1 deletions
diff --git a/src/librustc_typeck/check/mod.rs b/src/librustc_typeck/check/mod.rs
index efcf498b72c..24ffc0ca542 100644
--- a/src/librustc_typeck/check/mod.rs
+++ b/src/librustc_typeck/check/mod.rs
@@ -4194,7 +4194,7 @@ impl<'a, 'gcx, 'tcx> FnCtxt<'a, 'gcx, 'tcx> {
             // type of the lvalue it is referencing, and not some
             // supertype thereof.
             let init_ty = self.check_expr_with_lvalue_pref(init, LvaluePreference::from_mutbl(m));
-            self.demand_eqtype(init.span, init_ty, local_ty);
+            self.demand_eqtype(init.span, local_ty, init_ty);
             init_ty
         } else {
             self.check_expr_coercable_to_type(init, local_ty)
diff --git a/src/test/ui/switched-expectations.rs b/src/test/ui/switched-expectations.rs
new file mode 100644
index 00000000000..2a43679bdb8
--- /dev/null
+++ b/src/test/ui/switched-expectations.rs
@@ -0,0 +1,14 @@
+// Copyright 2017 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.
+
+fn main() {
+    let var = 10i32;
+    let ref string: String = var; //~ ERROR mismatched types [E0308]
+}
diff --git a/src/test/ui/switched-expectations.stderr b/src/test/ui/switched-expectations.stderr
new file mode 100644
index 00000000000..822ffeb0d32
--- /dev/null
+++ b/src/test/ui/switched-expectations.stderr
@@ -0,0 +1,11 @@
+error[E0308]: mismatched types
+  --> $DIR/switched-expectations.rs:13:30
+   |
+13 |     let ref string: String = var; //~ ERROR mismatched types [E0308]
+   |                              ^^^ expected struct `std::string::String`, found i32
+   |
+   = note: expected type `std::string::String`
+              found type `i32`
+
+error: aborting due to previous error
+