2012-01-24 21:16:01 -08:00
|
|
|
#[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({
|
2012-02-17 15:59:57 -08:00
|
|
|
fold_item: fold_item,
|
2012-01-25 18:51:46 -08:00
|
|
|
fold_fn: fold_fn,
|
2012-01-26 22:27:13 -08:00
|
|
|
fold_enum: fold_enum,
|
2012-01-30 19:36:58 -08:00
|
|
|
fold_res: fold_res,
|
2012-01-31 20:42:06 -08:00
|
|
|
fold_iface: fold_iface,
|
2012-02-17 15:59:57 -08:00
|
|
|
fold_impl: fold_impl
|
2012-01-24 21:16:01 -08:00
|
|
|
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) }
|
|
|
|
}
|
|
|
|
|
2012-02-17 15:59:57 -08:00
|
|
|
fn fold_item(fold: fold::fold<op>, doc: doc::itemdoc) -> doc::itemdoc {
|
|
|
|
let doc = fold::default_seq_fold_item(fold, doc);
|
2012-01-24 21:16:01 -08:00
|
|
|
|
2012-01-30 13:05:25 -08:00
|
|
|
{
|
2012-02-17 15:59:57 -08:00
|
|
|
brief: maybe_apply_op(fold.ctxt, doc.brief),
|
|
|
|
desc: maybe_apply_op(fold.ctxt, doc.desc)
|
2012-01-30 13:05:25 -08:00
|
|
|
with doc
|
2012-01-24 21:16:01 -08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
fn fold_fn(fold: fold::fold<op>, doc: doc::fndoc) -> doc::fndoc {
|
|
|
|
let doc = fold::default_seq_fold_fn(fold, doc);
|
|
|
|
|
2012-01-30 13:05:25 -08:00
|
|
|
{
|
2012-01-24 21:16:01 -08:00
|
|
|
args: vec::map(doc.args) {|doc|
|
2012-01-30 13:05:25 -08:00
|
|
|
{
|
2012-01-24 21:16:01 -08:00
|
|
|
desc: maybe_apply_op(fold.ctxt, doc.desc)
|
2012-01-30 13:05:25 -08:00
|
|
|
with doc
|
2012-01-24 21:16:01 -08:00
|
|
|
}
|
|
|
|
},
|
|
|
|
return: {
|
|
|
|
desc: maybe_apply_op(fold.ctxt, doc.return.desc)
|
|
|
|
with doc.return
|
|
|
|
},
|
|
|
|
failure: maybe_apply_op(fold.ctxt, doc.failure)
|
2012-01-30 13:05:25 -08:00
|
|
|
with doc
|
2012-01-24 21:16:01 -08:00
|
|
|
}
|
|
|
|
}
|
2012-01-25 18:51:46 -08:00
|
|
|
|
|
|
|
fn fold_enum(fold: fold::fold<op>, doc: doc::enumdoc) -> doc::enumdoc {
|
2012-02-17 15:59:57 -08:00
|
|
|
let doc = fold::default_seq_fold_enum(fold, doc);
|
|
|
|
|
2012-01-30 13:05:25 -08:00
|
|
|
{
|
2012-01-25 18:51:46 -08:00
|
|
|
variants: vec::map(doc.variants) {|variant|
|
2012-01-30 13:05:25 -08:00
|
|
|
{
|
2012-01-25 18:51:46 -08:00
|
|
|
desc: maybe_apply_op(fold.ctxt, variant.desc)
|
2012-01-30 13:05:25 -08:00
|
|
|
with variant
|
2012-01-25 18:51:46 -08:00
|
|
|
}
|
|
|
|
}
|
2012-01-30 13:05:25 -08:00
|
|
|
with doc
|
2012-01-25 18:51:46 -08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2012-01-26 22:27:13 -08:00
|
|
|
fn fold_res(fold: fold::fold<op>, doc: doc::resdoc) -> doc::resdoc {
|
2012-02-17 15:59:57 -08:00
|
|
|
let doc = fold::default_seq_fold_res(fold, doc);
|
|
|
|
|
2012-01-30 13:05:25 -08:00
|
|
|
{
|
2012-01-26 22:27:13 -08:00
|
|
|
args: vec::map(doc.args) {|arg|
|
2012-01-30 13:05:25 -08:00
|
|
|
{
|
2012-01-26 22:27:13 -08:00
|
|
|
desc: maybe_apply_op(fold.ctxt, arg.desc)
|
2012-01-30 13:05:25 -08:00
|
|
|
with arg
|
2012-01-26 22:27:13 -08:00
|
|
|
}
|
|
|
|
}
|
2012-01-30 13:05:25 -08:00
|
|
|
with doc
|
2012-01-26 22:27:13 -08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2012-01-30 19:36:58 -08:00
|
|
|
fn fold_iface(fold: fold::fold<op>, doc: doc::ifacedoc) -> doc::ifacedoc {
|
2012-02-17 15:59:57 -08:00
|
|
|
let doc = fold::default_seq_fold_iface(fold, doc);
|
|
|
|
|
2012-01-30 19:36:58 -08:00
|
|
|
{
|
2012-01-31 20:42:06 -08:00
|
|
|
methods: apply_to_methods(fold.ctxt, doc.methods)
|
|
|
|
with doc
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
fn apply_to_methods(op: op, docs: [doc::methoddoc]) -> [doc::methoddoc] {
|
|
|
|
vec::map(docs) {|doc|
|
|
|
|
{
|
|
|
|
brief: maybe_apply_op(op, doc.brief),
|
|
|
|
desc: maybe_apply_op(op, doc.desc),
|
|
|
|
args: vec::map(doc.args) {|doc|
|
|
|
|
{
|
|
|
|
desc: maybe_apply_op(op, doc.desc)
|
|
|
|
with doc
|
|
|
|
}
|
|
|
|
},
|
|
|
|
return: {
|
|
|
|
desc: maybe_apply_op(op, doc.return.desc)
|
|
|
|
with doc.return
|
|
|
|
},
|
|
|
|
failure: maybe_apply_op(op, doc.failure)
|
|
|
|
with doc
|
2012-01-30 19:36:58 -08:00
|
|
|
}
|
2012-01-31 20:42:06 -08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
fn fold_impl(fold: fold::fold<op>, doc: doc::impldoc) -> doc::impldoc {
|
2012-02-17 15:59:57 -08:00
|
|
|
let doc = fold::default_seq_fold_impl(fold, doc);
|
2012-01-30 19:36:58 -08:00
|
|
|
|
2012-02-01 22:41:41 -08:00
|
|
|
{
|
2012-02-17 15:59:57 -08:00
|
|
|
methods: apply_to_methods(fold.ctxt, doc.methods)
|
2012-02-01 22:41:41 -08:00
|
|
|
with doc
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2012-01-25 18:51:46 -08:00
|
|
|
#[test]
|
|
|
|
fn should_execute_op_on_enum_brief() {
|
2012-01-31 18:32:37 -08:00
|
|
|
let doc = test::mk_doc("#[doc(brief = \" a \")] enum a { b }");
|
2012-02-17 14:46:30 -08:00
|
|
|
assert doc.topmod.enums()[0].brief() == some("a");
|
2012-01-25 18:51:46 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn should_execute_op_on_enum_desc() {
|
2012-01-31 18:32:37 -08:00
|
|
|
let doc = test::mk_doc("#[doc(desc = \" a \")] enum a { b }");
|
2012-02-17 14:46:30 -08:00
|
|
|
assert doc.topmod.enums()[0].desc() == some("a");
|
2012-01-25 18:51:46 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn should_execute_op_on_variant_desc() {
|
2012-01-31 18:32:37 -08:00
|
|
|
let doc = test::mk_doc("enum a { #[doc = \" a \"] b }");
|
2012-01-28 15:04:36 -08:00
|
|
|
assert doc.topmod.enums()[0].variants[0].desc == some("a");
|
2012-01-26 22:27:13 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn should_execute_op_on_resource_brief() {
|
2012-01-31 18:32:37 -08:00
|
|
|
let doc = test::mk_doc("#[doc(brief = \" a \")] resource r(a: bool) { }");
|
2012-02-17 14:46:30 -08:00
|
|
|
assert doc.topmod.resources()[0].brief() == some("a");
|
2012-01-26 22:27:13 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn should_execute_op_on_resource_desc() {
|
2012-01-31 18:32:37 -08:00
|
|
|
let doc = test::mk_doc("#[doc(desc = \" a \")] resource r(a: bool) { }");
|
2012-02-17 14:46:30 -08:00
|
|
|
assert doc.topmod.resources()[0].desc() == some("a");
|
2012-01-26 22:27:13 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn should_execute_op_on_resource_args() {
|
2012-01-31 18:32:37 -08:00
|
|
|
let doc = test::mk_doc(
|
|
|
|
"#[doc(args(a = \" a \"))] resource r(a: bool) { }");
|
2012-01-28 14:36:35 -08:00
|
|
|
assert doc.topmod.resources()[0].args[0].desc == some("a");
|
2012-01-30 19:36:58 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn should_execute_op_on_iface_brief() {
|
2012-01-31 18:32:37 -08:00
|
|
|
let doc = test::mk_doc(
|
|
|
|
"#[doc(brief = \" a \")] iface i { fn a(); }");
|
2012-02-17 14:46:30 -08:00
|
|
|
assert doc.topmod.ifaces()[0].brief() == some("a");
|
2012-01-30 19:36:58 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn should_execute_op_on_iface_desc() {
|
2012-01-31 18:32:37 -08:00
|
|
|
let doc = test::mk_doc(
|
|
|
|
"#[doc(desc = \" a \")] iface i { fn a(); }");
|
2012-02-17 14:46:30 -08:00
|
|
|
assert doc.topmod.ifaces()[0].desc() == some("a");
|
2012-01-30 19:36:58 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn should_execute_op_on_iface_method_brief() {
|
2012-01-31 18:32:37 -08:00
|
|
|
let doc = test::mk_doc(
|
|
|
|
"iface i { #[doc(brief = \" a \")] fn a(); }");
|
2012-01-30 19:36:58 -08:00
|
|
|
assert doc.topmod.ifaces()[0].methods[0].brief == some("a");
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn should_execute_op_on_iface_method_desc() {
|
2012-01-31 18:32:37 -08:00
|
|
|
let doc = test::mk_doc(
|
|
|
|
"iface i { #[doc(desc = \" a \")] fn a(); }");
|
2012-01-30 19:36:58 -08:00
|
|
|
assert doc.topmod.ifaces()[0].methods[0].desc == some("a");
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn should_execute_op_on_iface_method_args() {
|
2012-01-31 18:32:37 -08:00
|
|
|
let doc = test::mk_doc(
|
|
|
|
"iface i { #[doc(args(a = \" a \"))] fn a(a: bool); }");
|
2012-01-30 19:36:58 -08:00
|
|
|
assert doc.topmod.ifaces()[0].methods[0].args[0].desc == some("a");
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn should_execute_op_on_iface_method_return() {
|
2012-01-31 18:32:37 -08:00
|
|
|
let doc = test::mk_doc(
|
|
|
|
"iface i { #[doc(return = \" a \")] fn a() -> int; }");
|
2012-01-30 19:36:58 -08:00
|
|
|
assert doc.topmod.ifaces()[0].methods[0].return.desc == some("a");
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn should_execute_op_on_iface_method_failure_condition() {
|
2012-01-31 18:32:37 -08:00
|
|
|
let doc = test::mk_doc("iface i { #[doc(failure = \" a \")] fn a(); }");
|
2012-01-30 19:36:58 -08:00
|
|
|
assert doc.topmod.ifaces()[0].methods[0].failure == some("a");
|
|
|
|
}
|
2012-01-31 18:32:37 -08:00
|
|
|
|
2012-01-31 20:42:06 -08:00
|
|
|
#[test]
|
|
|
|
fn should_execute_op_on_impl_brief() {
|
|
|
|
let doc = test::mk_doc(
|
|
|
|
"#[doc(brief = \" a \")] impl i for int { fn a() { } }");
|
2012-02-17 14:46:30 -08:00
|
|
|
assert doc.topmod.impls()[0].brief() == some("a");
|
2012-01-31 20:42:06 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn should_execute_op_on_impl_desc() {
|
|
|
|
let doc = test::mk_doc(
|
|
|
|
"#[doc(desc = \" a \")] impl i for int { fn a() { } }");
|
2012-02-17 14:46:30 -08:00
|
|
|
assert doc.topmod.impls()[0].desc() == some("a");
|
2012-01-31 20:42:06 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn should_execute_op_on_impl_method_brief() {
|
|
|
|
let doc = test::mk_doc(
|
|
|
|
"impl i for int { #[doc(brief = \" a \")] fn a() { } }");
|
|
|
|
assert doc.topmod.impls()[0].methods[0].brief == some("a");
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn should_execute_op_on_impl_method_desc() {
|
|
|
|
let doc = test::mk_doc(
|
|
|
|
"impl i for int { #[doc(desc = \" a \")] fn a() { } }");
|
|
|
|
assert doc.topmod.impls()[0].methods[0].desc == some("a");
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn should_execute_op_on_impl_method_args() {
|
|
|
|
let doc = test::mk_doc(
|
|
|
|
"impl i for int { #[doc(args(a = \" a \"))] fn a(a: bool) { } }");
|
|
|
|
assert doc.topmod.impls()[0].methods[0].args[0].desc == some("a");
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn should_execute_op_on_impl_method_return() {
|
|
|
|
let doc = test::mk_doc(
|
|
|
|
"impl i for int { #[doc(return = \" a \")] fn a() -> int { fail } }");
|
|
|
|
assert doc.topmod.impls()[0].methods[0].return.desc == some("a");
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn should_execute_op_on_impl_method_failure_condition() {
|
|
|
|
let doc = test::mk_doc(
|
|
|
|
"impl i for int { #[doc(failure = \" a \")] fn a() { } }");
|
|
|
|
assert doc.topmod.impls()[0].methods[0].failure == some("a");
|
|
|
|
}
|
|
|
|
|
2012-02-01 22:41:41 -08:00
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn should_execute_op_on_type_brief() {
|
|
|
|
let doc = test::mk_doc(
|
|
|
|
"#[doc(brief = \" a \")] type t = int;");
|
2012-02-17 14:46:30 -08:00
|
|
|
assert doc.topmod.types()[0].brief() == some("a");
|
2012-02-01 22:41:41 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn should_execute_op_on_type_desc() {
|
|
|
|
let doc = test::mk_doc(
|
|
|
|
"#[doc(desc = \" a \")] type t = int;");
|
2012-02-17 14:46:30 -08:00
|
|
|
assert doc.topmod.types()[0].desc() == some("a");
|
2012-02-01 22:41:41 -08:00
|
|
|
}
|
|
|
|
|
2012-01-31 18:32:37 -08:00
|
|
|
#[cfg(test)]
|
|
|
|
mod test {
|
|
|
|
fn mk_doc(source: str) -> doc::cratedoc {
|
2012-02-20 20:44:33 -08:00
|
|
|
let srv = astsrv::from_str(source);
|
2012-01-31 18:32:37 -08:00
|
|
|
let doc = extract::from_srv(srv, "");
|
|
|
|
let doc = attr_pass::mk_pass()(srv, doc);
|
|
|
|
mk_pass(str::trim)(srv, doc)
|
|
|
|
}
|
|
|
|
}
|