-
Notifications
You must be signed in to change notification settings - Fork 13.4k
Remove unneeded ItemId::Primitive variant #106628
New issue
Have a question about this project? # for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “#”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? # to your account
Conversation
Some changes occurred in src/librustdoc/clean/types.rs cc @camelid |
src/librustdoc/clean/inline.rs
Outdated
@@ -600,7 +600,7 @@ fn build_module_items( | |||
items.push(clean::Item { | |||
name: None, | |||
attrs: Box::new(clean::Attributes::default()), | |||
item_id: ItemId::Primitive(prim_ty, did.krate), | |||
item_id: ItemId::DefId(DefId { index: 0u32.into(), krate: did.krate }), |
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.
This change is very ugly though. I wondered if making item_id
an Option
would have been better but in the end I just left as is. If you have a better idea, I'm all for it. Otherwise I can add a comment.
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.
Maybe use index: 0xFFFF_FFFFu32.into()
to prevent potential confusion with the crate root?
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.
Wouldn't u32::MAX
be better?
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.
That would work too :)
07c387b
to
db5d20f
Compare
This comment has been minimized.
This comment has been minimized.
Ah so it's |
db5d20f
to
fc7d9de
Compare
I think it needs to be rust/compiler/rustc_macros/src/newtype.rs Lines 84 to 85 in 89e0576
|
Oh that's a shame. I think I'll go back to 0 since we don't use the |
fc7d9de
to
2c09286
Compare
Sentinel If the PrimitiveType field of #[derive(Debug, Clone, PartialEq, Eq, Hash, Copy)]
pub(crate) enum ItemId {
/// A "normal" item that uses a [`DefId`] for identification.
DefId(DefId),
/// Identifier that is used for auto traits.
Auto { trait_: DefId, for_: DefId },
/// Identifier that is used for blanket implementations.
Blanket { impl_id: DefId, for_: DefId },
/// Identifier for primitive types.
Primitive(CrateNum),
} |
At this point we could just keep |
The other option, like you already mentioned, would be to wrap the |
Which one do you prefer? |
I don't really like I guess I would prefer to keep |
Let's go with that then! I'll make the update tomorrow. |
Actually the solution was much simpler: we can use the item's |
2c09286
to
afa65e0
Compare
afa65e0
to
36c9b49
Compare
@bors r=notriddle rollup |
🌲 The tree is currently closed for pull requests below priority 999. This pull request will be tested once the tree is reopened. |
Rollup of 14 pull requests Successful merges: - rust-lang#105194 (Add comment to cleanup_kinds) - rust-lang#106521 (remove E0280) - rust-lang#106628 (Remove unneeded ItemId::Primitive variant) - rust-lang#106635 (std sync tests: better type name, clarifying comment) - rust-lang#106642 (Add test for rust-lang#106062) - rust-lang#106645 ([RFC 2397] Initial implementation) - rust-lang#106653 (Fix help docs for -Zallow-features) - rust-lang#106657 (Remove myself from rust-lang/rust reviewers) - rust-lang#106662 (specialize impl of `ToString` on `bool`) - rust-lang#106669 (create helper function for `rustc_lint_defs::Level` and remove it's duplicated code) - rust-lang#106671 (Change flags with a fixed default value from Option<bool> to bool) - rust-lang#106689 (Fix invalid files array re-creation in rustdoc-gui tester) - rust-lang#106690 (Fix scrolling for item declaration block) - rust-lang#106698 (Add compiler-errors to some trait system notification groups) Failed merges: r? `@ghost` `@rustbot` modify labels: rollup
As I mentioned here, I wondered if
ItemId::Primitive
was actually used for anything. Apparently, it seems so because removing it led to no changes as far as I and tests could see.r? @notriddle