Use FieldIdx
in various things related to aggregates
Shrank `AggregateKind` by 8 bytes on x64, since the active field of a union is tracked as an `Option<FieldIdx>` instead of `Option<usize>`.
This commit is contained in:
parent
480068c235
commit
b5b6def021
13 changed files with 51 additions and 46 deletions
|
@ -306,9 +306,9 @@ pub fn coerce_unsized_into<'a, 'tcx, Bx: BuilderMethods<'a, 'tcx>>(
|
|||
(&ty::Adt(def_a, _), &ty::Adt(def_b, _)) => {
|
||||
assert_eq!(def_a, def_b);
|
||||
|
||||
for i in 0..def_a.variant(FIRST_VARIANT).fields.len() {
|
||||
let src_f = src.project_field(bx, i);
|
||||
let dst_f = dst.project_field(bx, i);
|
||||
for i in def_a.variant(FIRST_VARIANT).fields.indices() {
|
||||
let src_f = src.project_field(bx, i.as_usize());
|
||||
let dst_f = dst.project_field(bx, i.as_usize());
|
||||
|
||||
if dst_f.layout.is_zst() {
|
||||
continue;
|
||||
|
|
|
@ -123,16 +123,16 @@ impl<'a, 'tcx, Bx: BuilderMethods<'a, 'tcx>> FunctionCx<'a, 'tcx, Bx> {
|
|||
if active_field_index.is_some() {
|
||||
assert_eq!(operands.len(), 1);
|
||||
}
|
||||
for (i, operand) in operands.iter().enumerate() {
|
||||
for (i, operand) in operands.iter_enumerated() {
|
||||
let op = self.codegen_operand(bx, operand);
|
||||
// Do not generate stores and GEPis for zero-sized fields.
|
||||
if !op.layout.is_zst() {
|
||||
let field_index = active_field_index.unwrap_or(i);
|
||||
let field = if let mir::AggregateKind::Array(_) = **kind {
|
||||
let llindex = bx.cx().const_usize(field_index as u64);
|
||||
let llindex = bx.cx().const_usize(field_index.as_u32().into());
|
||||
variant_dest.project_index(bx, llindex)
|
||||
} else {
|
||||
variant_dest.project_field(bx, field_index)
|
||||
variant_dest.project_field(bx, field_index.as_usize())
|
||||
};
|
||||
op.val.store(bx, field);
|
||||
}
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue