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

unstable proc_macro tracked::* rename/restructure #87173

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

Conversation

drahnr
Copy link
Contributor

@drahnr drahnr commented Jul 15, 2021

Extracted restructure of the unstable tracked::{fs,env}::*

Originally part of #84029

It's slightly clunky to to have three distinct unstable features, since one cannot use two annotations on one mod tracked {..} declaration.

The second thing I am unsure is rust-analyzer which would need some adaption for the new structure.

CC @Xanewok

@rust-highfive
Copy link
Collaborator

r? @petrochenkov

(rust-highfive has picked a reviewer for you, use r? to override)

@rust-highfive rust-highfive added the S-waiting-on-review Status: Awaiting review from the assignee but also interested parties. label Jul 15, 2021
@drahnr drahnr changed the title tracked restructure unstable proc_macro tracked::* rename/restructure Jul 15, 2021
@rust-log-analyzer

This comment has been minimized.

@petrochenkov petrochenkov added T-libs-api Relevant to the library API team, which will review and decide on the PR/issue. S-waiting-on-team Status: Awaiting decision from the relevant subteam (see the T-<team> label). I-nominated and removed S-waiting-on-review Status: Awaiting review from the assignee but also interested parties. labels Jul 16, 2021
@petrochenkov
Copy link
Contributor

I'm going to transfer this to the libs API team.
These are APIs that allow to trigger a rebuild when a certain environment variable or a file used from a proc macro change.

I'm not sure what the current library conventions are, but seeing >2 segment paths like tracked::fs::path in code is uncommon, so the new structure will likely result in the API being used through renamed imports like

use tracked::fs::path as track_path;
use tracked::env::var as tracked_env_var;

fn my_proc_macro() {
    track_path("my_file.txt"); // returns nothing
    let var = tracked_env_var("MY_VAR"); // returns the variable's value
}

@drahnr
Copy link
Contributor Author

drahnr commented Jul 16, 2021

Totally understandable, and I don't have a strong opinion, mostly going off of what was discussed in the referenced #84029 issue. If it is at odds with the current naming and module nesting depth, feel free to close.

At the very least though, I think it should be unified to either track_ or tracked_ prefixes for consistency.

@m-ou-se m-ou-se self-assigned this Aug 4, 2021
@joshtriplett
Copy link
Member

We discussed this in today's @rust-lang/libs-api meeting. We don't want to see an extra level of submodule nesting here; we should just have tracked::path and tracked::env_var. We didn't find the parallel with std compelling, because this will never have any significant fraction of std, and of the two methods we already have, one (path) already has no parallel in std.

Also, separate from this issue, several people in the meeting felt that we shouldn't restrict path to just str. We understand that the metadata format currently can't handle non-UTF-8, but we'd still like to see this accept a path, to avoid hardcoding that limitation in the API. We can always internally raise an error if it's not UTF-8 and the metadata can't handle it.

@m-ou-se m-ou-se added S-waiting-on-author Status: This is awaiting some action (such as code changes or more information) from the author. and removed I-nominated S-waiting-on-team Status: Awaiting decision from the relevant subteam (see the T-<team> label). labels Aug 11, 2021
@drahnr
Copy link
Contributor Author

drahnr commented Aug 11, 2021

@m-ou-se I'll implement the required changes this week, just wasn't entirely sure what your self assignment implied.

@pksunkara
Copy link
Contributor

so the new structure will likely result in the API being used through renamed imports like

Shouldn't we name the functions track_path and track_env_var then?

@drahnr
Copy link
Contributor Author

drahnr commented Aug 11, 2021

so the new structure will likely result in the API being used through renamed imports like

Shouldn't we name the functions track_path and track_env_var then?

I'd prefer the one module level variants, which is in line with other macro impls iirc:

.. we should just have tracked::path and tracked::env_var ..

@drahnr
Copy link
Contributor Author

drahnr commented Aug 13, 2021

Also, separate from this issue, several people in the meeting felt that we shouldn't restrict path to just str. We understand that the metadata format currently can't handle non-UTF-8, but we'd still like to see this accept a path, to avoid hardcoding that limitation in the API. We can always internally raise an error if it's not UTF-8 and the metadata can't handle it.

What's meant by internally raising an error, where should this be handled? Is path.to_str().expect() good enough? Encode does not provide means to return a result type. I'd appreciate some input.

@drahnr
Copy link
Contributor Author

drahnr commented Aug 17, 2021

Pending access to something that can be cast to a byte slice, the impl currently accepts valid UTF-8 only. I am not sure the error handling is as desired. Either way, I'd like some feedback :) Thanks!

@rustbot label -S-waiting-on-author +S-waiting-on-review

@rustbot rustbot added S-waiting-on-review Status: Awaiting review from the assignee but also interested parties. and removed S-waiting-on-author Status: This is awaiting some action (such as code changes or more information) from the author. labels Aug 17, 2021
@petrochenkov
Copy link
Contributor

It's not necessary to return a Result, proc macro server can simply report a compiler error if the passed Path is non-UTF8.

