diff options
| author | Andrew Kelley <andrew@ziglang.org> | 2022-03-11 12:59:20 -0700 |
|---|---|---|
| committer | Andrew Kelley <andrew@ziglang.org> | 2022-03-11 12:59:20 -0700 |
| commit | a2517117e7cffcc4be21e944f2b4f8661c8f15a3 (patch) | |
| tree | 5e80c067eedc2941d8a30d62706a11e150f728c1 /src | |
| parent | 6a9c9afbae24897a5c6fa843794be33e4ed33f12 (diff) | |
| download | zig-a2517117e7cffcc4be21e944f2b4f8661c8f15a3.tar.gz zig-a2517117e7cffcc4be21e944f2b4f8661c8f15a3.zip | |
Sema: make `@hasField` support tuples too
Diffstat (limited to 'src')
| -rw-r--r-- | src/Sema.zig | 4 |
1 files changed, 4 insertions, 0 deletions
diff --git a/src/Sema.zig b/src/Sema.zig index 41ca123062..ac43ef76b3 100644 --- a/src/Sema.zig +++ b/src/Sema.zig @@ -7795,6 +7795,10 @@ fn zirHasField(sema: *Sema, block: *Block, inst: Zir.Inst.Index) CompileError!Ai if (mem.eql(u8, name, field_name)) break true; } else false; } + if (ty.isTuple()) { + const field_index = std.fmt.parseUnsigned(u32, field_name, 10) catch break :hf false; + break :hf field_index < ty.structFieldCount(); + } break :hf switch (ty.zigTypeTag()) { .Struct => ty.structFields().contains(field_name), .Union => ty.unionFields().contains(field_name), |
