describe_enum_variant: Reduce code duplication

This commit is contained in:
Tyler Mandry 2019-04-02 13:51:13 -07:00
parent 3de0106789
commit b58624727c

View File

@ -1535,6 +1535,14 @@ fn describe_enum_variant(
unique_type_id, unique_type_id,
Some(containing_scope)); Some(containing_scope));
let arg_name = |i: usize| {
if variant.ctor_kind == CtorKind::Fn {
format!("__{}", i)
} else {
variant.fields[i].ident.to_string()
}
};
// Build an array of (field name, field type) pairs to be captured in the factory closure. // Build an array of (field name, field type) pairs to be captured in the factory closure.
let (offsets, args) = if use_enum_fallback(cx) { let (offsets, args) = if use_enum_fallback(cx) {
// If this is not a univariant enum, there is also the discriminant field. // If this is not a univariant enum, there is also the discriminant field.
@ -1552,12 +1560,7 @@ fn describe_enum_variant(
layout.fields.offset(i) layout.fields.offset(i)
})).collect(), })).collect(),
discr_arg.into_iter().chain((0..layout.fields.count()).map(|i| { discr_arg.into_iter().chain((0..layout.fields.count()).map(|i| {
let name = if variant.ctor_kind == CtorKind::Fn { (arg_name(i), layout.field(cx, i).ty)
format!("__{}", i)
} else {
variant.fields[i].ident.to_string()
};
(name, layout.field(cx, i).ty)
})).collect() })).collect()
) )
} else { } else {
@ -1566,12 +1569,7 @@ fn describe_enum_variant(
layout.fields.offset(i) layout.fields.offset(i)
}).collect(), }).collect(),
(0..layout.fields.count()).map(|i| { (0..layout.fields.count()).map(|i| {
let name = if variant.ctor_kind == CtorKind::Fn { (arg_name(i), layout.field(cx, i).ty)
format!("__{}", i)
} else {
variant.fields[i].ident.to_string()
};
(name, layout.field(cx, i).ty)
}).collect() }).collect()
) )
}; };