mirror of
https://github.com/ziglang/zig.git
synced 2025-01-08 11:12:14 +00:00
0fe3fd01dd
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.
37 lines
1.1 KiB
Zig
37 lines
1.1 KiB
Zig
const std = @import("std");
|
|
const expect = std.testing.expect;
|
|
const expectError = std.testing.expectError;
|
|
|
|
fn isFieldOptional(comptime T: type, field_index: usize) !bool {
|
|
const fields = @typeInfo(T).@"struct".fields;
|
|
return switch (field_index) {
|
|
// This prong is analyzed twice with `idx` being a
|
|
// comptime-known value each time.
|
|
inline 0, 1 => |idx| @typeInfo(fields[idx].type) == .optional,
|
|
else => return error.IndexOutOfBounds,
|
|
};
|
|
}
|
|
|
|
const Struct1 = struct { a: u32, b: ?u32 };
|
|
|
|
test "using @typeInfo with runtime values" {
|
|
var index: usize = 0;
|
|
try expect(!try isFieldOptional(Struct1, index));
|
|
index += 1;
|
|
try expect(try isFieldOptional(Struct1, index));
|
|
index += 1;
|
|
try expectError(error.IndexOutOfBounds, isFieldOptional(Struct1, index));
|
|
}
|
|
|
|
// Calls to `isFieldOptional` on `Struct1` get unrolled to an equivalent
|
|
// of this function:
|
|
fn isFieldOptionalUnrolled(field_index: usize) !bool {
|
|
return switch (field_index) {
|
|
0 => false,
|
|
1 => true,
|
|
else => return error.IndexOutOfBounds,
|
|
};
|
|
}
|
|
|
|
// test
|