Skip to content

Commit

Permalink
rustdoc: Extract a general apply-function-to-strings pass from trim_pass
Browse files Browse the repository at this point in the history
  • Loading branch information
brson committed Jan 25, 2012
1 parent e7d7f4e commit e869458
Show file tree
Hide file tree
Showing 3 changed files with 78 additions and 65 deletions.
70 changes: 70 additions & 0 deletions src/rustdoc/desc_pass.rs
@@ -0,0 +1,70 @@
#[doc = "Generic pass for performing an operation on all descriptions"];

export mk_pass;

fn mk_pass(op: fn~(str) -> str) -> pass {
fn~(srv: astsrv::srv, doc: doc::cratedoc) -> doc::cratedoc {
run(srv, doc, op)
}
}

type op = fn~(str) -> str;

fn run(
_srv: astsrv::srv,
doc: doc::cratedoc,
op: op
) -> doc::cratedoc {
let fold = fold::fold({
fold_mod: fold_mod,
fold_const: fold_const,
fold_fn: fold_fn
with *fold::default_seq_fold(op)
});
fold.fold_crate(fold, doc)
}

fn maybe_apply_op(op: op, s: option<str>) -> option<str> {
option::map(s) {|s| op(s) }
}

fn fold_mod(fold: fold::fold<op>, doc: doc::moddoc) -> doc::moddoc {
let doc = fold::default_seq_fold_mod(fold, doc);

~{
brief: maybe_apply_op(fold.ctxt, doc.brief),
desc: maybe_apply_op(fold.ctxt, doc.desc)
with *doc
}
}

fn fold_const(fold: fold::fold<op>, doc: doc::constdoc) -> doc::constdoc {
let doc = fold::default_seq_fold_const(fold, doc);

~{
brief: maybe_apply_op(fold.ctxt, doc.brief),
desc: maybe_apply_op(fold.ctxt, doc.desc)
with *doc
}
}

fn fold_fn(fold: fold::fold<op>, doc: doc::fndoc) -> doc::fndoc {
let doc = fold::default_seq_fold_fn(fold, doc);

~{
brief: maybe_apply_op(fold.ctxt, doc.brief),
desc: maybe_apply_op(fold.ctxt, doc.desc),
args: vec::map(doc.args) {|doc|
~{
desc: maybe_apply_op(fold.ctxt, doc.desc)
with *doc
}
},
return: {
desc: maybe_apply_op(fold.ctxt, doc.return.desc)
with doc.return
},
failure: maybe_apply_op(fold.ctxt, doc.failure)
with *doc
}
}
1 change: 1 addition & 0 deletions src/rustdoc/rustdoc.rc
Expand Up @@ -24,6 +24,7 @@ mod tystr_pass;
mod prune_undoc_pass;
mod prune_unexported_pass;
mod desc_to_brief_pass;
mod desc_pass;
mod trim_pass;
mod astsrv;
mod demo;
72 changes: 7 additions & 65 deletions src/rustdoc/trim_pass.rs
Expand Up @@ -10,34 +10,7 @@ is interpreted as the brief description.
export mk_pass;

fn mk_pass() -> pass {
run
}

fn run(
_srv: astsrv::srv,
doc: doc::cratedoc
) -> doc::cratedoc {
let fold = fold::fold({
fold_mod: fold_mod,
fold_const: fold_const,
fold_fn: fold_fn
with *fold::default_seq_fold(())
});
fold.fold_crate(fold, doc)
}

fn trimopt(s: option<str>) -> option<str> {
option::map(s, {|s| str::trim(s) })
}

fn fold_mod(fold: fold::fold<()>, doc: doc::moddoc) -> doc::moddoc {
let doc = fold::default_seq_fold_mod(fold, doc);

~{
brief: trimopt(doc.brief),
desc: trimopt(doc.desc)
with *doc
}
desc_pass::mk_pass(str::trim)
}

#[test]
Expand All @@ -48,21 +21,11 @@ fn should_trim_mod() {
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);
let doc = mk_pass()(srv, doc);
assert doc.topmod.mods[0].brief == some("brief");
assert doc.topmod.mods[0].desc == some("desc");
}

fn fold_const(fold: fold::fold<()>, doc: doc::constdoc) -> doc::constdoc {
let doc = fold::default_seq_fold_const(fold, doc);

~{
brief: trimopt(doc.brief),
desc: trimopt(doc.desc)
with *doc
}
}

#[test]
fn should_trim_const() {
let source = "#[doc(brief = \"\nbrief\n\", \
Expand All @@ -71,32 +34,11 @@ fn should_trim_const() {
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);
let doc = mk_pass()(srv, doc);
assert doc.topmod.consts[0].brief == some("brief");
assert doc.topmod.consts[0].desc == some("desc");
}

fn fold_fn(fold: fold::fold<()>, doc: doc::fndoc) -> doc::fndoc {
let doc = fold::default_seq_fold_fn(fold, doc);

~{
brief: trimopt(doc.brief),
desc: trimopt(doc.desc),
args: vec::map(doc.args) {|doc|
~{
desc: trimopt(doc.desc)
with *doc
}
},
return: {
desc: trimopt(doc.return.desc)
with doc.return
},
failure: trimopt(doc.failure)
with *doc
}
}

#[test]
fn should_trim_fn() {
let source = "#[doc(brief = \"\nbrief\n\", \
Expand All @@ -105,7 +47,7 @@ fn should_trim_fn() {
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);
let doc = mk_pass()(srv, doc);
assert doc.topmod.fns[0].brief == some("brief");
assert doc.topmod.fns[0].desc == some("desc");
}
Expand All @@ -116,7 +58,7 @@ fn should_trim_args() {
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);
let doc = mk_pass()(srv, doc);
assert doc.topmod.fns[0].args[0].desc == some("a");
}

Expand All @@ -126,7 +68,7 @@ fn should_trim_ret() {
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);
let doc = mk_pass()(srv, doc);
assert doc.topmod.fns[0].return.desc == some("a");
}

Expand All @@ -136,6 +78,6 @@ fn should_trim_failure_conditions() {
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);
let doc = mk_pass()(srv, doc);
assert doc.topmod.fns[0].failure == some("a");
}

0 comments on commit e869458

Please sign in to comment.