2012-07-04 22:53:12 +01:00
|
|
|
//! Build indexes as appropriate for the markdown pass
|
2012-03-02 15:17:13 -08:00
|
|
|
|
|
|
|
export mk_pass;
|
|
|
|
|
2012-03-06 15:57:36 -08:00
|
|
|
fn mk_pass(config: config::config) -> pass {
|
2012-03-02 15:17:13 -08:00
|
|
|
{
|
|
|
|
name: "markdown_index",
|
2012-03-06 15:57:36 -08:00
|
|
|
f: fn~(srv: astsrv::srv, doc: doc::doc) -> doc::doc {
|
|
|
|
run(srv, doc, config)
|
|
|
|
}
|
2012-03-02 15:17:13 -08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2012-03-06 15:57:36 -08:00
|
|
|
fn run(
|
|
|
|
_srv: astsrv::srv,
|
|
|
|
doc: doc::doc,
|
|
|
|
config: config::config
|
|
|
|
) -> doc::doc {
|
2012-03-02 15:17:13 -08:00
|
|
|
let fold = fold::fold({
|
2012-03-11 16:36:20 -07:00
|
|
|
fold_mod: fold_mod,
|
|
|
|
fold_nmod: fold_nmod
|
|
|
|
with *fold::default_any_fold(config)
|
2012-03-02 15:17:13 -08:00
|
|
|
});
|
2012-03-02 18:33:25 -08:00
|
|
|
fold.fold_doc(fold, doc)
|
2012-03-02 15:17:13 -08:00
|
|
|
}
|
|
|
|
|
2012-03-06 15:57:36 -08:00
|
|
|
fn fold_mod(
|
|
|
|
fold: fold::fold<config::config>,
|
|
|
|
doc: doc::moddoc
|
|
|
|
) -> doc::moddoc {
|
2012-03-02 15:17:13 -08:00
|
|
|
|
|
|
|
let doc = fold::default_any_fold_mod(fold, doc);
|
|
|
|
|
|
|
|
{
|
2012-03-11 16:36:20 -07:00
|
|
|
index: some(build_mod_index(doc, fold.ctxt))
|
2012-03-02 15:17:13 -08:00
|
|
|
with doc
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2012-03-11 16:36:20 -07:00
|
|
|
fn fold_nmod(
|
|
|
|
fold: fold::fold<config::config>,
|
|
|
|
doc: doc::nmoddoc
|
|
|
|
) -> doc::nmoddoc {
|
|
|
|
|
|
|
|
let doc = fold::default_any_fold_nmod(fold, doc);
|
|
|
|
|
|
|
|
{
|
|
|
|
index: some(build_nmod_index(doc, fold.ctxt))
|
|
|
|
with doc
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
fn build_mod_index(
|
2012-03-06 15:57:36 -08:00
|
|
|
doc: doc::moddoc,
|
|
|
|
config: config::config
|
|
|
|
) -> doc::index {
|
2012-03-02 15:17:13 -08:00
|
|
|
{
|
2012-06-30 16:19:07 -07:00
|
|
|
entries: par::anymap(doc.items, |doc| {
|
2012-03-11 16:36:20 -07:00
|
|
|
item_to_entry(doc, config)
|
2012-06-26 13:55:56 -07:00
|
|
|
})
|
2012-03-11 16:36:20 -07:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
fn build_nmod_index(
|
|
|
|
doc: doc::nmoddoc,
|
|
|
|
config: config::config
|
|
|
|
) -> doc::index {
|
|
|
|
{
|
2012-06-30 16:19:07 -07:00
|
|
|
entries: par::anymap(doc.fns, |doc| {
|
2012-03-11 16:36:20 -07:00
|
|
|
item_to_entry(doc::fntag(doc), config)
|
2012-06-26 13:55:56 -07:00
|
|
|
})
|
2012-03-02 15:17:13 -08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2012-03-06 15:57:36 -08:00
|
|
|
fn item_to_entry(
|
|
|
|
doc: doc::itemtag,
|
|
|
|
config: config::config
|
|
|
|
) -> doc::index_entry {
|
|
|
|
let link = alt doc {
|
2012-03-10 16:44:48 -08:00
|
|
|
doc::modtag(_) | doc::nmodtag(_)
|
|
|
|
if config.output_style == config::doc_per_mod {
|
2012-03-06 15:57:36 -08:00
|
|
|
markdown_writer::make_filename(config, doc::itempage(doc))
|
|
|
|
}
|
|
|
|
_ {
|
|
|
|
"#" + pandoc_header_id(markdown_pass::header_text(doc))
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
2012-03-02 15:17:13 -08:00
|
|
|
{
|
|
|
|
kind: markdown_pass::header_kind(doc),
|
|
|
|
name: markdown_pass::header_name(doc),
|
2012-03-06 16:51:40 -08:00
|
|
|
brief: doc.brief(),
|
2012-03-06 15:57:36 -08:00
|
|
|
link: link
|
2012-03-02 15:17:13 -08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
fn pandoc_header_id(header: str) -> str {
|
|
|
|
|
|
|
|
// http://johnmacfarlane.net/pandoc/README.html#headers
|
|
|
|
|
|
|
|
let header = remove_formatting(header);
|
|
|
|
let header = remove_punctuation(header);
|
|
|
|
let header = replace_with_hyphens(header);
|
|
|
|
let header = convert_to_lowercase(header);
|
|
|
|
let header = remove_up_to_first_letter(header);
|
|
|
|
let header = maybe_use_section_id(header);
|
|
|
|
ret header;
|
|
|
|
|
2012-03-07 15:45:16 -08:00
|
|
|
fn remove_formatting(s: str) -> str {
|
2012-03-02 15:17:13 -08:00
|
|
|
str::replace(s, "`", "")
|
|
|
|
}
|
2012-03-07 15:45:16 -08:00
|
|
|
fn remove_punctuation(s: str) -> str {
|
|
|
|
let s = str::replace(s, "<", "");
|
|
|
|
let s = str::replace(s, ">", "");
|
2012-03-10 15:38:52 -08:00
|
|
|
let s = str::replace(s, "[", "");
|
|
|
|
let s = str::replace(s, "]", "");
|
|
|
|
let s = str::replace(s, "(", "");
|
|
|
|
let s = str::replace(s, ")", "");
|
|
|
|
let s = str::replace(s, "@", "");
|
|
|
|
let s = str::replace(s, "~", "");
|
2012-06-25 20:00:46 -07:00
|
|
|
let s = str::replace(s, "/", "");
|
2012-07-09 14:59:24 -07:00
|
|
|
let s = str::replace(s, ":", "");
|
|
|
|
let s = str::replace(s, "&", "");
|
2012-03-07 15:45:16 -08:00
|
|
|
ret s;
|
|
|
|
}
|
2012-03-02 15:17:13 -08:00
|
|
|
fn replace_with_hyphens(s: str) -> str {
|
|
|
|
str::replace(s, " ", "-")
|
|
|
|
}
|
|
|
|
fn convert_to_lowercase(s: str) -> str { str::to_lower(s) }
|
|
|
|
fn remove_up_to_first_letter(s: str) -> str { s }
|
|
|
|
fn maybe_use_section_id(s: str) -> str { s }
|
|
|
|
}
|
|
|
|
|
2012-03-07 15:45:16 -08:00
|
|
|
#[test]
|
2012-03-10 15:38:52 -08:00
|
|
|
fn should_remove_punctuation_from_headers() {
|
2012-03-07 15:45:16 -08:00
|
|
|
assert pandoc_header_id("impl foo of bar<A>") == "impl-foo-of-bara";
|
2012-06-29 16:26:56 -07:00
|
|
|
assert pandoc_header_id("fn@(~[~A])") == "fna";
|
2012-07-09 14:59:24 -07:00
|
|
|
assert pandoc_header_id("impl of num::num for int")
|
|
|
|
== "impl-of-numnum-for-int";
|
|
|
|
assert pandoc_header_id("impl of num::num for int/&")
|
|
|
|
== "impl-of-numnum-for-int";
|
2012-03-07 15:45:16 -08:00
|
|
|
}
|
|
|
|
|
2012-03-02 15:17:13 -08:00
|
|
|
#[test]
|
|
|
|
fn should_index_mod_contents() {
|
2012-03-06 15:57:36 -08:00
|
|
|
let doc = test::mk_doc(
|
|
|
|
config::doc_per_crate,
|
|
|
|
"mod a { } fn b() { }"
|
|
|
|
);
|
|
|
|
assert option::get(doc.cratemod().index).entries[0] == {
|
|
|
|
kind: "Module",
|
|
|
|
name: "a",
|
2012-03-06 16:51:40 -08:00
|
|
|
brief: none,
|
2012-03-06 15:57:36 -08:00
|
|
|
link: "#module-a"
|
|
|
|
};
|
|
|
|
assert option::get(doc.cratemod().index).entries[1] == {
|
|
|
|
kind: "Function",
|
|
|
|
name: "b",
|
2012-03-06 16:51:40 -08:00
|
|
|
brief: none,
|
2012-03-06 15:57:36 -08:00
|
|
|
link: "#function-b"
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn should_index_mod_contents_multi_page() {
|
|
|
|
let doc = test::mk_doc(
|
|
|
|
config::doc_per_mod,
|
|
|
|
"mod a { } fn b() { }"
|
|
|
|
);
|
2012-03-02 18:33:25 -08:00
|
|
|
assert option::get(doc.cratemod().index).entries[0] == {
|
2012-03-02 15:17:13 -08:00
|
|
|
kind: "Module",
|
|
|
|
name: "a",
|
2012-03-06 16:51:40 -08:00
|
|
|
brief: none,
|
2012-03-06 15:57:36 -08:00
|
|
|
link: "a.html"
|
2012-03-02 15:17:13 -08:00
|
|
|
};
|
2012-03-02 18:33:25 -08:00
|
|
|
assert option::get(doc.cratemod().index).entries[1] == {
|
2012-03-02 15:17:13 -08:00
|
|
|
kind: "Function",
|
|
|
|
name: "b",
|
2012-03-06 16:51:40 -08:00
|
|
|
brief: none,
|
2012-03-06 15:57:36 -08:00
|
|
|
link: "#function-b"
|
2012-03-02 15:17:13 -08:00
|
|
|
};
|
|
|
|
}
|
|
|
|
|
2012-03-10 16:44:48 -08:00
|
|
|
#[test]
|
2012-06-26 16:18:37 -07:00
|
|
|
fn should_index_foreign_mod_pages() {
|
2012-03-10 16:44:48 -08:00
|
|
|
let doc = test::mk_doc(
|
|
|
|
config::doc_per_mod,
|
2012-07-03 16:11:00 -07:00
|
|
|
"extern mod a { }"
|
2012-03-10 16:44:48 -08:00
|
|
|
);
|
|
|
|
assert option::get(doc.cratemod().index).entries[0] == {
|
2012-07-03 16:11:00 -07:00
|
|
|
kind: "Foreign module",
|
2012-03-10 16:44:48 -08:00
|
|
|
name: "a",
|
|
|
|
brief: none,
|
|
|
|
link: "a.html"
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
2012-03-06 16:51:40 -08:00
|
|
|
#[test]
|
|
|
|
fn should_add_brief_desc_to_index() {
|
|
|
|
let doc = test::mk_doc(
|
|
|
|
config::doc_per_mod,
|
2012-03-09 18:12:15 -08:00
|
|
|
"#[doc = \"test\"] mod a { }"
|
2012-03-06 16:51:40 -08:00
|
|
|
);
|
|
|
|
assert option::get(doc.cratemod().index).entries[0].brief == some("test");
|
|
|
|
}
|
|
|
|
|
2012-03-11 16:36:20 -07:00
|
|
|
#[test]
|
2012-06-26 16:18:37 -07:00
|
|
|
fn should_index_foreign_mod_contents() {
|
2012-03-11 16:36:20 -07:00
|
|
|
let doc = test::mk_doc(
|
|
|
|
config::doc_per_crate,
|
2012-07-03 16:11:00 -07:00
|
|
|
"extern mod a { fn b(); }"
|
2012-03-11 16:36:20 -07:00
|
|
|
);
|
|
|
|
assert option::get(doc.cratemod().nmods()[0].index).entries[0] == {
|
|
|
|
kind: "Function",
|
|
|
|
name: "b",
|
|
|
|
brief: none,
|
|
|
|
link: "#function-b"
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
2012-03-02 15:17:13 -08:00
|
|
|
#[cfg(test)]
|
|
|
|
mod test {
|
2012-03-06 15:57:36 -08:00
|
|
|
fn mk_doc(output_style: config::output_style, source: str) -> doc::doc {
|
2012-06-30 16:19:07 -07:00
|
|
|
do astsrv::from_str(source) |srv| {
|
2012-03-06 15:57:36 -08:00
|
|
|
let config = {
|
|
|
|
output_style: output_style
|
|
|
|
with config::default_config("whatever")
|
|
|
|
};
|
2012-03-02 15:17:13 -08:00
|
|
|
let doc = extract::from_srv(srv, "");
|
2012-03-06 16:51:40 -08:00
|
|
|
let doc = attr_pass::mk_pass().f(srv, doc);
|
2012-03-09 18:12:15 -08:00
|
|
|
let doc = desc_to_brief_pass::mk_pass().f(srv, doc);
|
2012-03-02 15:17:13 -08:00
|
|
|
let doc = path_pass::mk_pass().f(srv, doc);
|
2012-03-06 15:57:36 -08:00
|
|
|
run(srv, doc, config)
|
2012-03-02 15:17:13 -08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|