Skip to content

Commit 37bb0c7

Browse files
committed
def_collector: Do not forget to save indices of fields with multiple attributes
1 parent e41ced3 commit 37bb0c7

File tree

2 files changed

+18
-9
lines changed

2 files changed

+18
-9
lines changed

src/librustc_resolve/def_collector.rs

+7-9
Original file line numberDiff line numberDiff line change
@@ -80,15 +80,16 @@ impl<'a> DefCollector<'a> {
8080
}
8181

8282
fn collect_field(&mut self, field: &'a StructField, index: Option<usize>) {
83+
let index = |this: &Self| index.unwrap_or_else(|| {
84+
let node_id = NodeId::placeholder_from_expn_id(this.expansion);
85+
this.definitions.placeholder_field_index(node_id)
86+
});
87+
8388
if field.is_placeholder {
89+
self.definitions.set_placeholder_field_index(field.id, index(self));
8490
self.visit_macro_invoc(field.id);
8591
} else {
86-
let name = field.ident.map(|ident| ident.name)
87-
.or_else(|| index.map(sym::integer))
88-
.unwrap_or_else(|| {
89-
let node_id = NodeId::placeholder_from_expn_id(self.expansion);
90-
sym::integer(self.definitions.placeholder_field_index(node_id))
91-
});
92+
let name = field.ident.map_or_else(|| sym::integer(index(self)), |ident| ident.name);
9293
let def = self.create_def(field.id, DefPathData::ValueNs(name), field.span);
9394
self.with_parent(def, |this| visit::walk_struct_field(this, field));
9495
}
@@ -190,9 +191,6 @@ impl<'a> visit::Visitor<'a> for DefCollector<'a> {
190191
// and every such attribute expands into a single field after it's resolved.
191192
for (index, field) in data.fields().iter().enumerate() {
192193
self.collect_field(field, Some(index));
193-
if field.is_placeholder && field.ident.is_none() {
194-
self.definitions.set_placeholder_field_index(field.id, index);
195-
}
196194
}
197195
}
198196

Original file line numberDiff line numberDiff line change
@@ -0,0 +1,11 @@
1+
// Duplicate non-builtin attributes can be used on unnamed fields.
2+
3+
// check-pass
4+
5+
struct S (
6+
#[rustfmt::skip]
7+
#[rustfmt::skip]
8+
u8
9+
);
10+
11+
fn main() {}

0 commit comments

Comments
 (0)