rust/tests/ui/async-await/issue-61076.stderr

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

78 lines
2.6 KiB
Plaintext
Raw Normal View History

error[E0277]: the `?` operator can only be applied to values that implement `Try`
2020-08-20 15:34:08 +08:00
--> $DIR/issue-61076.rs:42:5
2020-05-10 22:34:20 +08:00
|
LL | foo()?;
2021-11-16 16:16:23 -08:00
| ^^^^^^ the `?` operator cannot be applied to type `impl Future<Output = Result<(), ()>>`
2020-05-10 22:34:20 +08:00
|
2021-11-16 16:16:23 -08:00
= help: the trait `Try` is not implemented for `impl Future<Output = Result<(), ()>>`
2020-10-21 14:25:09 -07:00
help: consider `await`ing on the `Future`
|
LL | foo().await?;
| ++++++
2020-05-10 22:34:20 +08:00
error[E0277]: the `?` operator can only be applied to values that implement `Try`
--> $DIR/issue-61076.rs:62:5
2020-05-14 23:07:46 +08:00
|
LL | t?;
2020-10-21 14:25:09 -07:00
| ^^ the `?` operator cannot be applied to type `T`
2020-05-14 23:07:46 +08:00
|
= help: the trait `Try` is not implemented for `T`
2020-10-21 14:25:09 -07:00
help: consider `await`ing on the `Future`
|
LL | t.await?;
| ++++++
2020-05-14 23:07:46 +08:00
2021-11-16 16:16:23 -08:00
error[E0609]: no field `0` on type `impl Future<Output = Tuple>`
--> $DIR/issue-61076.rs:71:26
2020-05-30 22:57:12 +08:00
|
2020-08-16 20:25:22 +08:00
LL | let _: i32 = tuple().0;
| ^ field not available in `impl Future`, but it is available in its `Output`
|
help: consider `await`ing on the `Future` and access the field of its `Output`
|
LL | let _: i32 = tuple().await.0;
| ++++++
2020-05-30 22:57:12 +08:00
2021-11-16 16:16:23 -08:00
error[E0609]: no field `a` on type `impl Future<Output = Struct>`
--> $DIR/issue-61076.rs:75:28
2020-05-30 22:57:12 +08:00
|
2020-08-16 20:25:22 +08:00
LL | let _: i32 = struct_().a;
| ^ field not available in `impl Future`, but it is available in its `Output`
|
help: consider `await`ing on the `Future` and access the field of its `Output`
|
LL | let _: i32 = struct_().await.a;
| ++++++
2020-05-30 22:57:12 +08:00
2021-11-16 16:16:23 -08:00
error[E0599]: no method named `method` found for opaque type `impl Future<Output = Struct>` in the current scope
--> $DIR/issue-61076.rs:79:15
2020-08-20 15:34:08 +08:00
|
LL | struct_().method();
2021-11-16 16:16:23 -08:00
| ^^^^^^ method not found in `impl Future<Output = Struct>`
|
help: consider `await`ing on the `Future` and calling the method on its `Output`
|
LL | struct_().await.method();
| ++++++
2020-08-20 15:34:08 +08:00
2020-08-20 18:42:08 +08:00
error[E0308]: mismatched types
--> $DIR/issue-61076.rs:88:9
2020-08-20 18:42:08 +08:00
|
LL | match tuple() {
| ------- this expression has type `impl Future<Output = Tuple>`
LL |
2020-08-20 18:42:08 +08:00
LL | Tuple(_) => {}
fix: improve the suggestion on future not awaited Considering the following code ```rust fn foo() -> u8 { async fn async_fn() -> u8 { 22 } async_fn() } fn main() {} ``` the error generated before this commit from the compiler is ``` ➜ rust git:(macros/async_fn_suggestion) ✗ rustc test.rs --edition 2021 error[E0308]: mismatched types --> test.rs:4:5 | 1 | fn foo() -> u8 { | -- expected `u8` because of return type ... 4 | async_fn() | ^^^^^^^^^^ expected `u8`, found opaque type | = note: expected type `u8` found opaque type `impl Future<Output = u8>` help: consider `await`ing on the `Future` | 4 | async_fn().await | ++++++ error: aborting due to previous error ``` In this case the error is nor perfect, and can confuse the user that do not know that the opaque type is the future. So this commit will propose (and conclude the work start in https://github.com/rust-lang/rust/issues/80658) to change the string `opaque type` to `future` when applicable and also remove the Expected vs Received note by adding a more specific one regarding the async function that return a future type. So the new error emitted by the compiler is ``` error[E0308]: mismatched types --> test.rs:4:5 | 1 | fn foo() -> u8 { | -- expected `u8` because of return type ... 4 | async_fn() | ^^^^^^^^^^ expected `u8`, found future | note: calling an async function returns a future --> test.rs:4:5 | 4 | async_fn() | ^^^^^^^^^^ help: consider `await`ing on the `Future` | 4 | async_fn().await | ++++++ error: aborting due to previous error ``` Signed-off-by: Vincenzo Palazzo <vincenzopalazzodev@gmail.com>
2023-02-10 19:03:54 +01:00
| ^^^^^^^^ expected future, found `Tuple`
2020-08-20 18:42:08 +08:00
|
2021-11-16 16:16:23 -08:00
= note: expected opaque type `impl Future<Output = Tuple>`
2020-08-20 18:42:08 +08:00
found struct `Tuple`
2020-10-22 19:03:36 -07:00
help: consider `await`ing on the `Future`
|
LL | match tuple().await {
| ++++++
2020-08-20 18:42:08 +08:00
error: aborting due to 6 previous errors
2020-05-10 22:34:20 +08:00
2020-08-20 18:42:08 +08:00
Some errors have detailed explanations: E0277, E0308, E0599, E0609.
2020-05-30 22:57:12 +08:00
For more information about an error, try `rustc --explain E0277`.