Skip to content

Commit

Permalink
fix: don't rely on std.time.microTimestamp() for accurate statistics
Browse files Browse the repository at this point in the history
I don't know the extent to which you care about accuracy for rendering
statistics. I found when working on seamstress that the `timestamp`
calls in `std.time` were so unreliable as to be unusable, sometimes
reporting negative time deltas within a single
function. `std.time.Timer`, on the other hand, has been rock-solid in
my experience.
  • Loading branch information
robbielyman authored and rockorager committed Mar 14, 2024
1 parent 1e5560c commit 9496270
Showing 1 changed file with 4 additions and 2 deletions.
6 changes: 4 additions & 2 deletions src/vaxis.zig
Original file line number Diff line number Diff line change
Expand Up @@ -81,6 +81,7 @@ pub fn Vaxis(comptime T: type) type {
// statistics
renders: usize = 0,
render_dur: i128 = 0,
render_timer: std.time.Timer,

/// Initialize Vaxis with runtime options
pub fn init(_: Options) !Self {
Expand All @@ -89,6 +90,7 @@ pub fn Vaxis(comptime T: type) type {
.tty = null,
.screen = .{},
.screen_last = .{},
.render_timer = try std.time.Timer.start(),
};
}

Expand Down Expand Up @@ -264,9 +266,9 @@ pub fn Vaxis(comptime T: type) type {
pub fn render(self: *Self) !void {
var tty = self.tty orelse return;
self.renders += 1;
const timer_start = std.time.microTimestamp();
self.render_timer.reset();
defer {
self.render_dur += std.time.microTimestamp() - timer_start;
self.render_dur += self.render_timer.read() / std.time.ns_per_us;
}

defer self.refresh = false;
Expand Down

0 comments on commit 9496270

Please sign in to comment.