diff options
| author | Ginger Bill <bill@gingerbill.org> | 2017-06-27 22:47:19 +0100 |
|---|---|---|
| committer | Ginger Bill <bill@gingerbill.org> | 2017-06-27 22:47:19 +0100 |
| commit | 647e2cafd7d353a454fd1593d54fe09824a8e527 (patch) | |
| tree | 57cfcb426bc9766e572c8425fe9df62e033dcc6b /src/ir.cpp | |
| parent | 5df854fcef6d3c37f3703ed5568ef7de8ca6719e (diff) | |
Fix `expand_to_tuple`
Diffstat (limited to 'src/ir.cpp')
| -rw-r--r-- | src/ir.cpp | 8 |
1 files changed, 5 insertions, 3 deletions
diff --git a/src/ir.cpp b/src/ir.cpp index e0ca61522..69b4c75f6 100644 --- a/src/ir.cpp +++ b/src/ir.cpp @@ -4316,9 +4316,11 @@ irValue *ir_build_builtin_proc(irProcedure *proc, AstNode *expr, TypeAndValue tv GB_ASSERT(is_type_tuple(tv.type)); irValue *tuple = ir_add_local_generated(proc, tv.type); - for (isize i = 0; i < t->Record.field_count; i++) { - irValue *f = ir_emit_struct_ev(proc, s, i); - irValue *ep = ir_emit_struct_ep(proc, tuple, i); + for (isize src_index = 0; src_index < t->Record.field_count; src_index++) { + Entity *field = t->Record.fields_in_src_order[src_index]; + i32 field_index = field->Variable.field_index; + irValue *f = ir_emit_struct_ev(proc, s, field_index); + irValue *ep = ir_emit_struct_ep(proc, tuple, src_index); ir_emit_store(proc, ep, f); } return ir_emit_load(proc, tuple); |