Fix swizzling of pointers to arrays

This commit is contained in:
gingerBill
2021-06-28 11:05:52 +01:00
parent 76d3bab955
commit 185277a2b6
+7 -2
View File
@@ -12978,8 +12978,13 @@ lbAddr lb_build_addr(lbProcedure *p, Ast *expr) {
u8 index = swizzle_indices_raw>>(i*2) & 3;
swizzle_indices[i] = index;
}
lbAddr addr = lb_build_addr(p, se->expr);
lbValue a = lb_addr_get_ptr(p, addr);
lbValue a = {};
if (is_type_pointer(tav.type)) {
a = lb_build_expr(p, se->expr);
} else {
lbAddr addr = lb_build_addr(p, se->expr);
a = lb_addr_get_ptr(p, addr);
}
GB_ASSERT(is_type_array(expr->tav.type));
return lb_addr_swizzle(a, expr->tav.type, swizzle_count, swizzle_indices);