Skip to content

Conversation

@Centril
Copy link
Contributor

@Centril Centril commented Nov 13, 2019

Avoid using rountrip parsing in the encoder and in fn load_macro_untracked.

The main reason I was interested in this was to remove rustc_parse as a dependency of rustc_metadata but it seems like this had other benefits as well.

Fixes #49511.

r? @eddyb
cc @matthewjasper @estebank @petrochenkov

@rust-highfive rust-highfive added the S-waiting-on-review Status: Awaiting review from the assignee but also interested parties. label Nov 13, 2019
Copy link
Member

@Mark-Simulacrum Mark-Simulacrum left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Overall though I think this is reasonable, I guess :)

@rust-highfive

This comment has been minimized.

@bors

This comment has been minimized.

@rust-highfive

This comment has been minimized.

@petrochenkov petrochenkov self-assigned this Nov 13, 2019
@bors

This comment has been minimized.

@Centril
Copy link
Contributor Author

Centril commented Nov 14, 2019

All the tests passed (before I adjusted the comment), so this should be ready for review now. :)

@rust-highfive

This comment has been minimized.

@eddyb

This comment has been minimized.

@Centril Centril added S-waiting-on-author Status: This is awaiting some action (such as code changes or more information) from the author. and removed S-waiting-on-review Status: Awaiting review from the assignee but also interested parties. labels Nov 15, 2019
@petrochenkov petrochenkov added the S-waiting-on-review Status: Awaiting review from the assignee but also interested parties. label Nov 16, 2019
@Centril Centril added S-waiting-on-review Status: Awaiting review from the assignee but also interested parties. and removed S-waiting-on-review Status: Awaiting review from the assignee but also interested parties. labels Nov 17, 2019
@petrochenkov petrochenkov removed the S-waiting-on-review Status: Awaiting review from the assignee but also interested parties. label Nov 17, 2019
@petrochenkov petrochenkov removed their assignment Nov 17, 2019
@petrochenkov
Copy link
Contributor

Do not forget to run perf on this.
Stringification was a cheat, but it could be a performance-friendly cheat.

@Centril
Copy link
Contributor Author

Centril commented Nov 21, 2019

Let's try a perf run now (and maybe one later after doing some more changes according to #66364 (comment)):

@bors try @rust-timer queue

@rust-timer
Copy link
Collaborator

Awaiting bors try build completion

@bors
Copy link
Collaborator

bors commented Nov 21, 2019

⌛ Trying commit a2ec40b4bf40b57c3df20d4c679804812d3be8e6 with merge 8391cac23555ae55fb9f4d7fc909c58c3f1313bf...

@pietroalbini
Copy link
Member

@bors retry

Yield to the beta release

@bors
Copy link
Collaborator

bors commented Mar 10, 2020

⌛ Testing commit bafa5cc with merge 1581278...

@bors
Copy link
Collaborator

bors commented Mar 10, 2020

☀️ Test successful - checks-azure
Approved by: petrochenkov,eddyb
Pushing 1581278 to master...

@bors bors added the merged-by-bors This PR was explicitly merged by bors. label Mar 10, 2020
@bors bors merged commit 1581278 into rust-lang:master Mar 10, 2020
@Centril Centril deleted the cleanup-macro-def branch March 10, 2020 20:55
@Mark-Simulacrum Mark-Simulacrum added the relnotes Marks issues that should be documented in the release notes of the next release. label Mar 12, 2020
@Mark-Simulacrum
Copy link
Member

Tagging as relnotes (so we don't forget about it -- it may not go into the final version), though that may be a false positive. @tomaka reported some breakage here (https://twitter.com/tomaka17/status/1238204339505770499) though it may be entirely in unstable features and unobservable on stable, in which case we wouldn't need to document it in relnotes.

@eddyb tells me @petrochenkov is the person to ask on whether there's something to say in relnotes here :)

@Mark-Simulacrum
Copy link
Member

Further discussion on Discord informed me that perhaps there is not a significant change here and the only exposed changes are to unstable APIs in proc_macro anyway, so untagging.

@Mark-Simulacrum Mark-Simulacrum removed the relnotes Marks issues that should be documented in the release notes of the next release. label Mar 12, 2020
@petrochenkov
Copy link
Contributor

Spans can affect many things, starting from lints (as this PR itself shows).
I guess the beta crater run will show the full extent of changes this PR caused.

@petrochenkov
Copy link
Contributor

Actually, running a separate crater check for this PR would be reasonable.

Dylan-DPC-zz pushed a commit to Dylan-DPC-zz/rust that referenced this pull request Mar 14, 2020
rustc_metadata: Remove `rmeta::MacroDef`

And other related cleanups.

Follow-up to rust-lang#66364.
r? @Centril
Centril added a commit to Centril/rust that referenced this pull request Mar 15, 2020
rustc_metadata: Remove `rmeta::MacroDef`

And other related cleanups.

Follow-up to rust-lang#66364.
r? @Centril
Centril added a commit to Centril/rust that referenced this pull request Apr 10, 2020
Fix JSON file_name documentation for macros.

JSON `file_name` paths were changed in rust-lang#66364 for macros to point to actual source files instead of using `<MACRONAME macros>`.

Closes rust-lang#70396
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

merged-by-bors This PR was explicitly merged by bors. S-waiting-on-bors Status: Waiting on bors to run and complete tests. Bors will change the label on completion.

Projects

None yet

Development

Successfully merging this pull request may close these issues.

macro_rules macros should not be serialized through strings in crate metadata.