add pathological example as a terminal perf test

This commit is contained in:
Tim Culverhouse 2024-02-09 12:27:22 -06:00
parent c99517181e
commit a733860a21
3 changed files with 60 additions and 2 deletions

View file

@ -20,7 +20,7 @@ pub fn build(b: *std.Build) void {
const exe = b.addExecutable(.{ const exe = b.addExecutable(.{
.name = "vaxis", .name = "vaxis",
.root_source_file = .{ .path = "examples/text_input.zig" }, .root_source_file = .{ .path = "examples/pathological.zig" },
.target = target, .target = target,
.optimize = optimize, .optimize = optimize,
}); });

View file

@ -2,7 +2,7 @@
.name = "vaxis", .name = "vaxis",
// This is a [Semantic Version](https://semver.org/). // This is a [Semantic Version](https://semver.org/).
// In a future version of Zig it will be used for package deduplication. // In a future version of Zig it will be used for package deduplication.
.version = "0.0.0", .version = "0.1.0",
// This field is optional. // This field is optional.
// This is currently advisory only; Zig does not yet do anything // This is currently advisory only; Zig does not yet do anything

58
examples/pathological.zig Normal file
View file

@ -0,0 +1,58 @@
const std = @import("std");
const vaxis = @import("vaxis");
const Cell = vaxis.Cell;
const log = std.log.scoped(.main);
const Event = union(enum) {
winsize: vaxis.Winsize,
};
pub fn main() !void {
var gpa = std.heap.GeneralPurposeAllocator(.{}){};
const alloc = gpa.allocator();
var vx = try vaxis.init(Event, .{});
errdefer vx.deinit(alloc);
try vx.startReadThread();
defer vx.stopReadThread();
try vx.enterAltScreen();
try vx.queryTerminal();
outer: while (true) {
const event = vx.nextEvent();
switch (event) {
.winsize => |ws| {
try vx.resize(alloc, ws);
break :outer;
},
}
}
const timer_start = std.time.microTimestamp();
var iter: usize = 0;
while (iter < 10_000) : (iter += 1) {
const win = vx.window();
const child = win.initChild(0, 0, .{ .limit = 20 }, .{ .limit = 20 });
win.clear();
var row: usize = 0;
while (row < child.height) : (row += 1) {
var col: usize = 0;
while (col < child.width) : (col += 1) {
child.writeCell(col, row, .{
.char = .{
.grapheme = " ",
.width = 1,
},
.style = .{
.bg = .{ .index = @truncate(col + iter) },
},
});
}
}
try vx.render();
}
const took = std.time.microTimestamp() - timer_start;
vx.deinit(alloc);
log.info("took {d}ms", .{@divTrunc(took, std.time.us_per_ms)});
}