Skip to main content
Glama
ssv445

Lorem Ipsum MCP Server

by ssv445
PubSub.ts6.22 kB
/** * @since 2.0.0 */ import type * as Effect from "./Effect.js" import * as internal from "./internal/pubsub.js" import type { Pipeable } from "./Pipeable.js" import type * as Queue from "./Queue.js" import type * as Scope from "./Scope.js" /** * A `PubSub<A>` is an asynchronous message hub into which publishers can publish * messages of type `A` and subscribers can subscribe to take messages of type * `A`. * * @since 2.0.0 * @category models */ export interface PubSub<in out A> extends Queue.Enqueue<A>, Pipeable { /** * Publishes a message to the `PubSub`, returning whether the message was published * to the `PubSub`. */ publish(value: A): Effect.Effect<boolean> /** * Publishes all of the specified messages to the `PubSub`, returning whether they * were published to the `PubSub`. */ publishAll(elements: Iterable<A>): Effect.Effect<boolean> /** * Subscribes to receive messages from the `PubSub`. The resulting subscription can * be evaluated multiple times within the scope to take a message from the `PubSub` * each time. */ readonly subscribe: Effect.Effect<Queue.Dequeue<A>, never, Scope.Scope> } /** * Creates a bounded `PubSub` with the back pressure strategy. The `PubSub` will retain * messages until they have been taken by all subscribers, applying back * pressure to publishers if the `PubSub` is at capacity. * * For best performance use capacities that are powers of two. * * @since 2.0.0 * @category constructors */ export const bounded: <A>( capacity: number | { readonly capacity: number; readonly replay?: number | undefined } ) => Effect.Effect<PubSub<A>> = internal.bounded /** * Creates a bounded `PubSub` with the dropping strategy. The `PubSub` will drop new * messages if the `PubSub` is at capacity. * * For best performance use capacities that are powers of two. * * @since 2.0.0 * @category constructors */ export const dropping: <A>( capacity: number | { readonly capacity: number; readonly replay?: number | undefined } ) => Effect.Effect<PubSub<A>> = internal.dropping /** * Creates a bounded `PubSub` with the sliding strategy. The `PubSub` will add new * messages and drop old messages if the `PubSub` is at capacity. * * For best performance use capacities that are powers of two. * * @since 2.0.0 * @category constructors */ export const sliding: <A>( capacity: number | { readonly capacity: number; readonly replay?: number | undefined } ) => Effect.Effect<PubSub<A>> = internal.sliding /** * Creates an unbounded `PubSub`. * * @since 2.0.0 * @category constructors */ export const unbounded: <A>(options?: { readonly replay?: number | undefined }) => Effect.Effect<PubSub<A>> = internal.unbounded /** * Returns the number of elements the queue can hold. * * @since 2.0.0 * @category getters */ export const capacity: <A>(self: PubSub<A>) => number = internal.capacity /** * Retrieves the size of the queue, which is equal to the number of elements * in the queue. This may be negative if fibers are suspended waiting for * elements to be added to the queue. * * @since 2.0.0 * @category getters */ export const size: <A>(self: PubSub<A>) => Effect.Effect<number> = internal.size /** * Returns `true` if the `Queue` contains at least one element, `false` * otherwise. * * @since 2.0.0 * @category getters */ export const isFull: <A>(self: PubSub<A>) => Effect.Effect<boolean> = internal.isFull /** * Returns `true` if the `Queue` contains zero elements, `false` otherwise. * * @since 2.0.0 * @category getters */ export const isEmpty: <A>(self: PubSub<A>) => Effect.Effect<boolean> = internal.isEmpty /** * Interrupts any fibers that are suspended on `offer` or `take`. Future calls * to `offer*` and `take*` will be interrupted immediately. * * @since 2.0.0 * @category utils */ export const shutdown: <A>(self: PubSub<A>) => Effect.Effect<void> = internal.shutdown /** * Returns `true` if `shutdown` has been called, otherwise returns `false`. * * @since 2.0.0 * @category getters */ export const isShutdown: <A>(self: PubSub<A>) => Effect.Effect<boolean> = internal.isShutdown /** * Waits until the queue is shutdown. The `Effect` returned by this method will * not resume until the queue has been shutdown. If the queue is already * shutdown, the `Effect` will resume right away. * * @since 2.0.0 * @category utils */ export const awaitShutdown: <A>(self: PubSub<A>) => Effect.Effect<void> = internal.awaitShutdown /** * Publishes a message to the `PubSub`, returning whether the message was published * to the `PubSub`. * * @since 2.0.0 * @category utils */ export const publish: { /** * Publishes a message to the `PubSub`, returning whether the message was published * to the `PubSub`. * * @since 2.0.0 * @category utils */ <A>(value: A): (self: PubSub<A>) => Effect.Effect<boolean> /** * Publishes a message to the `PubSub`, returning whether the message was published * to the `PubSub`. * * @since 2.0.0 * @category utils */ <A>(self: PubSub<A>, value: A): Effect.Effect<boolean> } = internal.publish /** * Publishes all of the specified messages to the `PubSub`, returning whether they * were published to the `PubSub`. * * @since 2.0.0 * @category utils */ export const publishAll: { /** * Publishes all of the specified messages to the `PubSub`, returning whether they * were published to the `PubSub`. * * @since 2.0.0 * @category utils */ <A>(elements: Iterable<A>): (self: PubSub<A>) => Effect.Effect<boolean> /** * Publishes all of the specified messages to the `PubSub`, returning whether they * were published to the `PubSub`. * * @since 2.0.0 * @category utils */ <A>(self: PubSub<A>, elements: Iterable<A>): Effect.Effect<boolean> } = internal.publishAll /** * Subscribes to receive messages from the `PubSub`. The resulting subscription can * be evaluated multiple times within the scope to take a message from the `PubSub` * each time. * * @since 2.0.0 * @category utils */ export const subscribe: <A>(self: PubSub<A>) => Effect.Effect<Queue.Dequeue<A>, never, Scope.Scope> = internal.subscribe

Latest Blog Posts

MCP directory API

We provide all the information about MCP servers via our MCP API.

curl -X GET 'https://glama.ai/api/mcp/v1/servers/ssv445/lorem-ipsum-mcp'

If you have feedback or need assistance with the MCP directory API, please join our Discord server