add basic error handling

This commit is contained in:
Jeeves 2024-03-18 12:32:14 -06:00
parent d1809c641f
commit 2858050579

View file

@ -12,6 +12,9 @@ const memory = @import("modules/memory.zig");
const loadavg = @import("modules/loadavg.zig"); const loadavg = @import("modules/loadavg.zig");
const Module = @import("module.zig"); const Module = @import("module.zig");
const bg_left_color = Color{ .r = 0, .g = 0, .b = 0 };
const bg_right_color = Color{ .r = 0.2, .g = 0.2, .b = 0.2 };
pub fn main() !void { pub fn main() !void {
var arena = heap.ArenaAllocator.init(heap.page_allocator); var arena = heap.ArenaAllocator.init(heap.page_allocator);
defer arena.deinit(); defer arena.deinit();
@ -34,11 +37,28 @@ pub fn main() !void {
}; };
while (true) { while (true) {
// const start_time = std.time.milliTimestamp();
try stdout.print("[", .{}); try stdout.print("[", .{});
const modules_len = 1 / @as(f32, @floatFromInt(modules.len));
var bg = Color{ .r = 0.0, .g = 0.0, .b = 0.0 }; var bg = Color{ .r = 0.0, .g = 0.0, .b = 0.0 };
for (modules, 0..) |module, idx| { for (modules, 0..) |module, idx| {
_ = idx; // const module_start_time = std.time.nanoTimestamp();
var output = try module.getJson();
var output = module.getJson() catch {
const output = Module.JSON{
.full_text = " [error] ",
.background = try bg.getString(arena.allocator()),
.color = try bg.add(Color{ .r = 1, .g = 0.3, .b = 0.3 }).getString(arena.allocator()),
.separator = false,
.separator_block_width = 0,
};
try json.stringify(output, .{ .emit_null_optional_fields = false }, stdout);
try stdout.print(",", .{});
const progress = @as(f32, @floatFromInt(idx + 1)) * modules_len;
bg = bg_left_color.mix(bg_right_color, progress);
continue;
};
output.full_text = try std.fmt.allocPrint(arena.allocator(), " {s} ", .{output.full_text}); output.full_text = try std.fmt.allocPrint(arena.allocator(), " {s} ", .{output.full_text});
output.background = try bg.getString(arena.allocator()); output.background = try bg.getString(arena.allocator());
var color = bg.add(Color{ .r = 0.6, .g = 0.6, .b = 0.6 }); var color = bg.add(Color{ .r = 0.6, .g = 0.6, .b = 0.6 });
@ -48,14 +68,21 @@ pub fn main() !void {
try json.stringify(output, .{ .emit_null_optional_fields = false }, stdout); try json.stringify(output, .{ .emit_null_optional_fields = false }, stdout);
try stdout.print(",", .{}); try stdout.print(",", .{});
bg.r += 0.025; const progress = @as(f32, @floatFromInt(idx + 1)) * modules_len;
bg.g += 0.025; // std.debug.print("\n{d}\n", .{progress});
bg.b += 0.025; bg = bg_left_color.mix(bg_right_color, progress);
// const module_end_time = std.time.nanoTimestamp();
// std.debug.print("\nmodule {d}: finished in {d}ns", .{ idx, module_end_time - module_start_time });
} }
try stdout.print("],\n", .{}); try stdout.print("],\n", .{});
// std.debug.print("\n", .{});
try bw.flush(); try bw.flush();
_ = arena.reset(.retain_capacity); _ = arena.reset(.retain_capacity);
// const end_time = std.time.milliTimestamp();
// std.debug.print("\nFinished in {d}ms", .{end_time - start_time});
std.time.sleep(1000_000_000); std.time.sleep(1000_000_000);
} }
} }
@ -99,7 +126,8 @@ pub const Color = struct {
pub fn mix(a: *const Color, b: Color, t: f32) Color { pub fn mix(a: *const Color, b: Color, t: f32) Color {
const va = a.getVector(); const va = a.getVector();
const vb = b.getVector(); const vb = b.getVector();
return Color.fromVector(std.math.lerp(va, vb, t)); const vt = VecRGB{ t, t, t };
return Color.fromVector(@mulAdd(VecRGB, vb - va, vt, va));
} }
fn getVector(self: *const Color) VecRGB { fn getVector(self: *const Color) VecRGB {