rust/src/rustdoc/fold.rs

372 lines
9.4 KiB
Rust
Raw Normal View History

2012-01-16 16:49:40 -06:00
export fold;
export default_seq_fold;
export default_seq_fold_doc;
export default_seq_fold_crate;
2012-02-17 17:51:58 -06:00
export default_seq_fold_item;
export default_seq_fold_mod;
2012-02-24 15:34:35 -06:00
export default_seq_fold_nmod;
export default_seq_fold_fn;
2012-01-24 02:44:47 -06:00
export default_seq_fold_const;
2012-01-25 20:40:47 -06:00
export default_seq_fold_enum;
export default_seq_fold_trait;
2012-01-31 17:28:09 -06:00
export default_seq_fold_impl;
2012-02-02 00:41:41 -06:00
export default_seq_fold_type;
2012-02-21 00:08:24 -06:00
export default_par_fold;
export default_par_fold_mod;
export default_par_fold_nmod;
export default_any_fold;
export default_any_fold_mod;
export default_any_fold_nmod;
2012-01-16 16:49:40 -06:00
enum fold<T> = t<T>;
2012-01-16 16:49:40 -06:00
type fold_doc<T> = fn~(fold: fold<T>, doc: doc::doc) -> doc::doc;
2012-01-19 02:14:41 -06:00
type fold_crate<T> = fn~(fold: fold<T>, doc: doc::cratedoc) -> doc::cratedoc;
2012-02-17 17:51:58 -06:00
type fold_item<T> = fn~(fold: fold<T>, doc: doc::itemdoc) -> doc::itemdoc;
2012-01-19 02:14:41 -06:00
type fold_mod<T> = fn~(fold: fold<T>, doc: doc::moddoc) -> doc::moddoc;
2012-02-24 15:34:35 -06:00
type fold_nmod<T> = fn~(fold: fold<T>, doc: doc::nmoddoc) -> doc::nmoddoc;
2012-01-19 02:14:41 -06:00
type fold_fn<T> = fn~(fold: fold<T>, doc: doc::fndoc) -> doc::fndoc;
type fold_const<T> = fn~(fold: fold<T>, doc: doc::constdoc) -> doc::constdoc;
2012-01-25 18:56:28 -06:00
type fold_enum<T> = fn~(fold: fold<T>, doc: doc::enumdoc) -> doc::enumdoc;
type fold_trait<T> = fn~(fold: fold<T>, doc: doc::traitdoc) -> doc::traitdoc;
2012-01-31 17:28:09 -06:00
type fold_impl<T> = fn~(fold: fold<T>, doc: doc::impldoc) -> doc::impldoc;
2012-02-02 00:41:41 -06:00
type fold_type<T> = fn~(fold: fold<T>, doc: doc::tydoc) -> doc::tydoc;
2012-01-16 16:49:40 -06:00
type t<T> = {
ctxt: T,
fold_doc: fold_doc<T>,
fold_crate: fold_crate<T>,
2012-02-17 17:51:58 -06:00
fold_item: fold_item<T>,
fold_mod: fold_mod<T>,
2012-02-24 15:34:35 -06:00
fold_nmod: fold_nmod<T>,
fold_fn: fold_fn<T>,
fold_const: fold_const<T>,
2012-01-25 18:56:28 -06:00
fold_enum: fold_enum<T>,
fold_trait: fold_trait<T>,
2012-02-02 00:41:41 -06:00
fold_impl: fold_impl<T>,
fold_type: fold_type<T>
2012-01-16 16:49:40 -06:00
};
// This exists because fn types don't infer correctly as record
// initializers, but they do as function arguments
fn mk_fold<T:copy>(
ctxt: T,
+fold_doc: fold_doc<T>,
+fold_crate: fold_crate<T>,
+fold_item: fold_item<T>,
+fold_mod: fold_mod<T>,
+fold_nmod: fold_nmod<T>,
+fold_fn: fold_fn<T>,
+fold_const: fold_const<T>,
+fold_enum: fold_enum<T>,
+fold_trait: fold_trait<T>,
+fold_impl: fold_impl<T>,
+fold_type: fold_type<T>
) -> fold<T> {
2012-01-16 16:49:40 -06:00
fold({
ctxt: ctxt,
fold_doc: fold_doc,
2012-01-16 16:49:40 -06:00
fold_crate: fold_crate,
2012-02-17 17:51:58 -06:00
fold_item: fold_item,
2012-01-16 16:49:40 -06:00
fold_mod: fold_mod,
2012-02-24 15:34:35 -06:00
fold_nmod: fold_nmod,
2012-01-16 16:49:40 -06:00
fold_fn: fold_fn,
fold_const: fold_const,
2012-01-25 18:56:28 -06:00
fold_enum: fold_enum,
fold_trait: fold_trait,
2012-02-02 00:41:41 -06:00
fold_impl: fold_impl,
fold_type: fold_type
2012-01-16 16:49:40 -06:00
})
}
fn default_any_fold<T:send copy>(ctxt: T) -> fold<T> {
2012-02-27 00:38:35 -06:00
mk_fold(
ctxt,
2012-06-30 18:19:07 -05:00
|f, d| default_seq_fold_doc(f, d),
|f, d| default_seq_fold_crate(f, d),
|f, d| default_seq_fold_item(f, d),
|f, d| default_any_fold_mod(f, d),
|f, d| default_any_fold_nmod(f, d),
|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_trait(f, d),
2012-06-30 18:19:07 -05:00
|f, d| default_seq_fold_impl(f, d),
|f, d| default_seq_fold_type(f, d)
2012-02-27 00:38:35 -06:00
)
}
fn default_seq_fold<T:copy>(ctxt: T) -> fold<T> {
2012-01-16 16:49:40 -06:00
mk_fold(
ctxt,
2012-06-30 18:19:07 -05:00
|f, d| default_seq_fold_doc(f, d),
|f, d| default_seq_fold_crate(f, d),
|f, d| default_seq_fold_item(f, d),
|f, d| default_seq_fold_mod(f, d),
|f, d| default_seq_fold_nmod(f, d),
|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_trait(f, d),
2012-06-30 18:19:07 -05:00
|f, d| default_seq_fold_impl(f, d),
|f, d| default_seq_fold_type(f, d)
2012-01-16 16:49:40 -06:00
)
}
fn default_par_fold<T:send copy>(ctxt: T) -> fold<T> {
2012-02-21 00:08:24 -06:00
mk_fold(
ctxt,
2012-06-30 18:19:07 -05:00
|f, d| default_seq_fold_doc(f, d),
|f, d| default_seq_fold_crate(f, d),
|f, d| default_seq_fold_item(f, d),
|f, d| default_par_fold_mod(f, d),
|f, d| default_par_fold_nmod(f, d),
|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_trait(f, d),
2012-06-30 18:19:07 -05:00
|f, d| default_seq_fold_impl(f, d),
|f, d| default_seq_fold_type(f, d)
2012-02-21 00:08:24 -06:00
)
}
fn default_seq_fold_doc<T>(fold: fold<T>, doc: doc::doc) -> doc::doc {
doc::doc_({
pages: do vec::map(doc.pages) |page| {
2012-08-06 14:34:08 -05:00
match page {
2012-08-03 21:59:04 -05:00
doc::cratepage(doc) => {
doc::cratepage(fold.fold_crate(fold, doc))
}
2012-08-03 21:59:04 -05:00
doc::itempage(doc) => {
doc::itempage(fold_itemtag(fold, doc))
}
}
}
with *doc
})
}
fn default_seq_fold_crate<T>(
fold: fold<T>,
2012-01-16 16:49:40 -06:00
doc: doc::cratedoc
) -> doc::cratedoc {
2012-01-30 15:05:25 -06:00
{
2012-01-16 16:49:40 -06:00
topmod: fold.fold_mod(fold, doc.topmod)
}
}
2012-02-17 17:51:58 -06:00
fn default_seq_fold_item<T>(
_fold: fold<T>,
doc: doc::itemdoc
) -> doc::itemdoc {
doc
}
fn default_any_fold_mod<T:send copy>(
fold: fold<T>,
2012-01-16 16:49:40 -06:00
doc: doc::moddoc
) -> doc::moddoc {
doc::moddoc_({
2012-02-17 17:51:58 -06:00
item: fold.fold_item(fold, doc.item),
items: par::map(doc.items, |itemtag, copy fold| {
2012-02-21 00:08:24 -06:00
fold_itemtag(fold, itemtag)
})
with *doc
})
2012-02-21 00:08:24 -06:00
}
2012-02-27 00:38:35 -06:00
fn default_seq_fold_mod<T>(
2012-02-24 15:34:35 -06:00
fold: fold<T>,
2012-02-27 00:38:35 -06:00
doc: doc::moddoc
) -> doc::moddoc {
doc::moddoc_({
2012-02-24 15:34:35 -06:00
item: fold.fold_item(fold, doc.item),
items: vec::map(doc.items, |itemtag| {
2012-02-27 00:38:35 -06:00
fold_itemtag(fold, itemtag)
})
with *doc
})
2012-02-24 15:34:35 -06:00
}
fn default_par_fold_mod<T:send copy>(
2012-02-21 00:08:24 -06:00
fold: fold<T>,
doc: doc::moddoc
) -> doc::moddoc {
doc::moddoc_({
2012-02-21 00:08:24 -06:00
item: fold.fold_item(fold, doc.item),
items: par::map(doc.items, |itemtag, copy fold| {
2012-02-21 00:08:24 -06:00
fold_itemtag(fold, itemtag)
})
with *doc
})
2012-01-16 16:49:40 -06:00
}
fn default_any_fold_nmod<T:send copy>(
fold: fold<T>,
doc: doc::nmoddoc
) -> doc::nmoddoc {
{
item: fold.fold_item(fold, doc.item),
fns: par::map(doc.fns, |fndoc, copy fold| {
fold.fold_fn(fold, fndoc)
})
with doc
}
}
2012-02-27 00:38:35 -06:00
fn default_seq_fold_nmod<T>(
fold: fold<T>,
2012-02-27 00:38:35 -06:00
doc: doc::nmoddoc
) -> doc::nmoddoc {
{
item: fold.fold_item(fold, doc.item),
fns: vec::map(doc.fns, |fndoc| {
fold.fold_fn(fold, fndoc)
})
with doc
}
}
fn default_par_fold_nmod<T:send copy>(
fold: fold<T>,
doc: doc::nmoddoc
) -> doc::nmoddoc {
{
item: fold.fold_item(fold, doc.item),
fns: par::map(doc.fns, |fndoc, copy fold| {
2012-02-27 00:38:35 -06:00
fold.fold_fn(fold, fndoc)
})
2012-02-27 00:38:35 -06:00
with doc
}
}
2012-02-21 00:08:24 -06:00
fn fold_itemtag<T>(fold: fold<T>, doc: doc::itemtag) -> doc::itemtag {
2012-08-06 14:34:08 -05:00
match doc {
2012-08-03 21:59:04 -05:00
doc::modtag(moddoc) => {
2012-02-21 00:08:24 -06:00
doc::modtag(fold.fold_mod(fold, moddoc))
}
2012-08-03 21:59:04 -05:00
doc::nmodtag(nmoddoc) => {
2012-02-24 15:34:35 -06:00
doc::nmodtag(fold.fold_nmod(fold, nmoddoc))
}
2012-08-03 21:59:04 -05:00
doc::fntag(fndoc) => {
2012-02-21 00:08:24 -06:00
doc::fntag(fold.fold_fn(fold, fndoc))
}
2012-08-03 21:59:04 -05:00
doc::consttag(constdoc) => {
2012-02-21 00:08:24 -06:00
doc::consttag(fold.fold_const(fold, constdoc))
}
2012-08-03 21:59:04 -05:00
doc::enumtag(enumdoc) => {
2012-02-21 00:08:24 -06:00
doc::enumtag(fold.fold_enum(fold, enumdoc))
}
2012-08-03 21:59:04 -05:00
doc::traittag(traitdoc) => {
doc::traittag(fold.fold_trait(fold, traitdoc))
2012-02-21 00:08:24 -06:00
}
2012-08-03 21:59:04 -05:00
doc::impltag(impldoc) => {
2012-02-21 00:08:24 -06:00
doc::impltag(fold.fold_impl(fold, impldoc))
}
2012-08-03 21:59:04 -05:00
doc::tytag(tydoc) => {
2012-02-21 00:08:24 -06:00
doc::tytag(fold.fold_type(fold, tydoc))
}
}
}
fn default_seq_fold_fn<T>(
2012-02-17 17:51:58 -06:00
fold: fold<T>,
2012-01-16 16:49:40 -06:00
doc: doc::fndoc
) -> doc::fndoc {
2012-02-17 17:51:58 -06:00
{
item: fold.fold_item(fold, doc.item)
with doc
}
2012-01-16 16:49:40 -06:00
}
fn default_seq_fold_const<T>(
2012-02-17 17:51:58 -06:00
fold: fold<T>,
doc: doc::constdoc
) -> doc::constdoc {
2012-02-17 17:51:58 -06:00
{
item: fold.fold_item(fold, doc.item)
with doc
}
}
2012-01-25 18:56:28 -06:00
fn default_seq_fold_enum<T>(
2012-02-17 17:51:58 -06:00
fold: fold<T>,
2012-01-25 18:56:28 -06:00
doc: doc::enumdoc
) -> doc::enumdoc {
2012-02-17 17:51:58 -06:00
{
item: fold.fold_item(fold, doc.item)
with doc
}
2012-01-25 18:56:28 -06:00
}
fn default_seq_fold_trait<T>(
2012-02-17 17:51:58 -06:00
fold: fold<T>,
doc: doc::traitdoc
) -> doc::traitdoc {
2012-02-17 17:51:58 -06:00
{
item: fold.fold_item(fold, doc.item)
with doc
}
2012-01-30 16:11:35 -06:00
}
2012-01-31 17:28:09 -06:00
fn default_seq_fold_impl<T>(
2012-02-17 17:51:58 -06:00
fold: fold<T>,
2012-01-31 17:28:09 -06:00
doc: doc::impldoc
) -> doc::impldoc {
2012-02-17 17:51:58 -06:00
{
item: fold.fold_item(fold, doc.item)
with doc
}
2012-01-31 17:28:09 -06:00
}
2012-02-02 00:41:41 -06:00
fn default_seq_fold_type<T>(
2012-02-17 17:51:58 -06:00
fold: fold<T>,
2012-02-02 00:41:41 -06:00
doc: doc::tydoc
) -> doc::tydoc {
2012-02-17 17:51:58 -06:00
{
item: fold.fold_item(fold, doc.item)
with doc
}
2012-02-02 00:41:41 -06:00
}
#[test]
fn default_fold_should_produce_same_doc() {
let source = ~"mod a { fn b() { } mod c { fn d() { } } }";
let ast = parse::from_str(source);
let doc = extract::extract(ast, ~"");
let fld = default_seq_fold(());
let folded = fld.fold_doc(fld, doc);
assert doc == folded;
}
#[test]
fn default_fold_should_produce_same_consts() {
let source = ~"const a: int = 0;";
let ast = parse::from_str(source);
let doc = extract::extract(ast, ~"");
let fld = default_seq_fold(());
let folded = fld.fold_doc(fld, doc);
assert doc == folded;
2012-01-25 18:56:28 -06:00
}
#[test]
fn default_fold_should_produce_same_enums() {
let source = ~"enum a { b }";
let ast = parse::from_str(source);
let doc = extract::extract(ast, ~"");
2012-01-25 18:56:28 -06:00
let fld = default_seq_fold(());
let folded = fld.fold_doc(fld, doc);
2012-01-25 18:56:28 -06:00
assert doc == folded;
2012-02-21 00:08:24 -06:00
}
#[test]
fn default_parallel_fold_should_produce_same_doc() {
let source = ~"mod a { fn b() { } mod c { fn d() { } } }";
let ast = parse::from_str(source);
let doc = extract::extract(ast, ~"");
2012-02-21 00:08:24 -06:00
let fld = default_par_fold(());
let folded = fld.fold_doc(fld, doc);
2012-02-21 00:08:24 -06:00
assert doc == folded;
}