diff --git a/src/terminal/Terminal.zig b/src/terminal/Terminal.zig index 1c79fc615..bf66647f4 100644 --- a/src/terminal/Terminal.zig +++ b/src/terminal/Terminal.zig @@ -1346,10 +1346,12 @@ pub fn deleteChars(self: *Terminal, count: usize) !void { } } -pub fn eraseChars(self: *Terminal, count: usize) void { +pub fn eraseChars(self: *Terminal, count_req: usize) void { const tracy = trace(@src()); defer tracy.end(); + const count = @max(count_req, 1); + // This resets the pending wrap state self.screen.cursor.pending_wrap = false; @@ -4787,6 +4789,23 @@ test "Terminal: eraseChars simple operation" { } } +test "Terminal: eraseChars minimum one" { + const alloc = testing.allocator; + var t = try init(alloc, 5, 5); + defer t.deinit(alloc); + + for ("ABC") |c| try t.print(c); + t.setCursorPos(1, 1); + t.eraseChars(0); + try t.print('X'); + + { + var str = try t.plainString(testing.allocator); + defer testing.allocator.free(str); + try testing.expectEqualStrings("XBC", str); + } +} + test "Terminal: eraseChars beyond screen edge" { const alloc = testing.allocator; var t = try init(alloc, 5, 5);