mirror of
https://codeberg.org/ziglang/zig.git
synced 2025-12-06 05:44:20 +00:00
Sema: initialize OPV comptime allocs correctly
This was caused a `[0]std.builtin.Type.StructField.Attributes` to be
considered `undefined`, even though that type is OPV so should prefer
its OPV `.{}` over `undefined`.
Resolves: #30039
This commit is contained in:
parent
e52232cd57
commit
8f5db19791
2 changed files with 12 additions and 1 deletions
|
|
@ -175,9 +175,11 @@ const ComptimeAlloc = struct {
|
|||
|
||||
/// `src` may be `null` if `is_const` will be set.
|
||||
fn newComptimeAlloc(sema: *Sema, block: *Block, src: LazySrcLoc, ty: Type, alignment: Alignment) !ComptimeAllocIndex {
|
||||
const pt = sema.pt;
|
||||
const init_val = try sema.typeHasOnePossibleValue(ty) orelse try pt.undefValue(ty);
|
||||
const idx = sema.comptime_allocs.items.len;
|
||||
try sema.comptime_allocs.append(sema.gpa, .{
|
||||
.val = .{ .interned = try sema.pt.intern(.{ .undef = ty.toIntern() }) },
|
||||
.val = .{ .interned = init_val.toIntern() },
|
||||
.is_const = false,
|
||||
.src = src,
|
||||
.alignment = alignment,
|
||||
|
|
|
|||
|
|
@ -427,3 +427,12 @@ test "undefined type value" {
|
|||
};
|
||||
comptime assert(@TypeOf(S.undef_type) == type);
|
||||
}
|
||||
|
||||
test "reify struct with zero fields through const arrays" {
|
||||
const names: [0][]const u8 = .{};
|
||||
const types: [0]type = .{};
|
||||
const attrs: [0]std.builtin.Type.StructField.Attributes = .{};
|
||||
const S = @Struct(.auto, null, &names, &types, &attrs);
|
||||
comptime assert(@typeInfo(S) == .@"struct");
|
||||
comptime assert(@typeInfo(S).@"struct".fields.len == 0);
|
||||
}
|
||||
|
|
|
|||
Loading…
Add table
Reference in a new issue