diff options
| author | bors <bors@rust-lang.org> | 2017-11-21 03:03:28 +0000 |
|---|---|---|
| committer | bors <bors@rust-lang.org> | 2017-11-21 03:03:28 +0000 |
| commit | 421a2113a840aa5801230e7226fc9628100072ef (patch) | |
| tree | 17e45188fe0fcdd5ffcb838a33a200562528ab67 /src/libstd/sys/unix/stack_overflow.rs | |
| parent | 1e44fee88d48e9f7844c6d316ae8540db19dc9fa (diff) | |
| parent | 6047a0365976cbf7ad2991e6d88e4adf2fc6d0f4 (diff) | |
| download | rust-421a2113a840aa5801230e7226fc9628100072ef.tar.gz rust-421a2113a840aa5801230e7226fc9628100072ef.zip | |
Auto merge of #45039 - QuietMisdreavus:doc-spotlight, r=GuillaumeGomez,QuietMisdreavus
show in docs whether the return type of a function impls Iterator/Read/Write
Closes #25928
This PR makes it so that when rustdoc documents a function, it checks the return type to see whether it implements a handful of specific traits. If so, it will print the impl and any associated types. Rather than doing this via a whitelist within rustdoc, i chose to do this by a new `#[doc]` attribute parameter, so things like `Future` could tap into this if desired.
### Known shortcomings
~~The printing of impls currently uses the `where` class over the whole thing to shrink the font size relative to the function definition itself. Naturally, when the impl has a where clause of its own, it gets shrunken even further:~~ (This is no longer a problem because the design changed and rendered this concern moot.)
The lookup currently just looks at the top-level type, not looking inside things like Result or Option, which renders the spotlights on Read/Write a little less useful:
<details><summary>`File::{open, create}` don't have spotlight info (pic of old design)</summary>

</details>
All three of the initially spotlighted traits are generically implemented on `&mut` references. Rustdoc currently treats a `&mut T` reference-to-a-generic as an impl on the reference primitive itself. `&mut Self` counts as a generic in the eyes of rustdoc. All this combines to create this lovely scene on `Iterator::by_ref`:
<details><summary>`Iterator::by_ref` spotlights Iterator, Read, and Write (pic of old design)</summary>

</details>
Diffstat (limited to 'src/libstd/sys/unix/stack_overflow.rs')
0 files changed, 0 insertions, 0 deletions
