使用 FP-TS 时,我经常会发现结构体位于 aTask
或IO
. 我设法通过编写一个合并函数和单独的提升函数来解决这个问题,使其与Task
or一起使用IO
。有关更详细的说明,请参阅包含的代码示例。该代码有效,但我想知道我编写的自定义函数是否已经以某种形式或形式在 FP-TS 中可用。
import { deepStrictEqual as assertEqual } from 'assert'
import { IO, of, io, map } from 'fp-ts/lib/IO';
import { sequenceT } from 'fp-ts/lib/Apply';
import { pipe, tupled } from 'fp-ts/lib/function';
type Merge<A, B> = A & B
function merge<A, B>(a: A, b: B): Merge<A, B> {
return {...a, ...b}
}
type Foo = { foo: 123 }
type Bar = { bar: 456 }
type FooBar = Merge<Foo, Bar>;
const foo: Foo = { foo: 123 }
const bar: Bar = { bar: 456 }
const fooBar: FooBar = merge(foo, bar)
type IOLift<A, AS extends Array<any>, B> = (a: IO<A>, ...as: { [I in keyof AS]: IO<AS[I]> }) => IO<B>
function ioLift<A, AS extends Array<any>, B>(f: (a: A, ...as: AS) => B): IOLift<A, AS, B> {
return (...a) => pipe(
sequenceT(io)(...a),
map(tupled(f))
)
}
const ioMerge = ioLift(merge)
const ioFoo: IO<Foo> = of(foo)
const ioBar: IO<Bar> = of(bar)
const ioFooBar: IO<FooBar> = ioMerge(ioFoo, ioBar)
assertEqual(ioFooBar(), fooBar)