aboutsummaryrefslogtreecommitdiff
path: root/src/codegen/ssa.cpp
diff options
context:
space:
mode:
authorgingerBill <ginger.bill.22@gmail.com>2016-08-16 21:01:59 +0100
committergingerBill <ginger.bill.22@gmail.com>2016-08-16 21:01:59 +0100
commit9e61e3beee6ca5ae48db68fd03ed0c73604e7279 (patch)
tree937d3130c4a68e2b36a3af5380b7d19f2e54aafd /src/codegen/ssa.cpp
parente8530ca883edd79c188443ced54cea2c5d3ad4ed (diff)
field = value, for structure literals
Diffstat (limited to 'src/codegen/ssa.cpp')
-rw-r--r--src/codegen/ssa.cpp40
1 files changed, 27 insertions, 13 deletions
diff --git a/src/codegen/ssa.cpp b/src/codegen/ssa.cpp
index f6497fc81..5ff0c7cfd 100644
--- a/src/codegen/ssa.cpp
+++ b/src/codegen/ssa.cpp
@@ -1576,20 +1576,34 @@ ssaValue *ssa_build_single_expr(ssaProcedure *proc, AstNode *expr, TypeAndValue
case Type_Structure: {
auto *st = &base_type->structure;
- isize index = 0;
- for (AstNode *elem = cl->elem_list;
- elem != NULL;
- elem = elem->next, index++) {
- ssaValue *field_expr = ssa_build_expr(proc, elem);
- Type *t = ssa_value_type(field_expr);
- GB_ASSERT(t->kind != Type_Tuple);
- Entity *field = st->fields[index];
- Type *ft = field->type;
- ssaValue *fv = ssa_emit_conv(proc, field_expr, ft);
- ssaValue *gep = ssa_emit_struct_gep(proc, v, index, ft);
- ssa_emit_store(proc, gep, fv);
- }
+ if (cl->elem_list != NULL) {
+ isize index = 0;
+ AstNode *elem = cl->elem_list;
+ for (;
+ elem != NULL;
+ elem = elem->next, index++) {
+ isize field_index = index;
+ ssaValue *field_expr = NULL;
+ Entity *field = NULL;
+
+ if (elem->kind == AstNode_FieldValue) {
+ ast_node(kv, FieldValue, elem);
+ Entity *e = lookup_field(base_type, kv->field, &field_index);
+ field_expr = ssa_build_expr(proc, kv->value);
+ } else {
+ field_expr = ssa_build_expr(proc, elem);
+ }
+
+ GB_ASSERT(ssa_value_type(field_expr)->kind != Type_Tuple);
+ field = st->fields[field_index];
+
+ Type *ft = field->type;
+ ssaValue *fv = ssa_emit_conv(proc, field_expr, ft);
+ ssaValue *gep = ssa_emit_struct_gep(proc, v, field_index, ft);
+ ssa_emit_store(proc, gep, fv);
+ }
+ }
} break;
case Type_Array: {
isize index = 0;