zig

fork of https://codeberg.org/ziglang/zig
Log | Files | Refs | README | LICENSE

commit 149eace5d563a3326604baf808dabb02edbe7fba (tree)
parent adee3ee9a2c679069a15bd5476860d45f05b356b
Author: Carter Snook <cartersnook04@gmail.com>
Date:   Fri, 21 Mar 2025 12:42:29 -0500

deprecate O(n) union field type helpers in std.meta

Users should be using @FieldType() instead.

Diffstat:
Mlib/std/meta.zig | 5+++--
1 file changed, 3 insertions(+), 2 deletions(-)

diff --git a/lib/std/meta.zig b/lib/std/meta.zig @@ -693,8 +693,10 @@ test activeTag { try testing.expect(activeTag(u) == UE.Float); } +/// Deprecated: Use @FieldType(U, tag_name) const TagPayloadType = TagPayload; +/// Deprecated: Use @FieldType(U, tag_name) pub fn TagPayloadByName(comptime U: type, comptime tag_name: []const u8) type { const info = @typeInfo(U).@"union"; @@ -706,8 +708,7 @@ pub fn TagPayloadByName(comptime U: type, comptime tag_name: []const u8) type { @compileError("no field '" ++ tag_name ++ "' in union '" ++ @typeName(U) ++ "'"); } -/// Given a tagged union type, and an enum, return the type of the union field -/// corresponding to the enum tag. +/// Deprecated: Use @FieldType(U, @tagName(tag)) pub fn TagPayload(comptime U: type, comptime tag: Tag(U)) type { return TagPayloadByName(U, @tagName(tag)); }