-
Notifications
You must be signed in to change notification settings - Fork 13k
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
Check method input expressions once #94438
Check method input expressions once #94438
Conversation
(rust-highfive has picked a reviewer for you, use r? to override) |
0993495
to
defdfbe
Compare
This comment has been minimized.
This comment has been minimized.
defdfbe
to
7543067
Compare
Thanks for the PR, @compiler-errors! r? rust-lang/diagnostics |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I think this seems reasonable and the slight regression on overloaded-calls-bad
is okay.
@bors r+ |
📌 Commit 7543067 has been approved by |
…askrgr Rollup of 3 pull requests Successful merges: - rust-lang#94438 (Check method input expressions once) - rust-lang#94459 (Update cargo) - rust-lang#94470 (:arrow_up: rust-analyzer) Failed merges: r? `@ghost` `@rustbot` modify labels: rollup
I'm not sure if this makes sense to backport or not, but I nominated it just in case. |
Actually, this PR seems to have led to an ICE of its own, so it probably doesn't make sense to backport it: #94516 |
Yeah, can't be backported until that one is fixed too. I can investigate it soon. |
…plicate, r=estebank Delay bug in expr adjustment when check_expr is called multiple times Instead of including slightly more complicated logic in `check_argument_types` to fix the bug (rust-lang#94516) I introduced in rust-lang#94438, and inevitably have this bug appear once again when some other diagnostic is written that causes `check_expr` to be called an expression during a (bad) code path, just delay the bug in adjustment logic. I am open to other implementations that don't delay the bug here. Fixes rust-lang#94516
…ulacrum [beta] backports * Update LLVM submodule rust-lang#94764 * Statically compile libstdc++ everywhere if asked rust-lang#94719 * Downgrade #[test] on macro call to warning rust-lang#94624 * Delay bug in expr adjustment when check_expr is called multiple times rust-lang#94596 * bootstrap: correct reading of flags for llvm rust-lang#94466 * Check method input expressions once rust-lang#94438 * remove feature gate in control_flow examples rust-lang#94283 r? `@Mark-Simulacrum`
…k-Simulacrum [beta] Remove statement that was forgotten when backporting rust-lang#94596 This `if` statement was introduced in rust-lang#94438, then removed in rust-lang#94596. Both of these PRs were beta-backported in rust-lang#94933, but I think there was a mistake in the order they were applied or this removal was overlooked. I think this fixes the remaining issues referenced in rust-lang#94511 (comment). Not sure this is the correct way to put something up for beta-backport, but the PR is at least open so it can be referenced and the commit can be cherry-picked. Feel free to close this PR. r? `@Mark-Simulacrum` cc: rust-lang#94511
If the user mistakenly forgets to wrap their method args in a tuple, then the compiler tries to check that types within the tuple match the expression args. This means we call
check_expr
once within this diagnostic code, so when we check the expr once again indemand_compatible
, we attempt to apply expr adjustments twice, leading to ICEs.This PR attempts to fix this by skipping the expression type check in
demand_compatible
if we have detected an method arg mismatch at all.This does lead to a single UI test regressing slightly, due to a diagnostic disappearing, though I don't know if it is generally meaningful to even raise an type error after noting that the argument count is incorrect in a function call, since the user might be providing (in-context) meaningless expressions to the wrong method.
I can adjust this to be a bit more targeted (to just skip checking exprs in
demand_compatible
in the tuple case) if this UI test regression is a problem.fixes #94334
cc #94291
Also drive-by fixup of
.node_type(expr.hir_id)
to.expr_ty(expr)
, since that method exists.