2012-01-15 17:23:19 -08:00
|
|
|
import rustc::syntax::ast;
|
2012-01-15 21:45:13 -08:00
|
|
|
|
2012-01-16 17:30:57 -08:00
|
|
|
export from_srv, extract;
|
|
|
|
|
|
|
|
// FIXME: Want this to be from_srv<T:ast::srv> but it crashes
|
|
|
|
fn from_srv(
|
|
|
|
srv: astsrv::seq_srv,
|
|
|
|
default_name: str
|
|
|
|
) -> doc::cratedoc {
|
|
|
|
import astsrv::seq_srv;
|
|
|
|
srv.exec {|ctxt|
|
|
|
|
extract(ctxt.ast, default_name)
|
|
|
|
}
|
|
|
|
}
|
2012-01-15 17:23:19 -08:00
|
|
|
|
|
|
|
#[doc = "Converts the Rust AST to the rustdoc document model"]
|
2012-01-15 21:45:13 -08:00
|
|
|
fn extract(
|
2012-01-16 00:19:35 -08:00
|
|
|
crate: @ast::crate,
|
|
|
|
default_name: str
|
2012-01-15 21:45:13 -08:00
|
|
|
) -> doc::cratedoc {
|
|
|
|
~{
|
2012-01-16 00:19:35 -08:00
|
|
|
topmod: top_moddoc_from_crate(crate, default_name),
|
2012-01-15 21:45:13 -08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
fn top_moddoc_from_crate(
|
2012-01-16 00:19:35 -08:00
|
|
|
crate: @ast::crate,
|
|
|
|
default_name: str
|
2012-01-15 21:45:13 -08:00
|
|
|
) -> doc::moddoc {
|
2012-01-16 16:01:33 -08:00
|
|
|
moddoc_from_mod(crate.node.module, default_name)
|
2012-01-15 21:45:13 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
fn moddoc_from_mod(
|
|
|
|
module: ast::_mod,
|
2012-01-16 16:01:33 -08:00
|
|
|
name: ast::ident
|
2012-01-15 21:45:13 -08:00
|
|
|
) -> doc::moddoc {
|
|
|
|
~{
|
|
|
|
name: name,
|
|
|
|
mods: doc::modlist(
|
|
|
|
vec::filter_map(module.items) {|item|
|
|
|
|
alt item.node {
|
|
|
|
ast::item_mod(m) {
|
2012-01-16 16:01:33 -08:00
|
|
|
some(moddoc_from_mod(m, item.ident))
|
2012-01-15 21:45:13 -08:00
|
|
|
}
|
|
|
|
_ {
|
|
|
|
none
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}),
|
|
|
|
fns: doc::fnlist(
|
|
|
|
vec::filter_map(module.items) {|item|
|
|
|
|
alt item.node {
|
2012-01-16 16:01:33 -08:00
|
|
|
ast::item_fn(decl, _, _) {
|
2012-01-15 21:45:13 -08:00
|
|
|
some(fndoc_from_fn(
|
2012-01-16 16:01:33 -08:00
|
|
|
decl, item.ident, item.id))
|
2012-01-15 21:45:13 -08:00
|
|
|
}
|
|
|
|
_ {
|
|
|
|
none
|
|
|
|
}
|
|
|
|
}
|
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
fn fndoc_from_fn(
|
|
|
|
_decl: ast::fn_decl,
|
|
|
|
name: ast::ident,
|
2012-01-16 16:01:33 -08:00
|
|
|
id: ast::node_id
|
2012-01-15 21:45:13 -08:00
|
|
|
) -> doc::fndoc {
|
2012-01-16 16:01:33 -08:00
|
|
|
~{
|
|
|
|
id: id,
|
|
|
|
name: name,
|
|
|
|
brief: none,
|
|
|
|
desc: none,
|
|
|
|
return: none,
|
|
|
|
args: []
|
|
|
|
}
|
2012-01-15 17:23:19 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
#[cfg(test)]
|
|
|
|
mod tests {
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn extract_empty_crate() {
|
|
|
|
let source = ""; // empty crate
|
|
|
|
let ast = parse::from_str(source);
|
2012-01-16 00:19:35 -08:00
|
|
|
let doc = extract(ast, "");
|
2012-01-15 21:45:13 -08:00
|
|
|
// FIXME #1535: These are boxed to prevent a crash
|
|
|
|
assert ~doc.topmod.mods == ~doc::modlist([]);
|
|
|
|
assert ~doc.topmod.fns == ~doc::fnlist([]);
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn extract_mods() {
|
|
|
|
let source = "mod a { mod b { } mod c { } }";
|
|
|
|
let ast = parse::from_str(source);
|
2012-01-16 00:19:35 -08:00
|
|
|
let doc = extract(ast, "");
|
2012-01-15 21:45:13 -08:00
|
|
|
assert doc.topmod.mods[0].name == "a";
|
|
|
|
assert doc.topmod.mods[0].mods[0].name == "b";
|
|
|
|
assert doc.topmod.mods[0].mods[1].name == "c";
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn extract_mods_deep() {
|
|
|
|
let source = "mod a { mod b { mod c { } } }";
|
|
|
|
let ast = parse::from_str(source);
|
2012-01-16 00:19:35 -08:00
|
|
|
let doc = extract(ast, "");
|
2012-01-15 21:45:13 -08:00
|
|
|
assert doc.topmod.mods[0].mods[0].mods[0].name == "c";
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn extract_fns() {
|
|
|
|
let source =
|
|
|
|
"fn a() { } \
|
|
|
|
mod b { fn c() { } }";
|
|
|
|
let ast = parse::from_str(source);
|
2012-01-16 00:19:35 -08:00
|
|
|
let doc = extract(ast, "");
|
2012-01-15 21:45:13 -08:00
|
|
|
assert doc.topmod.fns[0].name == "a";
|
|
|
|
assert doc.topmod.mods[0].fns[0].name == "c";
|
2012-01-15 17:23:19 -08:00
|
|
|
}
|
2012-01-16 00:15:03 -08:00
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn extract_should_set_fn_ast_id() {
|
|
|
|
let source = "fn a() { }";
|
|
|
|
let ast = parse::from_str(source);
|
2012-01-16 00:19:35 -08:00
|
|
|
let doc = extract(ast, "");
|
2012-01-16 00:15:03 -08:00
|
|
|
assert doc.topmod.fns[0].id != 0;
|
|
|
|
}
|
2012-01-16 00:19:35 -08:00
|
|
|
|
|
|
|
#[test]
|
2012-01-16 16:01:33 -08:00
|
|
|
fn extract_should_use_default_crate_name() {
|
2012-01-16 00:19:35 -08:00
|
|
|
let source = "";
|
|
|
|
let ast = parse::from_str(source);
|
|
|
|
let doc = extract(ast, "burp");
|
|
|
|
assert doc.topmod.name == "burp";
|
|
|
|
}
|
2012-01-16 17:30:57 -08:00
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn extract_from_seq_srv() {
|
|
|
|
import astsrv::seq_srv;
|
|
|
|
let source = "";
|
|
|
|
let srv = astsrv::mk_seq_srv_from_str(source);
|
|
|
|
let doc = from_srv(srv, "name");
|
|
|
|
assert doc.topmod.name == "name";
|
|
|
|
}
|
2012-01-15 17:23:19 -08:00
|
|
|
}
|