summaryrefslogtreecommitdiff
path: root/trace/ctx.ha
diff options
context:
space:
mode:
authorLassi Pulkkinen <lassi@pulk.fi>2024-10-31 03:11:21 +0200
committerLassi Pulkkinen <lassi@pulk.fi>2024-10-31 03:51:35 +0200
commitae44478b30d890fe0fb04022f44d474dcdcc3f9d (patch)
tree5f462459ae4b47d22114eed717d1382d08cf4dfe /trace/ctx.ha
Initial commit (import old repo)HEADmain
Diffstat (limited to 'trace/ctx.ha')
-rw-r--r--trace/ctx.ha33
1 files changed, 33 insertions, 0 deletions
diff --git a/trace/ctx.ha b/trace/ctx.ha
new file mode 100644
index 0000000..26a1ce6
--- /dev/null
+++ b/trace/ctx.ha
@@ -0,0 +1,33 @@
+use fmt;
+
+export type ctxtracer = struct {
+ tracer,
+ sink: *tracer,
+ fmt: str,
+ fields: []fmt::field,
+};
+
+export fn ctx(sink: *tracer, fmt: str, fields: fmt::field...) ctxtracer = {
+ return ctxtracer {
+ log = &ctx_log,
+ sink = sink,
+ fmt = fmt,
+ fields = fields,
+ };
+};
+
+fn ctx_log(
+ tr: *tracer,
+ ctx: nullable *context,
+ lvl: level,
+ fmt: str,
+ fields: fmt::field...
+) void = {
+ const tr = tr: *ctxtracer;
+ const ctx_ = context {
+ fmt = tr.fmt,
+ fields = tr.fields,
+ next = ctx,
+ };
+ log(tr.sink, &ctx_, lvl, fmt, fields...);
+};