-
Notifications
You must be signed in to change notification settings - Fork 12.5k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Explain editions when trying to use async block in 2015 edition #67204
Comments
Can you provide the full input used to produce ^--? |
fn foo() {
let x = async {};
} error[E0422]: cannot find struct, variant or union type `async` in this scope
--> src/main.rs:3:12
|
3 | let x = async {};
| ^^^^^ not found in this scope
error: aborting due to previous error
For more information about this error, try `rustc --explain E0422`.
error: could not compile `playground`.
To learn more, run the command again with --verbose. |
That doesn't include:
What does the parser error come from? |
fn main() {}
fn bar() -> Result<(), ()> {
panic!()
}
fn foo() -> Result<(), ()> {
let x = async {
bar()?;
};
Ok(())
} |
For what is worth, I think the parser should use the snapshot approach here when in 2015 mode and try both parses, if one succeeds and the other one fails, give a targeted error. |
I think we could just do this in resolve instead of the parser as it seems like the parser is able to recover and we reach resolve. |
We can, but if we also handle it in the parser we can make the output be
The reason the parser recovers is because when it finds a parse error it consumes the rest of the block. |
I'm skeptical of the additional complexity here in doing it in the parser (which I suspect would be non-trivial, in an already complicated part of the parser). This would also have a perf cost in the happy path due to |
Fair.
True, the cost there is verbosity/vertical space, and that is fine, just not ideal. I think you're overestimating the added complexity on isolation (or you're extrapolating to the addition of all these checks throughout the parser, in which case, fair) and of the size and prevalence of the performance hit. We can check whether the struct ident is With all of that, this is not necessarily something we need to rush into because
The first point is something we've gotten better at, mainly extrapolating what are some common errors that will be caused by a new feature and preemptively handling them. Async await for example had some great checks even before hitting beta. We should continue to strive for that level of quality in our output for all new features. |
Visiting from triage. @estebank would you be willing to mentor this? |
I see I was a bit confused |
If we do this in resolve, does this mean that the output would include both the parse error and then a "nice" resolve error? If so, I think that's not great. Ideally, we'd produce just a nice async error -- but at minimum we should give a nice async error first. That said, I think we could just look for parse errors that occur when parsing some "struct named async" and trigger the nice error in that case, I'm not quite sure why we have to do anything too smart to read ahead and see if it "really is" an async block. I guess I think that the probability of 2015 code that uses a struct named We might be able to thread the needle with some kind of "note" or something to also give the user better info about the parse error. (However, I also think that parsing it as an async-block would be "ok", presuming that's something we do fairly often -- and maybe my proposal is sort of violating the "Hippocratic oath" of nice errors to "first do no harm". i.e., it could be pretty confusing to a user who does have a struct named |
@nikomatsakis I do think that long term there would be value in consider removing this discrepancy between 2015 and 2019 and make @tmandry I'm down for it. |
Ping from triage. @Centril have you made progress on this? If not, do you intend to work on it or should I make it available for someone else to take on? |
If e.g., @estebank or anyone else wants to take over implementing this that would be fine. In that case I'll most likely review the PR. I'll probably not get to this in a while. |
I won't be able to tackle this anytime soon but can help any interested party. |
Detect errors caused by `async` block in 2015 edition Fix rust-lang#67204.
Detect errors caused by `async` block in 2015 edition Fix rust-lang#67204.
Trying to use an
async
block in 2015 edition doesn't mention the concept of editions nor pushes the user in the right direction:The text was updated successfully, but these errors were encountered: