From 2671aa9058b3dcff147ef01dcf3876b0bb231673 Mon Sep 17 00:00:00 2001 From: Andrew Kelley Date: Wed, 20 Sep 2023 15:11:26 -0700 Subject: InternPool: fix nameIndex for tuples --- src/InternPool.zig | 6 +++++- 1 file changed, 5 insertions(+), 1 deletion(-) (limited to 'src') diff --git a/src/InternPool.zig b/src/InternPool.zig index 141e48972c..2aa4fef448 100644 --- a/src/InternPool.zig +++ b/src/InternPool.zig @@ -439,7 +439,11 @@ pub const Key = union(enum) { /// Look up field index based on field name. pub fn nameIndex(self: StructType, ip: *const InternPool, name: NullTerminatedString) ?u32 { - const names_map = self.names_map.unwrap() orelse return null; + const names_map = self.names_map.unwrap() orelse { + const i = name.toUnsigned(ip) orelse return null; + if (i >= self.field_types.len) return null; + return i; + }; const map = &ip.maps.items[@intFromEnum(names_map)]; const adapter: NullTerminatedString.Adapter = .{ .strings = self.field_names.get(ip) }; const field_index = map.getIndexAdapted(name, adapter) orelse return null; -- cgit v1.2.3