aboutsummaryrefslogtreecommitdiff
path: root/src/llvm_backend_expr.cpp
diff options
context:
space:
mode:
authorgingerBill <bill@gingerbill.org>2023-02-26 13:26:35 +0000
committergingerBill <bill@gingerbill.org>2023-02-26 13:26:35 +0000
commita9182cfd8cf9dd8cec125221e39c0fcd7a3fd3e3 (patch)
treef66b628ddf041d894a89469974969045167c5f15 /src/llvm_backend_expr.cpp
parentde6c0f682ffae88dfa6f64b44652e243f651a0a6 (diff)
Allow compound literals to access fields through `using`
Diffstat (limited to 'src/llvm_backend_expr.cpp')
-rw-r--r--src/llvm_backend_expr.cpp20
1 files changed, 16 insertions, 4 deletions
diff --git a/src/llvm_backend_expr.cpp b/src/llvm_backend_expr.cpp
index 5bffc7226..3676847b4 100644
--- a/src/llvm_backend_expr.cpp
+++ b/src/llvm_backend_expr.cpp
@@ -4044,7 +4044,6 @@ gb_internal lbAddr lb_build_addr_slice_expr(lbProcedure *p, Ast *expr) {
return {};
}
-
gb_internal lbAddr lb_build_addr_compound_lit(lbProcedure *p, Ast *expr) {
ast_node(cl, CompoundLit, expr);
@@ -4093,12 +4092,25 @@ gb_internal lbAddr lb_build_addr_compound_lit(lbProcedure *p, Ast *expr) {
ast_node(fv, FieldValue, elem);
String name = fv->field->Ident.token.string;
Selection sel = lookup_field(bt, name, false);
- index = sel.index[0];
+ GB_ASSERT(!sel.indirect);
+
elem = fv->value;
- TypeAndValue tav = type_and_value_of_expr(elem);
+ if (sel.index.count > 1) {
+ if (lb_is_nested_possibly_constant(type, sel, elem)) {
+ continue;
+ }
+ lbValue dst = lb_emit_deep_field_gep(p, comp_lit_ptr, sel);
+ field_expr = lb_build_expr(p, elem);
+ field_expr = lb_emit_conv(p, field_expr, sel.entity->type);
+ lb_emit_store(p, dst, field_expr);
+ continue;
+ }
+
+ index = sel.index[0];
} else {
- TypeAndValue tav = type_and_value_of_expr(elem);
Selection sel = lookup_field_from_index(bt, st->fields[field_index]->Variable.field_index);
+ GB_ASSERT(sel.index.count == 1);
+ GB_ASSERT(!sel.indirect);
index = sel.index[0];
}