2012-01-17 17:44:32 -08:00
|
|
|
#[doc = "Prunes branches of the document tree that contain no documentation"];
|
|
|
|
|
|
2012-01-17 16:12:50 -08:00
|
|
|
export mk_pass;
|
|
|
|
|
|
|
|
|
|
fn mk_pass() -> pass {
|
|
|
|
|
run
|
|
|
|
|
}
|
2012-01-16 22:50:00 -08:00
|
|
|
|
|
|
|
|
type ctxt = {
|
|
|
|
|
mutable have_docs: bool
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
fn run(
|
2012-01-17 16:12:31 -08:00
|
|
|
_srv: astsrv::srv,
|
2012-01-16 22:50:00 -08:00
|
|
|
doc: doc::cratedoc
|
|
|
|
|
) -> doc::cratedoc {
|
|
|
|
|
let ctxt = {
|
|
|
|
|
mutable have_docs: true
|
|
|
|
|
};
|
|
|
|
|
let fold = fold::fold({
|
|
|
|
|
fold_fn: fn~(
|
|
|
|
|
f: fold::fold<ctxt>,
|
|
|
|
|
d: doc::fndoc
|
|
|
|
|
) -> doc::fndoc {
|
|
|
|
|
fold_fn(f, d)
|
|
|
|
|
},
|
|
|
|
|
fold_fnlist: fn~(
|
|
|
|
|
f: fold::fold<ctxt>,
|
|
|
|
|
l: doc::fnlist
|
|
|
|
|
) -> doc::fnlist {
|
|
|
|
|
fold_fnlist(f, l)
|
|
|
|
|
}
|
|
|
|
|
with *fold::default_seq_fold(ctxt)
|
|
|
|
|
});
|
|
|
|
|
fold.fold_crate(fold, doc)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
fn fold_fn(
|
|
|
|
|
fold: fold::fold<ctxt>,
|
|
|
|
|
doc: doc::fndoc
|
|
|
|
|
) -> doc::fndoc {
|
|
|
|
|
fold.ctxt.have_docs =
|
|
|
|
|
doc.brief != none
|
|
|
|
|
|| doc.desc != none
|
|
|
|
|
|| doc.return != none;
|
|
|
|
|
ret doc;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
fn fold_fnlist(
|
|
|
|
|
fold: fold::fold<ctxt>,
|
|
|
|
|
list: doc::fnlist
|
|
|
|
|
) -> doc::fnlist {
|
|
|
|
|
doc::fnlist(vec::filter_map(*list) {|doc|
|
|
|
|
|
let doc = fold_fn(fold, doc);
|
|
|
|
|
if fold.ctxt.have_docs {
|
|
|
|
|
some(doc)
|
|
|
|
|
} else {
|
|
|
|
|
none
|
|
|
|
|
}
|
|
|
|
|
})
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
#[cfg(test)]
|
|
|
|
|
mod tests {
|
|
|
|
|
#[test]
|
|
|
|
|
fn should_elide_undocumented_fns() {
|
|
|
|
|
let source = "fn a() { }";
|
2012-01-17 16:12:31 -08:00
|
|
|
let srv = astsrv::mk_srv_from_str(source);
|
2012-01-16 22:50:00 -08:00
|
|
|
let doc = extract::from_srv(srv, "");
|
|
|
|
|
let doc = run(srv, doc);
|
|
|
|
|
assert vec::is_empty(*doc.topmod.fns);
|
|
|
|
|
}
|
|
|
|
|
}
|