resolve module docs based on inner/outer attributes
This commit is contained in:
parent
1a62b17f7d
commit
b31bb097f5
@ -20,7 +20,7 @@ pub use self::FunctionRetTy::*;
|
|||||||
pub use self::Visibility::*;
|
pub use self::Visibility::*;
|
||||||
|
|
||||||
use syntax::abi::Abi;
|
use syntax::abi::Abi;
|
||||||
use syntax::ast;
|
use syntax::ast::{self, AttrStyle};
|
||||||
use syntax::attr;
|
use syntax::attr;
|
||||||
use syntax::codemap::Spanned;
|
use syntax::codemap::Spanned;
|
||||||
use syntax::feature_gate::UnstableFeatures;
|
use syntax::feature_gate::UnstableFeatures;
|
||||||
@ -472,11 +472,22 @@ impl Clean<Item> for doctree::Module {
|
|||||||
"".to_string()
|
"".to_string()
|
||||||
};
|
};
|
||||||
|
|
||||||
// maintain a stack of mod ids
|
// maintain a stack of mod ids, for doc comment path resolution
|
||||||
// we could also pass this down through clean()
|
// but we also need to resolve the module's own docs based on whether its docs were written
|
||||||
// but that might complicate things.
|
// inside or outside the module, so check for that
|
||||||
cx.mod_ids.borrow_mut().push(self.id);
|
let attrs = if self.attrs.iter()
|
||||||
let attrs = self.attrs.clean(cx);
|
.filter(|a| a.check_name("doc"))
|
||||||
|
.next()
|
||||||
|
.map_or(true, |a| a.style == AttrStyle::Inner) {
|
||||||
|
// inner doc comment, use the module's own scope for resolution
|
||||||
|
cx.mod_ids.borrow_mut().push(self.id);
|
||||||
|
self.attrs.clean(cx)
|
||||||
|
} else {
|
||||||
|
// outer doc comment, use its parent's scope
|
||||||
|
let attrs = self.attrs.clean(cx);
|
||||||
|
cx.mod_ids.borrow_mut().push(self.id);
|
||||||
|
attrs
|
||||||
|
};
|
||||||
|
|
||||||
let mut items: Vec<Item> = vec![];
|
let mut items: Vec<Item> = vec![];
|
||||||
items.extend(self.extern_crates.iter().map(|x| x.clean(cx)));
|
items.extend(self.extern_crates.iter().map(|x| x.clean(cx)));
|
||||||
|
Loading…
x
Reference in New Issue
Block a user