From 054e20cb94cb1e5c8299a7e4ce1c5d2d965d9bda Mon Sep 17 00:00:00 2001 From: Pierre Tachoire Date: Tue, 21 May 2024 17:27:57 +0200 Subject: [PATCH] loop: log timeout and cancel errors instead of panicking --- src/loop.zig | 17 ++++++++++++++--- 1 file changed, 14 insertions(+), 3 deletions(-) diff --git a/src/loop.zig b/src/loop.zig index a7ec7ed..7e48fe0 100644 --- a/src/loop.zig +++ b/src/loop.zig @@ -20,6 +20,8 @@ pub const IO = @import("tigerbeetle-io").IO; const public = @import("api.zig"); const JSCallback = public.Callback; +const log = std.log.scoped(.loop); + fn report(comptime fmt: []const u8, args: anytype) void { const max_len = 200; var buf: [max_len]u8 = undefined; @@ -113,7 +115,13 @@ pub const SingleThreaded = struct { defer ctx.loop.freeCbk(completion, ctx); // TODO: return the error to the callback - result catch |err| @panic(@errorName(err)); + result catch |err| { + switch (err) { + error.Canceled => {}, + else => log.err("timeout callback: {any}", .{err}), + } + return; + }; const old_events_nb = ctx.loop.removeEvent(); if (builtin.is_test) { @@ -159,7 +167,10 @@ pub const SingleThreaded = struct { defer ctx.loop.freeCbk(completion, ctx); // TODO: return the error to the callback - result catch |err| @panic(@errorName(err)); + result catch |err| { + log.err("cancel callback: {any}", .{err}); + return; + }; const old_events_nb = ctx.loop.removeEvent(); if (builtin.is_test) { @@ -180,7 +191,7 @@ pub const SingleThreaded = struct { const completion = self.alloc.create(IO.Completion) catch unreachable; completion.* = undefined; - const ctx = self.alloc.create(ContextTimeout) catch unreachable; + const ctx = self.alloc.create(ContextCancel) catch unreachable; ctx.* = ContextCancel{ .loop = self, .js_cbk = js_cbk,