Skip to content

Commit 23af1e9

Browse files
committed
---
yaml --- r: 10840 b: refs/heads/master c: 21fc2a3 h: refs/heads/master v: v3
1 parent 91a5814 commit 23af1e9

File tree

3 files changed

+24
-9
lines changed

3 files changed

+24
-9
lines changed

[refs]

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -1,5 +1,5 @@
11
---
2-
refs/heads/master: 06ab83de2c72ebaf87b33133007a0dd0e79962db
2+
refs/heads/master: 21fc2a36d8941242e65227d1362259bc7b399bec
33
refs/heads/snap-stage1: e33de59e47c5076a89eadeb38f4934f58a3618a6
44
refs/heads/snap-stage3: 4a81779abd786ff22d71434c6d9a5917ea4cdfff
55
refs/heads/try: 2898dcc5d97da9427ac367542382b6239d9c0bbf

trunk/src/rustdoc/attr_pass.rs

Lines changed: 11 additions & 5 deletions
Original file line numberDiff line numberDiff line change
@@ -320,11 +320,17 @@ fn fold_res(
320320
~{
321321
brief: attrs.brief,
322322
desc: attrs.desc,
323-
args: vec::map(attrs.args) {|attrs|
324-
~{
325-
name: attrs.name,
326-
desc: some(attrs.desc),
327-
ty: none
323+
args: vec::map(doc.args) {|doc|
324+
alt vec::find(attrs.args) {|attr|
325+
attr.name == doc.name
326+
} {
327+
some(attr) {
328+
~{
329+
desc: some(attr.desc)
330+
with *doc
331+
}
332+
}
333+
none { doc }
328334
}
329335
}
330336
with *doc

trunk/src/rustdoc/extract.rs

Lines changed: 12 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -91,8 +91,8 @@ fn moddoc_from_mod(
9191
resources: doc::reslist(
9292
vec::filter_map(module.items) {|item|
9393
alt item.node {
94-
ast::item_res(_, _, _, _, _) {
95-
some(resdoc_from_resource(item.ident, item.id))
94+
ast::item_res(decl, _, _, _, _) {
95+
some(resdoc_from_resource(decl, item.ident, item.id))
9696
}
9797
_ {
9898
none
@@ -212,6 +212,7 @@ fn should_extract_enum_variants() {
212212
}
213213

214214
fn resdoc_from_resource(
215+
decl: ast::fn_decl,
215216
name: str,
216217
id: ast::node_id
217218
) -> doc::resdoc {
@@ -220,7 +221,7 @@ fn resdoc_from_resource(
220221
name: name,
221222
brief: none,
222223
desc: none,
223-
args: [],
224+
args: argdocs_from_args(decl.inputs),
224225
sig: none
225226
}
226227
}
@@ -234,6 +235,14 @@ fn should_extract_resources() {
234235
assert doc.topmod.resources[0].name == "r";
235236
}
236237

238+
#[test]
239+
fn should_extract_resource_args() {
240+
let source = "resource r(b: bool) { }";
241+
let ast = parse::from_str(source);
242+
let doc = extract(ast, "");
243+
assert doc.topmod.resources[0].args[0].name == "b";
244+
}
245+
237246
#[cfg(test)]
238247
mod tests {
239248

0 commit comments

Comments
 (0)