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:
Jeffrey Seyfried 2016-06-29 00:33:10 +00:00
commit 2fda7d4a51
3 changed files with 1 additions and 23 deletions

View File

@ -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_,

View File

@ -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)),
}), }),
}); });

View File

@ -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(())
} }