This commit is contained in:
gingerBill
2021-08-07 11:23:40 +01:00
parent beaad719ad
commit f5e51a29b5
+5 -3
View File
@@ -9372,7 +9372,7 @@ lbValue lb_emit_call(lbProcedure *p, lbValue value, Array<lbValue> const &args,
lbValue lb_emit_array_ep(lbProcedure *p, lbValue s, lbValue index) {
Type *t = s.type;
GB_ASSERT(is_type_pointer(t));
GB_ASSERT_MSG(is_type_pointer(t), "%s", type_to_string(t));
Type *st = base_type(type_deref(t));
GB_ASSERT_MSG(is_type_array(st) || is_type_enumerated_array(st), "%s", type_to_string(st));
GB_ASSERT_MSG(is_type_integer(core_type(index.type)), "%s", type_to_string(index.type));
@@ -13346,8 +13346,10 @@ lbAddr lb_build_addr(lbProcedure *p, Ast *expr) {
case_ast_node(ue, UnaryExpr, expr);
switch (ue->op.kind) {
case Token_And:
return lb_build_addr(p, ue->expr);
case Token_And: {
lbValue ptr = lb_build_expr(p, expr);
return lb_addr(lb_address_from_load_or_generate_local(p, ptr));
}
default:
GB_PANIC("Invalid unary expression for lb_build_addr");
}