|
| 1 | +package fx |
| 2 | + |
| 3 | +type And[A, B any] func() (A, B) |
| 4 | + |
| 5 | +func swap[A, B any](ab And[A, B]) And[B, A] { |
| 6 | + var ba And[B, A] = func() (B, A) { |
| 7 | + a, b := ab() |
| 8 | + return b, a |
| 9 | + } |
| 10 | + return ba |
| 11 | +} |
| 12 | + |
| 13 | +func left[A, B any](ab And[A, B]) A { |
| 14 | + a, _ := ab() |
| 15 | + return a |
| 16 | +} |
| 17 | + |
| 18 | +func right[A, B any](ab And[A, B]) B { |
| 19 | + _, b := ab() |
| 20 | + return b |
| 21 | +} |
| 22 | + |
| 23 | +func AndNil[S, V any](e Fx[S, V]) Fx[And[S, Nil], V] { |
| 24 | + return Then[And[S, Nil], V](left, Const)(e) |
| 25 | +} |
| 26 | + |
| 27 | +func AndContra[A, B, V any](e Fx[A, V], f func(B) A) Fx[B, V] { |
| 28 | + return ContraMap[V](f)(e) |
| 29 | +} |
| 30 | + |
| 31 | +func AndSwap[A, B, V any](e Fx[And[A, B], V]) Fx[And[B, A], V] { |
| 32 | + return Then[And[B, A], V](swap[B, A], Const)(e) |
| 33 | +} |
| 34 | + |
| 35 | +func AndFlat[A, B, V any](e Fx[A, Fx[B, V]]) Fx[And[A, B], V] { |
| 36 | + return FlatMap(e, identity) |
| 37 | +} |
| 38 | + |
| 39 | +func AndNest[A, B, V any](e Fx[And[A, B], V]) Fx[A, Fx[B, V]] { |
| 40 | + return Pending(func(a A) Fx[A, Fx[B, V]] { return Const[A](ProvideLeft(e, a)) }) |
| 41 | +} |
| 42 | + |
| 43 | +func AndCollapse[A, V any](e Fx[And[A, A], V]) Fx[A, V] { |
| 44 | + return Pending(func(a A) Fx[A, V] { return ProvideLeft(e, a) }) |
| 45 | +} |
0 commit comments