// ets_tracing: off import * as E from "../Either/index.js" import { succeed } from "./core.js" import type { Effect, RIO } from "./effect.js" import { foldM_ } from "./foldM.js" /** * Returns an effect whose failure and success have been lifted into an * `Either`. The resulting effect cannot fail, because the failure case has * been exposed as part of the `Either` success case. * * This method is useful for recovering from effects that may fail. * * The error parameter of the returned is `never`, since it is * guaranteed the effect does not model failure. */ export function either( self: Effect, __trace?: string ): RIO> { return foldM_( self, (e) => succeed(E.left(e)), (a) => succeed(E.right(a)), __trace ) }