/** * @since 3.5.0 */ import type * as Duration from "./Duration.js"; import type * as Effect from "./Effect.js"; import type * as Readable from "./Readable.js"; import type * as Scope from "./Scope.js"; import type * as Types from "./Types.js"; import type * as Unify from "./Unify.js"; /** * @since 3.5.0 * @category type ids */ export declare const TypeId: unique symbol; /** * @since 3.5.0 * @category type ids */ export type TypeId = typeof TypeId; /** * @since 3.5.0 * @category models */ export interface RcRef extends Effect.Effect, Readable.Readable { readonly [TypeId]: RcRef.Variance; readonly [Unify.typeSymbol]?: unknown; readonly [Unify.unifySymbol]?: RcRefUnify; readonly [Unify.ignoreSymbol]?: RcRefUnifyIgnore; } /** * @category models * @since 3.8.0 */ export interface RcRefUnify extends Effect.EffectUnify { RcRef?: () => A[Unify.typeSymbol] extends RcRef | infer _ ? RcRef : never; } /** * @category models * @since 3.8.0 */ export interface RcRefUnifyIgnore extends Effect.EffectUnifyIgnore { Effect?: true; } /** * @since 3.5.0 * @category models */ export declare namespace RcRef { /** * @since 3.5.0 * @category models */ interface Variance { readonly _A: Types.Covariant; readonly _E: Types.Covariant; } } /** * Create an `RcRef` from an acquire `Effect`. * * An RcRef wraps a reference counted resource that can be acquired and released * multiple times. * * The resource is lazily acquired on the first call to `get` and released when * the last reference is released. * * @since 3.5.0 * @category constructors * @example * ```ts * import { Effect, RcRef } from "effect" * * Effect.gen(function*() { * const ref = yield* RcRef.make({ * acquire: Effect.acquireRelease( * Effect.succeed("foo"), * () => Effect.log("release foo") * ) * }) * * // will only acquire the resource once, and release it * // when the scope is closed * yield* RcRef.get(ref).pipe( * Effect.andThen(RcRef.get(ref)), * Effect.scoped * ) * }) * ``` */ export declare const make: (options: { readonly acquire: Effect.Effect; /** * When the reference count reaches zero, the resource will be released * after this duration. */ readonly idleTimeToLive?: Duration.DurationInput | undefined; }) => Effect.Effect, never, R | Scope.Scope>; /** * @since 3.5.0 * @category combinators */ export declare const get: (self: RcRef) => Effect.Effect; //# sourceMappingURL=RcRef.d.ts.map