diff options
| author | Rosa <rosaontheweb@proton.me> | 2026-05-27 13:24:15 -0400 |
|---|---|---|
| committer | Rosa <rosaontheweb@proton.me> | 2026-05-27 13:24:15 -0400 |
| commit | 16e4f8f2a9ead0f79b5b275dc547b517cc8891e9 (patch) | |
| tree | 79ef9796388c4b8a0f1fec99ba5d4b75f8b475f7 /util | |
| parent | 72983cf263053cd40dafbd5f1cb63d3f0b9f1eb8 (diff) | |
add 404.html, remove legacy code
Diffstat (limited to '')
| -rw-r--r-- | util/generate_html.zig | 74 | ||||
| -rw-r--r-- | util/lighttpd.conf | 1 | ||||
| -rw-r--r-- | util/pages.zig | 27 |
3 files changed, 1 insertions, 101 deletions
diff --git a/util/generate_html.zig b/util/generate_html.zig deleted file mode 100644 index 0933d18..0000000 --- a/util/generate_html.zig +++ /dev/null @@ -1,74 +0,0 @@ -const std = @import("std"); -const pages = @import("pages.zig").pages; - -pub fn main(init: std.process.Init) !void { - const sources_dir = try std.Io.Dir.cwd().createDirPathOpen(init.io, "src", .{}); - defer sources_dir.close(init.io); - const out_dir = try std.Io.Dir.cwd().createDirPathOpen(init.io, "html-out", .{}); - defer out_dir.close(init.io); - - const templates_dir = try sources_dir.createDirPathOpen(init.io, "templates", .{ .open_options = .{ .iterate = true } }); - defer templates_dir.close(init.io); - const pages_dir = try sources_dir.createDirPathOpen(init.io, "pages", .{ .open_options = .{ .iterate = true } }); - defer pages_dir.close(init.io); - try generateHtmlPages(init.io, init.arena.allocator(), templates_dir, pages_dir, out_dir); - - const static_dir = try sources_dir.createDirPathOpen(init.io, "static", .{ .open_options = .{ .iterate = true } }); - defer static_dir.close(init.io); - try copyStaticFiles(init.io, init.arena.allocator(), static_dir, out_dir); -} - -fn generateHtmlPages(io: std.Io, ally: std.mem.Allocator, templates_dir: std.Io.Dir, pages_dir: std.Io.Dir, out_dir: std.Io.Dir) !void { - for (pages) |page_def| { - const template = try templates_dir.openFile(io, page_def.template_path, .{}); - defer template.close(io); - const template_buf = try ally.alloc(u8, (try template.stat(io)).size); - _ = try template.readPositionalAll(io, template_buf, 0); - - const page = try pages_dir.openFile(io, page_def.source_path, .{}); - defer page.close(io); - const page_buf = try ally.alloc(u8, (try page.stat(io)).size); - _ = try page.readPositionalAll(io, page_buf, 0); - - var out_buf: []u8 = template_buf; - for (page_def.replacements) |replacement| { - switch (replacement.replacement) { - .file_content => { - out_buf = try std.mem.replaceOwned(u8, ally, out_buf, replacement.placeholder, page_buf); - }, - .literal => |value| { - out_buf = try std.mem.replaceOwned(u8, ally, out_buf, replacement.placeholder, value); - }, - } - } - - const maybeDirname = std.mem.cutLast(u8, page_def.source_path, "/"); - if (maybeDirname) |dirname| { - try out_dir.createDirPath(io, dirname[0]); - } - const out = try out_dir.createFile(io, page_def.source_path, .{}); - defer out.close(io); - std.debug.print("Writing page {s}...\n", .{page_def.source_path}); - try out.writeStreamingAll(io, out_buf); - } -} - -fn copyStaticFiles(io: std.Io, ally: std.mem.Allocator, sources_dir: std.Io.Dir, out_dir: std.Io.Dir) !void { - var walker = try sources_dir.walk(ally); - defer walker.deinit(); - while (try walker.next(io)) |entry| { - switch (entry.kind) { - .file, .sym_link => { - std.debug.print("Copying static file {s}...\n", .{entry.path}); - try entry.dir.copyFile(entry.basename, out_dir, entry.basename, io, .{}); - }, - .directory => { - const new_out = try out_dir.createDirPathOpen(io, entry.basename, .{ .open_options = .{ .iterate = true } }); - defer new_out.close(io); - try copyStaticFiles(io, ally, sources_dir, out_dir); - }, - - else => {}, - } - } -} diff --git a/util/lighttpd.conf b/util/lighttpd.conf index b4f012f..ba34f3f 100644 --- a/util/lighttpd.conf +++ b/util/lighttpd.conf @@ -2,3 +2,4 @@ index-file.names = ( "index.html" ) server.bind = "127.0.0.1" server.document-root = var.CWD + "/html-out" server.port = 8888 +server.errorfile-prefix = server.document-root + "/errors/" diff --git a/util/pages.zig b/util/pages.zig deleted file mode 100644 index 1881aff..0000000 --- a/util/pages.zig +++ /dev/null @@ -1,27 +0,0 @@ -const std = @import("std"); - -pub const pages = [_]Page{Page{ - .source_path = "index.html", - .template_path = "base.html", - .replacements = &[_]Replacement{ Replacement{ - .placeholder = "{{title}}", - .replacement = .{ .literal = "home" }, - }, Replacement{ - .placeholder = "{{body}}", - .replacement = .{ .file_content = {} }, - } }, -}}; - -const Page = struct { - source_path: []const u8, - template_path: []const u8, - replacements: []const Replacement, -}; - -const Replacement = struct { - placeholder: []const u8, - replacement: union(enum) { - file_content, - literal: []const u8, - }, -}; |
