forked from rust-lang/rust
-
Notifications
You must be signed in to change notification settings - Fork 6
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Fix type-inference regression in rust-lang#112225
The type inference of argument-position closures and async blocks regressed in 1.70 as the evaluation order of async blocks changed, as they are not implicitly wrapped in an identity-function anymore. Fixes rust-lang#112225 by making sure the evaluation order stays the same as it used to.
- Loading branch information
Showing
4 changed files
with
65 additions
and
1 deletion.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,18 @@ | ||
// check-pass | ||
// edition:2021 | ||
|
||
use core::future::Future; | ||
|
||
fn main() { | ||
do_async(async { (0,) }, { | ||
// closure must be inside block | ||
|info| println!("{:?}", info.0) | ||
}); | ||
} | ||
|
||
fn do_async<R, Fut, F>(_tokio_fut: Fut, _glib_closure: F) | ||
where | ||
Fut: Future<Output = R>, | ||
F: FnOnce(R), | ||
{ | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,20 @@ | ||
// edition:2021 | ||
|
||
// With the current compiler logic, we cannot have both the `112225-1` case, | ||
// and this `112225-2` case working, as the type inference depends on the evaluation | ||
// order, and there is some explicit ordering going on. | ||
// See the `check_closures` part in `FnCtxt::check_argument_types`. | ||
// The `112225-1` case was a regression in real world code, whereas the `112225-2` | ||
// case never used to work prior to 1.70. | ||
|
||
use core::future::Future; | ||
|
||
fn main() { | ||
let x = Default::default(); | ||
//~^ ERROR: type annotations needed | ||
do_async( | ||
async { x.0; }, | ||
{ || { let _: &(i32,) = &x; } }, | ||
); | ||
} | ||
fn do_async<Fut, T>(_fut: Fut, _val: T, ) {} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,17 @@ | ||
error[E0282]: type annotations needed | ||
--> $DIR/issue-112225-2.rs:13:9 | ||
| | ||
LL | let x = Default::default(); | ||
| ^ | ||
... | ||
LL | async { x.0; }, | ||
| - type must be known at this point | ||
| | ||
help: consider giving `x` an explicit type | ||
| | ||
LL | let x: /* Type */ = Default::default(); | ||
| ++++++++++++ | ||
|
||
error: aborting due to previous error | ||
|
||
For more information about this error, try `rustc --explain E0282`. |