1
0
Fork 0
mirror of https://github.com/denoland/deno.git synced 2024-11-01 09:24:20 -04:00
denoland-deno/ext/node/polyfills/diagnostics_channel.ts
Bartek Iwańczuk d47147fb6a
feat(ext/node): embed std/node into the snapshot (#17724)
This commit moves "deno_std/node" in "ext/node" crate. The code is
transpiled and snapshotted during the build process.

During the first pass a minimal amount of work was done to create the
snapshot, a lot of code in "ext/node" depends on presence of "Deno"
global. This code will be gradually fixed in the follow up PRs to migrate
it to import relevant APIs from "internal:" modules.

Currently the code from snapshot is not used in any way, and all
Node/npm compatibility still uses code from 
"https://deno.land/std/node" (or from the location specified by 
"DENO_NODE_COMPAT_URL"). This will also be handled in a follow 
up PRs.

---------

Co-authored-by: crowlkats <crowlkats@toaxl.com>
Co-authored-by: Divy Srivastava <dj.srivastava23@gmail.com>
Co-authored-by: Yoshiya Hinosawa <stibium121@gmail.com>
2023-02-14 17:38:45 +01:00

89 lines
2 KiB
TypeScript

// Copyright 2018-2023 the Deno authors. All rights reserved. MIT license.
import { ERR_INVALID_ARG_TYPE } from "internal:deno_node/polyfills/internal/errors.ts";
import { validateFunction } from "internal:deno_node/polyfills/internal/validators.mjs";
import { nextTick } from "internal:deno_node/polyfills/process.ts";
type Subscriber = (message: unknown, name?: string) => void;
export class Channel {
_subscribers: Subscriber[];
name: string;
constructor(name: string) {
this._subscribers = [];
this.name = name;
}
publish(message: unknown) {
for (const subscriber of this._subscribers) {
try {
subscriber(message, this.name);
} catch (err) {
nextTick(() => {
throw err;
});
}
}
}
subscribe(subscription: Subscriber) {
validateFunction(subscription, "subscription");
this._subscribers.push(subscription);
}
unsubscribe(subscription: Subscriber) {
if (!this._subscribers.includes(subscription)) {
return false;
}
this._subscribers.splice(this._subscribers.indexOf(subscription), 1);
return true;
}
get hasSubscribers() {
return this._subscribers.length > 0;
}
}
const channels: Record<string, Channel> = {};
export function channel(name: string) {
if (typeof name !== "string" && typeof name !== "symbol") {
throw new ERR_INVALID_ARG_TYPE("channel", ["string", "symbol"], name);
}
if (!Object.hasOwn(channels, name)) {
channels[name] = new Channel(name);
}
return channels[name];
}
export function hasSubscribers(name: string) {
if (!Object.hasOwn(channels, name)) {
return false;
}
return channels[name].hasSubscribers;
}
export function subscribe(name: string, subscription: Subscriber) {
const c = channel(name);
return c.subscribe(subscription);
}
export function unsubscribe(name: string, subscription: Subscriber) {
const c = channel(name);
return c.unsubscribe(subscription);
}
export default {
channel,
hasSubscribers,
subscribe,
unsubscribe,
Channel,
};