summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorGravatar Jose Colon Rodriguez2024-03-26 08:20:15 -0400
committerGravatar Jose Colon Rodriguez2024-03-26 08:20:15 -0400
commit524c0b63bddbf2a0794af8e55d47c18473542199 (patch)
tree0d2b69a1422cbef5a4a572e7a09a6564a704bfba
parentUsing diff for uppercase mapping (diff)
downloadzg-524c0b63bddbf2a0794af8e55d47c18473542199.tar.gz
zg-524c0b63bddbf2a0794af8e55d47c18473542199.tar.xz
zg-524c0b63bddbf2a0794af8e55d47c18473542199.zip
Using diff for lowercase mapping
-rw-r--r--codegen/lower.zig14
-rw-r--r--src/CaseData.zig5
2 files changed, 10 insertions, 9 deletions
diff --git a/codegen/lower.zig b/codegen/lower.zig
index 5a1f1b3..644ec13 100644
--- a/codegen/lower.zig
+++ b/codegen/lower.zig
@@ -31,26 +31,26 @@ pub fn main() !void {
31 if (line.len == 0) continue; 31 if (line.len == 0) continue;
32 32
33 var field_iter = std.mem.splitScalar(u8, line, ';'); 33 var field_iter = std.mem.splitScalar(u8, line, ';');
34 var cps: [2]u24 = undefined; 34 var cp: i24 = undefined;
35 35
36 var i: usize = 0; 36 var i: usize = 0;
37 while (field_iter.next()) |field| : (i += 1) { 37 while (field_iter.next()) |field| : (i += 1) {
38 switch (i) { 38 switch (i) {
39 0 => cps[0] = try std.fmt.parseInt(u24, field, 16), 39 0 => cp = try std.fmt.parseInt(i24, field, 16),
40
41 2 => if (line[0] == '<') continue :lines,
40 42
41 13 => { 43 13 => {
42 // Simple lowercase mapping 44 // Simple lowercase mapping
43 if (field.len == 0) continue :lines; 45 if (field.len == 0) continue :lines;
44 cps[1] = try std.fmt.parseInt(u24, field, 16); 46 try writer.writeInt(i24, cp, endian);
47 const mapping = try std.fmt.parseInt(i24, field, 16);
48 try writer.writeInt(i24, mapping - cp, endian);
45 }, 49 },
46 50
47 2 => if (line[0] == '<') continue :lines,
48
49 else => {}, 51 else => {},
50 } 52 }
51 } 53 }
52
53 for (&cps) |cp| try writer.writeInt(u24, cp, endian);
54 } 54 }
55 55
56 try writer.writeInt(u24, 0, endian); 56 try writer.writeInt(u24, 0, endian);
diff --git a/src/CaseData.zig b/src/CaseData.zig
index 98a74b1..4f06636 100644
--- a/src/CaseData.zig
+++ b/src/CaseData.zig
@@ -51,9 +51,10 @@ pub fn init(allocator: mem.Allocator) !Self {
51 var lower_reader = lower_decomp.reader(); 51 var lower_reader = lower_decomp.reader();
52 52
53 while (true) { 53 while (true) {
54 const cp = try lower_reader.readInt(u24, endian); 54 const cp = try lower_reader.readInt(i24, endian);
55 if (cp == 0) break; 55 if (cp == 0) break;
56 self.case_map[cp][1] = @intCast(try lower_reader.readInt(u24, endian)); 56 const diff = try lower_reader.readInt(i24, endian);
57 self.case_map[@intCast(cp)][1] = @intCast(cp + diff);
57 } 58 }
58 59
59 // Case properties 60 // Case properties