zig/test/cases/compile_errors/reify_struct.zig
mlugg 0fe3fd01dd
std: update std.builtin.Type fields to follow naming conventions
The compiler actually doesn't need any functional changes for this: Sema
does reification based on the tag indices of `std.builtin.Type` already!
So, no zig1.wasm update is necessary.

This change is necessary to disallow name clashes between fields and
decls on a type, which is a prerequisite of #9938.
2024-08-28 08:39:59 +01:00

81 lines
1.9 KiB
Zig

comptime {
@Type(.{ .@"struct" = .{
.layout = .auto,
.fields = &.{.{
.name = "foo",
.type = u32,
.default_value = null,
.is_comptime = false,
.alignment = 4,
}},
.decls = &.{},
.is_tuple = true,
} });
}
comptime {
@Type(.{ .@"struct" = .{
.layout = .auto,
.fields = &.{.{
.name = "3",
.type = u32,
.default_value = null,
.is_comptime = false,
.alignment = 4,
}},
.decls = &.{},
.is_tuple = true,
} });
}
comptime {
@Type(.{ .@"struct" = .{
.layout = .auto,
.fields = &.{.{
.name = "0",
.type = u32,
.default_value = null,
.is_comptime = true,
.alignment = 4,
}},
.decls = &.{},
.is_tuple = true,
} });
}
comptime {
@Type(.{ .@"struct" = .{
.layout = .@"extern",
.fields = &.{.{
.name = "0",
.type = u32,
.default_value = null,
.is_comptime = true,
.alignment = 4,
}},
.decls = &.{},
.is_tuple = false,
} });
}
comptime {
@Type(.{ .@"struct" = .{
.layout = .@"packed",
.fields = &.{.{
.name = "0",
.type = u32,
.default_value = null,
.is_comptime = true,
.alignment = 4,
}},
.decls = &.{},
.is_tuple = false,
} });
}
// error
// backend=stage2
// target=native
//
// :2:5: error: tuple cannot have non-numeric field 'foo'
// :16:5: error: tuple field name '3' does not match field index 0
// :30:5: error: comptime field without default initialization value
// :44:5: error: extern struct fields cannot be marked comptime
// :58:5: error: alignment in a packed struct field must be set to 0