Skip to content

Commit

Permalink
rustdoc: External module item links to the module contents. Fixes rus…
Browse files Browse the repository at this point in the history
…t-lang#12926.

the basic strategy is to distinguish `mod foo;` from `mod foo {...}`
by checking if the span for the module item and module contents is
in different files. if it's the case, we prefer module contents.

it is technically possible to fix rust-lang#12926 without changing the AST,
probably by checking the individual items' span. this is not without
a problem though, since it is possible that some items inside
`mod foo {...}` may have originated from other file (e.g. `include!`).
therefore it is better to record both spans explicitly.
  • Loading branch information
lifthrasiir committed Apr 27, 2014
1 parent dee21a6 commit c8a29c4
Show file tree
Hide file tree
Showing 3 changed files with 24 additions and 4 deletions.
19 changes: 18 additions & 1 deletion src/librustdoc/clean.rs
Original file line number Diff line number Diff line change
Expand Up @@ -223,10 +223,27 @@ impl Clean<Item> for doctree::Module {
self.view_items.clean().move_iter().collect(),
self.macros.clean().move_iter().collect()
);

// determine if we should display the inner contents or
// the outer `mod` item for the source code.
let where = {
let ctxt = local_data::get(super::ctxtkey, |x| *x.unwrap());
let cm = ctxt.sess().codemap();
let outer = cm.lookup_char_pos(self.where_outer.lo);
let inner = cm.lookup_char_pos(self.where_inner.lo);
if outer.file.start_pos == inner.file.start_pos {
// mod foo { ... }
self.where_outer
} else {
// mod foo; (and a separate FileMap for the contents)
self.where_inner
}
};

Item {
name: Some(name),
attrs: self.attrs.clean(),
source: self.where.clean(),
source: where.clean(),
visibility: self.vis.clean(),
id: self.id,
inner: ModuleItem(Module {
Expand Down
6 changes: 4 additions & 2 deletions src/librustdoc/doctree.rs
Original file line number Diff line number Diff line change
Expand Up @@ -19,7 +19,8 @@ use syntax::ast::{Ident, NodeId};
pub struct Module {
pub name: Option<Ident>,
pub attrs: Vec<ast::Attribute>,
pub where: Span,
pub where_outer: Span,
pub where_inner: Span,
pub structs: Vec<Struct>,
pub enums: Vec<Enum>,
pub fns: Vec<Function>,
Expand All @@ -42,7 +43,8 @@ impl Module {
name : name,
id: 0,
vis: ast::Inherited,
where: syntax::codemap::DUMMY_SP,
where_outer: syntax::codemap::DUMMY_SP,
where_inner: syntax::codemap::DUMMY_SP,
attrs : Vec::new(),
structs : Vec::new(),
enums : Vec::new(),
Expand Down
3 changes: 2 additions & 1 deletion src/librustdoc/visit_ast.rs
Original file line number Diff line number Diff line change
Expand Up @@ -118,7 +118,8 @@ impl<'a> RustdocVisitor<'a> {
for item in m.view_items.iter() {
self.visit_view_item(item, &mut om);
}
om.where = span;
om.where_outer = span;
om.where_inner = m.inner;
om.attrs = attrs;
om.vis = vis;
om.id = id;
Expand Down

1 comment on commit c8a29c4

@huonw
Copy link

@huonw huonw commented on c8a29c4 Apr 28, 2014

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

r+

Please sign in to comment.