summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorGravatar Jose Colon Rodriguez2024-03-26 08:15:09 -0400
committerGravatar Jose Colon Rodriguez2024-03-26 08:15:09 -0400
commit7fd00b85752e07153c7df46a81917f8e97f6e8c9 (patch)
tree5adf52d94a550aee636a94cb74ba1e19d5cea958
parentRemoved title case processing (diff)
downloadzg-7fd00b85752e07153c7df46a81917f8e97f6e8c9.tar.gz
zg-7fd00b85752e07153c7df46a81917f8e97f6e8c9.tar.xz
zg-7fd00b85752e07153c7df46a81917f8e97f6e8c9.zip
Using diff for uppercase mapping
-rw-r--r--codegen/upper.zig14
-rw-r--r--src/CaseData.zig5
2 files changed, 10 insertions, 9 deletions
diff --git a/codegen/upper.zig b/codegen/upper.zig
index 6fea608..455fe2c 100644
--- a/codegen/upper.zig
+++ b/codegen/upper.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 12 => { 43 12 => {
42 // Simple uppercase mapping 44 // Simple uppercase 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 d790e8c..98a74b1 100644
--- a/src/CaseData.zig
+++ b/src/CaseData.zig
@@ -37,9 +37,10 @@ pub fn init(allocator: mem.Allocator) !Self {
37 var upper_reader = upper_decomp.reader(); 37 var upper_reader = upper_decomp.reader();
38 38
39 while (true) { 39 while (true) {
40 const cp = try upper_reader.readInt(u24, endian); 40 const cp = try upper_reader.readInt(i24, endian);
41 if (cp == 0) break; 41 if (cp == 0) break;
42 self.case_map[cp][0] = @intCast(try upper_reader.readInt(u24, endian)); 42 const diff = try upper_reader.readInt(i24, endian);
43 self.case_map[@intCast(cp)][0] = @intCast(cp + diff);
43 } 44 }
44 45
45 // Lowercase 46 // Lowercase