Rollup merge of #128082 - compiler-errors:closure-cap, r=estebank
Note closure captures when reporting cast to fn ptr failed Fixes #128078 We already had logic to point out a closure having captures when that's possibly the source of a coercion error to `fn()`, but we weren't reporting it during an explicit `as` cast.
This commit is contained in:
commit
c2ba4b1cb0
2 changed files with 7 additions and 0 deletions
|
@ -495,6 +495,7 @@ impl<'a, 'tcx> CastCheck<'tcx> {
|
|||
err.span_label(self.span, "invalid cast");
|
||||
}
|
||||
|
||||
fcx.suggest_no_capture_closure(&mut err, self.cast_ty, self.expr_ty);
|
||||
self.try_suggest_collection_to_bool(fcx, &mut err);
|
||||
|
||||
err.emit();
|
||||
|
|
|
@ -3,6 +3,12 @@ error[E0605]: non-primitive cast: `{closure@$DIR/closure-no-fn-3.rs:6:28: 6:30}`
|
|||
|
|
||||
LL | let baz: fn() -> u8 = (|| { b }) as fn() -> u8;
|
||||
| ^^^^^^^^^^^^^^^^^^^^^^^^ invalid cast
|
||||
|
|
||||
note: closures can only be coerced to `fn` types if they do not capture any variables
|
||||
--> $DIR/closure-no-fn-3.rs:6:33
|
||||
|
|
||||
LL | let baz: fn() -> u8 = (|| { b }) as fn() -> u8;
|
||||
| ^ `b` captured here
|
||||
|
||||
error: aborting due to 1 previous error
|
||||
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue