diff options
| author | bors <bors@rust-lang.org> | 2017-12-10 04:01:00 +0000 |
|---|---|---|
| committer | bors <bors@rust-lang.org> | 2017-12-10 04:01:00 +0000 |
| commit | 02b4d3ddfb7cd9f1caf8ed90f18f8e798a1f4b05 (patch) | |
| tree | 1222bd0c64470f5627d6a27200968b6352da978d | |
| parent | c89e206eedee079c4620eacbfb4e3bc6cf392fc8 (diff) | |
| parent | 484729478b65443447516ba2d0cfb44fe8f8e430 (diff) | |
| download | rust-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.rs | 2 | ||||
| -rw-r--r-- | src/test/ui/switched-expectations.rs | 14 | ||||
| -rw-r--r-- | src/test/ui/switched-expectations.stderr | 11 |
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 + |
