@typed/fx 0.0.13 → 0.0.14
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.eslintcache +1 -1
- package/cjs/Fx.d.ts +6 -3
- package/cjs/Fx.d.ts.map +1 -1
- package/cjs/Fx.js.map +1 -1
- package/cjs/Subject.d.ts +8 -2
- package/cjs/Subject.d.ts.map +1 -1
- package/cjs/Subject.js +26 -9
- package/cjs/Subject.js.map +1 -1
- package/cjs/filterLoop.d.ts +6 -0
- package/cjs/filterLoop.d.ts.map +1 -1
- package/cjs/filterLoop.js +6 -0
- package/cjs/filterLoop.js.map +1 -1
- package/cjs/filterMap.d.ts +6 -0
- package/cjs/filterMap.d.ts.map +1 -1
- package/cjs/filterMap.js +6 -0
- package/cjs/filterMap.js.map +1 -1
- package/cjs/flatMap.js.map +1 -1
- package/cjs/fromEffect.d.ts.map +1 -1
- package/cjs/fromEffect.js +2 -1
- package/cjs/fromEffect.js.map +1 -1
- package/cjs/fromIterable.d.ts +3 -0
- package/cjs/fromIterable.d.ts.map +1 -1
- package/cjs/fromIterable.js +3 -0
- package/cjs/fromIterable.js.map +1 -1
- package/cjs/mapCause.js.map +1 -1
- package/cjs/multicast.d.ts +3 -0
- package/cjs/multicast.d.ts.map +1 -1
- package/cjs/multicast.js +3 -0
- package/cjs/multicast.js.map +1 -1
- package/cjs/runCollect.d.ts.map +1 -1
- package/cjs/runCollect.js +2 -1
- package/cjs/runCollect.js.map +1 -1
- package/cjs/runDrain.d.ts.map +1 -1
- package/cjs/runDrain.js +2 -1
- package/cjs/runDrain.js.map +1 -1
- package/cjs/runObserve.d.ts.map +1 -1
- package/cjs/runObserve.js +2 -1
- package/cjs/runObserve.js.map +1 -1
- package/cjs/snapshot.d.ts +1 -1
- package/cjs/snapshot.d.ts.map +1 -1
- package/cjs/snapshot.js +1 -1
- package/cjs/snapshot.js.map +1 -1
- package/cjs/withEmitter.d.ts +2 -6
- package/cjs/withEmitter.d.ts.map +1 -1
- package/cjs/withEmitter.js.map +1 -1
- package/esm/Fx.d.ts +6 -3
- package/esm/Fx.d.ts.map +1 -1
- package/esm/Fx.js.map +1 -1
- package/esm/Subject.d.ts +8 -2
- package/esm/Subject.d.ts.map +1 -1
- package/esm/Subject.js +26 -9
- package/esm/Subject.js.map +1 -1
- package/esm/filterLoop.d.ts +6 -0
- package/esm/filterLoop.d.ts.map +1 -1
- package/esm/filterLoop.js +6 -0
- package/esm/filterLoop.js.map +1 -1
- package/esm/filterMap.d.ts +6 -0
- package/esm/filterMap.d.ts.map +1 -1
- package/esm/filterMap.js +6 -0
- package/esm/filterMap.js.map +1 -1
- package/esm/flatMap.js.map +1 -1
- package/esm/fromEffect.d.ts.map +1 -1
- package/esm/fromEffect.js +1 -1
- package/esm/fromEffect.js.map +1 -1
- package/esm/fromIterable.d.ts +3 -0
- package/esm/fromIterable.d.ts.map +1 -1
- package/esm/fromIterable.js +3 -0
- package/esm/fromIterable.js.map +1 -1
- package/esm/mapCause.js.map +1 -1
- package/esm/multicast.d.ts +3 -0
- package/esm/multicast.d.ts.map +1 -1
- package/esm/multicast.js +3 -0
- package/esm/multicast.js.map +1 -1
- package/esm/runCollect.d.ts.map +1 -1
- package/esm/runCollect.js +2 -1
- package/esm/runCollect.js.map +1 -1
- package/esm/runDrain.d.ts.map +1 -1
- package/esm/runDrain.js +2 -1
- package/esm/runDrain.js.map +1 -1
- package/esm/runObserve.d.ts.map +1 -1
- package/esm/runObserve.js +2 -1
- package/esm/runObserve.js.map +1 -1
- package/esm/snapshot.d.ts +1 -1
- package/esm/snapshot.d.ts.map +1 -1
- package/esm/snapshot.js +1 -1
- package/esm/snapshot.js.map +1 -1
- package/esm/withEmitter.d.ts +2 -6
- package/esm/withEmitter.d.ts.map +1 -1
- package/esm/withEmitter.js.map +1 -1
- package/package.json +1 -1
- package/src/Fx.ts +12 -4
- package/src/Subject.test.ts +28 -0
- package/src/Subject.ts +38 -12
- package/src/filterLoop.ts +8 -0
- package/src/filterMap.ts +8 -0
- package/src/flatMap.ts +4 -1
- package/src/fromEffect.ts +2 -2
- package/src/fromIterable.ts +4 -0
- package/src/mapCause.ts +4 -1
- package/src/multicast.ts +4 -0
- package/src/runCollect.ts +2 -0
- package/src/runDrain.ts +2 -0
- package/src/runObserve.ts +2 -0
- package/src/snapshot.ts +5 -9
- package/src/withEmitter.ts +2 -6
package/esm/mapCause.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"mapCause.js","sourceRoot":"","sources":["../src/mapCause.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,MAAM,uBAAuB,CAAA;AAC9C,OAAO,EAAE,IAAI,EAAE,MAAM,sBAAsB,CAAA;AAE3C,OAAO,EAAE,OAAO,EAAE,EAAE,EAAE,MAAM,SAAS,CAAA;AAErC,MAAM,UAAU,QAAQ,CAAQ,CAA6C;IAC3E,OAAO,CAAO,EAAe,EAAgB,EAAE,CAAC,SAAS,CAAC,EAAE,EAAE,CAAC,CAAC,CAAA;AAClE,CAAC;AAED,MAAM,UAAU,QAAQ,CAAQ,CAAmB;IACjD,OAAO,CAAO,EAAe,EAAgB,EAAE,CAAC,SAAS,CAAC,EAAE,EAAE,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAA;AAC7E,CAAC;AAED,SAAS,SAAS,
|
|
1
|
+
{"version":3,"file":"mapCause.js","sourceRoot":"","sources":["../src/mapCause.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,MAAM,uBAAuB,CAAA;AAC9C,OAAO,EAAE,IAAI,EAAE,MAAM,sBAAsB,CAAA;AAE3C,OAAO,EAAE,OAAO,EAAE,EAAE,EAAE,MAAM,SAAS,CAAA;AAErC,MAAM,UAAU,QAAQ,CAAQ,CAA6C;IAC3E,OAAO,CAAO,EAAe,EAAgB,EAAE,CAAC,SAAS,CAAC,EAAE,EAAE,CAAC,CAAC,CAAA;AAClE,CAAC;AAED,MAAM,UAAU,QAAQ,CAAQ,CAAmB;IACjD,OAAO,CAAO,EAAe,EAAgB,EAAE,CAAC,SAAS,CAAC,EAAE,EAAE,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAA;AAC7E,CAAC;AAED,SAAS,SAAS,CAChB,EAAe,EACf,CAA6C;IAE7C,OAAO,EAAE,CAAC,CAAC,OAAO,EAAE,EAAE,CAAC,EAAE,CAAC,GAAG,CAAC,OAAO,CAAC,OAAO,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC,EAAE,OAAO,CAAC,SAAS,CAAC,EAAE,OAAO,CAAC,GAAG,CAAC,CAAC,CAAC,CAAA;AAChG,CAAC"}
|
package/esm/multicast.d.ts
CHANGED
|
@@ -13,6 +13,9 @@ export interface MulticastObserver<E, A> {
|
|
|
13
13
|
}
|
|
14
14
|
export declare class Multicast<R, E, A> implements Fx<R, E, A>, Emitter<never, E, A> {
|
|
15
15
|
readonly fx: Fx<R, E, A>;
|
|
16
|
+
readonly _R: () => R;
|
|
17
|
+
readonly _E: () => E;
|
|
18
|
+
readonly _A: () => A;
|
|
16
19
|
protected observers: MulticastObserver<E, A>[];
|
|
17
20
|
protected fiber: Fiber.Fiber<never, unknown> | undefined;
|
|
18
21
|
constructor(fx: Fx<R, E, A>);
|
package/esm/multicast.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"multicast.d.ts","sourceRoot":"","sources":["../src/multicast.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,MAAM,uBAAuB,CAAA;AAC9C,OAAO,KAAK,QAAQ,MAAM,0BAA0B,CAAA;AACpD,OAAO,KAAK,MAAM,MAAM,wBAAwB,CAAA;AAChD,OAAO,KAAK,KAAK,MAAM,uBAAuB,CAAA;AAC9C,OAAO,EAAE,KAAK,EAAE,MAAM,uBAAuB,CAAA;AAG7C,OAAO,EAAE,GAAG,EAAE,MAAM,4BAA4B,CAAA;AAEhD,OAAO,EAAE,OAAO,EAAE,EAAE,EAAE,MAAM,SAAS,CAAA;AAErC,wBAAgB,SAAS,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,EAAE,EAAE,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,GAAG,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAE/D;AAED,MAAM,WAAW,iBAAiB,CAAC,CAAC,EAAE,CAAC;IACrC,QAAQ,CAAC,OAAO,EAAE,OAAO,CAAC,GAAG,EAAE,CAAC,EAAE,CAAC,CAAC,CAAA;IACpC,QAAQ,CAAC,GAAG,EAAE,GAAG,CAAC,GAAG,CAAC,CAAA;IACtB,QAAQ,CAAC,QAAQ,EAAE,QAAQ,CAAC,QAAQ,CAAC,KAAK,EAAE,IAAI,CAAC,CAAA;CAClD;AAED,qBAAa,SAAS,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAE,YAAW,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,OAAO,CAAC,KAAK,EAAE,CAAC,EAAE,CAAC,CAAC;
|
|
1
|
+
{"version":3,"file":"multicast.d.ts","sourceRoot":"","sources":["../src/multicast.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,MAAM,uBAAuB,CAAA;AAC9C,OAAO,KAAK,QAAQ,MAAM,0BAA0B,CAAA;AACpD,OAAO,KAAK,MAAM,MAAM,wBAAwB,CAAA;AAChD,OAAO,KAAK,KAAK,MAAM,uBAAuB,CAAA;AAC9C,OAAO,EAAE,KAAK,EAAE,MAAM,uBAAuB,CAAA;AAG7C,OAAO,EAAE,GAAG,EAAE,MAAM,4BAA4B,CAAA;AAEhD,OAAO,EAAE,OAAO,EAAE,EAAE,EAAE,MAAM,SAAS,CAAA;AAErC,wBAAgB,SAAS,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,EAAE,EAAE,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,GAAG,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAE/D;AAED,MAAM,WAAW,iBAAiB,CAAC,CAAC,EAAE,CAAC;IACrC,QAAQ,CAAC,OAAO,EAAE,OAAO,CAAC,GAAG,EAAE,CAAC,EAAE,CAAC,CAAC,CAAA;IACpC,QAAQ,CAAC,GAAG,EAAE,GAAG,CAAC,GAAG,CAAC,CAAA;IACtB,QAAQ,CAAC,QAAQ,EAAE,QAAQ,CAAC,QAAQ,CAAC,KAAK,EAAE,IAAI,CAAC,CAAA;CAClD;AAED,qBAAa,SAAS,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAE,YAAW,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,OAAO,CAAC,KAAK,EAAE,CAAC,EAAE,CAAC,CAAC;IAQ9D,QAAQ,CAAC,EAAE,EAAE,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC;IAPpC,QAAQ,CAAC,EAAE,EAAG,MAAM,CAAC,CAAA;IACrB,QAAQ,CAAC,EAAE,EAAG,MAAM,CAAC,CAAA;IACrB,QAAQ,CAAC,EAAE,EAAG,MAAM,CAAC,CAAA;IAErB,SAAS,CAAC,SAAS,EAAE,iBAAiB,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAK;IACnD,SAAS,CAAC,KAAK,EAAE,KAAK,CAAC,KAAK,CAAC,KAAK,EAAE,OAAO,CAAC,GAAG,SAAS,CAAA;gBAEnC,EAAE,EAAE,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC;IAKpC,GAAG,CAAC,EAAE,EAAE,OAAO,EAAE,OAAO,CAAC,EAAE,EAAE,CAAC,EAAE,CAAC,CAAC,GAAG,MAAM,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,GAAG,KAAK,EAAE,KAAK,EAAE,OAAO,CAAC;IAqBlF,IAAI,CAAC,CAAC,EAAE,CAAC;IAMT,SAAS,CAAC,CAAC,EAAE,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC;IAS3B,IAAI,GAAG,sCAON;IAED,SAAS,CAAC,QAAQ,CAAC,CAAC,EAAE,CAAC,EAAE,QAAQ,EAAE,iBAAiB,CAAC,CAAC,EAAE,CAAC,CAAC;IAQ1D,SAAS,CAAC,YAAY,CAAC,CAAC,EAAE,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,QAAQ,EAAE,iBAAiB,CAAC,CAAC,EAAE,CAAC,CAAC;IAU3E,SAAS,CAAC,MAAM,CAAC,QAAQ,EAAE,iBAAiB,CAAC,CAAC,EAAE,CAAC,CAAC;IAUlD,SAAS,CAAC,OAAO;CAQlB"}
|
package/esm/multicast.js
CHANGED
package/esm/multicast.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"multicast.js","sourceRoot":"","sources":["../src/multicast.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,QAAQ,MAAM,0BAA0B,CAAA;AACpD,OAAO,KAAK,MAAM,MAAM,wBAAwB,CAAA;AAChD,OAAO,KAAK,KAAK,MAAM,uBAAuB,CAAA;AAE9C,OAAO,EAAE,IAAI,EAAE,MAAM,sBAAsB,CAAA;AAC3C,OAAO,KAAK,QAAQ,MAAM,8BAA8B,CAAA;AAKxD,MAAM,UAAU,SAAS,CAAU,EAAe;IAChD,OAAO,IAAI,SAAS,CAAC,EAAE,CAAC,CAAA;AAC1B,CAAC;AAQD,MAAM,OAAO,SAAS;
|
|
1
|
+
{"version":3,"file":"multicast.js","sourceRoot":"","sources":["../src/multicast.ts"],"names":[],"mappings":"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"}
|
package/esm/runCollect.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"runCollect.d.ts","sourceRoot":"","sources":["../src/runCollect.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,MAAM,wBAAwB,CAAA;AAGhD,OAAO,EAAE,EAAE,EAAE,MAAM,SAAS,CAAA;
|
|
1
|
+
{"version":3,"file":"runCollect.d.ts","sourceRoot":"","sources":["../src/runCollect.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,MAAM,wBAAwB,CAAA;AAGhD,OAAO,EAAE,EAAE,EAAE,MAAM,SAAS,CAAA;AAI5B,wBAAgB,UAAU,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,EAAE,EAAE,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,GAAG,MAAM,CAAC,MAAM,CAAC,CAAC,EAAE,CAAC,EAAE,aAAa,CAAC,CAAC,CAAC,CAAC,CAa1F"}
|
package/esm/runCollect.js
CHANGED
|
@@ -1,7 +1,8 @@
|
|
|
1
1
|
import * as Effect from '@effect/core/io/Effect';
|
|
2
2
|
import { pipe } from '@fp-ts/data/Function';
|
|
3
|
+
import { onEarlyExitFailure } from './_internal.js';
|
|
3
4
|
import { runObserve } from './runObserve.js';
|
|
4
5
|
export function runCollect(fx) {
|
|
5
|
-
return pipe(Effect.sync(() => []), Effect.flatMap((values) => pipe(fx, runObserve((a) => Effect.sync(() => values.push(a))), Effect.map(() => values))), Effect.scoped);
|
|
6
|
+
return pipe(Effect.sync(() => []), Effect.flatMap((values) => pipe(fx, runObserve((a) => Effect.sync(() => values.push(a))), onEarlyExitFailure(Effect.unit), Effect.map(() => values))), Effect.scoped);
|
|
6
7
|
}
|
|
7
8
|
//# sourceMappingURL=runCollect.js.map
|
package/esm/runCollect.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"runCollect.js","sourceRoot":"","sources":["../src/runCollect.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,MAAM,wBAAwB,CAAA;AAChD,OAAO,EAAE,IAAI,EAAE,MAAM,sBAAsB,CAAA;AAG3C,OAAO,EAAE,UAAU,EAAE,MAAM,iBAAiB,CAAA;AAE5C,MAAM,UAAU,UAAU,CAAU,EAAe;IACjD,OAAO,IAAI,CACT,MAAM,CAAC,IAAI,CAAM,GAAG,EAAE,CAAC,EAAE,CAAC,EAC1B,MAAM,CAAC,OAAO,CAAC,CAAC,MAAM,EAAE,EAAE,CACxB,IAAI,CACF,EAAE,EACF,UAAU,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,MAAM,CAAC,IAAI,CAAC,GAAG,EAAE,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,EACpD,MAAM,CAAC,GAAG,CAAC,GAAG,EAAE,CAAC,MAAM,CAAC,CACzB,CACF,EACD,MAAM,CAAC,MAAM,CACd,CAAA;AACH,CAAC"}
|
|
1
|
+
{"version":3,"file":"runCollect.js","sourceRoot":"","sources":["../src/runCollect.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,MAAM,wBAAwB,CAAA;AAChD,OAAO,EAAE,IAAI,EAAE,MAAM,sBAAsB,CAAA;AAG3C,OAAO,EAAE,kBAAkB,EAAE,MAAM,gBAAgB,CAAA;AACnD,OAAO,EAAE,UAAU,EAAE,MAAM,iBAAiB,CAAA;AAE5C,MAAM,UAAU,UAAU,CAAU,EAAe;IACjD,OAAO,IAAI,CACT,MAAM,CAAC,IAAI,CAAM,GAAG,EAAE,CAAC,EAAE,CAAC,EAC1B,MAAM,CAAC,OAAO,CAAC,CAAC,MAAM,EAAE,EAAE,CACxB,IAAI,CACF,EAAE,EACF,UAAU,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,MAAM,CAAC,IAAI,CAAC,GAAG,EAAE,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,EACpD,kBAAkB,CAAC,MAAM,CAAC,IAAI,CAAC,EAC/B,MAAM,CAAC,GAAG,CAAC,GAAG,EAAE,CAAC,MAAM,CAAC,CACzB,CACF,EACD,MAAM,CAAC,MAAM,CACd,CAAA;AACH,CAAC"}
|
package/esm/runDrain.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"runDrain.d.ts","sourceRoot":"","sources":["../src/runDrain.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,MAAM,MAAM,wBAAwB,CAAA;AAGhD,OAAO,EAAE,EAAE,EAAE,MAAM,SAAS,CAAA;
|
|
1
|
+
{"version":3,"file":"runDrain.d.ts","sourceRoot":"","sources":["../src/runDrain.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,MAAM,MAAM,wBAAwB,CAAA;AAGhD,OAAO,EAAE,EAAE,EAAE,MAAM,SAAS,CAAA;AAG5B,wBAAgB,QAAQ,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,EAAE,EAAE,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,GAAG,MAAM,CAAC,MAAM,CAAC,CAAC,EAAE,CAAC,EAAE,IAAI,CAAC,CAiB5E"}
|
package/esm/runDrain.js
CHANGED
|
@@ -1,11 +1,12 @@
|
|
|
1
1
|
import * as Deferred from '@effect/core/io/Deferred';
|
|
2
2
|
import * as Effect from '@effect/core/io/Effect';
|
|
3
3
|
import { pipe } from '@fp-ts/data/Function';
|
|
4
|
+
import { onEarlyExitFailure } from './_internal.js';
|
|
4
5
|
export function runDrain(fx) {
|
|
5
6
|
return pipe(Deferred.make(), Effect.flatMap((deferred) => pipe(fx.run({
|
|
6
7
|
emit: () => Effect.unit,
|
|
7
8
|
failCause: (c) => deferred.failCauseSync(c),
|
|
8
9
|
end: deferred.succeed(undefined),
|
|
9
|
-
}), Effect.forkScoped, Effect.zipRight(deferred.await))), Effect.scoped);
|
|
10
|
+
}), Effect.forkScoped, Effect.zipRight(deferred.await), onEarlyExitFailure(Effect.sync(() => deferred.succeed(undefined))))), Effect.scoped);
|
|
10
11
|
}
|
|
11
12
|
//# sourceMappingURL=runDrain.js.map
|
package/esm/runDrain.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"runDrain.js","sourceRoot":"","sources":["../src/runDrain.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,QAAQ,MAAM,0BAA0B,CAAA;AACpD,OAAO,KAAK,MAAM,MAAM,wBAAwB,CAAA;AAChD,OAAO,EAAE,IAAI,EAAE,MAAM,sBAAsB,CAAA;
|
|
1
|
+
{"version":3,"file":"runDrain.js","sourceRoot":"","sources":["../src/runDrain.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,QAAQ,MAAM,0BAA0B,CAAA;AACpD,OAAO,KAAK,MAAM,MAAM,wBAAwB,CAAA;AAChD,OAAO,EAAE,IAAI,EAAE,MAAM,sBAAsB,CAAA;AAG3C,OAAO,EAAE,kBAAkB,EAAE,MAAM,gBAAgB,CAAA;AAEnD,MAAM,UAAU,QAAQ,CAAU,EAAe;IAC/C,OAAO,IAAI,CACT,QAAQ,CAAC,IAAI,EAAW,EACxB,MAAM,CAAC,OAAO,CAAC,CAAC,QAAQ,EAAE,EAAE,CAC1B,IAAI,CACF,EAAE,CAAC,GAAG,CAAC;QACL,IAAI,EAAE,GAAG,EAAE,CAAC,MAAM,CAAC,IAAI;QACvB,SAAS,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,QAAQ,CAAC,aAAa,CAAC,CAAC,CAAC;QAC3C,GAAG,EAAE,QAAQ,CAAC,OAAO,CAAC,SAAS,CAAC;KACjC,CAAC,EACF,MAAM,CAAC,UAAU,EACjB,MAAM,CAAC,QAAQ,CAAC,QAAQ,CAAC,KAAK,CAAC,EAC/B,kBAAkB,CAAC,MAAM,CAAC,IAAI,CAAC,GAAG,EAAE,CAAC,QAAQ,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC,CAAC,CACnE,CACF,EACD,MAAM,CAAC,MAAM,CACd,CAAA;AACH,CAAC"}
|
package/esm/runObserve.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"runObserve.d.ts","sourceRoot":"","sources":["../src/runObserve.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,MAAM,MAAM,wBAAwB,CAAA;AAGhD,OAAO,EAAW,EAAE,EAAE,MAAM,SAAS,CAAA;
|
|
1
|
+
{"version":3,"file":"runObserve.d.ts","sourceRoot":"","sources":["../src/runObserve.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,MAAM,MAAM,wBAAwB,CAAA;AAGhD,OAAO,EAAW,EAAE,EAAE,MAAM,SAAS,CAAA;AAGrC,wBAAgB,UAAU,CAAC,CAAC,EAAE,EAAE,EAAE,EAAE,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,KAAK,MAAM,CAAC,MAAM,CAAC,EAAE,EAAE,EAAE,EAAE,CAAC,CAAC,kEAyB7E"}
|
package/esm/runObserve.js
CHANGED
|
@@ -2,7 +2,8 @@ import * as Deferred from '@effect/core/io/Deferred';
|
|
|
2
2
|
import * as Effect from '@effect/core/io/Effect';
|
|
3
3
|
import { flow, pipe } from '@fp-ts/data/Function';
|
|
4
4
|
import { Emitter } from './Fx.js';
|
|
5
|
+
import { onEarlyExitFailure } from './_internal.js';
|
|
5
6
|
export function runObserve(f) {
|
|
6
|
-
return (fx) => pipe(Deferred.make(), Effect.tap((deferred) => Effect.forkScoped(fx.run(Emitter(flow(f, Effect.foldCauseEffect((c) => deferred.failCauseSync(c), () => Effect.unit)), (c) => deferred.failCauseSync(c), deferred.succeed(undefined))))), Effect.flatMap((deferred) => deferred.await), Effect.scoped);
|
|
7
|
+
return (fx) => pipe(Deferred.make(), Effect.tap((deferred) => Effect.forkScoped(fx.run(Emitter(flow(f, Effect.foldCauseEffect((c) => deferred.failCauseSync(c), () => Effect.unit)), (c) => deferred.failCauseSync(c), deferred.succeed(undefined))))), Effect.flatMap((deferred) => deferred.await), onEarlyExitFailure(Effect.unit), Effect.scoped);
|
|
7
8
|
}
|
|
8
9
|
//# sourceMappingURL=runObserve.js.map
|
package/esm/runObserve.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"runObserve.js","sourceRoot":"","sources":["../src/runObserve.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,QAAQ,MAAM,0BAA0B,CAAA;AACpD,OAAO,KAAK,MAAM,MAAM,wBAAwB,CAAA;AAChD,OAAO,EAAE,IAAI,EAAE,IAAI,EAAE,MAAM,sBAAsB,CAAA;AAEjD,OAAO,EAAE,OAAO,EAAM,MAAM,SAAS,CAAA;
|
|
1
|
+
{"version":3,"file":"runObserve.js","sourceRoot":"","sources":["../src/runObserve.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,QAAQ,MAAM,0BAA0B,CAAA;AACpD,OAAO,KAAK,MAAM,MAAM,wBAAwB,CAAA;AAChD,OAAO,EAAE,IAAI,EAAE,IAAI,EAAE,MAAM,sBAAsB,CAAA;AAEjD,OAAO,EAAE,OAAO,EAAM,MAAM,SAAS,CAAA;AACrC,OAAO,EAAE,kBAAkB,EAAE,MAAM,gBAAgB,CAAA;AAEnD,MAAM,UAAU,UAAU,CAAe,CAAqC;IAC5E,OAAO,CAAO,EAAe,EAAuC,EAAE,CACpE,IAAI,CACF,QAAQ,CAAC,IAAI,EAAgB,EAC7B,MAAM,CAAC,GAAG,CAAC,CAAC,QAAQ,EAAE,EAAE,CACtB,MAAM,CAAC,UAAU,CACf,EAAE,CAAC,GAAG,CACJ,OAAO,CACL,IAAI,CACF,CAAC,EACD,MAAM,CAAC,eAAe,CACpB,CAAC,CAAC,EAAE,EAAE,CAAC,QAAQ,CAAC,aAAa,CAAC,CAAC,CAAC,EAChC,GAAG,EAAE,CAAC,MAAM,CAAC,IAAI,CAClB,CACF,EACD,CAAC,CAAC,EAAE,EAAE,CAAC,QAAQ,CAAC,aAAa,CAAC,CAAC,CAAC,EAChC,QAAQ,CAAC,OAAO,CAAC,SAAS,CAAC,CAC5B,CACF,CACF,CACF,EACD,MAAM,CAAC,OAAO,CAAC,CAAC,QAAQ,EAAE,EAAE,CAAC,QAAQ,CAAC,KAAK,CAAC,EAC5C,kBAAkB,CAAC,MAAM,CAAC,IAAI,CAAC,EAC/B,MAAM,CAAC,MAAM,CACd,CAAA;AACL,CAAC"}
|
package/esm/snapshot.d.ts
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
1
|
import { Fx } from './Fx.js';
|
|
2
|
-
export declare function snapshot<R2, E2, B, A,
|
|
2
|
+
export declare function snapshot<R2, E2, B, A, C>(sampled: Fx<R2, E2, B>, f: (b: B, a: A) => C): <R, E>(sampler: Fx<R, E, A>) => Fx<R2 | R, E2 | E, C>;
|
|
3
3
|
export declare function sample<R2, E2, B>(sampled: Fx<R2, E2, B>): <R, E, A>(sampler: Fx<R, E, A>) => Fx<R2 | R, E2 | E, readonly [A, B]>;
|
|
4
4
|
//# sourceMappingURL=snapshot.d.ts.map
|
package/esm/snapshot.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"snapshot.d.ts","sourceRoot":"","sources":["../src/snapshot.ts"],"names":[],"mappings":"AAKA,OAAO,EAAW,EAAE,EAAE,MAAM,SAAS,CAAA;AAErC,wBAAgB,QAAQ,CAAC,EAAE,EAAE,EAAE,EAAE,CAAC,EAAE,CAAC,EAAE,
|
|
1
|
+
{"version":3,"file":"snapshot.d.ts","sourceRoot":"","sources":["../src/snapshot.ts"],"names":[],"mappings":"AAKA,OAAO,EAAW,EAAE,EAAE,MAAM,SAAS,CAAA;AAErC,wBAAgB,QAAQ,CAAC,EAAE,EAAE,EAAE,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,OAAO,EAAE,EAAE,CAAC,EAAE,EAAE,EAAE,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,KAAK,CAAC,yDAErF;AAED,wBAAgB,MAAM,CAAC,EAAE,EAAE,EAAE,EAAE,CAAC,EAAE,OAAO,EAAE,EAAE,CAAC,EAAE,EAAE,EAAE,EAAE,CAAC,CAAC,0EAGvD"}
|
package/esm/snapshot.js
CHANGED
|
@@ -7,7 +7,7 @@ export function snapshot(sampled, f) {
|
|
|
7
7
|
return (sampler) => snapshot_(sampler, sampled, f);
|
|
8
8
|
}
|
|
9
9
|
export function sample(sampled) {
|
|
10
|
-
return (sampler) =>
|
|
10
|
+
return (sampler) => snapshot_(sampler, sampled, (b, a) => [a, b]);
|
|
11
11
|
}
|
|
12
12
|
function snapshot_(sampler, sampled, f) {
|
|
13
13
|
return Fx((emitter) => pipe(Effect.sync(() => new AtomicReference(Maybe.none)), Effect.tap((ref) => Effect.forkScoped(sampled.run(Emitter((a) => Effect.sync(() => ref.set(Maybe.some(a))), emitter.failCause, Effect.unit)))), Effect.flatMap((ref) => sampler.run(Emitter((a) => pipe(ref.get, Maybe.fold(() => Effect.unit, (b) => emitter.emit(f(b, a)))), emitter.failCause, emitter.end)))));
|
package/esm/snapshot.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"snapshot.js","sourceRoot":"","sources":["../src/snapshot.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,MAAM,wBAAwB,CAAA;AAChD,OAAO,EAAE,IAAI,EAAE,MAAM,sBAAsB,CAAA;AAC3C,OAAO,EAAE,eAAe,EAAE,MAAM,qCAAqC,CAAA;AACrE,OAAO,KAAK,KAAK,MAAM,2BAA2B,CAAA;AAElD,OAAO,EAAE,OAAO,EAAE,EAAE,EAAE,MAAM,SAAS,CAAA;AAErC,MAAM,UAAU,QAAQ,
|
|
1
|
+
{"version":3,"file":"snapshot.js","sourceRoot":"","sources":["../src/snapshot.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,MAAM,wBAAwB,CAAA;AAChD,OAAO,EAAE,IAAI,EAAE,MAAM,sBAAsB,CAAA;AAC3C,OAAO,EAAE,eAAe,EAAE,MAAM,qCAAqC,CAAA;AACrE,OAAO,KAAK,KAAK,MAAM,2BAA2B,CAAA;AAElD,OAAO,EAAE,OAAO,EAAE,EAAE,EAAE,MAAM,SAAS,CAAA;AAErC,MAAM,UAAU,QAAQ,CAAkB,OAAsB,EAAE,CAAoB;IACpF,OAAO,CAAO,OAAoB,EAAyB,EAAE,CAAC,SAAS,CAAC,OAAO,EAAE,OAAO,EAAE,CAAC,CAAC,CAAA;AAC9F,CAAC;AAED,MAAM,UAAU,MAAM,CAAY,OAAsB;IACtD,OAAO,CAAU,OAAoB,EAAuC,EAAE,CAC5E,SAAS,CAAC,OAAO,EAAE,OAAO,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAA;AACjD,CAAC;AAED,SAAS,SAAS,CAChB,OAAoB,EACpB,OAAsB,EACtB,CAAoB;IAEpB,OAAO,EAAE,CAAC,CAAC,OAAO,EAAE,EAAE,CACpB,IAAI,CACF,MAAM,CAAC,IAAI,CAAC,GAAG,EAAE,CAAC,IAAI,eAAe,CAAiB,KAAK,CAAC,IAAI,CAAC,CAAC,EAClE,MAAM,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE,CACjB,MAAM,CAAC,UAAU,CACf,OAAO,CAAC,GAAG,CACT,OAAO,CACL,CAAC,CAAC,EAAE,EAAE,CAAC,MAAM,CAAC,IAAI,CAAC,GAAG,EAAE,CAAC,GAAG,CAAC,GAAG,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,EAChD,OAAO,CAAC,SAAS,EACjB,MAAM,CAAC,IAAI,CACZ,CACF,CACF,CACF,EACD,MAAM,CAAC,OAAO,CAAC,CAAC,GAAG,EAAE,EAAE,CACrB,OAAO,CAAC,GAAG,CACT,OAAO,CACL,CAAC,CAAC,EAAE,EAAE,CACJ,IAAI,CACF,GAAG,CAAC,GAAG,EACP,KAAK,CAAC,IAAI,CACR,GAAG,EAAE,CAAC,MAAM,CAAC,IAAI,EACjB,CAAC,CAAC,EAAE,EAAE,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAC7B,CACF,EACH,OAAO,CAAC,SAAS,EACjB,OAAO,CAAC,GAAG,CACZ,CACF,CACF,CACF,CACF,CAAA;AACH,CAAC"}
|
package/esm/withEmitter.d.ts
CHANGED
|
@@ -1,9 +1,5 @@
|
|
|
1
|
-
import { Cause } from '@effect/core/io/Cause';
|
|
2
1
|
import * as Effect from '@effect/core/io/Effect';
|
|
3
2
|
import { Fx } from './Fx.js';
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
readonly failCause: (cause: Cause<E>) => void;
|
|
7
|
-
readonly end: () => void;
|
|
8
|
-
}) => Effect.Canceler<R>): Fx<R, E, A>;
|
|
3
|
+
import type { SubjectEmitter } from './Subject.js';
|
|
4
|
+
export declare function withEmitter<R, E, A>(f: (emitter: SubjectEmitter<E, A>) => Effect.Canceler<R>): Fx<R, E, A>;
|
|
9
5
|
//# sourceMappingURL=withEmitter.d.ts.map
|
package/esm/withEmitter.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"withEmitter.d.ts","sourceRoot":"","sources":["../src/withEmitter.ts"],"names":[],"mappings":"AAAA,OAAO,
|
|
1
|
+
{"version":3,"file":"withEmitter.d.ts","sourceRoot":"","sources":["../src/withEmitter.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,MAAM,wBAAwB,CAAA;AAMhD,OAAO,EAAW,EAAE,EAAE,MAAM,SAAS,CAAA;AACrC,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,cAAc,CAAA;AAElD,wBAAgB,WAAW,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EACjC,CAAC,EAAE,CAAC,OAAO,EAAE,cAAc,CAAC,CAAC,EAAE,CAAC,CAAC,KAAK,MAAM,CAAC,QAAQ,CAAC,CAAC,CAAC,GACvD,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAiCb"}
|
package/esm/withEmitter.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"withEmitter.js","sourceRoot":"","sources":["../src/withEmitter.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"withEmitter.js","sourceRoot":"","sources":["../src/withEmitter.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,MAAM,wBAAwB,CAAA;AAChD,OAAO,KAAK,IAAI,MAAM,sBAAsB,CAAA;AAC5C,OAAO,EAAE,mBAAmB,EAAE,MAAM,yCAAyC,CAAA;AAE7E,OAAO,EAAE,IAAI,EAAE,IAAI,EAAE,MAAM,sBAAsB,CAAA;AAEjD,OAAO,EAAW,EAAE,EAAE,MAAM,SAAS,CAAA;AAGrC,MAAM,UAAU,WAAW,CACzB,CAAwD;IAExD,OAAO,EAAE,CAAU,CAAK,IAAuB,EAAE,EAAE;QACjD,OAAO,MAAM,CAAC,gBAAgB,CAAiC,CAAC,KAAK,EAAE,MAAM,EAAE,EAAE;YAC/E,MAAM,SAAS,GAAG,CAChB,GAA2B,EAC3B,QAAyC,EACzC,EAAE;gBACF,MAAM,CAAC,GAAG,mBAAmB,CAAC,GAAG,EAAE,KAAK,EAAE,MAAM,CAAC,YAAY,CAAC,CAAA;gBAC9D,CAAC,CAAC,WAAW,CAAC,QAAQ,CAAC,CAAA;gBACvB,CAAC,CAAC,KAAK,CAAC,GAAG,CAAC,CAAA;YACd,CAAC,CAAA;YAED,IAAI,QAAQ,GAAuB,MAAM,CAAC,IAAI,CAAA;YAE9C,OAAO,IAAI,CACT,MAAM,CAAC,YAAY,CAAC,MAAM,CAAC,cAAc,CAAC,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,EAC1D,MAAM,CAAC,QAAQ,CACb,MAAM,CAAC,WAAW,CAA6C,CAAC,EAAE,EAAE,EAAE;gBACpE,QAAQ,GAAG,CAAC,CAAC;oBACX,IAAI,EAAE,CAAC,CAAC,EAAE,EAAE,CACV,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,IAAI,EAAE,EAAE,CAC/B,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,MAAM,CAAC,SAAS,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,SAAS,CACpE;oBACH,SAAS,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,SAAS,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,IAAI,CAAC,MAAM,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC;oBACrE,GAAG,EAAE,GAAG,EAAE,CAAC,SAAS,CAAC,IAAI,CAAC,GAAG,EAAE,IAAI,CAAC,MAAM,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC;iBACtD,CAAC,CAAA;gBAEF,OAAO,QAAQ,CAAA;YACjB,CAAC,CAAC,CACH,CACF,CAAA;QACH,CAAC,CAAC,CAAA;IACJ,CAAC,CAAC,CAAA;AACJ,CAAC"}
|
package/package.json
CHANGED
package/src/Fx.ts
CHANGED
|
@@ -3,19 +3,27 @@ import * as Effect from '@effect/core/io/Effect'
|
|
|
3
3
|
import { Scope } from '@effect/core/io/Scope'
|
|
4
4
|
|
|
5
5
|
export interface Fx<R, E, A> {
|
|
6
|
+
readonly _R: () => R
|
|
7
|
+
readonly _E: () => E
|
|
8
|
+
readonly _A: () => A
|
|
9
|
+
|
|
6
10
|
run<R2>(emitter: Emitter<R2, E, A>): Effect.Effect<R | R2 | Scope, never, unknown>
|
|
7
11
|
}
|
|
8
12
|
|
|
9
13
|
export function Fx<R, E, A>(run: Fx<R, E, A>['run']): Fx<R, E, A> {
|
|
10
14
|
return {
|
|
11
15
|
run,
|
|
12
|
-
}
|
|
16
|
+
} as Fx<R, E, A>
|
|
13
17
|
}
|
|
14
18
|
|
|
15
19
|
export namespace Fx {
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
export type
|
|
20
|
+
/* eslint-disable @typescript-eslint/no-unused-vars */
|
|
21
|
+
|
|
22
|
+
export type ResourcesOf<T> = [T] extends [Fx<infer R, infer _E, infer _A>] ? R : never
|
|
23
|
+
export type ErrorsOf<T> = [T] extends [Fx<infer _R, infer E, infer _A>] ? E : never
|
|
24
|
+
export type OutputOf<T> = [T] extends [Fx<infer _R, infer _E, infer A>] ? A : never
|
|
25
|
+
|
|
26
|
+
/* eslint-enable @typescript-eslint/no-unused-vars */
|
|
19
27
|
}
|
|
20
28
|
|
|
21
29
|
export interface Emitter<R, E, A> {
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
import { deepStrictEqual } from 'assert'
|
|
2
|
+
|
|
3
|
+
import * as Effect from '@effect/core/io/Effect'
|
|
4
|
+
import { pipe } from '@fp-ts/data/Function'
|
|
5
|
+
|
|
6
|
+
import * as Fx from './index.js'
|
|
7
|
+
|
|
8
|
+
describe(import.meta.url, () => {
|
|
9
|
+
describe('Subject', () => {
|
|
10
|
+
it('creates a stream which can be pushed into imperatively', async () => {
|
|
11
|
+
const subject = Fx.Subject.unsafeMake<number, number>()
|
|
12
|
+
const promise = pipe(
|
|
13
|
+
subject,
|
|
14
|
+
Fx.map((n) => n * 2),
|
|
15
|
+
Fx.take(3),
|
|
16
|
+
Fx.runCollect,
|
|
17
|
+
Effect.unsafeRunPromise,
|
|
18
|
+
)
|
|
19
|
+
|
|
20
|
+
subject.emit(1)
|
|
21
|
+
subject.emit(2)
|
|
22
|
+
subject.emit(3)
|
|
23
|
+
subject.end()
|
|
24
|
+
|
|
25
|
+
deepStrictEqual(await promise, [2, 4, 6])
|
|
26
|
+
})
|
|
27
|
+
})
|
|
28
|
+
})
|
package/src/Subject.ts
CHANGED
|
@@ -1,17 +1,33 @@
|
|
|
1
1
|
import * as Effect from '@effect/core/io/Effect'
|
|
2
2
|
import * as Maybe from '@tsplus/stdlib/data/Maybe'
|
|
3
|
+
import { Cause } from 'node_modules/@effect/core/io/Cause.js'
|
|
3
4
|
import { pipe } from 'node_modules/@fp-ts/data/Function.js'
|
|
4
5
|
import { LazyArg } from 'node_modules/@tsplus/stdlib/data/Function.js'
|
|
5
6
|
|
|
6
|
-
import {
|
|
7
|
+
import { Fx } from './Fx.js'
|
|
7
8
|
import { never } from './fromEffect.js'
|
|
8
9
|
import { Hold } from './hold.js'
|
|
9
10
|
import { Multicast } from './multicast.js'
|
|
10
11
|
|
|
11
|
-
export interface Subject<E, A> extends
|
|
12
|
+
export interface Subject<E, A> extends SubjectEmitter<E, A>, Fx<never, E, A> {}
|
|
13
|
+
|
|
14
|
+
export interface SubjectEmitter<E, A> {
|
|
15
|
+
readonly emit: (a: A) => void
|
|
16
|
+
readonly failCause: (cause: Cause<E>) => void
|
|
17
|
+
readonly end: () => void
|
|
18
|
+
}
|
|
12
19
|
|
|
13
20
|
export namespace Subject {
|
|
14
|
-
export const unsafeMake = <E, A>(): Subject<E, A> =>
|
|
21
|
+
export const unsafeMake = <E, A>(): Subject<E, A> => {
|
|
22
|
+
const m = new Multicast<never, E, A>(never)
|
|
23
|
+
|
|
24
|
+
return {
|
|
25
|
+
run: m.run.bind(m),
|
|
26
|
+
emit: (a) => Effect.unsafeRunAsync(m.emit(a)),
|
|
27
|
+
failCause: (c) => Effect.unsafeRunAsync(m.failCause(c)),
|
|
28
|
+
end: () => Effect.unsafeRunAsync(m.end),
|
|
29
|
+
} as Subject<E, A>
|
|
30
|
+
}
|
|
15
31
|
}
|
|
16
32
|
|
|
17
33
|
export interface HoldSubject<E, A> extends Subject<E, A> {
|
|
@@ -19,7 +35,17 @@ export interface HoldSubject<E, A> extends Subject<E, A> {
|
|
|
19
35
|
}
|
|
20
36
|
|
|
21
37
|
export namespace HoldSubject {
|
|
22
|
-
export const unsafeMake = <E, A>(): HoldSubject<E, A> =>
|
|
38
|
+
export const unsafeMake = <E, A>(): HoldSubject<E, A> => {
|
|
39
|
+
const h = new Hold<never, E, A>(never)
|
|
40
|
+
|
|
41
|
+
return {
|
|
42
|
+
run: h.run.bind(h),
|
|
43
|
+
get: h.get,
|
|
44
|
+
emit: (a) => Effect.unsafeRunAsync(h.emit(a)),
|
|
45
|
+
failCause: (c) => Effect.unsafeRunAsync(h.failCause(c)),
|
|
46
|
+
end: () => Effect.unsafeRunAsync(h.end),
|
|
47
|
+
} as HoldSubject<E, A>
|
|
48
|
+
}
|
|
23
49
|
}
|
|
24
50
|
|
|
25
51
|
export interface BehaviorSubject<E, A> extends Subject<E, A> {
|
|
@@ -28,19 +54,19 @@ export interface BehaviorSubject<E, A> extends Subject<E, A> {
|
|
|
28
54
|
|
|
29
55
|
export namespace BehaviorSubject {
|
|
30
56
|
export const unsafeMake = <E, A>(initial: LazyArg<A>): BehaviorSubject<E, A> => {
|
|
31
|
-
const
|
|
57
|
+
const h = new Hold<never, E, A>(never)
|
|
32
58
|
|
|
33
59
|
// We're mutating a protected variable here to ensure an initial value is held.
|
|
34
60
|
// eslint-disable-next-line @typescript-eslint/ban-ts-comment
|
|
35
61
|
// @ts-expect-error
|
|
36
|
-
|
|
62
|
+
h._value = Maybe.some(initial())
|
|
37
63
|
|
|
38
64
|
return {
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
}
|
|
65
|
+
run: h.run.bind(h),
|
|
66
|
+
get: pipe(h.get, Effect.map(Maybe.getOrElse(initial))),
|
|
67
|
+
emit: (a) => Effect.unsafeRunAsync(h.emit(a)),
|
|
68
|
+
failCause: (c) => Effect.unsafeRunAsync(h.failCause(c)),
|
|
69
|
+
end: () => Effect.unsafeRunAsync(h.end),
|
|
70
|
+
} as BehaviorSubject<E, A>
|
|
45
71
|
}
|
|
46
72
|
}
|
package/src/filterLoop.ts
CHANGED
|
@@ -42,6 +42,10 @@ export function filterScan<A, B>(seed: A, f: (a: A, b: B) => Maybe.Maybe<A>) {
|
|
|
42
42
|
}
|
|
43
43
|
|
|
44
44
|
export class Loop<R, E, A, B, C> implements Fx<R, E, C> {
|
|
45
|
+
readonly _R!: () => R
|
|
46
|
+
readonly _E!: () => E
|
|
47
|
+
readonly _A!: () => C
|
|
48
|
+
|
|
45
49
|
constructor(
|
|
46
50
|
readonly fx: Fx<R, E, B>,
|
|
47
51
|
readonly seed: A,
|
|
@@ -92,6 +96,10 @@ export class Loop<R, E, A, B, C> implements Fx<R, E, C> {
|
|
|
92
96
|
}
|
|
93
97
|
|
|
94
98
|
export class FilterLoop<R, E, A, B, C> implements Fx<R, E, C> {
|
|
99
|
+
readonly _R!: () => R
|
|
100
|
+
readonly _E!: () => E
|
|
101
|
+
readonly _A!: () => C
|
|
102
|
+
|
|
95
103
|
constructor(
|
|
96
104
|
readonly fx: Fx<R, E, B>,
|
|
97
105
|
readonly seed: A,
|
package/src/filterMap.ts
CHANGED
|
@@ -14,6 +14,10 @@ export const map =
|
|
|
14
14
|
export const as = <B>(value: B): (<R, E, A>(fx: Fx<R, E, A>) => Fx<R, E, B>) => map(() => value)
|
|
15
15
|
|
|
16
16
|
export class Map<R, E, A, B> implements Fx<R, E, B> {
|
|
17
|
+
readonly _R!: () => R
|
|
18
|
+
readonly _E!: () => E
|
|
19
|
+
readonly _A!: () => B
|
|
20
|
+
|
|
17
21
|
constructor(readonly fx: Fx<R, E, A>, readonly f: (a: A) => B) {}
|
|
18
22
|
|
|
19
23
|
run<R2>(emitter: Emitter<R2, E, B>): Effect.Effect<R | R2 | Scope, never, unknown> {
|
|
@@ -42,6 +46,10 @@ export function filter<A>(predicate: Predicate<A>) {
|
|
|
42
46
|
}
|
|
43
47
|
|
|
44
48
|
export class FilterMap<R, E, A, B> implements Fx<R, E, B> {
|
|
49
|
+
readonly _R!: () => R
|
|
50
|
+
readonly _E!: () => E
|
|
51
|
+
readonly _A!: () => B
|
|
52
|
+
|
|
45
53
|
constructor(readonly fx: Fx<R, E, A>, readonly f: (a: A) => Maybe.Maybe<B>) {}
|
|
46
54
|
|
|
47
55
|
run<R2>(emitter: Emitter<R2, E, B>): Effect.Effect<R | R2 | Scope, never, unknown> {
|
package/src/flatMap.ts
CHANGED
|
@@ -14,7 +14,10 @@ export function join<R, E, R2, E2, A>(fx: Fx<R, E, Fx<R2, E2, A>>): Fx<R | R2, E
|
|
|
14
14
|
return flatMap_(fx, (fx) => fx)
|
|
15
15
|
}
|
|
16
16
|
|
|
17
|
-
function flatMap_<R, E, A, R2, E2, B>(
|
|
17
|
+
function flatMap_<R, E, A, R2, E2, B>(
|
|
18
|
+
fx: Fx<R, E, A>,
|
|
19
|
+
f: (a: A) => Fx<R2, E2, B>,
|
|
20
|
+
): Fx<R | R2, E | E2, B> {
|
|
18
21
|
return Fx((emitter) =>
|
|
19
22
|
withDynamicCountdownLatch(
|
|
20
23
|
1,
|
package/src/fromEffect.ts
CHANGED
|
@@ -71,10 +71,10 @@ export const tryPromise: <A>(promise: LazyArg<Promise<A>>) => Fx<never, unknown,
|
|
|
71
71
|
fromEffect,
|
|
72
72
|
)
|
|
73
73
|
|
|
74
|
-
export const tryCatchPromise
|
|
74
|
+
export const tryCatchPromise = <A, E>(
|
|
75
75
|
promise: LazyArg<Promise<A>>,
|
|
76
76
|
onThrow: (u: unknown) => E,
|
|
77
|
-
)
|
|
77
|
+
): Fx<never, E, A> => fromEffect(Effect.tryCatchPromise(promise, onThrow))
|
|
78
78
|
|
|
79
79
|
export const tryCatch: <A, E>(f: LazyArg<A>, onThrow: (u: unknown) => E) => Fx<never, E, A> = flow(
|
|
80
80
|
Effect.tryCatch,
|
package/src/fromIterable.ts
CHANGED
|
@@ -7,6 +7,10 @@ export function fromIterable<A>(iterable: Iterable<A>): Fx<never, never, A> {
|
|
|
7
7
|
}
|
|
8
8
|
|
|
9
9
|
export class FromIterable<A> implements Fx<never, never, A> {
|
|
10
|
+
readonly _R!: () => never
|
|
11
|
+
readonly _E!: () => never
|
|
12
|
+
readonly _A!: () => A
|
|
13
|
+
|
|
10
14
|
constructor(readonly iterable: Iterable<A>) {}
|
|
11
15
|
|
|
12
16
|
run<R2>(emitter: Emitter<R2, never, A>) {
|
package/src/mapCause.ts
CHANGED
|
@@ -11,6 +11,9 @@ export function mapError<E, E2>(f: (error: E) => E2) {
|
|
|
11
11
|
return <R, A>(fx: Fx<R, E, A>): Fx<R, E2, A> => mapCause_(fx, Cause.map(f))
|
|
12
12
|
}
|
|
13
13
|
|
|
14
|
-
function mapCause_<R, E, A, E2>(
|
|
14
|
+
function mapCause_<R, E, A, E2>(
|
|
15
|
+
fx: Fx<R, E, A>,
|
|
16
|
+
f: (cause: Cause.Cause<E>) => Cause.Cause<E2>,
|
|
17
|
+
): Fx<R, E2, A> {
|
|
15
18
|
return Fx((emitter) => fx.run(Emitter(emitter.emit, flow(f, emitter.failCause), emitter.end)))
|
|
16
19
|
}
|
package/src/multicast.ts
CHANGED
|
@@ -20,6 +20,10 @@ export interface MulticastObserver<E, A> {
|
|
|
20
20
|
}
|
|
21
21
|
|
|
22
22
|
export class Multicast<R, E, A> implements Fx<R, E, A>, Emitter<never, E, A> {
|
|
23
|
+
readonly _R!: () => R
|
|
24
|
+
readonly _E!: () => E
|
|
25
|
+
readonly _A!: () => A
|
|
26
|
+
|
|
23
27
|
protected observers: MulticastObserver<E, A>[] = []
|
|
24
28
|
protected fiber: Fiber.Fiber<never, unknown> | undefined
|
|
25
29
|
|
package/src/runCollect.ts
CHANGED
|
@@ -2,6 +2,7 @@ import * as Effect from '@effect/core/io/Effect'
|
|
|
2
2
|
import { pipe } from '@fp-ts/data/Function'
|
|
3
3
|
|
|
4
4
|
import { Fx } from './Fx.js'
|
|
5
|
+
import { onEarlyExitFailure } from './_internal.js'
|
|
5
6
|
import { runObserve } from './runObserve.js'
|
|
6
7
|
|
|
7
8
|
export function runCollect<R, E, A>(fx: Fx<R, E, A>): Effect.Effect<R, E, ReadonlyArray<A>> {
|
|
@@ -11,6 +12,7 @@ export function runCollect<R, E, A>(fx: Fx<R, E, A>): Effect.Effect<R, E, Readon
|
|
|
11
12
|
pipe(
|
|
12
13
|
fx,
|
|
13
14
|
runObserve((a) => Effect.sync(() => values.push(a))),
|
|
15
|
+
onEarlyExitFailure(Effect.unit),
|
|
14
16
|
Effect.map(() => values),
|
|
15
17
|
),
|
|
16
18
|
),
|
package/src/runDrain.ts
CHANGED
|
@@ -3,6 +3,7 @@ import * as Effect from '@effect/core/io/Effect'
|
|
|
3
3
|
import { pipe } from '@fp-ts/data/Function'
|
|
4
4
|
|
|
5
5
|
import { Fx } from './Fx.js'
|
|
6
|
+
import { onEarlyExitFailure } from './_internal.js'
|
|
6
7
|
|
|
7
8
|
export function runDrain<R, E, A>(fx: Fx<R, E, A>): Effect.Effect<R, E, void> {
|
|
8
9
|
return pipe(
|
|
@@ -16,6 +17,7 @@ export function runDrain<R, E, A>(fx: Fx<R, E, A>): Effect.Effect<R, E, void> {
|
|
|
16
17
|
}),
|
|
17
18
|
Effect.forkScoped,
|
|
18
19
|
Effect.zipRight(deferred.await),
|
|
20
|
+
onEarlyExitFailure(Effect.sync(() => deferred.succeed(undefined))),
|
|
19
21
|
),
|
|
20
22
|
),
|
|
21
23
|
Effect.scoped,
|
package/src/runObserve.ts
CHANGED
|
@@ -3,6 +3,7 @@ import * as Effect from '@effect/core/io/Effect'
|
|
|
3
3
|
import { flow, pipe } from '@fp-ts/data/Function'
|
|
4
4
|
|
|
5
5
|
import { Emitter, Fx } from './Fx.js'
|
|
6
|
+
import { onEarlyExitFailure } from './_internal.js'
|
|
6
7
|
|
|
7
8
|
export function runObserve<A, R2, E2, B>(f: (a: A) => Effect.Effect<R2, E2, B>) {
|
|
8
9
|
return <R, E>(fx: Fx<R, E, A>): Effect.Effect<R | R2, E | E2, void> =>
|
|
@@ -26,6 +27,7 @@ export function runObserve<A, R2, E2, B>(f: (a: A) => Effect.Effect<R2, E2, B>)
|
|
|
26
27
|
),
|
|
27
28
|
),
|
|
28
29
|
Effect.flatMap((deferred) => deferred.await),
|
|
30
|
+
onEarlyExitFailure(Effect.unit),
|
|
29
31
|
Effect.scoped,
|
|
30
32
|
)
|
|
31
33
|
}
|
package/src/snapshot.ts
CHANGED
|
@@ -5,24 +5,20 @@ import * as Maybe from '@tsplus/stdlib/data/Maybe'
|
|
|
5
5
|
|
|
6
6
|
import { Emitter, Fx } from './Fx.js'
|
|
7
7
|
|
|
8
|
-
export function snapshot<R2, E2, B, A,
|
|
9
|
-
return <R, E>(sampler: Fx<R, E, A>): Fx<R
|
|
10
|
-
snapshot_(sampler, sampled, f)
|
|
8
|
+
export function snapshot<R2, E2, B, A, C>(sampled: Fx<R2, E2, B>, f: (b: B, a: A) => C) {
|
|
9
|
+
return <R, E>(sampler: Fx<R, E, A>): Fx<R | R2, E | E2, C> => snapshot_(sampler, sampled, f)
|
|
11
10
|
}
|
|
12
11
|
|
|
13
12
|
export function sample<R2, E2, B>(sampled: Fx<R2, E2, B>) {
|
|
14
13
|
return <R, E, A>(sampler: Fx<R, E, A>): Fx<R | R2, E | E2, readonly [A, B]> =>
|
|
15
|
-
|
|
16
|
-
sampler,
|
|
17
|
-
snapshot(sampled, (b, a) => [a, b]),
|
|
18
|
-
)
|
|
14
|
+
snapshot_(sampler, sampled, (b, a) => [a, b])
|
|
19
15
|
}
|
|
20
16
|
|
|
21
|
-
function snapshot_<R, E, A, R2, E2, B,
|
|
17
|
+
function snapshot_<R, E, A, R2, E2, B, C>(
|
|
22
18
|
sampler: Fx<R, E, A>,
|
|
23
19
|
sampled: Fx<R2, E2, B>,
|
|
24
20
|
f: (b: B, a: A) => C,
|
|
25
|
-
): Fx<R | R2
|
|
21
|
+
): Fx<R | R2, E | E2, C> {
|
|
26
22
|
return Fx((emitter) =>
|
|
27
23
|
pipe(
|
|
28
24
|
Effect.sync(() => new AtomicReference<Maybe.Maybe<B>>(Maybe.none)),
|
package/src/withEmitter.ts
CHANGED
|
@@ -1,4 +1,3 @@
|
|
|
1
|
-
import { Cause } from '@effect/core/io/Cause'
|
|
2
1
|
import * as Effect from '@effect/core/io/Effect'
|
|
3
2
|
import * as Exit from '@effect/core/io/Exit'
|
|
4
3
|
import { unsafeForkUnstarted } from '@effect/core/io/Fiber/_internal/runtime'
|
|
@@ -6,13 +5,10 @@ import { Scope } from '@effect/core/io/Scope'
|
|
|
6
5
|
import { flow, pipe } from '@fp-ts/data/Function'
|
|
7
6
|
|
|
8
7
|
import { Emitter, Fx } from './Fx.js'
|
|
8
|
+
import type { SubjectEmitter } from './Subject.js'
|
|
9
9
|
|
|
10
10
|
export function withEmitter<R, E, A>(
|
|
11
|
-
f: (
|
|
12
|
-
readonly emit: (a: A) => void
|
|
13
|
-
readonly failCause: (cause: Cause<E>) => void
|
|
14
|
-
readonly end: () => void
|
|
15
|
-
}) => Effect.Canceler<R>,
|
|
11
|
+
f: (emitter: SubjectEmitter<E, A>) => Effect.Canceler<R>,
|
|
16
12
|
): Fx<R, E, A> {
|
|
17
13
|
return Fx<R, E, A>(<R2>(sink: Emitter<R2, E, A>) => {
|
|
18
14
|
return Effect.withFiberRuntime<R | R2 | Scope, never, unknown>((fiber, status) => {
|