/** * @since 2.0.0 */ import type * as Effect from "./Effect.js" import * as internal from "./internal/ref.js" import type * as Option from "./Option.js" import type * as Readable from "./Readable.js" import type * as Types from "./Types.js" import type * as Unify from "./Unify.js" /** * @since 2.0.0 * @category symbols */ export const RefTypeId: unique symbol = internal.RefTypeId /** * @since 2.0.0 * @category symbols */ export type RefTypeId = typeof RefTypeId /** * @since 2.0.0 * @category models */ export interface Ref extends Ref.Variance, Effect.Effect, Readable.Readable { modify(f: (a: A) => readonly [B, A]): Effect.Effect readonly [Unify.typeSymbol]?: unknown readonly [Unify.unifySymbol]?: RefUnify readonly [Unify.ignoreSymbol]?: RefUnifyIgnore } /** * @category models * @since 3.8.0 */ export interface RefUnify extends Effect.EffectUnify { Ref?: () => Extract> } /** * @category models * @since 3.8.0 */ export interface RefUnifyIgnore extends Effect.EffectUnifyIgnore { Effect?: true } /** * @since 2.0.0 * @category models */ export declare namespace Ref { /** * @since 2.0.0 */ export interface Variance { readonly [RefTypeId]: { readonly _A: Types.Invariant } } } /** * @since 2.0.0 * @category constructors */ export const make: (value: A) => Effect.Effect> = internal.make /** * @since 2.0.0 * @category getters */ export const get: (self: Ref) => Effect.Effect = internal.get /** * @since 2.0.0 * @category utils */ export const getAndSet: { /** * @since 2.0.0 * @category utils */ (value: A): (self: Ref) => Effect.Effect /** * @since 2.0.0 * @category utils */ (self: Ref, value: A): Effect.Effect } = internal.getAndSet /** * @since 2.0.0 * @category utils */ export const getAndUpdate: { /** * @since 2.0.0 * @category utils */ (f: (a: A) => A): (self: Ref) => Effect.Effect /** * @since 2.0.0 * @category utils */ (self: Ref, f: (a: A) => A): Effect.Effect } = internal.getAndUpdate /** * @since 2.0.0 * @category utils */ export const getAndUpdateSome: { /** * @since 2.0.0 * @category utils */ (pf: (a: A) => Option.Option): (self: Ref) => Effect.Effect /** * @since 2.0.0 * @category utils */ (self: Ref, pf: (a: A) => Option.Option): Effect.Effect } = internal.getAndUpdateSome /** * @since 2.0.0 * @category utils */ export const modify: { /** * @since 2.0.0 * @category utils */ (f: (a: A) => readonly [B, A]): (self: Ref) => Effect.Effect /** * @since 2.0.0 * @category utils */ (self: Ref, f: (a: A) => readonly [B, A]): Effect.Effect } = internal.modify /** * @since 2.0.0 * @category utils */ export const modifySome: { /** * @since 2.0.0 * @category utils */ (fallback: B, pf: (a: A) => Option.Option): (self: Ref) => Effect.Effect /** * @since 2.0.0 * @category utils */ (self: Ref, fallback: B, pf: (a: A) => Option.Option): Effect.Effect } = internal.modifySome /** * @since 2.0.0 * @category utils */ export const set: { /** * @since 2.0.0 * @category utils */ (value: A): (self: Ref) => Effect.Effect /** * @since 2.0.0 * @category utils */ (self: Ref, value: A): Effect.Effect } = internal.set /** * @since 2.0.0 * @category utils */ export const setAndGet: { /** * @since 2.0.0 * @category utils */ (value: A): (self: Ref) => Effect.Effect /** * @since 2.0.0 * @category utils */ (self: Ref, value: A): Effect.Effect } = internal.setAndGet /** * @since 2.0.0 * @category utils */ export const update: { /** * @since 2.0.0 * @category utils */ (f: (a: A) => A): (self: Ref) => Effect.Effect /** * @since 2.0.0 * @category utils */ (self: Ref, f: (a: A) => A): Effect.Effect } = internal.update /** * @since 2.0.0 * @category utils */ export const updateAndGet: { /** * @since 2.0.0 * @category utils */ (f: (a: A) => A): (self: Ref) => Effect.Effect /** * @since 2.0.0 * @category utils */ (self: Ref, f: (a: A) => A): Effect.Effect } = internal.updateAndGet /** * @since 2.0.0 * @category utils */ export const updateSome: { /** * @since 2.0.0 * @category utils */ (f: (a: A) => Option.Option): (self: Ref) => Effect.Effect /** * @since 2.0.0 * @category utils */ (self: Ref, f: (a: A) => Option.Option): Effect.Effect } = internal.updateSome /** * @since 2.0.0 * @category utils */ export const updateSomeAndGet: { /** * @since 2.0.0 * @category utils */ (pf: (a: A) => Option.Option): (self: Ref) => Effect.Effect /** * @since 2.0.0 * @category utils */ (self: Ref, pf: (a: A) => Option.Option): Effect.Effect } = internal.updateSomeAndGet /** * @since 2.0.0 * @category unsafe */ export const unsafeMake: (value: A) => Ref = internal.unsafeMake