-
Notifications
You must be signed in to change notification settings - Fork 12.9k
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 JSON] Primitive types in core
are missing from the index
#104064
Comments
@rustbot modify labels: +A-rustdoc-json +T-rustdoc |
Investigating this:
Python 3.10.7 (main, Nov 24 2022, 19:45:47) [GCC 12.2.0] on linux
Type "help", "copyright", "credits" or "license" for more information.
>>> import json
>>> import pprint
>>> with open("./build/x86_64-unknown-linux-gnu/json-doc/core.json") as f:
... j = json.load(f)
...
>>> pprint.pp([(k, v) for (k, v) in j["index"].items() if v["name"] == "i32"])
[('0:75939:717',
{'id': '0:75939:717',
'crate_id': 0,
'name': 'i32',
'span': {'filename': 'library/core/src/primitive_docs.rs',
'begin': [1179, 0],
'end': [1179, 15]},
'visibility': 'public',
'docs': 'The 32-bit signed integer type.',
'links': {},
'attrs': ['#[doc(primitive = "i32")]',
'#[stable(feature = "rust1", since = "1.0.0")]'],
'deprecation': None,
'kind': 'primitive',
'inner': {'name': 'i32',
'impls': ['0:889',
# abridged
'0:23323']}}),
('0:67:717',
{'id': '0:67:717',
'crate_id': 0,
'name': 'i32',
'span': {'filename': 'library/core/src/num/shells/i32.rs',
'begin': [1, 0],
'end': [13, 19]},
'visibility': 'public',
'docs': 'Constants for the 32-bit signed integer type.\n'
'\n'
'*[See also the `i32` primitive type][i32].*\n'
'\n'
'New code should use the associated constants directly on the '
'primitive type.',
'links': {'i32': '0:75939:79042'},
'attrs': ['#[path = "num/shells/i32.rs"]',
'#![stable(feature = "rust1", since = "1.0.0")]',
'#![deprecated(since = "TBD", note =\n'
'"all constants in this module replaced by associated constants '
'on `i32`")]'],
'deprecation': {'since': 'TBD',
'note': 'all constants in this module replaced by '
'associated constants on `i32`'},
'kind': 'module',
'inner': {'is_crate': False,
'items': ['0:23361:2593', '0:23362:2600'],
'is_stripped': False}})]
>>> pprint.pp([(k,v) for k,v in j["paths"].items() if v["path"] == ["core", "i32"]])
[('0:67:717', {'crate_id': 0, 'path': ['core', 'i32'], 'kind': 'module'}),
('0:75939:79042',
{'crate_id': 0, 'path': ['core', 'i32'], 'kind': 'primitive'})]
>>> However the type has a different ID in each, but only in the last part. Therefor, it seems the issue may be somewhere in ID generation. |
MCVE: #![feature(no_core)]
#![feature(rustc_attrs)]
#![feature(rustdoc_internals)]
#![no_core]
#![rustc_coherence_is_core]
//! Link to [i32][prim@i32]
#[doc(primitive = "i32")]
mod prim_i32 {} produces (abridged) {
"crate_version": null,
"external_crates": {},
"format_version": 23,
"includes_private": false,
"index": {
"0:0:1572": {
"docs": "Link to [i32][prim@i32]",
"id": "0:0:1572",
"kind": "module",
"links": {"prim@i32": "0:1:1571"},
"name": "path_index_id"
},
"0:1:717": {
"docs": null,
"id": "0:1:717",
"kind": "primitive",
"links": {},
"name": "i32"
}
},
"paths": {
"0:0:1572": {"kind": "module", "path": ["path_index_id"]},
"0:1:1571": {"kind": "primitive", "path": ["path_index_id", "i32"]}
},
"root": "0:0:1572"
} Which used both |
Found the issue: the primitive type when defined in the current crate has a fn retrieve_primitive_defid_if_needed(tcx: TyCtxt<'_>, cache: &Cache, def_id: DefId) -> DefId {
if matches!(tcx.def_kind(def_id), DefKind::Mod) &&
let Some(prim) = tcx.get_attrs(def_id, sym::doc)
.flat_map(|attr| attr.meta_item_list().unwrap_or_default())
.filter(|attr| attr.has_name(sym::primitive))
.find_map(|attr| attr.value_str()) {
crate::clean::PrimitiveType::from_symbol(prim).and_then(|p| crate::clean::Type::Primitive(p).def_id(cache)).unwrap_or(def_id)
} else {
def_id
}
}
// Then we call it into `JsonRenderer::convert_item`:
impl JsonRenderer<'_> {
pub(super) fn convert_item(&self, item: clean::Item) -> Option<Item> {
let deprecation = item.deprecation(self.tcx);
let links = self
.cache
.intra_doc_links
.get(&item.item_id)
.into_iter()
.flatten()
.map(|clean::ItemLink { link, page_id, fragment, .. }| {
let id = match fragment {
Some(UrlFragment::Item(frag_id)) => {
// We need this work-around because links to primitive.
retrieve_primitive_defid_if_needed(self.tcx, &self.cache, *frag_id)
},
// FIXME: Pass the `UserWritten` segment to JSON consumer.
Some(UrlFragment::UserWritten(_)) | None => {
// We need this work-around because links to primitive.
retrieve_primitive_defid_if_needed(self.tcx, &self.cache, *page_id)
}
};
(link.clone(), from_item_id(id.into(), self.tcx))
})
.collect(); because the |
I would expect the proper fix to be adding the |
I actually switched the primitive module ID (which isn't present in the output because it's private) with the primitive type directly (which is present in the output). However if it's defined in the same crate, it's not treated as a primitive type, not sure if it's intended or not. Since the ID is the |
…al-item, r=notriddle jsondoclint: Check local items in `paths` are also in `index`. Would have caught rust-lang#104064 (if core.json was linted in CI). Closes rust-lang#106433. r? rustdoc
…al-item, r=notriddle jsondoclint: Check local items in `paths` are also in `index`. Would have caught rust-lang#104064 (if core.json was linted in CI). Closes rust-lang#106433. r? rustdoc
The issue
The id for
i32
in the JSON documentation generated forcore
is0:79316:78663
.It appears in the
path
:but it is not present in the
index
, although it's referenced in thelinks
section for many other items.The same happens to the other primitives I checked - e.g.
i64
(0:79317:78665
) orchar
(0:79294:78252
).How to reproduce
Add the
rust-docs-json
component to yournightly
toolchain, usingYou can then inspect
core.json
in.rustup/toolchains/nightly-<platform-triplet>/share/doc/rust/json/core.json
The text was updated successfully, but these errors were encountered: