Rollup merge of #34105 - ollie27:rustdoc_derived, r=alexcrichton
rustdoc: Remove Derived Implementations title As far as I know whether a trait was derived or not does not change the public API so there is no need to include this information in the docs. This title currently just adds an extra divide in the list of trait implementations which I don't think needs to be there.
This commit is contained in:
commit
2fda7d4a51
@ -432,7 +432,6 @@ pub fn build_impl<'a, 'tcx>(cx: &DocContext,
|
|||||||
ret.push(clean::Item {
|
ret.push(clean::Item {
|
||||||
inner: clean::ImplItem(clean::Impl {
|
inner: clean::ImplItem(clean::Impl {
|
||||||
unsafety: hir::Unsafety::Normal, // FIXME: this should be decoded
|
unsafety: hir::Unsafety::Normal, // FIXME: this should be decoded
|
||||||
derived: clean::detect_derived(&attrs),
|
|
||||||
provided_trait_methods: provided,
|
provided_trait_methods: provided,
|
||||||
trait_: trait_,
|
trait_: trait_,
|
||||||
for_: for_,
|
for_: for_,
|
||||||
|
@ -2239,14 +2239,9 @@ pub struct Impl {
|
|||||||
pub trait_: Option<Type>,
|
pub trait_: Option<Type>,
|
||||||
pub for_: Type,
|
pub for_: Type,
|
||||||
pub items: Vec<Item>,
|
pub items: Vec<Item>,
|
||||||
pub derived: bool,
|
|
||||||
pub polarity: Option<ImplPolarity>,
|
pub polarity: Option<ImplPolarity>,
|
||||||
}
|
}
|
||||||
|
|
||||||
fn detect_derived<M: AttrMetaMethods>(attrs: &[M]) -> bool {
|
|
||||||
attr::contains_name(attrs, "automatically_derived")
|
|
||||||
}
|
|
||||||
|
|
||||||
impl Clean<Vec<Item>> for doctree::Impl {
|
impl Clean<Vec<Item>> for doctree::Impl {
|
||||||
fn clean(&self, cx: &DocContext) -> Vec<Item> {
|
fn clean(&self, cx: &DocContext) -> Vec<Item> {
|
||||||
let mut ret = Vec::new();
|
let mut ret = Vec::new();
|
||||||
@ -2283,7 +2278,6 @@ impl Clean<Vec<Item>> for doctree::Impl {
|
|||||||
trait_: trait_,
|
trait_: trait_,
|
||||||
for_: self.for_.clean(cx),
|
for_: self.for_.clean(cx),
|
||||||
items: items,
|
items: items,
|
||||||
derived: detect_derived(&self.attrs),
|
|
||||||
polarity: Some(self.polarity.clean(cx)),
|
polarity: Some(self.polarity.clean(cx)),
|
||||||
}),
|
}),
|
||||||
});
|
});
|
||||||
|
@ -399,7 +399,6 @@ fn init_ids() -> HashMap<String, usize> {
|
|||||||
"methods",
|
"methods",
|
||||||
"deref-methods",
|
"deref-methods",
|
||||||
"implementations",
|
"implementations",
|
||||||
"derived_implementations"
|
|
||||||
].into_iter().map(|id| (String::from(*id), 1)).collect()
|
].into_iter().map(|id| (String::from(*id), 1)).collect()
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -2524,25 +2523,11 @@ fn render_assoc_items(w: &mut fmt::Formatter,
|
|||||||
}
|
}
|
||||||
write!(w, "<h2 id='implementations'>Trait \
|
write!(w, "<h2 id='implementations'>Trait \
|
||||||
Implementations</h2>")?;
|
Implementations</h2>")?;
|
||||||
let (derived, manual): (Vec<_>, Vec<&Impl>) = traits.iter().partition(|i| {
|
for i in &traits {
|
||||||
i.inner_impl().derived
|
|
||||||
});
|
|
||||||
for i in &manual {
|
|
||||||
let did = i.trait_did().unwrap();
|
let did = i.trait_did().unwrap();
|
||||||
let assoc_link = AssocItemLink::GotoSource(did, &i.inner_impl().provided_trait_methods);
|
let assoc_link = AssocItemLink::GotoSource(did, &i.inner_impl().provided_trait_methods);
|
||||||
render_impl(w, cx, i, assoc_link, true, containing_item.stable_since())?;
|
render_impl(w, cx, i, assoc_link, true, containing_item.stable_since())?;
|
||||||
}
|
}
|
||||||
if !derived.is_empty() {
|
|
||||||
write!(w, "<h3 id='derived_implementations'>\
|
|
||||||
Derived Implementations \
|
|
||||||
</h3>")?;
|
|
||||||
for i in &derived {
|
|
||||||
let did = i.trait_did().unwrap();
|
|
||||||
let assoc_link = AssocItemLink::GotoSource(did,
|
|
||||||
&i.inner_impl().provided_trait_methods);
|
|
||||||
render_impl(w, cx, i, assoc_link, true, containing_item.stable_since())?;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
Ok(())
|
Ok(())
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user