Files
rust/src/rustdoc/prune_undoc_pass.rs

208 lines
5.1 KiB
Rust
Raw Normal View History

2012-01-17 17:44:32 -08:00
#[doc = "Prunes branches of the document tree that contain no documentation"];
export mk_pass;
fn mk_pass() -> pass {
run
}
type ctxt = {
mutable have_docs: bool
};
fn run(
_srv: astsrv::srv,
doc: doc::cratedoc
) -> doc::cratedoc {
let ctxt = {
mutable have_docs: true
};
let fold = fold::fold({
2012-01-23 15:40:01 -08:00
fold_mod: fold_mod,
2012-01-19 00:14:41 -08:00
fold_fn: fold_fn,
2012-01-24 00:44:47 -08:00
fold_const: fold_const,
2012-01-23 15:40:01 -08:00
fold_modlist: fold_modlist,
2012-01-24 00:44:47 -08:00
fold_fnlist: fold_fnlist,
fold_constlist: fold_constlist
with *fold::default_seq_fold(ctxt)
});
fold.fold_crate(fold, doc)
}
2012-01-23 15:40:01 -08:00
fn fold_mod(
fold: fold::fold<ctxt>,
doc: doc::moddoc
) -> doc::moddoc {
let doc = fold::default_seq_fold_mod(fold, doc);
fold.ctxt.have_docs =
doc.brief != none
|| doc.desc != none
|| vec::is_not_empty(*doc.mods)
|| vec::is_not_empty(*doc.fns);
ret doc;
}
fn fold_fn(
fold: fold::fold<ctxt>,
doc: doc::fndoc
) -> doc::fndoc {
let have_arg_docs = false;
2012-01-23 15:54:13 -08:00
let doc = ~{
args: vec::filter_map(doc.args) {|doc|
if option::is_some(doc.desc) {
have_arg_docs = true;
2012-01-23 15:54:13 -08:00
some(doc)
} else {
none
}
},
return: {
ty: if option::is_some(doc.return.desc) {
doc.return.ty
} else {
none
}
with doc.return
2012-01-23 15:54:13 -08:00
}
with *doc
};
fold.ctxt.have_docs =
doc.brief != none
|| doc.desc != none
|| have_arg_docs
2012-01-19 19:14:12 -08:00
|| doc.return.desc != none;
ret doc;
}
2012-01-23 15:54:13 -08:00
#[test]
fn should_elide_undocumented_arguments() {
let source = "#[doc = \"hey\"] fn a(b: int) { }";
let srv = astsrv::mk_srv_from_str(source);
let doc = extract::from_srv(srv, "");
let doc = attr_pass::mk_pass()(srv, doc);
let doc = run(srv, doc);
assert vec::is_empty(doc.topmod.fns[0].args);
}
#[test]
fn should_not_elide_fns_with_documented_arguments() {
let source = "#[doc(args(a = \"b\"))] fn a(a: int) { }";
let srv = astsrv::mk_srv_from_str(source);
let doc = extract::from_srv(srv, "");
let doc = attr_pass::mk_pass()(srv, doc);
let doc = run(srv, doc);
assert vec::is_not_empty(*doc.topmod.fns);
}
#[test]
fn should_elide_undocumented_return_values() {
let source = "#[doc = \"fonz\"] fn a() -> int { }";
let srv = astsrv::mk_srv_from_str(source);
let doc = extract::from_srv(srv, "");
let doc = tystr_pass::mk_pass()(srv, doc);
let doc = attr_pass::mk_pass()(srv, doc);
let doc = run(srv, doc);
assert doc.topmod.fns[0].return.ty == none;
}
2012-01-23 15:40:01 -08:00
fn fold_modlist(
fold: fold::fold<ctxt>,
list: doc::modlist
) -> doc::modlist {
doc::modlist(vec::filter_map(*list) {|doc|
2012-01-24 00:44:47 -08:00
let doc = fold.fold_mod(fold, doc);
2012-01-23 15:40:01 -08:00
if fold.ctxt.have_docs {
some(doc)
} else {
none
}
})
}
2012-01-23 15:54:13 -08:00
#[test]
fn should_elide_undocumented_mods() {
let source = "mod a { }";
let srv = astsrv::mk_srv_from_str(source);
let doc = extract::from_srv(srv, "");
let doc = run(srv, doc);
assert vec::is_empty(*doc.topmod.mods);
}
#[test]
fn should_not_elide_undocument_mods_with_documented_mods() {
let source = "mod a { #[doc = \"b\"] mod b { } }";
let srv = astsrv::mk_srv_from_str(source);
let doc = extract::from_srv(srv, "");
let doc = attr_pass::mk_pass()(srv, doc);
let doc = run(srv, doc);
assert vec::is_not_empty(*doc.topmod.mods);
}
#[test]
fn should_not_elide_undocument_mods_with_documented_fns() {
let source = "mod a { #[doc = \"b\"] fn b() { } }";
let srv = astsrv::mk_srv_from_str(source);
let doc = extract::from_srv(srv, "");
let doc = attr_pass::mk_pass()(srv, doc);
let doc = run(srv, doc);
assert vec::is_not_empty(*doc.topmod.mods);
}
fn fold_fnlist(
fold: fold::fold<ctxt>,
list: doc::fnlist
) -> doc::fnlist {
doc::fnlist(vec::filter_map(*list) {|doc|
2012-01-24 00:44:47 -08:00
let doc = fold.fold_fn(fold, doc);
if fold.ctxt.have_docs {
some(doc)
} else {
none
}
})
}
2012-01-23 15:54:13 -08:00
#[test]
fn should_elide_undocumented_fns() {
let source = "fn a() { }";
let srv = astsrv::mk_srv_from_str(source);
let doc = extract::from_srv(srv, "");
let doc = run(srv, doc);
assert vec::is_empty(*doc.topmod.fns);
}
2012-01-24 00:44:47 -08:00
fn fold_const(
fold: fold::fold<ctxt>,
doc: doc::constdoc
) -> doc::constdoc {
let doc = fold::default_seq_fold_const(fold, doc);
fold.ctxt.have_docs =
doc.brief != none
|| doc.desc != none;
ret doc;
}
fn fold_constlist(
fold: fold::fold<ctxt>,
list: doc::constlist
) -> doc::constlist {
doc::constlist(vec::filter_map(*list) {|doc|
let doc = fold.fold_const(fold, doc);
if fold.ctxt.have_docs {
some(doc)
} else {
none
}
})
}
#[test]
fn should_elide_undocumented_consts() {
let source = "const a: bool = true;";
let srv = astsrv::mk_srv_from_str(source);
let doc = extract::from_srv(srv, "");
let doc = run(srv, doc);
assert vec::is_empty(*doc.topmod.consts);
}