Handle yet another case of break
type mismatch
This commit is contained in:
parent
f6d4950fee
commit
2e0ad2025f
2 changed files with 10 additions and 2 deletions
|
@ -43,7 +43,10 @@ use rustc_infer::traits::query::NoSolution;
|
|||
use rustc_infer::traits::ObligationCause;
|
||||
use rustc_middle::middle::stability;
|
||||
use rustc_middle::ty::adjustment::{Adjust, Adjustment, AllowTwoPhase};
|
||||
use rustc_middle::ty::error::TypeError::FieldMisMatch;
|
||||
use rustc_middle::ty::error::{
|
||||
ExpectedFound,
|
||||
TypeError::{FieldMisMatch, Sorts},
|
||||
};
|
||||
use rustc_middle::ty::GenericArgsRef;
|
||||
use rustc_middle::ty::{self, AdtKind, Ty, TypeVisitableExt};
|
||||
use rustc_session::errors::ExprParenthesesNeeded;
|
||||
|
@ -664,6 +667,8 @@ impl<'a, 'tcx> FnCtxt<'a, 'tcx> {
|
|||
self.suggest_mismatched_types_on_tail(
|
||||
&mut err, expr, ty, e_ty, target_id,
|
||||
);
|
||||
let error = Some(Sorts(ExpectedFound { expected: ty, found: e_ty }));
|
||||
self.annotate_loop_expected_due_to_inference(&mut err, expr, error);
|
||||
if let Some(val) = ty_kind_suggestion(ty) {
|
||||
let label = destination
|
||||
.label
|
||||
|
|
|
@ -134,7 +134,10 @@ error[E0308]: mismatched types
|
|||
--> $DIR/loop-break-value.rs:4:31
|
||||
|
|
||||
LL | let val: ! = loop { break break; };
|
||||
| ^^^^^ expected `!`, found `()`
|
||||
| --- ---- ^^^^^ expected `!`, found `()`
|
||||
| | |
|
||||
| | this loop is expected to be of type `!`
|
||||
| expected because of this assignment
|
||||
|
|
||||
= note: expected type `!`
|
||||
found unit type `()`
|
||||
|
|
Loading…
Add table
Reference in a new issue