diff options
| author | Anhgelus Morhtuuzh <william@herges.fr> | 2026-04-30 14:33:13 +0200 |
|---|---|---|
| committer | Anhgelus Morhtuuzh <william@herges.fr> | 2026-04-30 14:33:13 +0200 |
| commit | 987bd9323a384e8f042311262d9b0e0eba38da15 (patch) | |
| tree | 852be64f4342f569b991106b8770c75cb160e8ac /src/eval/html/Void.zig | |
| parent | c0d1bd44fb6f5ceb5a79fe607cd40444b7aec2e6 (diff) | |
refactor(html): generalize element creation
Diffstat (limited to 'src/eval/html/Void.zig')
| -rw-r--r-- | src/eval/html/Void.zig | 10 |
1 files changed, 2 insertions, 8 deletions
diff --git a/src/eval/html/Void.zig b/src/eval/html/Void.zig index 99bc923..431536c 100644 --- a/src/eval/html/Void.zig +++ b/src/eval/html/Void.zig @@ -30,7 +30,7 @@ pub fn init(alloc: Allocator, tag: []const u8) Error!*Self { } pub fn element(self: *Self) Element { - return .{ .vtable = .{ .render = render, .node = getNode }, .ptr = self }; + return (Element.Wrapper(Self){ .ptr = self }).element(); } pub fn setAttribute(self: *Self, k: []const u8, v: []const u8) Error!void { @@ -57,18 +57,12 @@ pub fn removeClass(self: *Self, v: []const u8) void { self.class_list.remove(v); } -fn getNode(context: *anyopaque) *Node { - const self: *Self = @ptrCast(@alignCast(context)); - return &self.node; -} - fn fromNode(context: *anyopaque) Element { const self: *Self = @ptrCast(@alignCast(context)); return self.element(); } -fn render(context: *anyopaque, alloc: Allocator) Error![]const u8 { - const self: *Self = @ptrCast(@alignCast(context)); +pub fn render(self: *Self, alloc: Allocator) Error![]const u8 { const attr = try renderAttribute(alloc, &self.attributes, &self.class_list); defer if (attr) |it| alloc.free(it); var acc = try List(u8).initCapacity(alloc, self.tag.len + 2); |
