|
const std = @import("../std.zig"); const builtin = @import("builtin"); const io = std.io; |
StreamSource Provides |
pub const StreamSource = union(enum) { // TODO: expose UEFI files to std.os in a way that allows this to be true const has_file = (builtin.os.tag != .freestanding and builtin.os.tag != .uefi); buffer: io.FixedBufferStream([]u8), const_buffer: io.FixedBufferStream([]const u8), file: if (has_file) std.fs.File else void, pub const ReadError = io.FixedBufferStream([]u8).ReadError || (if (has_file) std.fs.File.ReadError else error{}); pub const WriteError = error{AccessDenied} || io.FixedBufferStream([]u8).WriteError || (if (has_file) std.fs.File.WriteError else error{}); pub const SeekError = io.FixedBufferStream([]u8).SeekError || (if (has_file) std.fs.File.SeekError else error{}); pub const GetSeekPosError = io.FixedBufferStream([]u8).GetSeekPosError || (if (has_file) std.fs.File.GetSeekPosError else error{}); pub const Reader = io.Reader(*StreamSource, ReadError, read); pub const Writer = io.Writer(*StreamSource, WriteError, write); pub const SeekableStream = io.SeekableStream( *StreamSource, SeekError, GetSeekPosError, seekTo, seekBy, getPos, getEndPos, ); |
read() The stream access is redirected to this buffer. The stream access is redirected to this buffer. Writing to the source will always yield |
pub fn read(self: *StreamSource, dest: []u8) ReadError!usize { switch (self.*) { .buffer => |*x| return x.read(dest), .const_buffer => |*x| return x.read(dest), .file => |x| if (!has_file) unreachable else return x.read(dest), } } |
write() |
pub fn write(self: *StreamSource, bytes: []const u8) WriteError!usize { switch (self.*) { .buffer => |*x| return x.write(bytes), .const_buffer => return error.AccessDenied, .file => |x| if (!has_file) unreachable else return x.write(bytes), } } |
seekTo() |
pub fn seekTo(self: *StreamSource, pos: u64) SeekError!void { switch (self.*) { .buffer => |*x| return x.seekTo(pos), .const_buffer => |*x| return x.seekTo(pos), .file => |x| if (!has_file) unreachable else return x.seekTo(pos), } } |
seekBy() |
pub fn seekBy(self: *StreamSource, amt: i64) SeekError!void { switch (self.*) { .buffer => |*x| return x.seekBy(amt), .const_buffer => |*x| return x.seekBy(amt), .file => |x| if (!has_file) unreachable else return x.seekBy(amt), } } |
getEndPos() |
pub fn getEndPos(self: *StreamSource) GetSeekPosError!u64 { switch (self.*) { .buffer => |*x| return x.getEndPos(), .const_buffer => |*x| return x.getEndPos(), .file => |x| if (!has_file) unreachable else return x.getEndPos(), } } |
getPos() |
pub fn getPos(self: *StreamSource) GetSeekPosError!u64 { switch (self.*) { .buffer => |*x| return x.getPos(), .const_buffer => |*x| return x.getPos(), .file => |x| if (!has_file) unreachable else return x.getPos(), } } |
reader() |
pub fn reader(self: *StreamSource) Reader { return .{ .context = self }; } |
writer() |
pub fn writer(self: *StreamSource) Writer { return .{ .context = self }; } |
seekableStream() |
pub fn seekableStream(self: *StreamSource) SeekableStream { return .{ .context = self }; } }; |
Test:StreamSource (refs) |
test "StreamSource (refs)" { std.testing.refAllDecls(StreamSource); } |
Test:StreamSource (mutable buffer) |
test "StreamSource (mutable buffer)" { var buffer: [64]u8 = undefined; var source = StreamSource{ .buffer = std.io.fixedBufferStream(&buffer) }; var writer = source.writer(); try writer.writeAll("Hello, World!"); try std.testing.expectEqualStrings("Hello, World!", source.buffer.getWritten()); } |
Test:StreamSource (const buffer) |
test "StreamSource (const buffer)" { const buffer: [64]u8 = "Hello, World!".* ++ ([1]u8{0xAA} ** 51); var source = StreamSource{ .const_buffer = std.io.fixedBufferStream(&buffer) }; var reader = source.reader(); var dst_buffer: [13]u8 = undefined; try reader.readNoEof(&dst_buffer); try std.testing.expectEqualStrings("Hello, World!", &dst_buffer); } |
Generated by zstd-browse2 on 2023-11-04 14:12:29 -0400. |