From fda143d5d81da852af73386a2100e18784bd0d3c Mon Sep 17 00:00:00 2001 From: Daniele Cocca Date: Thu, 28 Apr 2022 22:59:16 +0100 Subject: CBE: fix renderValue() for struct fields with no runtime bits These shouldn't count towards the total emitted, or the stray comma separators would cause compilation errors. --- src/codegen/c.zig | 6 ++++-- 1 file changed, 4 insertions(+), 2 deletions(-) (limited to 'src/codegen/c.zig') diff --git a/src/codegen/c.zig b/src/codegen/c.zig index 46fee271cc..8f73daca46 100644 --- a/src/codegen/c.zig +++ b/src/codegen/c.zig @@ -821,12 +821,14 @@ pub const DeclGen = struct { try dg.renderTypecast(writer, ty); try writer.writeAll("){"); - for (field_vals) |field_val, i| { - const field_ty = ty.structFieldType(i); + var i: usize = 0; + for (field_vals) |field_val, field_index| { + const field_ty = ty.structFieldType(field_index); if (!field_ty.hasRuntimeBits()) continue; if (i != 0) try writer.writeAll(","); try dg.renderValue(writer, field_ty, field_val, location); + i += 1; } try writer.writeAll("}"); -- cgit v1.2.3