zig/lib/std /
io/buffered_writer.zig
|
const std = @import("../std.zig");
|
BufferedWriter()
|
const io = std.io;
const mem = std.mem;
|
Error
|
pub fn BufferedWriter(comptime buffer_size: usize, comptime WriterType: type) type {
return struct {
unbuffered_writer: WriterType,
buf: [buffer_size]u8 = undefined,
end: usize = 0,
|
Writer
|
pub const Error = WriterType.Error;
pub const Writer = io.Writer(*Self, Error, write);
|
flush()
|
const Self = @This();
|
writer()
|
pub fn flush(self: *Self) !void {
try self.unbuffered_writer.writeAll(self.buf[0..self.end]);
self.end = 0;
}
|
write()
|
pub fn writer(self: *Self) Writer {
return .{ .context = self };
}
|
bufferedWriter()
|
pub fn write(self: *Self, bytes: []const u8) Error!usize {
if (self.end + bytes.len > self.buf.len) {
try self.flush();
if (bytes.len > self.buf.len)
return self.unbuffered_writer.write(bytes);
}
const new_end = self.end + bytes.len;
@memcpy(self.buf[self.end..new_end], bytes);
self.end = new_end;
return bytes.len;
}
};
}
pub fn bufferedWriter(underlying_stream: anytype) BufferedWriter(4096, @TypeOf(underlying_stream)) {
return .{ .unbuffered_writer = underlying_stream };
}
|
|