summaryrefslogtreecommitdiff
path: root/codegen/compat.zig
diff options
context:
space:
mode:
authorGravatar Michael Chaten2025-09-13 08:38:24 -0700
committerGravatar Michael Chaten2025-09-14 01:48:41 -0700
commita3b5e884b12fdaa341010ef41bb9382fa0cd89f8 (patch)
tree8bdd22c1c54da0b56ef6b9fe0dc4c2ca667b71a3 /codegen/compat.zig
parentUpdate build to 0.15.0 (diff)
downloadzg-a3b5e884b12fdaa341010ef41bb9382fa0cd89f8.tar.gz
zg-a3b5e884b12fdaa341010ef41bb9382fa0cd89f8.tar.xz
zg-a3b5e884b12fdaa341010ef41bb9382fa0cd89f8.zip
Update codebase to Zig 0.15.1.
Removes compression support
Diffstat (limited to 'codegen/compat.zig')
-rw-r--r--codegen/compat.zig27
1 files changed, 15 insertions, 12 deletions
diff --git a/codegen/compat.zig b/codegen/compat.zig
index 07616fc..835a636 100644
--- a/codegen/compat.zig
+++ b/codegen/compat.zig
@@ -1,7 +1,7 @@
1const std = @import("std"); 1const std = @import("std");
2const builtin = @import("builtin"); 2const builtin = @import("builtin");
3 3
4pub fn main() !void { 4pub fn main() anyerror!void {
5 var arena = std.heap.ArenaAllocator.init(std.heap.page_allocator); 5 var arena = std.heap.ArenaAllocator.init(std.heap.page_allocator);
6 defer arena.deinit(); 6 defer arena.deinit();
7 const allocator = arena.allocator(); 7 const allocator = arena.allocator();
@@ -9,24 +9,22 @@ pub fn main() !void {
9 // Process UnicodeData.txt 9 // Process UnicodeData.txt
10 var in_file = try std.fs.cwd().openFile("data/unicode/UnicodeData.txt", .{}); 10 var in_file = try std.fs.cwd().openFile("data/unicode/UnicodeData.txt", .{});
11 defer in_file.close(); 11 defer in_file.close();
12 var in_buf = std.io.bufferedReader(in_file.reader()); 12 var line_buf: [4096]u8 = undefined;
13 const in_reader = in_buf.reader(); 13 var write_buf: [4096]u8 = undefined;
14 var in_reader = in_file.reader(&line_buf);
14 15
15 var args_iter = try std.process.argsWithAllocator(allocator); 16 var args_iter = try std.process.argsWithAllocator(allocator);
16 defer args_iter.deinit(); 17 defer args_iter.deinit();
17 _ = args_iter.skip(); 18 _ = args_iter.skip();
18 const output_path = args_iter.next() orelse @panic("No output file arg!"); 19 const output_path = args_iter.next() orelse @panic("No output file arg!");
19 20
20 const compressor = std.compress.flate.deflate.compressor;
21 var out_file = try std.fs.cwd().createFile(output_path, .{}); 21 var out_file = try std.fs.cwd().createFile(output_path, .{});
22 defer out_file.close(); 22 defer out_file.close();
23 var out_comp = try compressor(.raw, out_file.writer(), .{ .level = .best }); 23 var writer = out_file.writer(&write_buf);
24 const writer = out_comp.writer();
25 24
26 const endian = builtin.cpu.arch.endian(); 25 const endian = builtin.cpu.arch.endian();
27 var line_buf: [4096]u8 = undefined;
28 26
29 lines: while (try in_reader.readUntilDelimiterOrEof(&line_buf, '\n')) |line| { 27 lines: while (in_reader.interface.takeDelimiterExclusive('\n')) |line| {
30 if (line.len == 0) continue; 28 if (line.len == 0) continue;
31 29
32 var field_iter = std.mem.splitScalar(u8, line, ';'); 30 var field_iter = std.mem.splitScalar(u8, line, ';');
@@ -55,10 +53,15 @@ pub fn main() !void {
55 } 53 }
56 } 54 }
57 55
58 try writer.writeInt(u8, @intCast(len), endian); 56 try writer.interface.writeInt(u8, @intCast(len), endian);
59 for (cps[0..len]) |cp| try writer.writeInt(u24, cp, endian); 57 for (cps[0..len]) |cp| try writer.interface.writeInt(u24, cp, endian);
58 } else |err| switch (err) {
59 error.EndOfStream => {},
60 else => {
61 return err;
62 },
60 } 63 }
61 64
62 try writer.writeInt(u16, 0, endian); 65 try writer.interface.writeInt(u16, 0, endian);
63 try out_comp.flush(); 66 try writer.interface.flush();
64} 67}