commit 6a9c9afbae24897a5c6fa843794be33e4ed33f12 (tree)
parent 86a98b172be5060110efdd9c61415c841042564e
Author: Mitchell Hashimoto <mitchell.hashimoto@gmail.com>
Date: Fri, 11 Mar 2022 09:26:36 -0800
stage2: @hasField for anon structs
Diffstat:
2 files changed, 9 insertions(+), 0 deletions(-)
diff --git a/src/Sema.zig b/src/Sema.zig
@@ -7790,6 +7790,11 @@ fn zirHasField(sema: *Sema, block: *Block, inst: Zir.Inst.Index) CompileError!Ai
if (mem.eql(u8, field_name, "len")) break :hf true;
break :hf false;
}
+ if (ty.castTag(.anon_struct)) |pl| {
+ break :hf for (pl.data.names) |name| {
+ if (mem.eql(u8, name, field_name)) break true;
+ } else false;
+ }
break :hf switch (ty.zigTypeTag()) {
.Struct => ty.structFields().contains(field_name),
.Union => ty.unionFields().contains(field_name),
diff --git a/test/behavior/hasfield.zig b/test/behavior/hasfield.zig
@@ -34,4 +34,8 @@ test "@hasField" {
try expect(@hasField(enm, "b") == true);
try expect(@hasField(enm, "non-existant") == false);
try expect(@hasField(enm, "nope") == false);
+
+ const anon = @TypeOf(.{ .a = 1 });
+ try expect(@hasField(anon, "a") == true);
+ try expect(@hasField(anon, "b") == false);
}