Skip to content

Commit

Permalink
auto merge of rust-lang#13827 : lifthrasiir/rust/rustdoc-hidden-pub-f…
Browse files Browse the repository at this point in the history
…ield, r=alexcrichton

Fixes rust-lang#13806. Also adds a note to `HiddenStructField` about why it doesn't appear in the `clean` module itself.
  • Loading branch information
bors committed Apr 28, 2014
2 parents a3b28cb + 3b5d6b4 commit 3cd6c1e
Show file tree
Hide file tree
Showing 2 changed files with 32 additions and 16 deletions.
17 changes: 16 additions & 1 deletion src/librustdoc/clean.rs
Original file line number Diff line number Diff line change
Expand Up @@ -152,6 +152,21 @@ impl Item {
return None;
}

pub fn is_hidden_from_doc(&self) -> bool {
match self.doc_list() {
Some(ref l) => {
for innerattr in l.iter() {
match *innerattr {
Word(ref s) if "hidden" == *s => return true,
_ => (),
}
}
},
None => ()
}
return false;
}

pub fn is_mod(&self) -> bool {
match self.inner { ModuleItem(..) => true, _ => false }
}
Expand Down Expand Up @@ -736,7 +751,7 @@ impl Clean<Type> for ast::Ty {

#[deriving(Clone, Encodable, Decodable)]
pub enum StructField {
HiddenStructField,
HiddenStructField, // inserted later by strip passes
TypedStructField(Type),
}

Expand Down
31 changes: 16 additions & 15 deletions src/librustdoc/passes.rs
Original file line number Diff line number Diff line change
Expand Up @@ -33,23 +33,24 @@ pub fn strip_hidden(krate: clean::Crate) -> plugins::PluginResult {
};
impl<'a> fold::DocFolder for Stripper<'a> {
fn fold_item(&mut self, i: Item) -> Option<Item> {
for attr in i.attrs.iter() {
match attr {
&clean::List(ref x, ref l) if "doc" == *x => {
for innerattr in l.iter() {
match innerattr {
&clean::Word(ref s) if "hidden" == *s => {
debug!("found one in strip_hidden; removing");
self.stripped.insert(i.id);
return None;
},
_ => (),
}
}
},
_ => ()
if i.is_hidden_from_doc() {
debug!("found one in strip_hidden; removing");
self.stripped.insert(i.id);

// use a dedicated hidden item for given item type if any
match i.inner {
clean::StructFieldItem(..) => {
return Some(clean::Item {
inner: clean::StructFieldItem(clean::HiddenStructField),
..i
});
}
_ => {
return None;
}
}
}

self.fold_item_recur(i)
}
}
Expand Down

0 comments on commit 3cd6c1e

Please sign in to comment.