Skip to content
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

Rewrite on_unimplemented format string parser. #139091

Open
wants to merge 7 commits into
base: master
Choose a base branch
from

Conversation

mejrs
Copy link
Contributor

@mejrs mejrs commented Mar 29, 2025

This PR rewrites the format string parser for rustc_on_unimplemented and diagnostic::on_unimplemented. I plan on moving this code (and more) into the new attribute parsing system soon and wanted to PR it separately.

This PR introduces some minor differences though:

  • rustc_on_unimplemented on trait implementations is no longer checked/used - this is actually never used (outside of some tests) so I plan on removing it in the future.
  • for rustc_on_unimplemented, it introduces the {This} argument in favor of {ThisTraitname} (to be removed later). It'll be easier to parse.
  • for rustc_on_unimplemented, Self can now consistently be used as a filter, rather than just _Self. It used to not match correctly on for example Self = "[{integer}]"
  • Some error messages now have better spans.

Fixes #130627

@rustbot
Copy link
Collaborator

rustbot commented Mar 29, 2025

r? @jackh726

rustbot has assigned @jackh726.
They will have a look at your PR within the next two weeks and either review your PR or reassign to another reviewer.

Use r? to explicitly pick a reviewer

@rustbot rustbot added S-waiting-on-review Status: Awaiting review from the assignee but also interested parties. T-compiler Relevant to the compiler team, which will review and decide on the PR/issue. labels Mar 29, 2025
@rust-log-analyzer

This comment has been minimized.

@rustbot
Copy link
Collaborator

rustbot commented Mar 29, 2025

This PR changes a file inside tests/crashes. If a crash was fixed, please move into the corresponding ui subdir and add 'Fixes #' to the PR description to autoclose the issue upon merge.

@rust-log-analyzer

This comment has been minimized.

@rust-log-analyzer

This comment has been minimized.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
S-waiting-on-review Status: Awaiting review from the assignee but also interested parties. T-compiler Relevant to the compiler team, which will review and decide on the PR/issue.
Projects
None yet
Development

Successfully merging this pull request may close these issues.

RFC #1733 (Trait Aliases): compilation crash when putting "diagnostic::on_unimplemented" on alias
4 participants