From 4ca3cfac604519ea3053dc4bfcf3261ce0919202 Mon Sep 17 00:00:00 2001 From: -k Date: Thu, 12 Sep 2024 22:45:15 -0700 Subject: [PATCH 1/2] fix: resolve expanding `chars` --- src/main.zig | 19 ++++++++----------- 1 file changed, 8 insertions(+), 11 deletions(-) diff --git a/src/main.zig b/src/main.zig index e1e1046..ade4d8d 100644 --- a/src/main.zig +++ b/src/main.zig @@ -224,9 +224,9 @@ const Column = struct { active: bool = false, chars: std.ArrayList(?Char), - fn init(allocator: std.mem.Allocator) Column { + fn init(allocator: std.mem.Allocator, size: usize) Column { return .{ - .chars = std.ArrayList(?Char).init(allocator), + .chars = std.ArrayList(?Char).initCapacity(allocator, size) catch undefined, }; } @@ -300,10 +300,9 @@ fn printCells(core: *Core, handler: *Handler, rand: std.rand.Random) !void { }, .rain => { // init columns - if (core.columns.?.items.len != core.width) { + if (core.columns.?.items.len == 0) { for (0..@intCast(core.width)) |_| { - var column = Column.init(core.allocator); - try column.addNull(); + const column = Column.init(core.allocator, @intCast(core.height)); try core.columns.?.append(column); } @@ -314,19 +313,17 @@ fn printCells(core: *Core, handler: *Handler, rand: std.rand.Random) !void { } } - if (core.active_columns > 2) { + if (core.active_columns >= 2) { core.columns.?.items[rand.uintLessThan(u32, @intCast(core.width))].?.deactivate(core); } else { core.columns.?.items[rand.uintLessThan(u32, @intCast(core.width))].?.activate(core); } for (0..@intCast(core.width)) |w| { - if (core.columns.?.items[w].?.active) { - if (rand.boolean()) continue; - if (core.columns.?.items[w].?.chars.items.len == core.height) { - _ = core.columns.?.items[w].?.chars.pop(); - } + if (rand.boolean()) continue; + _ = core.columns.?.items[w].?.chars.pop(); + if (core.columns.?.items[w].?.active) { if (rand.uintLessThan(u3, 7) < 3) { try core.columns.?.items[w].?.addNull(); continue; From fc3904b406c9f7ca6169c1bc31a89cb7b26c52c1 Mon Sep 17 00:00:00 2001 From: -k Date: Thu, 12 Sep 2024 22:58:29 -0700 Subject: [PATCH 2/2] test(unit): fix `column` init --- src/main.zig | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/main.zig b/src/main.zig index ade4d8d..e1e6013 100644 --- a/src/main.zig +++ b/src/main.zig @@ -540,7 +540,7 @@ test "column" { var core = Core{ .allocator = std.testing.allocator }; try core.start(Style.default); - const column = Column.init(core.allocator); + const column = Column.init(core.allocator, @intCast(core.height)); try core.columns.?.append(column); try core.columns.?.items[0].?.addChar(&core, Mode.decimal, rand); try core.columns.?.items[0].?.addChar(&core, Mode.decimal, rand);