zig

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

commit 6e86910e194ccce076ee877a02b64e0762a270ab (tree)
parent c82403020d82718df7d42c9438f3145a9a050640
Author: John Benediktsson <mrjbq7@gmail.com>
Date:   Thu, 17 Jul 2025 04:29:22 -0700

std.Io: Fix GenericReader.adaptToNewApi; add DeprecatedReader.adaptToNewApi (#24484)


Diffstat:
Mlib/std/Io.zig | 2++
Mlib/std/Io/DeprecatedReader.zig | 28++++++++++++++++++++++++++++
2 files changed, 30 insertions(+), 0 deletions(-)

diff --git a/lib/std/Io.zig b/lib/std/Io.zig @@ -320,6 +320,8 @@ pub fn GenericReader( .new_interface = .{ .buffer = &.{}, .vtable = &.{ .stream = Adapter.stream }, + .seek = 0, + .end = 0, }, }; } diff --git a/lib/std/Io/DeprecatedReader.zig b/lib/std/Io/DeprecatedReader.zig @@ -372,6 +372,34 @@ pub fn discard(self: Self) anyerror!u64 { } } +/// Helper for bridging to the new `Reader` API while upgrading. +pub fn adaptToNewApi(self: *const Self) Adapter { + return .{ + .derp_reader = self.*, + .new_interface = .{ + .buffer = &.{}, + .vtable = &.{ .stream = Adapter.stream }, + .seek = 0, + .end = 0, + }, + }; +} + +pub const Adapter = struct { + derp_reader: Self, + new_interface: std.io.Reader, + err: ?Error = null, + + fn stream(r: *std.io.Reader, w: *std.io.Writer, limit: std.io.Limit) std.io.Reader.StreamError!usize { + const a: *@This() = @alignCast(@fieldParentPtr("new_interface", r)); + const buf = limit.slice(try w.writableSliceGreedy(1)); + return a.derp_reader.read(buf) catch |err| { + a.err = err; + return error.ReadFailed; + }; + } +}; + const std = @import("../std.zig"); const Self = @This(); const math = std.math;