-
Notifications
You must be signed in to change notification settings - Fork 13k
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
Add a chapter on reading Rustdoc output #90487
Changes from all commits
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,107 @@ | ||
# How to read rustdoc output | ||
|
||
Rustdoc's HTML output includes a friendly and useful navigation interface which | ||
makes it easier for users to navigate and understand your code. | ||
This chapter covers the major features of that interface, | ||
and is a great starting point for documentation authors and users alike. | ||
|
||
## Structure | ||
|
||
The `rustdoc` output is divided into three sections. | ||
Along the left side of each page is a quick navigation bar, | ||
which shows contextual information about the current entry. | ||
The rest of the page is taken up by the search interface at the top | ||
and the documentation for the current item below that. | ||
|
||
## The Item Documentation | ||
|
||
The majority of the screen is taken up with the documentation text for the item | ||
currently being viewed. | ||
At the top is some at-a-glance info and controls: | ||
|
||
- the type and name of the item, | ||
such as "Struct `std::time::Duration`", | ||
- a button to copy the item's path to the clipboard, | ||
which is a clipboard item | ||
- a button to collapse or expand the top-level documentation for that item | ||
(`[+]` or `[-]`), | ||
- a link to the source code (`[src]`), | ||
if [configured](the-doc-attribute.html#html_no_source), | ||
and present (the source may not be available if | ||
the documentation was created with `cargo doc --no-deps`), | ||
- and the version in which the item became stable, | ||
if it's a stable item in the standard library. | ||
|
||
Below this is the main documentation for the item, | ||
including a definition or function signature if appropriate, | ||
followed by a list of fields or variants for Rust types. | ||
Finally, the page lists associated functions and trait implementations, | ||
including automatic and blanket implementations that `rustdoc` knows about. | ||
|
||
### Navigation | ||
|
||
Subheadings, variants, fields, and many other things in this documentation | ||
are anchors and can be clicked on and deep-linked to, | ||
which is a great way to communicate exactly what you're talking about. | ||
The typograpical character "§" appears next to lines with anchors on them | ||
when hovered or given keyboard focus. | ||
|
||
## The Navigation Bar | ||
|
||
For example, when looking at documentation for the crate root, | ||
it shows all the crates documented in the documentation bundle, | ||
and quick links to the modules, structs, traits, functions, and macros available | ||
from the current crate. | ||
At the top, it displays a [configurable logo](the-doc-attribute.html#html_logo_url) | ||
alongside the current crate's name and version, | ||
or the current item whose documentation is being displayed. | ||
|
||
## The Theme Picker and Search Interface | ||
|
||
When viewing `rustdoc`'s output in a browser with JavaScript enabled, | ||
a dynamic interface appears at the top of the page. | ||
To the left is the theme picker, denoted with a paint-brush icon, | ||
and the search interface, help screen, and options appear to the right of that. | ||
|
||
### The Theme Picker | ||
|
||
Clicking on the theme picker provides a list of themes - | ||
by default `ayu`, `light`, and `dark` - | ||
which are available for viewing. | ||
jyn514 marked this conversation as resolved.
Show resolved
Hide resolved
|
||
|
||
### The Search Interface | ||
|
||
Typing in the search bar instantly searches the available documentation for | ||
the string entered with a fuzzy matching algorithm that is tolerant of minor | ||
typos. | ||
|
||
By default, the search results give are "In Names", | ||
meaning that the fuzzy match is made against the names of items. | ||
Matching names are shown on the left, and the first few words of their | ||
descriptions are given on the right. | ||
By clicking an item, you will navigate to its particular documentation. | ||
|
||
There are two other sets of results, shown as tabs in the search results pane. | ||
"In Parameters" shows matches for the string in the types of parameters to | ||
functions, and "In Return Types" shows matches in the return types of functions. | ||
Both are very useful when looking for a function whose name you can't quite | ||
bring to mind when you know the type you have or want. | ||
Comment on lines
+87
to
+88
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. It's also useful if you don't know whether the function exists, but you think it should (e.g. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Just noting that neither of those examples work as search queries currently. I assume you didn't mean using those as queries verbatim? There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. The results include functions that don't have There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. 🤷♂️ I don't think there exist any useful type-based search queries for which rustdoc doesn't have bugs. I don't think we should block documenting how to use the feature on fixing the bugs. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Those aren't useful searches though. We should give an example of why you would want to use the feature. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. What do you mean?
Giving a broken example of why you'd want to use the feature seems worse than giving no example at all. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Yeah, I think we should wait on this until it's updated, if that's already in progress. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. You can take a look here if you want to see what it looks like. ;) There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. (I opened the PR here). |
||
|
||
When typing in the search bar, you can prefix your search term with a type | ||
followed by a colon (such as `mod:`) to restrict the results to just that | ||
kind of item. (The available items are listed in the help popup.) | ||
|
||
### Shortcuts | ||
|
||
Pressing `S` while focused elsewhere on the page will move focus to the | ||
search bar, and pressing `?` shows the help screen, | ||
which includes all these shortcuts and more. | ||
Pressing `T` focuses the theme picker. | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Maybe talk about the help popup to see the full list (the one appearing when clicking on the There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Should I not include the full list here? There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. It's fine to keep them. Maybe add a note that they are listed directly in the help popup too. |
||
|
||
When the search results are focused, | ||
the left and right arrows move between tabs and the up and down arrows move | ||
among the results. | ||
Pressing the enter or return key opens the highlighted result. | ||
|
||
When looking at the documentation for an item, the plus and minus keys expand | ||
and collapse all sections in the document. |
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.
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.
Hi @NoraCodes - did you see this comment? Was it intentional to not add this sentence?
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.
Yeah, sorry! I thought there was a discussion about this but now I can't find it - did I hallucinate that? lol
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.
Okay, yeah, still can't find it. I don't think we should mention this here because it's intended to be a guide for docs readers - we document
--no-deps
elsewhere.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.
Hmm, so the reason I thought to mention it was because it's pretty common for people to be confused by reading docs and having missing links. But I don't feel super strongly about it.
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.
@NoraCodes I think you're thinking of #90487 (comment), which was a discussion about another command-line flag.