add pathological example as a terminal perf test
This commit is contained in:
parent
c99517181e
commit
a733860a21
3 changed files with 60 additions and 2 deletions
|
@ -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,
|
||||||
});
|
});
|
||||||
|
|
|
@ -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
58
examples/pathological.zig
Normal 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)});
|
||||||
|
}
|
Loading…
Reference in a new issue