diff options
Diffstat (limited to 'codegen/upper.zig')
| -rw-r--r-- | codegen/upper.zig | 31 |
1 files changed, 15 insertions, 16 deletions
diff --git a/codegen/upper.zig b/codegen/upper.zig index 5848911..5eb29e7 100644 --- a/codegen/upper.zig +++ b/codegen/upper.zig | |||
| @@ -1,32 +1,26 @@ | |||
| 1 | const std = @import("std"); | 1 | const std = @import("std"); |
| 2 | const builtin = @import("builtin"); | 2 | const builtin = @import("builtin"); |
| 3 | 3 | ||
| 4 | pub fn main() !void { | 4 | pub 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(); |
| 8 | 8 | ||
| 9 | var write_buf: [4096]u8 = undefined; | ||
| 9 | // Process UnicodeData.txt | 10 | // Process UnicodeData.txt |
| 10 | var in_file = try std.fs.cwd().openFile("data/unicode/UnicodeData.txt", .{}); | 11 | var in_reader = std.io.Reader.fixed(@embedFile("UnicodeData.txt")); |
| 11 | defer in_file.close(); | ||
| 12 | var in_buf = std.io.bufferedReader(in_file.reader()); | ||
| 13 | const in_reader = in_buf.reader(); | ||
| 14 | |||
| 15 | var args_iter = try std.process.argsWithAllocator(allocator); | 12 | var args_iter = try std.process.argsWithAllocator(allocator); |
| 16 | defer args_iter.deinit(); | 13 | defer args_iter.deinit(); |
| 17 | _ = args_iter.skip(); | 14 | _ = args_iter.skip(); |
| 18 | const output_path = args_iter.next() orelse @panic("No output file arg!"); | 15 | const output_path = args_iter.next() orelse @panic("No output file arg!"); |
| 19 | 16 | ||
| 20 | const compressor = std.compress.flate.deflate.compressor; | ||
| 21 | var out_file = try std.fs.cwd().createFile(output_path, .{}); | 17 | var out_file = try std.fs.cwd().createFile(output_path, .{}); |
| 22 | defer out_file.close(); | 18 | defer out_file.close(); |
| 23 | var out_comp = try compressor(.raw, out_file.writer(), .{ .level = .best }); | 19 | var file_writer = out_file.writer(&write_buf); |
| 24 | const writer = out_comp.writer(); | ||
| 25 | |||
| 26 | const endian = builtin.cpu.arch.endian(); | 20 | const endian = builtin.cpu.arch.endian(); |
| 27 | var line_buf: [4096]u8 = undefined; | ||
| 28 | 21 | ||
| 29 | lines: while (try in_reader.readUntilDelimiterOrEof(&line_buf, '\n')) |line| { | 22 | lines: while (in_reader.takeDelimiterInclusive('\n')) |took| { |
| 23 | const line = std.mem.trimRight(u8, took, "\n"); | ||
| 30 | if (line.len == 0) continue; | 24 | if (line.len == 0) continue; |
| 31 | 25 | ||
| 32 | var field_iter = std.mem.splitScalar(u8, line, ';'); | 26 | var field_iter = std.mem.splitScalar(u8, line, ';'); |
| @@ -42,16 +36,21 @@ pub fn main() !void { | |||
| 42 | 12 => { | 36 | 12 => { |
| 43 | // Simple uppercase mapping | 37 | // Simple uppercase mapping |
| 44 | if (field.len == 0) continue :lines; | 38 | if (field.len == 0) continue :lines; |
| 45 | try writer.writeInt(i24, cp, endian); | 39 | try file_writer.interface.writeInt(i24, cp, endian); |
| 46 | const mapping = try std.fmt.parseInt(i24, field, 16); | 40 | const mapping = try std.fmt.parseInt(i24, field, 16); |
| 47 | try writer.writeInt(i24, mapping - cp, endian); | 41 | try file_writer.interface.writeInt(i24, mapping - cp, endian); |
| 48 | }, | 42 | }, |
| 49 | 43 | ||
| 50 | else => {}, | 44 | else => {}, |
| 51 | } | 45 | } |
| 52 | } | 46 | } |
| 47 | } else |err| switch (err) { | ||
| 48 | error.EndOfStream => {}, | ||
| 49 | else => { | ||
| 50 | return err; | ||
| 51 | }, | ||
| 53 | } | 52 | } |
| 54 | 53 | ||
| 55 | try writer.writeInt(u24, 0, endian); | 54 | try file_writer.interface.writeInt(u24, 0, endian); |
| 56 | try out_comp.flush(); | 55 | try file_writer.interface.flush(); |
| 57 | } | 56 | } |