diff --git a/src/type.zig b/src/type.zig index ee0b19d099..88a3a7cc43 100644 --- a/src/type.zig +++ b/src/type.zig @@ -1244,6 +1244,7 @@ pub const Type = struct { .array_type => |array_type| { const len = array_type.len + @intFromBool(array_type.sentinel != .none); + if (len == 0) return .{ .scalar = 0 }; switch (try array_type.child.toType().abiSizeAdvanced(mod, strat)) { .scalar => |elem_size| return .{ .scalar = len * elem_size }, .val => switch (strat) { diff --git a/test/behavior/struct.zig b/test/behavior/struct.zig index 393f23ec6e..f6fb45f46b 100644 --- a/test/behavior/struct.zig +++ b/test/behavior/struct.zig @@ -995,6 +995,24 @@ test "struct with union field" { try expect(True.kind.Bool); } +test "struct with 0-length union array field" { + if (builtin.zig_backend == .stage2_aarch64) return error.SkipZigTest; // TODO + if (builtin.zig_backend == .stage2_arm) return error.SkipZigTest; // TODO + if (builtin.zig_backend == .stage2_sparc64) return error.SkipZigTest; // TODO + + const U = union { + a: u32, + b: u64, + }; + + const S = struct { + zero_length: [0]U, + }; + + var s: S = undefined; + try expectEqual(@as(usize, 0), s.zero_length.len); +} + test "type coercion of anon struct literal to struct" { if (builtin.zig_backend == .stage2_arm) return error.SkipZigTest; // TODO if (builtin.zig_backend == .stage2_aarch64) return error.SkipZigTest; // TODO