summaryrefslogtreecommitdiff
path: root/src/Server/parse/Payload.zig
diff options
context:
space:
mode:
authorRobby Zambito <contact@robbyzambito.me>2026-01-07 17:26:10 -0500
committerRobby Zambito <contact@robbyzambito.me>2026-01-07 23:19:19 -0500
commit96a3705069cf33a00ded143f876734c2a045cf1e (patch)
tree61fca89bddd554fb7f8e4800eddde965f7163b0b /src/Server/parse/Payload.zig
parente2a60c9427bfaf63149b4692459e86749553f755 (diff)
starting zero alloc parsing
Diffstat (limited to 'src/Server/parse/Payload.zig')
-rw-r--r--src/Server/parse/Payload.zig51
1 files changed, 0 insertions, 51 deletions
diff --git a/src/Server/parse/Payload.zig b/src/Server/parse/Payload.zig
deleted file mode 100644
index b512a81..0000000
--- a/src/Server/parse/Payload.zig
+++ /dev/null
@@ -1,51 +0,0 @@
-const std = @import("std");
-const Reader = std.Io.Reader;
-const Writer = std.Io.Writer;
-const Allocator = std.mem.Allocator;
-
-const Payload = @This();
-
-len: u32,
-short: [128]u8,
-long: ?[]u8,
-
-pub fn read(alloc: Allocator, in: *Reader, bytes: usize) !Payload {
- var res: Payload = .{
- .len = @intCast(bytes),
- .short = undefined,
- .long = null,
- };
-
- try in.readSliceAll(res.short[0..@min(bytes, res.short.len)]);
- if (bytes > res.short.len) {
- const long = try alloc.alloc(u8, bytes - res.short.len);
- errdefer alloc.free(long);
- try in.readSliceAll(long);
- res.long = long;
- }
- return res;
-}
-
-pub fn write(self: Payload, out: *Writer) !void {
- std.debug.assert(out.buffer.len >= self.short.len);
- std.debug.assert(self.len <= self.short.len or self.long != null);
- try out.writeAll(self.short[0..@min(self.len, self.short.len)]);
- if (self.long) |l| {
- try out.writeAll(l);
- }
-}
-
-pub fn deinit(self: Payload, alloc: Allocator) void {
- if (self.long) |l| {
- alloc.free(l);
- }
-}
-
-pub fn dupe(self: Payload, alloc: Allocator) !Payload {
- var res = self;
- if (self.long) |l| {
- res.long = try alloc.dupe(u8, l);
- }
- errdefer if (res.long) |l| alloc.free(l);
- return res;
-}