From 6201307fecf8398a1b53bf276bc08bfbb3524899 Mon Sep 17 00:00:00 2001 From: Nathan Reiner Date: Mon, 17 Nov 2025 13:09:02 +0100 Subject: implement memora.Stream --- src/routes/static.zig | 10 +++------- 1 file changed, 3 insertions(+), 7 deletions(-) (limited to 'src/routes/static.zig') diff --git a/src/routes/static.zig b/src/routes/static.zig index ef7d493..f52d178 100644 --- a/src/routes/static.zig +++ b/src/routes/static.zig @@ -8,16 +8,14 @@ const log = std.log.scoped(.fallback); pub const access = .everyone; -pub fn get(ctx: *Context) anyerror![]const u8 { +pub fn get(ctx: *Context) anyerror!memora.Stream { var static = try std.fs.cwd().openDir("static", .{}); defer static.close(); if (static.openFile(ctx.request.head.target[1..], .{})) |file| { - defer file.close(); - const content = file.readToEndAlloc(ctx.allocator, std.math.maxInt(usize)); const mime_type = mime.get_type(ctx.request.head.target); ctx.response.headers.content_type = mime_type; - return content; + return .from_file(file); } else |_| { var subdir = if (ctx.request.head.target.len == 1) static else (static.openDir(ctx.request.head.target[1..], .{}) catch { @@ -26,10 +24,8 @@ pub fn get(ctx: *Context) anyerror![]const u8 { defer if (ctx.request.head.target.len > 1) subdir.close(); if (subdir.openFile("index.html", .{})) |file| { - defer file.close(); - const content = file.readToEndAlloc(ctx.allocator, std.math.maxInt(usize)); ctx.response.headers.content_type = "text/html"; - return content; + return .from_file(file); } else |_| { log.warn("File '{s}' Not Found", .{ ctx.request.head.target }); return error.NotFound; -- cgit v1.2.3-70-g09d2