-
Couldn't load subscription status.
- Fork 13.9k
rustdoc: load the set of in-scope traits for modules with no docstring #93441
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
rustdoc: load the set of in-scope traits for modules with no docstring #93441
Conversation
Fixes rust-lang#93428 This fix is a response to a couple of special cases related to the `module_id`, which is eventually used for trait candidates: * The module id is always set to the current crate, when checking `crate::`. Normally, the set of in-scope traits would be set in `load_links_in_attrs`, but if there are no doc comments, then that loop will never run. * the module id is set to the parent module, when resolving a module that is spelled like this: // Notice how we use an outlined doc comment here! // [`Test::my_fn`] mod something { } As with the above problem with `crate::`, we need to make sure the module gets its traits in scope resolved, even if it has no doc comments of its own.
|
(rust-highfive has picked a reviewer for you, use r? to override) |
ab97bb0 to
3903ca1
Compare
|
Thanks! Could you also check whether it fixes the regression from #88679 (comment)? |
|
📌 Commit 3903ca1 has been approved by |
…askrgr Rollup of 8 pull requests Successful merges: - rust-lang#93256 (Make `join!` description more accurate) - rust-lang#93358 (Add note suggesting that predicate may be satisfied, but is not `const`) - rust-lang#93362 (Do not register infer var for GAT projection in RPIT) - rust-lang#93391 (rustdoc: remove tooltip from source link) - rust-lang#93414 (Move unstable is_{arch}_feature_detected! macros to std::arch) - rust-lang#93441 (rustdoc: load the set of in-scope traits for modules with no docstring) - rust-lang#93459 (fs: Don't copy d_name from struct dirent) - rust-lang#93463 (Rename _args -> args in format_args expansion) Failed merges: r? `@ghost` `@rustbot` modify labels: rollup
Fixes #93428
This fix is a response to a couple of special cases related to the
module_id, which is eventually used for trait candidates:The module id is always set to the current crate, when checking
crate::.Normally, the set of in-scope traits would be set in
load_links_in_attrs, but if there are no doc comments, then that loop will never run.the module id is set to the parent module, when resolving a module that is spelled like this:
As with the above problem with
crate::, we need to make sure the module gets its traits in scope resolved, even if it has no doc comments of its own.