Skip to content

Commit 0c0f69d

Browse files
committed
---
yaml --- r: 28622 b: refs/heads/try c: 6cf496c h: refs/heads/master v: v3
1 parent 089a65b commit 0c0f69d

File tree

2 files changed

+24
-11
lines changed

2 files changed

+24
-11
lines changed

[refs]

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -2,7 +2,7 @@
22
refs/heads/master: cd6f24f9d14ac90d167386a56e7a6ac1f0318195
33
refs/heads/snap-stage1: e33de59e47c5076a89eadeb38f4934f58a3618a6
44
refs/heads/snap-stage3: cd6f24f9d14ac90d167386a56e7a6ac1f0318195
5-
refs/heads/try: b056e98a277ad19bee8ee562e9685e6dc58fb93b
5+
refs/heads/try: 6cf496ce97cc466bfa92b7ed7190a759cd9c1c33
66
refs/tags/release-0.1: 1f5c5126e96c79d22cb7862f75304136e204f105
77
refs/heads/ndm: f3868061cd7988080c30d6d5bf352a5a5fe2460b
88
refs/heads/try2: d0c6ce338884ee21843f4b40bf6bf18d222ce5df

branches/try/src/rustdoc/attr_parser.rs

Lines changed: 23 additions & 10 deletions
Original file line numberDiff line numberDiff line change
@@ -44,11 +44,7 @@ fn doc_meta(
4444
* doc attribute
4545
*/
4646
47-
let doc_attrs = attr::find_attrs_by_name(attrs, ~"doc");
48-
let doc_metas = do doc_attrs.map |attr| {
49-
attr::attr_meta(attr::desugar_doc_attr(attr))
50-
};
51-
47+
let doc_metas = doc_metas(attrs);
5248
if vec::is_not_empty(doc_metas) {
5349
if vec::len(doc_metas) != 1u {
5450
warn!("ignoring %u doc attributes", vec::len(doc_metas) - 1u);
@@ -57,6 +53,19 @@ fn doc_meta(
5753
} else {
5854
None
5955
}
56+
57+
}
58+
59+
fn doc_metas(
60+
attrs: ~[ast::attribute]
61+
) -> ~[@ast::meta_item] {
62+
63+
let doc_attrs = attr::find_attrs_by_name(attrs, ~"doc");
64+
let doc_metas = do doc_attrs.map |attr| {
65+
attr::attr_meta(attr::desugar_doc_attr(attr))
66+
};
67+
68+
return doc_metas;
6069
}
6170

6271
fn parse_crate(attrs: ~[ast::attribute]) -> CrateAttrs {
@@ -117,18 +126,15 @@ fn parse_desc_should_parse_simple_doc_attributes() {
117126
}
118127

119128
fn parse_hidden(attrs: ~[ast::attribute]) -> bool {
120-
match doc_meta(attrs) {
121-
Some(meta) => {
129+
do doc_metas(attrs).find |meta| {
122130
match attr::get_meta_item_list(meta) {
123131
Some(metas) => {
124132
let hiddens = attr::find_meta_items_by_name(metas, ~"hidden");
125133
vec::is_not_empty(hiddens)
126134
}
127135
None => false
128136
}
129-
}
130-
None => false
131-
}
137+
}.is_some()
132138
}
133139

134140
#[test]
@@ -138,6 +144,13 @@ fn should_parse_hidden_attribute() {
138144
assert parse_hidden(attrs) == true;
139145
}
140146

147+
#[test]
148+
fn should_parse_hidden_attribute_with_other_docs() {
149+
let source = ~"#[doc = \"foo\"] #[doc(hidden)] #[doc = \"foo\"]";
150+
let attrs = test::parse_attributes(source);
151+
assert parse_hidden(attrs) == true;
152+
}
153+
141154
#[test]
142155
fn should_not_parse_non_hidden_attribute() {
143156
let source = ~"#[doc = \"\"]";

0 commit comments

Comments
 (0)