summaryrefslogtreecommitdiff
path: root/u/trace/util.ts
diff options
context:
space:
mode:
authorElizabeth Hunt <me@liz.coffee>2025-06-29 17:31:30 -0700
committerElizabeth Hunt <me@liz.coffee>2025-06-29 17:31:30 -0700
commit58be1809c46cbe517a18d86d0af52179dcc5cbf6 (patch)
tree9ccc678b3fd48c1a52fe501600dd2c2051740a55 /u/trace/util.ts
parentd4791f3d357634daf506fb8f91cc5332a794c421 (diff)
downloadci-58be1809c46cbe517a18d86d0af52179dcc5cbf6.tar.gz
ci-58be1809c46cbe517a18d86d0af52179dcc5cbf6.zip
Move to nodejs and also lots of significant refactoring that should've been broken up but idgaf
Diffstat (limited to 'u/trace/util.ts')
-rw-r--r--u/trace/util.ts72
1 files changed, 43 insertions, 29 deletions
diff --git a/u/trace/util.ts b/u/trace/util.ts
index db1db63..ec67571 100644
--- a/u/trace/util.ts
+++ b/u/trace/util.ts
@@ -1,45 +1,59 @@
import {
- ANSI,
+ IEither,
+ IMetric,
+ isEither,
+ ITraceable,
+ ITraceWith,
+ LogLevel,
+ ResultMetric,
type Callable,
- type IMetric,
type ITraceableMapper,
- type ITraceableTuple,
- type MetricsTraceSupplier,
} from '@emprespresso/pengueno';
export class TraceUtil {
- static withTrace<T, Trace>(
- trace: string,
- ansi?: Array<keyof typeof ANSI>,
- ): ITraceableMapper<T, ITraceableTuple<T, Trace | Array<Trace>>, Trace> {
- if (ansi) {
- return (t) => [t.get(), `${ansi.join('')}${trace}${ANSI.RESET}`];
- }
- return (t) => [t.get(), trace];
+ static promiseify<T, U, Trace>(
+ mapper: ITraceableMapper<T, U, Trace>,
+ ): ITraceableMapper<Promise<T>, Promise<U>, Trace> {
+ return (traceablePromise) =>
+ traceablePromise.flatMapAsync(async (t) => t.move(await t.get()).map(mapper)).get();
}
- static withMetricTrace<T, Trace extends MetricsTraceSupplier>(
- metric: IMetric,
- ): ITraceableMapper<T, ITraceableTuple<T, Trace | Array<Trace>>, Trace> {
- return (t) => [t.get(), metric as Trace];
+ static traceResultingEither<TErr, TOk, Trace>(
+ metric?: ResultMetric,
+ warnOnFailure = false,
+ ): ITraceableMapper<IEither<TErr, TOk>, ITraceable<IEither<TErr, TOk>, Trace>, Trace> {
+ return (t) => {
+ if (metric)
+ t.trace.trace(
+ t.get().fold(
+ (_err) => <Trace>(warnOnFailure ? metric.warn : metric.failure),
+ (_ok) => <Trace>metric.success,
+ ),
+ );
+ return t.traceScope((_t) =>
+ _t.get().fold(
+ (_err) => <Trace>(warnOnFailure ? LogLevel.WARN : LogLevel.ERROR),
+ (_ok) => <Trace>LogLevel.INFO,
+ ),
+ );
+ };
}
- static withFunctionTrace<F extends Callable, T, Trace>(
- f: F,
- ): ITraceableMapper<T, ITraceableTuple<T, Trace | Array<Trace>>, Trace> {
- return TraceUtil.withTrace(`fn.${f.name}`);
+ static withTrace<T, Trace, _Trace extends ITraceWith<Trace>>(
+ trace: _Trace,
+ ): ITraceableMapper<T, ITraceable<T, Trace>, Trace> {
+ return (t) => t.traceScope(() => <Trace>trace);
}
- static withClassTrace<C extends object, T, Trace>(
- c: C,
- ): ITraceableMapper<T, ITraceableTuple<T, Trace | Array<Trace>>, Trace> {
- return TraceUtil.withTrace(`class.${c.constructor.name}`);
+ static withMetricTrace<T, Trace>(metric: IMetric): ITraceableMapper<T, ITraceable<T, Trace>, Trace> {
+ return TraceUtil.withTrace(<Trace>metric);
}
- static promiseify<T, U, Trace>(
- mapper: ITraceableMapper<T, U, Trace>,
- ): ITraceableMapper<Promise<T>, Promise<U>, Trace> {
- return (traceablePromise) =>
- traceablePromise.flatMapAsync(async (t) => t.move(await t.get()).map(mapper)).get();
+ static withFunctionTrace<F extends Callable, T, Trace>(f: F): ITraceableMapper<T, ITraceable<T, Trace>, Trace> {
+ return TraceUtil.withTrace(<Trace>`fn.${f.name}`);
+ }
+
+ static withClassTrace<C extends object, T, Trace>(c: C): ITraceableMapper<T, ITraceable<T, Trace>, Trace> {
+ return TraceUtil.withTrace(<Trace>`class.${c.constructor.name}`);
}
}