rust/src/rustdoc/attr_parser.rs

147 lines
3.5 KiB
Rust
Raw Normal View History

2012-01-17 19:44:32 -06:00
#[doc(
brief = "Attribute parsing",
desc =
"The attribute parser provides methods for pulling documentation out of \
an AST's attributes."
)];
2012-09-05 12:41:47 -05:00
use syntax::ast;
use syntax::attr;
use core::tuple;
2012-03-09 20:12:15 -06:00
export crate_attrs;
export parse_crate, parse_desc;
2012-03-07 16:49:52 -06:00
export parse_hidden;
type crate_attrs = {
2012-08-20 14:23:37 -05:00
name: Option<~str>
};
2012-01-25 19:31:50 -06:00
#[cfg(test)]
mod test {
fn parse_attributes(source: ~str) -> ~[ast::attribute] {
use syntax::parse;
use parse::parser;
use parse::attr::parser_attr;
use syntax::codemap;
use syntax::diagnostic;
2012-01-25 19:31:50 -06:00
2012-08-20 14:23:37 -05:00
let parse_sess = syntax::parse::new_parse_sess(None);
let parser = parse::new_parser_from_source_str(
parse_sess, ~[], ~"-", codemap::fss_none, @source);
2012-01-25 19:31:50 -06:00
2012-05-24 15:44:42 -05:00
parser.parse_outer_attributes()
2012-01-25 19:31:50 -06:00
}
}
2012-01-16 22:00:46 -06:00
fn doc_meta(
attrs: ~[ast::attribute]
2012-08-20 14:23:37 -05:00
) -> Option<@ast::meta_item> {
2012-01-18 16:06:22 -06:00
/*!
* Given a vec of attributes, extract the meta_items contained in the \
* doc attribute
*/
2012-01-18 16:06:22 -06:00
let doc_attrs = attr::find_attrs_by_name(attrs, ~"doc");
Merge remote-tracking branch 'Dretch/prettydocs' Conflicts: src/compiletest/errors.rs src/libsyntax/parse/attr.rs src/libsyntax/parse/comments.rs src/test/compile-fail/ambig_impl_unify.rs src/test/compile-fail/assign-super.rs src/test/compile-fail/bad-for-loop.rs src/test/compile-fail/bad-var-env-capture-in-block-arg.rs src/test/compile-fail/block-arg-as-stmt-with-value.rs src/test/compile-fail/borrowck-assign-comp-idx.rs src/test/compile-fail/borrowck-lend-flow.rs src/test/compile-fail/borrowck-loan-blocks-move-cc.rs src/test/compile-fail/borrowck-loan-blocks-mut-uniq.rs src/test/compile-fail/borrowck-loan-rcvr.rs src/test/compile-fail/borrowck-loan-vec-content.rs src/test/compile-fail/borrowck-mut-vec-as-imm-slice-bad.rs src/test/compile-fail/cap-clause-with-stack-closure.rs src/test/compile-fail/do1.rs src/test/compile-fail/do2.rs src/test/compile-fail/empty-vec-trailing-comma.rs src/test/compile-fail/evec-subtyping.rs src/test/compile-fail/issue-1896.rs src/test/compile-fail/issue-2149.rs src/test/compile-fail/issue-2150.rs src/test/compile-fail/issue-2487-b.rs src/test/compile-fail/kindck-implicit-close-over-mut-var.rs src/test/compile-fail/liveness-issue-2163.rs src/test/compile-fail/liveness-use-in-index-lvalue.rs src/test/compile-fail/no-reuse-move-arc.rs src/test/compile-fail/no-send-res-ports.rs src/test/compile-fail/non-const.rs src/test/compile-fail/pure-higher-order.rs src/test/compile-fail/pure-loop-body.rs src/test/compile-fail/regions-addr-of-upvar-self.rs src/test/compile-fail/regions-escape-loop-via-vec.rs src/test/compile-fail/regions-scoping.rs src/test/compile-fail/seq-args.rs src/test/compile-fail/tstate-unsat-in-called-fn-expr.rs src/test/compile-fail/tstate-unsat-in-fn-expr.rs src/test/compile-fail/vec-add.rs src/test/compile-fail/vec-concat-bug.rs src/test/compile-fail/vector-no-ann.rs
2012-07-02 16:44:31 -05:00
let doc_metas = do doc_attrs.map |attr| {
attr::attr_meta(attr::desugar_doc_attr(attr))
};
2012-01-16 22:00:46 -06:00
if vec::is_not_empty(doc_metas) {
if vec::len(doc_metas) != 1u {
2012-08-22 19:24:52 -05:00
warn!("ignoring %u doc attributes", vec::len(doc_metas) - 1u);
2012-01-16 22:00:46 -06:00
}
2012-08-20 14:23:37 -05:00
Some(doc_metas[0])
2012-01-16 22:00:46 -06:00
} else {
2012-08-20 14:23:37 -05:00
None
2012-01-16 22:00:46 -06:00
}
}
fn parse_crate(attrs: ~[ast::attribute]) -> crate_attrs {
let link_metas = attr::find_linkage_metas(attrs);
{
2012-07-18 18:18:02 -05:00
name: attr::last_meta_item_value_str_by_name(link_metas, ~"name")
}
}
#[test]
fn should_extract_crate_name_from_link_attribute() {
let source = ~"#[link(name = \"snuggles\")]";
let attrs = test::parse_attributes(source);
let attrs = parse_crate(attrs);
2012-08-20 14:23:37 -05:00
assert attrs.name == Some(~"snuggles");
}
#[test]
fn should_not_extract_crate_name_if_no_link_attribute() {
let source = ~"";
let attrs = test::parse_attributes(source);
let attrs = parse_crate(attrs);
2012-08-20 14:23:37 -05:00
assert attrs.name == None;
}
#[test]
fn should_not_extract_crate_name_if_no_name_value_in_link_attribute() {
let source = ~"#[link(whatever)]";
let attrs = test::parse_attributes(source);
let attrs = parse_crate(attrs);
2012-08-20 14:23:37 -05:00
assert attrs.name == None;
}
2012-08-20 14:23:37 -05:00
fn parse_desc(attrs: ~[ast::attribute]) -> Option<~str> {
2012-08-06 14:34:08 -05:00
match doc_meta(attrs) {
2012-08-20 14:23:37 -05:00
Some(meta) => {
2012-07-18 18:18:02 -05:00
attr::get_meta_item_value_str(meta)
2012-03-09 20:12:15 -06:00
}
2012-08-20 14:23:37 -05:00
None => None
2012-03-09 20:12:15 -06:00
}
2012-01-18 20:02:56 -06:00
}
2012-01-18 20:02:56 -06:00
#[test]
2012-03-09 20:12:15 -06:00
fn parse_desc_should_handle_undocumented_mods() {
let source = ~"";
2012-01-18 20:02:56 -06:00
let attrs = test::parse_attributes(source);
2012-03-09 20:12:15 -06:00
let attrs = parse_desc(attrs);
2012-08-20 14:23:37 -05:00
assert attrs == None;
2012-01-18 20:02:56 -06:00
}
#[test]
2012-03-09 20:12:15 -06:00
fn parse_desc_should_parse_simple_doc_attributes() {
let source = ~"#[doc = \"basic\"]";
2012-01-18 20:02:56 -06:00
let attrs = test::parse_attributes(source);
2012-03-09 20:12:15 -06:00
let attrs = parse_desc(attrs);
2012-08-20 14:23:37 -05:00
assert attrs == Some(~"basic");
2012-01-18 20:02:56 -06:00
}
fn parse_hidden(attrs: ~[ast::attribute]) -> bool {
2012-08-06 14:34:08 -05:00
match doc_meta(attrs) {
2012-08-20 14:23:37 -05:00
Some(meta) => {
2012-08-06 14:34:08 -05:00
match attr::get_meta_item_list(meta) {
2012-08-20 14:23:37 -05:00
Some(metas) => {
let hiddens = attr::find_meta_items_by_name(metas, ~"hidden");
2012-03-09 20:12:15 -06:00
vec::is_not_empty(hiddens)
2012-02-17 18:52:27 -06:00
}
2012-08-20 14:23:37 -05:00
None => false
2012-02-17 18:52:27 -06:00
}
}
2012-08-20 14:23:37 -05:00
None => false
2012-02-17 18:52:27 -06:00
}
}
2012-01-18 20:02:56 -06:00
2012-03-07 16:49:52 -06:00
#[test]
fn shoulde_parse_hidden_attribute() {
let source = ~"#[doc(hidden)]";
2012-03-07 16:49:52 -06:00
let attrs = test::parse_attributes(source);
assert parse_hidden(attrs) == true;
}
#[test]
fn shoulde_not_parse_non_hidden_attribute() {
let source = ~"#[doc = \"\"]";
2012-03-07 16:49:52 -06:00
let attrs = test::parse_attributes(source);
assert parse_hidden(attrs) == false;
}