aboutsummaryrefslogtreecommitdiff
path: root/util
diff options
context:
space:
mode:
authorRosa <rosaontheweb@proton.me>2026-05-27 13:24:15 -0400
committerRosa <rosaontheweb@proton.me>2026-05-27 13:24:15 -0400
commit16e4f8f2a9ead0f79b5b275dc547b517cc8891e9 (patch)
tree79ef9796388c4b8a0f1fec99ba5d4b75f8b475f7 /util
parent72983cf263053cd40dafbd5f1cb63d3f0b9f1eb8 (diff)
add 404.html, remove legacy code
Diffstat (limited to 'util')
-rw-r--r--util/generate_html.zig74
-rw-r--r--util/lighttpd.conf1
-rw-r--r--util/pages.zig27
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,
- },
-};