From d3aa1748461e1220fb26a6e556a78b88a32cc2bd Mon Sep 17 00:00:00 2001 From: Brian Anderson Date: Mon, 30 Jan 2012 14:11:35 -0800 Subject: [PATCH] rustdoc: Add definition of iface docs --- src/rustdoc/doc.rs | 31 ++++++++++++++++++++++++++++++- src/rustdoc/fold.rs | 24 ++++++++++++++++++++---- 2 files changed, 50 insertions(+), 5 deletions(-) diff --git a/src/rustdoc/doc.rs b/src/rustdoc/doc.rs index a171bbc36d12..695ae1c19113 100644 --- a/src/rustdoc/doc.rs +++ b/src/rustdoc/doc.rs @@ -11,7 +11,8 @@ enum itemtag { consttag(constdoc), fntag(fndoc), enumtag(enumdoc), - restag(resdoc) + restag(resdoc), + ifacetag(ifacedoc) } type moddoc = { @@ -77,6 +78,24 @@ type resdoc = { sig: option }; +type ifacedoc = { + id: ast_id, + name: str, + brief: option, + desc: option, + methods: [methoddoc] +}; + +type methoddoc = { + name: str, + brief: option, + desc: option, + args: [argdoc], + return: retdoc, + failure: option, + sig: option +}; + impl util for moddoc { fn mods() -> [moddoc] { @@ -123,6 +142,15 @@ impl util for moddoc { } } } + + fn ifaces() -> [ifacedoc] { + vec::filter_map(*self.items) {|itemtag| + alt itemtag { + ifacetag(ifacedoc) { some(ifacedoc) } + _ { none } + } + } + } } impl util for itemtag { @@ -133,6 +161,7 @@ impl util for itemtag { doc::consttag({name, _}) { name } doc::enumtag({name, _}) { name } doc::restag({name, _}) { name } + doc::ifacetag({name, _}) { name } } } } diff --git a/src/rustdoc/fold.rs b/src/rustdoc/fold.rs index 0516a753ff35..6851299db87d 100644 --- a/src/rustdoc/fold.rs +++ b/src/rustdoc/fold.rs @@ -10,6 +10,7 @@ export default_seq_fold_fn; export default_seq_fold_const; export default_seq_fold_enum; export default_seq_fold_res; +export default_seq_fold_iface; enum fold = t; @@ -19,6 +20,7 @@ type fold_fn = fn~(fold: fold, doc: doc::fndoc) -> doc::fndoc; type fold_const = fn~(fold: fold, doc: doc::constdoc) -> doc::constdoc; type fold_enum = fn~(fold: fold, doc: doc::enumdoc) -> doc::enumdoc; type fold_res = fn~(fold: fold, doc: doc::resdoc) -> doc::resdoc; +type fold_iface = fn~(fold: fold, doc: doc::ifacedoc) -> doc::ifacedoc; type t = { ctxt: T, @@ -27,7 +29,8 @@ type t = { fold_fn: fold_fn, fold_const: fold_const, fold_enum: fold_enum, - fold_res: fold_res + fold_res: fold_res, + fold_iface: fold_iface }; @@ -40,7 +43,8 @@ fn mk_fold( fold_fn: fold_fn, fold_const: fold_const, fold_enum: fold_enum, - fold_res: fold_res + fold_res: fold_res, + fold_iface: fold_iface ) -> fold { fold({ ctxt: ctxt, @@ -49,7 +53,8 @@ fn mk_fold( fold_fn: fold_fn, fold_const: fold_const, fold_enum: fold_enum, - fold_res: fold_res + fold_res: fold_res, + fold_iface: fold_iface }) } @@ -61,7 +66,8 @@ fn default_seq_fold(ctxt: T) -> fold { {|f, d| default_seq_fold_fn(f, d)}, {|f, d| default_seq_fold_const(f, d)}, {|f, d| default_seq_fold_enum(f, d)}, - {|f, d| default_seq_fold_res(f, d)} + {|f, d| default_seq_fold_res(f, d)}, + {|f, d| default_seq_fold_iface(f, d)} ) } @@ -96,6 +102,9 @@ fn default_seq_fold_mod( doc::restag(resdoc) { doc::restag(fold.fold_res(fold, resdoc)) } + doc::ifacetag(ifacedoc) { + doc::ifacetag(fold.fold_iface(fold, ifacedoc)) + } } } with doc @@ -130,6 +139,13 @@ fn default_seq_fold_res( doc } +fn default_seq_fold_iface( + _fold: fold, + doc: doc::ifacedoc +) -> doc::ifacedoc { + doc +} + #[test] fn default_fold_should_produce_same_doc() { let source = "mod a { fn b() { } mod c { fn d() { } } }";