I'm not sure whether proc macro bridge can support passing Path though.
If it cannot, then we could actually determine non-UTF8-ness on the client side and return a Result.

@petrochenkov petrochenkov 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 Aug 17, 2021
@drahnr
Copy link
Contributor Author

drahnr commented Aug 29, 2021

It's not necessary to return a Result, proc macro server can simply report a compiler error if the passed Path is non-UTF8.

I'm not sure whether proc macro bridge can support passing Path though.
If it cannot, then we could actually determine non-UTF8-ness on the client side and return a Result.

Technically this would be possible, but that would require to access the currently private fn as_u8_slice and the unsafe fn from_u8_slice to be usable from the encode/decode impl.

I added an implementation adding a Result at the outer level, avoiding the encode and decode impls for PathBuf.

@JohnCSimon
Copy link
Member

Ping from triage:
@drahnr - can you please post your status on this PR?

@JohnCSimon JohnCSimon removed the S-blocked Status: Blocked on something else such as an RFC or other implementation work. label Nov 27, 2022
@Dylan-DPC
Copy link
Member

@drahnr any updates on this pr?

@drahnr
Copy link
Contributor Author

drahnr commented May 12, 2023

@drahnr any updates on this pr?

@Dylan-DPC If everything goes well, I can take another look at splitting things up next week~ish according along with #87173 (comment) and drop the remaining changes. I frankly forgot about the issue.

@Dylan-DPC
Copy link
Member

@drahnr any updates on this?

@drahnr
Copy link
Contributor Author

drahnr commented Jul 19, 2023

Back on it.

@drahnr drahnr force-pushed the bernhard-tracked-restructure branch from 0c57e65 to a46a7ba Compare July 20, 2023 12:33
@rustbot
Copy link
Collaborator

rustbot commented Jul 31, 2023

Some changes occurred in src/tools/rust-analyzer

cc @rust-lang/rust-analyzer

@rust-log-analyzer

This comment has been minimized.

@rustbot
Copy link
Collaborator

rustbot commented Aug 1, 2023

Some changes occurred in src/tools/clippy

cc @rust-lang/clippy

@rust-log-analyzer

This comment has been minimized.

@Dylan-DPC Dylan-DPC added S-waiting-on-review Status: Awaiting review from the assignee but also interested parties. and removed S-waiting-on-author Status: This is awaiting some action (such as code changes or more information) from the author. labels Oct 7, 2023
@drahnr drahnr force-pushed the bernhard-tracked-restructure branch from 7b4ac2f to fa67588 Compare October 10, 2023 23:20
@rust-log-analyzer

This comment has been minimized.

@bors
Copy link
Contributor

bors commented Dec 5, 2023

☔ The latest upstream changes (presumably #118646) made this pull request unmergeable. Please resolve the merge conflicts.

@rdrpenguin04
Copy link

What's left on this?

@drahnr
Copy link
Contributor Author

drahnr commented May 29, 2024

What's left on this?

A review, and another rebase, I think. It's been a while.

Copy link
Member

@m-ou-se m-ou-se left a comment

Choose a reason for hiding this comment

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

This PR does a few different things at once. One of them is changing the &str type to a PathBuf. That change was requested here and would be fine to merge. The other changes seem unrelated and it's unclear why some of them were made. (E.g. changing the tracking issue, or changing "environment" to "env" in a comment, or reordering some attributes/doc comments, etc.)

Comment on lines -1493 to +1492
#[unstable(feature = "proc_macro_tracked_env", issue = "99515")]
#[unstable(feature = "proc_macro_tracked_env", issue = "74690")]
Copy link
Member

Choose a reason for hiding this comment

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

Why is the tracking issue changed? #74690 is a closed issue.

Comment on lines +1521 to +1523
/// interpreted in a platform-specific way at compile time. So, for
/// instance, an invocation with a Windows path
/// containing backslashes `\` would not compile correctly on Unix.
Copy link
Member

Choose a reason for hiding this comment

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

I find the note on windows/unix paths quite confusing. Who is that note for? What user error is it trying to prevent?

Comment on lines +1519 to +1521
/// The file is located relative to the current file where the proc-macro
/// is used (similarly to how modules are found). The provided path is
/// interpreted in a platform-specific way at compile time. So, for
Copy link
Member

Choose a reason for hiding this comment

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

Is it not relative to the current working directory? So if I do File::open("a.txt") and tracked_path::path("a.txt"), can that refer to a different file?

Copy link
Member

Choose a reason for hiding this comment

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

If I understand the docs correct, this would behave similar to using the include!() family in the macro expansion, which indeed uses a different directory to be relative to than File::open() inside the proc macro. The behavior of include!() is almost certainly what you want. The current working directory that rustc is invoked with when using cargo is effectively undefined.

@m-ou-se m-ou-se 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 19, 2024
@alex-semenyuk
Copy link
Member

@drahnr
From wg-triage. Could you please take a look comments and make rebase?

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
S-waiting-on-author Status: This is awaiting some action (such as code changes or more information) from the author. T-libs-api Relevant to the library API team, which will review and decide on the PR/issue.
Projects
None yet
Development

Successfully merging this pull request may close these issues.