fastevent 2.1.4 → 2.2.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/eventbus/index.d.mts +64 -41
- package/dist/eventbus/index.d.ts +64 -41
- package/dist/eventbus/index.js +1 -1
- package/dist/eventbus/index.js.map +1 -1
- package/dist/eventbus/index.mjs +1 -1
- package/dist/eventbus/index.mjs.map +1 -1
- package/dist/executors/index.d.mts +10 -5
- package/dist/executors/index.d.ts +10 -5
- package/dist/executors/index.js.map +1 -1
- package/dist/executors/index.mjs.map +1 -1
- package/dist/index.d.mts +64 -41
- package/dist/index.d.ts +64 -41
- package/dist/index.js +1 -1
- package/dist/index.js.map +1 -1
- package/dist/index.mjs +1 -1
- package/dist/index.mjs.map +1 -1
- package/dist/pipes/index.d.mts +11 -6
- package/dist/pipes/index.d.ts +11 -6
- package/dist/pipes/index.js.map +1 -1
- package/dist/pipes/index.mjs.map +1 -1
- package/package.json +1 -1
|
@@ -8,14 +8,19 @@ type TypedFastEventMessage<Events extends Record<string, any> = Record<string, a
|
|
|
8
8
|
payload: Events[K];
|
|
9
9
|
meta: FastEventMeta & M & Record<string, any>;
|
|
10
10
|
};
|
|
11
|
-
}[Exclude<keyof Events, number | symbol>]) &
|
|
12
|
-
type
|
|
11
|
+
}[Exclude<keyof Events, number | symbol>]) & FastEventMessageExtends;
|
|
12
|
+
type TypedFastEventListener<T extends string = string, P = any, M = any, C = any> = (this: C, message: TypedFastEventMessage<{
|
|
13
13
|
[K in T]: P;
|
|
14
14
|
}, M>, args: FastEventListenerArgs<M>) => any | Promise<any>;
|
|
15
15
|
/**
|
|
16
|
-
* [
|
|
16
|
+
* [
|
|
17
|
+
* 监听器函数引用,
|
|
18
|
+
* 需要执行多少次, =0代表不限
|
|
19
|
+
* 实际执行的次数(用于负载均衡时记录)
|
|
20
|
+
* 标签 用于调试一般可以标识监听器类型或任意信息
|
|
21
|
+
* ]
|
|
17
22
|
*/
|
|
18
|
-
type FastListenerMeta = [
|
|
23
|
+
type FastListenerMeta = [TypedFastEventListener<any, any>, number, number, string?];
|
|
19
24
|
type FastEventListenerArgs<M = Record<string, any>> = {
|
|
20
25
|
retain?: boolean;
|
|
21
26
|
meta?: DeepPartial<M> & Record<string, any>;
|
|
@@ -37,7 +42,7 @@ type DeepPartial<T> = {
|
|
|
37
42
|
[P in keyof T]?: T[P] extends object ? DeepPartial<T[P]> : T[P];
|
|
38
43
|
};
|
|
39
44
|
|
|
40
|
-
type FastListenerExecutor = (listeners: FastListenerMeta[], message: TypedFastEventMessage, args: FastEventListenerArgs, execute: (listener:
|
|
45
|
+
type FastListenerExecutor = (listeners: FastListenerMeta[], message: TypedFastEventMessage, args: FastEventListenerArgs, execute: (listener: TypedFastEventListener, message: TypedFastEventMessage, args: FastEventListenerArgs, catchErrors?: boolean) => Promise<any> | any) => Promise<any[]> | any[];
|
|
41
46
|
type FastListenerExecutorBuilder<T extends Record<string, any>> = (options?: T) => FastListenerExecutor;
|
|
42
47
|
|
|
43
48
|
/**
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/executors/first.ts","../../src/executors/last.ts","../../src/executors/race.ts","../../src/executors/random.ts","../../src/executors/balance.ts","../../src/utils/isFunction.ts","../../src/utils/isString.ts","../../src/utils/expandable.ts","../../src/executors/series.ts","../../src/executors/waterfall.ts","../../src/executors/parallel.ts"],"names":["first","__name","listeners","message","args","execute","forEach","listener","last","length","race","winner","abortController","abortSignal","AbortController","signal","Promise","map","resolve","then","result","abort","random","index","Math","floor","balance","count","i","undefined","isFunction","fn","isString","str","series","options","reverse","onNext","onReturns","onError","Object","assign","_","cur","results","stepResult","item","e","behavior","waterfall","previous","payload","parallel"],"mappings":"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","file":"index.js","sourcesContent":["import { FastListenerExecutor } from \"./types\"\n\n/**\n * 执行第一个监听器的执行器函数\n * \n * @param listeners - 监听器数组,每个元素是一个包含监听器函数的元组\n * @param message - 要传递给监听器的消息对象\n * @param args - 要传递给监听器的额外参数\n * @param execute - 执行监听器的函数\n * @returns 返回一个数组,包含第一个监听器的执行结果\n */\nexport const first = (): FastListenerExecutor => {\n return (listeners, message, args, execute) => {\n listeners.forEach(listener => listener[2]--)\n listeners[0][2]++\n return [\n execute(listeners[0][0], message, args)\n ]\n }\n}","import { FastListenerExecutor } from \"./types\"\n\n/**\n * 执行监听器列表中的最后一个监听器\n * @param listeners - 监听器数组\n * @param message - 事件消息\n * @param args - 事件参数\n * @param execute - 执行器函数\n * @returns 返回包含最后一个监听器执行结果的数组\n */\nexport const last = (): FastListenerExecutor => {\n return (listeners, message, args, execute) => {\n listeners.forEach(listener => listener[2]--)\n listeners[listeners.length - 1][2]++\n return [\n execute(listeners[listeners.length - 1][0], message, args)\n ]\n }\n}","import { FastListenerMeta } from \"../types\"\nimport { FastListenerExecutor } from \"./types\"\n\n/**\n * 竞态执行器 - 同时执行多个监听器,只返回最快完成的结果\n * \n * @param listeners - 监听器元数据列表\n * @param message - 要处理的消息\n * @param args - 执行参数\n * @param execute - 执行函数\n * @returns 包含最快完成监听器结果的数组\n * \n * @description\n * - 只有第一个完成的监听器结果会被返回\n * - 其他未完成的监听器会被中止\n * - 如果没有提供中止信号,会自动创建一个\n * - 胜出的监听器计数会被恢复\n */\nexport const race = (): FastListenerExecutor => {\n return (listeners, message, args, execute) => {\n let winner: FastListenerMeta | undefined\n let abortController: AbortController | undefined\n if (!args || (args && !args.abortSignal)) {\n abortController = new AbortController()\n if (!args) args = {}\n args.abortSignal = abortController.signal\n }\n const result = Promise.race(listeners.map(listener => {\n listener[2]--\n return Promise.resolve(execute(listener[0], message, args)).then((result: any) => {\n if (!winner) {\n winner = listener\n listener[2]++\n }\n abortController?.abort()\n return result\n })\n }))\n return [\n result\n ]\n }\n}","import { FastListenerExecutor } from \"./types\"\n\n/**\n * 随机执行器 - 从监听器列表中随机选择一个监听器执行\n * \n * @param listeners - 监听器列表,每个元素为 [监听器函数, 优先级, 执行次数] 的元组\n * @param message - 要处理的消息对象\n * @param args - 传递给监听器的额外参数\n * @param execute - 执行监听器的函数\n * @returns 返回包含执行结果的数组\n * \n * @remarks\n * - 随机选择一个监听器执行\n * - 所有监听器的执行次数计数减1\n * - 被选中执行的监听器执行次数加1\n */\nexport const random = (): FastListenerExecutor => {\n return (listeners, message, args, execute) => {\n const index = Math.floor(Math.random() * listeners.length)\n listeners.forEach(listener => listener[2]--)\n listeners[index][2]++\n return [\n execute(listeners[index][0], message, args)\n ]\n }\n}","import { FastListenerExecutor } from \"./types\"\n\n/**\n * 负载均衡执行器,用于在多个监听器中选择执行次数最少的进行调用\n * @param listeners 监听器列表\n * @param message 消息对象\n * @param args 参数列表\n * @param execute 执行函数\n * @returns 返回包含单个执行结果的数组\n * \n * 执行策略:\n * 1. 遍历所有监听器,找出执行次数最少的监听器\n * 2. 由于监听器执行后会自动+1,因此先对所有监听器执行次数-1,以抵消后续的+1\n * 3. 只执行选中的监听器,其他监听器不执行\n */\nexport const balance = (): FastListenerExecutor => {\n return (listeners, message, args, execute) => {\n // 找出listeners里面所有执行器的执行次数最少的项\n let count: number\n let index: number = 0\n listeners.forEach((listener, i) => {\n // 为什么所有监听器的执行次数均减1?\n // 因为监听器执行完毕后会自动+1,但是在balance执行器中,只有一个会监听器会执行,因此在此先减一用来抵消后续的+1\n listener[2]--\n if (count === undefined || count > listener[2]) {\n count = listener[2]\n index = i\n }\n })\n listeners[index][2]++\n return [execute(listeners[index][0], message, args)]\n }\n}","export function isFunction(fn: any): fn is Function {\n return fn && typeof (fn) == \"function\"\n}","export function isString(str: any): str is string {\n return str && typeof (str) === \"string\"\n}","/**\n * \n * \n * 用于包括输入值为可展开的对象\n * \n * \n * 用在emit事件\n * \n * emitter1 = new FastEvent()\n * emitter2 = new FastEvent()\n * \n * emitter1.on(\"xxx\",(message)=>{\n * return emitter2.emit(message)\n * })\n * \n * emitter2.on(\"xxx\",()=>1)\n * emitter2.on(\"xxx\",()=>2)\n * \n * const results = emitter1.emit(\"xxx\")\n * // results == [[1,2]] 而不 [1,2],因为emitter2.emit返回的是一个[]\n * \n * expandable的作用就是对emit结果进行包括,当isExpandable时,在emit内部进行展开\n * \n * \n * \n * \n * emitter1.on(\"xxx\",(message)=>{\n * // 告诉emitter2.emit返回的是一个expandable对象\n * // 然后在内部就展开此对象\n * return emitter2.emit(message)\n * })\n * \n* const results = emitter1.emit(\"xxx\")\n * // results == [1,2]\n * \n * 为了实现对结果数据的展开处理,在emit内部需要对监听器的执行结果进行依次检查\n * 这多了一个迭代操作,为了不影响性能,可以关闭此特性\n * options.expandEmitResults = false\n * \n * \n */\n\nexport const __expandable__ = Symbol.for('__expandable__')\n\nexport function expandable(value: any) {\n value[__expandable__] = true\n return value\n}\n\nexport function isExpandable(value: any) {\n return value && value[__expandable__]\n}","import { FastEventListener, FastEventListenerArgs, TypedFastEventMessage } from \"../types\"\nimport { isString } from \"../utils\"\nimport { isFunction } from \"../utils/isFunction\"\nimport { FastListenerExecutor } from \"./types\"\n\n\nexport type SeriesExecutorOptions = {\n reverse?: boolean // 反向执行监听器\n /**\n * 控制监听器如何返回结果\n * \n * 提供一个reduce函数对所有监听器返回结果进行reduce操作\n * series({\n * onReturns: (result, cur)=>{\n * if(!result) result = []\n * return result.push(cur)\n * }\n * })\n */\n onReturns?: (results: any, cur: any) => any\n // 当调用下一个监听器前执行,返回false或触发错误均不再执行后续的监听器\n // 可以在此修改message\n onNext?: (index: number, previous: any, message: TypedFastEventMessage, args: FastEventListenerArgs, results: any) => boolean\n // 当执行监听器出错时的回调,返回false中止后续执行\n onError?: 'skip' | 'abort' | 'error' | ((e: any, message: TypedFastEventMessage, args: FastEventListenerArgs) => void | 'skip' | 'abort' | 'error')\n}\n\nexport const series = (options?: SeriesExecutorOptions): FastListenerExecutor => {\n const { reverse, onNext, onReturns, onError } = Object.assign({\n reverse: false,\n onError: () => { },\n onNext: () => true,\n onReturns: (_: any, cur: any) => cur\n }, options) as SeriesExecutorOptions\n return async (listeners, message, args, execute) => {\n let results: any = undefined\n let stepResult: any = undefined\n let index: number = 0\n // 全部执行次数-1\n listeners.forEach(listener => listener[2]--)\n for (let i = 0; i < listeners.length; i++) {\n const item = listeners[reverse ? listeners.length - 1 - i : i]\n const listener = item[0] as FastEventListener<any, any, any>\n try {\n if (isFunction(onNext) && onNext(++index, stepResult, message, args, results) === false) {\n break\n }\n stepResult = await execute(listener, message, args, false)\n if (isFunction(onReturns)) {\n results = onReturns(results, stepResult)\n } else {\n results = stepResult\n }\n // 实际执行次数+1\n item[2]++\n } catch (e: any) {\n try {\n const behavior = isString(onError) ? onError : isFunction(onError) && onError!(e, message, args)\n if (behavior === 'skip') {\n continue\n } else if (behavior === 'error') {\n results = e\n break\n } else if (behavior === 'abort') {\n break\n }\n } catch { }\n }\n }\n return results\n }\n\n}","import { TypedFastEventMessage } from \"../types\"\nimport { series, SeriesExecutorOptions } from \"./series\"\nimport { FastListenerExecutor } from \"./types\"\n\nexport type WaterfallExecutorOptions = Omit<SeriesExecutorOptions, 'onError' | 'onReturns' | 'onStep'>\n\n\n/**\n * 创建一个瀑布流执行器,用于按顺序执行监听器,并将前一个监听器的结果传递给下一个监听器\n * 如果出错就不再执行后续的监听器\n * \n * @param options - 执行器配置选项\n * @returns 返回一个 FastListener 执行器实例\n * \n * @remarks\n * - 当任一监听器执行出错时,会中断后续监听器的执行\n * - 每个监听器的执行结果会作为下一个监听器的 payload 参数\n */\nexport const waterfall = (options?: WaterfallExecutorOptions): FastListenerExecutor => {\n return series(Object.assign({}, options, {\n // 出错时不再执行后续的监听器\n onError: 'abort',\n // 将结果作为payload传给下一个监听器\n onNext: (index: number, previous: any, message: TypedFastEventMessage) => {\n message.payload = previous\n }\n }) as unknown as SeriesExecutorOptions)\n}","import { FastListenerExecutor } from \"./types\"\n\n/**\n * \n */\nexport const parallel = (): FastListenerExecutor => {\n return (listeners, message, args, execute) => {\n return listeners.map(listener => execute(listener[0], message, args, true))\n }\n}"]}
|
|
1
|
+
{"version":3,"sources":["../../src/executors/first.ts","../../src/executors/last.ts","../../src/executors/race.ts","../../src/executors/random.ts","../../src/executors/balance.ts","../../src/utils/isFunction.ts","../../src/utils/isString.ts","../../src/utils/expandable.ts","../../src/executors/series.ts","../../src/executors/waterfall.ts","../../src/executors/parallel.ts"],"names":["first","__name","listeners","message","args","execute","forEach","listener","last","length","race","winner","abortController","abortSignal","AbortController","signal","Promise","map","resolve","then","result","abort","random","index","Math","floor","balance","count","i","undefined","isFunction","fn","isString","str","series","options","reverse","onNext","onReturns","onError","Object","assign","_","cur","results","stepResult","item","e","behavior","waterfall","previous","payload","parallel"],"mappings":"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","file":"index.js","sourcesContent":["import { FastListenerExecutor } from \"./types\"\n\n/**\n * 执行第一个监听器的执行器函数\n * \n * @param listeners - 监听器数组,每个元素是一个包含监听器函数的元组\n * @param message - 要传递给监听器的消息对象\n * @param args - 要传递给监听器的额外参数\n * @param execute - 执行监听器的函数\n * @returns 返回一个数组,包含第一个监听器的执行结果\n */\nexport const first = (): FastListenerExecutor => {\n return (listeners, message, args, execute) => {\n listeners.forEach(listener => listener[2]--)\n listeners[0][2]++\n return [\n execute(listeners[0][0], message, args)\n ]\n }\n}","import { FastListenerExecutor } from \"./types\"\n\n/**\n * 执行监听器列表中的最后一个监听器\n * @param listeners - 监听器数组\n * @param message - 事件消息\n * @param args - 事件参数\n * @param execute - 执行器函数\n * @returns 返回包含最后一个监听器执行结果的数组\n */\nexport const last = (): FastListenerExecutor => {\n return (listeners, message, args, execute) => {\n listeners.forEach(listener => listener[2]--)\n listeners[listeners.length - 1][2]++\n return [\n execute(listeners[listeners.length - 1][0], message, args)\n ]\n }\n}","import { FastListenerMeta } from \"../types\"\nimport { FastListenerExecutor } from \"./types\"\n\n/**\n * 竞态执行器 - 同时执行多个监听器,只返回最快完成的结果\n * \n * @param listeners - 监听器元数据列表\n * @param message - 要处理的消息\n * @param args - 执行参数\n * @param execute - 执行函数\n * @returns 包含最快完成监听器结果的数组\n * \n * @description\n * - 只有第一个完成的监听器结果会被返回\n * - 其他未完成的监听器会被中止\n * - 如果没有提供中止信号,会自动创建一个\n * - 胜出的监听器计数会被恢复\n */\nexport const race = (): FastListenerExecutor => {\n return (listeners, message, args, execute) => {\n let winner: FastListenerMeta | undefined\n let abortController: AbortController | undefined\n if (!args || (args && !args.abortSignal)) {\n abortController = new AbortController()\n if (!args) args = {}\n args.abortSignal = abortController.signal\n }\n const result = Promise.race(listeners.map(listener => {\n listener[2]--\n return Promise.resolve(execute(listener[0], message, args)).then((result: any) => {\n if (!winner) {\n winner = listener\n listener[2]++\n }\n abortController?.abort()\n return result\n })\n }))\n return [\n result\n ]\n }\n}","import { FastListenerExecutor } from \"./types\"\n\n/**\n * 随机执行器 - 从监听器列表中随机选择一个监听器执行\n * \n * @param listeners - 监听器列表,每个元素为 [监听器函数, 优先级, 执行次数] 的元组\n * @param message - 要处理的消息对象\n * @param args - 传递给监听器的额外参数\n * @param execute - 执行监听器的函数\n * @returns 返回包含执行结果的数组\n * \n * @remarks\n * - 随机选择一个监听器执行\n * - 所有监听器的执行次数计数减1\n * - 被选中执行的监听器执行次数加1\n */\nexport const random = (): FastListenerExecutor => {\n return (listeners, message, args, execute) => {\n const index = Math.floor(Math.random() * listeners.length)\n listeners.forEach(listener => listener[2]--)\n listeners[index][2]++\n return [\n execute(listeners[index][0], message, args)\n ]\n }\n}","import { FastListenerExecutor } from \"./types\"\n\n/**\n * 负载均衡执行器,用于在多个监听器中选择执行次数最少的进行调用\n * @param listeners 监听器列表\n * @param message 消息对象\n * @param args 参数列表\n * @param execute 执行函数\n * @returns 返回包含单个执行结果的数组\n * \n * 执行策略:\n * 1. 遍历所有监听器,找出执行次数最少的监听器\n * 2. 由于监听器执行后会自动+1,因此先对所有监听器执行次数-1,以抵消后续的+1\n * 3. 只执行选中的监听器,其他监听器不执行\n */\nexport const balance = (): FastListenerExecutor => {\n return (listeners, message, args, execute) => {\n // 找出listeners里面所有执行器的执行次数最少的项\n let count: number\n let index: number = 0\n listeners.forEach((listener, i) => {\n // 为什么所有监听器的执行次数均减1?\n // 因为监听器执行完毕后会自动+1,但是在balance执行器中,只有一个会监听器会执行,因此在此先减一用来抵消后续的+1\n listener[2]--\n if (count === undefined || count > listener[2]) {\n count = listener[2]\n index = i\n }\n })\n listeners[index][2]++\n return [execute(listeners[index][0], message, args)]\n }\n}","export function isFunction(fn: any): fn is Function {\n return fn && typeof (fn) == \"function\"\n}","export function isString(str: any): str is string {\n return str && typeof (str) === \"string\"\n}","/**\n * \n * \n * 用于包括输入值为可展开的对象\n * \n * \n * 用在emit事件\n * \n * emitter1 = new FastEvent()\n * emitter2 = new FastEvent()\n * \n * emitter1.on(\"xxx\",(message)=>{\n * return emitter2.emit(message)\n * })\n * \n * emitter2.on(\"xxx\",()=>1)\n * emitter2.on(\"xxx\",()=>2)\n * \n * const results = emitter1.emit(\"xxx\")\n * // results == [[1,2]] 而不 [1,2],因为emitter2.emit返回的是一个[]\n * \n * expandable的作用就是对emit结果进行包括,当isExpandable时,在emit内部进行展开\n * \n * \n * \n * \n * emitter1.on(\"xxx\",(message)=>{\n * // 告诉emitter2.emit返回的是一个expandable对象\n * // 然后在内部就展开此对象\n * return emitter2.emit(message)\n * })\n * \n* const results = emitter1.emit(\"xxx\")\n * // results == [1,2]\n * \n * 为了实现对结果数据的展开处理,在emit内部需要对监听器的执行结果进行依次检查\n * 这多了一个迭代操作,为了不影响性能,可以关闭此特性\n * options.expandEmitResults = false\n * \n * \n */\n\nexport const __expandable__ = Symbol.for('__expandable__')\n\nexport function expandable(value: any) {\n value[__expandable__] = true\n return value\n}\n\nexport function isExpandable(value: any) {\n return value && value[__expandable__]\n}","import { TypedFastEventListener, FastEventListenerArgs, TypedFastEventMessage } from \"../types\"\nimport { isString } from \"../utils\"\nimport { isFunction } from \"../utils/isFunction\"\nimport { FastListenerExecutor } from \"./types\"\n\n\nexport type SeriesExecutorOptions = {\n reverse?: boolean // 反向执行监听器\n /**\n * 控制监听器如何返回结果\n * \n * 提供一个reduce函数对所有监听器返回结果进行reduce操作\n * series({\n * onReturns: (result, cur)=>{\n * if(!result) result = []\n * return result.push(cur)\n * }\n * })\n */\n onReturns?: (results: any, cur: any) => any\n // 当调用下一个监听器前执行,返回false或触发错误均不再执行后续的监听器\n // 可以在此修改message\n onNext?: (index: number, previous: any, message: TypedFastEventMessage, args: FastEventListenerArgs, results: any) => boolean\n // 当执行监听器出错时的回调,返回false中止后续执行\n onError?: 'skip' | 'abort' | 'error' | ((e: any, message: TypedFastEventMessage, args: FastEventListenerArgs) => void | 'skip' | 'abort' | 'error')\n}\n\nexport const series = (options?: SeriesExecutorOptions): FastListenerExecutor => {\n const { reverse, onNext, onReturns, onError } = Object.assign({\n reverse: false,\n onError: () => { },\n onNext: () => true,\n onReturns: (_: any, cur: any) => cur\n }, options) as SeriesExecutorOptions\n return async (listeners, message, args, execute) => {\n let results: any = undefined\n let stepResult: any = undefined\n let index: number = 0\n // 全部执行次数-1\n listeners.forEach(listener => listener[2]--)\n for (let i = 0; i < listeners.length; i++) {\n const item = listeners[reverse ? listeners.length - 1 - i : i]\n const listener = item[0] as TypedFastEventListener<any, any, any>\n try {\n if (isFunction(onNext) && onNext(++index, stepResult, message, args, results) === false) {\n break\n }\n stepResult = await execute(listener, message, args, false)\n if (isFunction(onReturns)) {\n results = onReturns(results, stepResult)\n } else {\n results = stepResult\n }\n // 实际执行次数+1\n item[2]++\n } catch (e: any) {\n try {\n const behavior = isString(onError) ? onError : isFunction(onError) && onError!(e, message, args)\n if (behavior === 'skip') {\n continue\n } else if (behavior === 'error') {\n results = e\n break\n } else if (behavior === 'abort') {\n break\n }\n } catch { }\n }\n }\n return results\n }\n\n}","import { TypedFastEventMessage } from \"../types\"\nimport { series, SeriesExecutorOptions } from \"./series\"\nimport { FastListenerExecutor } from \"./types\"\n\nexport type WaterfallExecutorOptions = Omit<SeriesExecutorOptions, 'onError' | 'onReturns' | 'onStep'>\n\n\n/**\n * 创建一个瀑布流执行器,用于按顺序执行监听器,并将前一个监听器的结果传递给下一个监听器\n * 如果出错就不再执行后续的监听器\n * \n * @param options - 执行器配置选项\n * @returns 返回一个 FastListener 执行器实例\n * \n * @remarks\n * - 当任一监听器执行出错时,会中断后续监听器的执行\n * - 每个监听器的执行结果会作为下一个监听器的 payload 参数\n */\nexport const waterfall = (options?: WaterfallExecutorOptions): FastListenerExecutor => {\n return series(Object.assign({}, options, {\n // 出错时不再执行后续的监听器\n onError: 'abort',\n // 将结果作为payload传给下一个监听器\n onNext: (index: number, previous: any, message: TypedFastEventMessage) => {\n message.payload = previous\n }\n }) as unknown as SeriesExecutorOptions)\n}","import { FastListenerExecutor } from \"./types\"\n\n/**\n * \n */\nexport const parallel = (): FastListenerExecutor => {\n return (listeners, message, args, execute) => {\n return listeners.map(listener => execute(listener[0], message, args, true))\n }\n}"]}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/executors/first.ts","../../src/executors/last.ts","../../src/executors/race.ts","../../src/executors/random.ts","../../src/executors/balance.ts","../../src/utils/isFunction.ts","../../src/utils/isString.ts","../../src/utils/expandable.ts","../../src/executors/series.ts","../../src/executors/waterfall.ts","../../src/executors/parallel.ts"],"names":["first","__name","listeners","message","args","execute","forEach","listener","last","length","race","winner","abortController","abortSignal","AbortController","signal","Promise","map","resolve","then","result","abort","random","index","Math","floor","balance","count","i","undefined","isFunction","fn","isString","str","series","options","reverse","onNext","onReturns","onError","Object","assign","_","cur","results","stepResult","item","e","behavior","waterfall","previous","payload","parallel"],"mappings":"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","file":"index.mjs","sourcesContent":["import { FastListenerExecutor } from \"./types\"\n\n/**\n * 执行第一个监听器的执行器函数\n * \n * @param listeners - 监听器数组,每个元素是一个包含监听器函数的元组\n * @param message - 要传递给监听器的消息对象\n * @param args - 要传递给监听器的额外参数\n * @param execute - 执行监听器的函数\n * @returns 返回一个数组,包含第一个监听器的执行结果\n */\nexport const first = (): FastListenerExecutor => {\n return (listeners, message, args, execute) => {\n listeners.forEach(listener => listener[2]--)\n listeners[0][2]++\n return [\n execute(listeners[0][0], message, args)\n ]\n }\n}","import { FastListenerExecutor } from \"./types\"\n\n/**\n * 执行监听器列表中的最后一个监听器\n * @param listeners - 监听器数组\n * @param message - 事件消息\n * @param args - 事件参数\n * @param execute - 执行器函数\n * @returns 返回包含最后一个监听器执行结果的数组\n */\nexport const last = (): FastListenerExecutor => {\n return (listeners, message, args, execute) => {\n listeners.forEach(listener => listener[2]--)\n listeners[listeners.length - 1][2]++\n return [\n execute(listeners[listeners.length - 1][0], message, args)\n ]\n }\n}","import { FastListenerMeta } from \"../types\"\nimport { FastListenerExecutor } from \"./types\"\n\n/**\n * 竞态执行器 - 同时执行多个监听器,只返回最快完成的结果\n * \n * @param listeners - 监听器元数据列表\n * @param message - 要处理的消息\n * @param args - 执行参数\n * @param execute - 执行函数\n * @returns 包含最快完成监听器结果的数组\n * \n * @description\n * - 只有第一个完成的监听器结果会被返回\n * - 其他未完成的监听器会被中止\n * - 如果没有提供中止信号,会自动创建一个\n * - 胜出的监听器计数会被恢复\n */\nexport const race = (): FastListenerExecutor => {\n return (listeners, message, args, execute) => {\n let winner: FastListenerMeta | undefined\n let abortController: AbortController | undefined\n if (!args || (args && !args.abortSignal)) {\n abortController = new AbortController()\n if (!args) args = {}\n args.abortSignal = abortController.signal\n }\n const result = Promise.race(listeners.map(listener => {\n listener[2]--\n return Promise.resolve(execute(listener[0], message, args)).then((result: any) => {\n if (!winner) {\n winner = listener\n listener[2]++\n }\n abortController?.abort()\n return result\n })\n }))\n return [\n result\n ]\n }\n}","import { FastListenerExecutor } from \"./types\"\n\n/**\n * 随机执行器 - 从监听器列表中随机选择一个监听器执行\n * \n * @param listeners - 监听器列表,每个元素为 [监听器函数, 优先级, 执行次数] 的元组\n * @param message - 要处理的消息对象\n * @param args - 传递给监听器的额外参数\n * @param execute - 执行监听器的函数\n * @returns 返回包含执行结果的数组\n * \n * @remarks\n * - 随机选择一个监听器执行\n * - 所有监听器的执行次数计数减1\n * - 被选中执行的监听器执行次数加1\n */\nexport const random = (): FastListenerExecutor => {\n return (listeners, message, args, execute) => {\n const index = Math.floor(Math.random() * listeners.length)\n listeners.forEach(listener => listener[2]--)\n listeners[index][2]++\n return [\n execute(listeners[index][0], message, args)\n ]\n }\n}","import { FastListenerExecutor } from \"./types\"\n\n/**\n * 负载均衡执行器,用于在多个监听器中选择执行次数最少的进行调用\n * @param listeners 监听器列表\n * @param message 消息对象\n * @param args 参数列表\n * @param execute 执行函数\n * @returns 返回包含单个执行结果的数组\n * \n * 执行策略:\n * 1. 遍历所有监听器,找出执行次数最少的监听器\n * 2. 由于监听器执行后会自动+1,因此先对所有监听器执行次数-1,以抵消后续的+1\n * 3. 只执行选中的监听器,其他监听器不执行\n */\nexport const balance = (): FastListenerExecutor => {\n return (listeners, message, args, execute) => {\n // 找出listeners里面所有执行器的执行次数最少的项\n let count: number\n let index: number = 0\n listeners.forEach((listener, i) => {\n // 为什么所有监听器的执行次数均减1?\n // 因为监听器执行完毕后会自动+1,但是在balance执行器中,只有一个会监听器会执行,因此在此先减一用来抵消后续的+1\n listener[2]--\n if (count === undefined || count > listener[2]) {\n count = listener[2]\n index = i\n }\n })\n listeners[index][2]++\n return [execute(listeners[index][0], message, args)]\n }\n}","export function isFunction(fn: any): fn is Function {\n return fn && typeof (fn) == \"function\"\n}","export function isString(str: any): str is string {\n return str && typeof (str) === \"string\"\n}","/**\n * \n * \n * 用于包括输入值为可展开的对象\n * \n * \n * 用在emit事件\n * \n * emitter1 = new FastEvent()\n * emitter2 = new FastEvent()\n * \n * emitter1.on(\"xxx\",(message)=>{\n * return emitter2.emit(message)\n * })\n * \n * emitter2.on(\"xxx\",()=>1)\n * emitter2.on(\"xxx\",()=>2)\n * \n * const results = emitter1.emit(\"xxx\")\n * // results == [[1,2]] 而不 [1,2],因为emitter2.emit返回的是一个[]\n * \n * expandable的作用就是对emit结果进行包括,当isExpandable时,在emit内部进行展开\n * \n * \n * \n * \n * emitter1.on(\"xxx\",(message)=>{\n * // 告诉emitter2.emit返回的是一个expandable对象\n * // 然后在内部就展开此对象\n * return emitter2.emit(message)\n * })\n * \n* const results = emitter1.emit(\"xxx\")\n * // results == [1,2]\n * \n * 为了实现对结果数据的展开处理,在emit内部需要对监听器的执行结果进行依次检查\n * 这多了一个迭代操作,为了不影响性能,可以关闭此特性\n * options.expandEmitResults = false\n * \n * \n */\n\nexport const __expandable__ = Symbol.for('__expandable__')\n\nexport function expandable(value: any) {\n value[__expandable__] = true\n return value\n}\n\nexport function isExpandable(value: any) {\n return value && value[__expandable__]\n}","import { FastEventListener, FastEventListenerArgs, TypedFastEventMessage } from \"../types\"\nimport { isString } from \"../utils\"\nimport { isFunction } from \"../utils/isFunction\"\nimport { FastListenerExecutor } from \"./types\"\n\n\nexport type SeriesExecutorOptions = {\n reverse?: boolean // 反向执行监听器\n /**\n * 控制监听器如何返回结果\n * \n * 提供一个reduce函数对所有监听器返回结果进行reduce操作\n * series({\n * onReturns: (result, cur)=>{\n * if(!result) result = []\n * return result.push(cur)\n * }\n * })\n */\n onReturns?: (results: any, cur: any) => any\n // 当调用下一个监听器前执行,返回false或触发错误均不再执行后续的监听器\n // 可以在此修改message\n onNext?: (index: number, previous: any, message: TypedFastEventMessage, args: FastEventListenerArgs, results: any) => boolean\n // 当执行监听器出错时的回调,返回false中止后续执行\n onError?: 'skip' | 'abort' | 'error' | ((e: any, message: TypedFastEventMessage, args: FastEventListenerArgs) => void | 'skip' | 'abort' | 'error')\n}\n\nexport const series = (options?: SeriesExecutorOptions): FastListenerExecutor => {\n const { reverse, onNext, onReturns, onError } = Object.assign({\n reverse: false,\n onError: () => { },\n onNext: () => true,\n onReturns: (_: any, cur: any) => cur\n }, options) as SeriesExecutorOptions\n return async (listeners, message, args, execute) => {\n let results: any = undefined\n let stepResult: any = undefined\n let index: number = 0\n // 全部执行次数-1\n listeners.forEach(listener => listener[2]--)\n for (let i = 0; i < listeners.length; i++) {\n const item = listeners[reverse ? listeners.length - 1 - i : i]\n const listener = item[0] as FastEventListener<any, any, any>\n try {\n if (isFunction(onNext) && onNext(++index, stepResult, message, args, results) === false) {\n break\n }\n stepResult = await execute(listener, message, args, false)\n if (isFunction(onReturns)) {\n results = onReturns(results, stepResult)\n } else {\n results = stepResult\n }\n // 实际执行次数+1\n item[2]++\n } catch (e: any) {\n try {\n const behavior = isString(onError) ? onError : isFunction(onError) && onError!(e, message, args)\n if (behavior === 'skip') {\n continue\n } else if (behavior === 'error') {\n results = e\n break\n } else if (behavior === 'abort') {\n break\n }\n } catch { }\n }\n }\n return results\n }\n\n}","import { TypedFastEventMessage } from \"../types\"\nimport { series, SeriesExecutorOptions } from \"./series\"\nimport { FastListenerExecutor } from \"./types\"\n\nexport type WaterfallExecutorOptions = Omit<SeriesExecutorOptions, 'onError' | 'onReturns' | 'onStep'>\n\n\n/**\n * 创建一个瀑布流执行器,用于按顺序执行监听器,并将前一个监听器的结果传递给下一个监听器\n * 如果出错就不再执行后续的监听器\n * \n * @param options - 执行器配置选项\n * @returns 返回一个 FastListener 执行器实例\n * \n * @remarks\n * - 当任一监听器执行出错时,会中断后续监听器的执行\n * - 每个监听器的执行结果会作为下一个监听器的 payload 参数\n */\nexport const waterfall = (options?: WaterfallExecutorOptions): FastListenerExecutor => {\n return series(Object.assign({}, options, {\n // 出错时不再执行后续的监听器\n onError: 'abort',\n // 将结果作为payload传给下一个监听器\n onNext: (index: number, previous: any, message: TypedFastEventMessage) => {\n message.payload = previous\n }\n }) as unknown as SeriesExecutorOptions)\n}","import { FastListenerExecutor } from \"./types\"\n\n/**\n * \n */\nexport const parallel = (): FastListenerExecutor => {\n return (listeners, message, args, execute) => {\n return listeners.map(listener => execute(listener[0], message, args, true))\n }\n}"]}
|
|
1
|
+
{"version":3,"sources":["../../src/executors/first.ts","../../src/executors/last.ts","../../src/executors/race.ts","../../src/executors/random.ts","../../src/executors/balance.ts","../../src/utils/isFunction.ts","../../src/utils/isString.ts","../../src/utils/expandable.ts","../../src/executors/series.ts","../../src/executors/waterfall.ts","../../src/executors/parallel.ts"],"names":["first","__name","listeners","message","args","execute","forEach","listener","last","length","race","winner","abortController","abortSignal","AbortController","signal","Promise","map","resolve","then","result","abort","random","index","Math","floor","balance","count","i","undefined","isFunction","fn","isString","str","series","options","reverse","onNext","onReturns","onError","Object","assign","_","cur","results","stepResult","item","e","behavior","waterfall","previous","payload","parallel"],"mappings":"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","file":"index.mjs","sourcesContent":["import { FastListenerExecutor } from \"./types\"\n\n/**\n * 执行第一个监听器的执行器函数\n * \n * @param listeners - 监听器数组,每个元素是一个包含监听器函数的元组\n * @param message - 要传递给监听器的消息对象\n * @param args - 要传递给监听器的额外参数\n * @param execute - 执行监听器的函数\n * @returns 返回一个数组,包含第一个监听器的执行结果\n */\nexport const first = (): FastListenerExecutor => {\n return (listeners, message, args, execute) => {\n listeners.forEach(listener => listener[2]--)\n listeners[0][2]++\n return [\n execute(listeners[0][0], message, args)\n ]\n }\n}","import { FastListenerExecutor } from \"./types\"\n\n/**\n * 执行监听器列表中的最后一个监听器\n * @param listeners - 监听器数组\n * @param message - 事件消息\n * @param args - 事件参数\n * @param execute - 执行器函数\n * @returns 返回包含最后一个监听器执行结果的数组\n */\nexport const last = (): FastListenerExecutor => {\n return (listeners, message, args, execute) => {\n listeners.forEach(listener => listener[2]--)\n listeners[listeners.length - 1][2]++\n return [\n execute(listeners[listeners.length - 1][0], message, args)\n ]\n }\n}","import { FastListenerMeta } from \"../types\"\nimport { FastListenerExecutor } from \"./types\"\n\n/**\n * 竞态执行器 - 同时执行多个监听器,只返回最快完成的结果\n * \n * @param listeners - 监听器元数据列表\n * @param message - 要处理的消息\n * @param args - 执行参数\n * @param execute - 执行函数\n * @returns 包含最快完成监听器结果的数组\n * \n * @description\n * - 只有第一个完成的监听器结果会被返回\n * - 其他未完成的监听器会被中止\n * - 如果没有提供中止信号,会自动创建一个\n * - 胜出的监听器计数会被恢复\n */\nexport const race = (): FastListenerExecutor => {\n return (listeners, message, args, execute) => {\n let winner: FastListenerMeta | undefined\n let abortController: AbortController | undefined\n if (!args || (args && !args.abortSignal)) {\n abortController = new AbortController()\n if (!args) args = {}\n args.abortSignal = abortController.signal\n }\n const result = Promise.race(listeners.map(listener => {\n listener[2]--\n return Promise.resolve(execute(listener[0], message, args)).then((result: any) => {\n if (!winner) {\n winner = listener\n listener[2]++\n }\n abortController?.abort()\n return result\n })\n }))\n return [\n result\n ]\n }\n}","import { FastListenerExecutor } from \"./types\"\n\n/**\n * 随机执行器 - 从监听器列表中随机选择一个监听器执行\n * \n * @param listeners - 监听器列表,每个元素为 [监听器函数, 优先级, 执行次数] 的元组\n * @param message - 要处理的消息对象\n * @param args - 传递给监听器的额外参数\n * @param execute - 执行监听器的函数\n * @returns 返回包含执行结果的数组\n * \n * @remarks\n * - 随机选择一个监听器执行\n * - 所有监听器的执行次数计数减1\n * - 被选中执行的监听器执行次数加1\n */\nexport const random = (): FastListenerExecutor => {\n return (listeners, message, args, execute) => {\n const index = Math.floor(Math.random() * listeners.length)\n listeners.forEach(listener => listener[2]--)\n listeners[index][2]++\n return [\n execute(listeners[index][0], message, args)\n ]\n }\n}","import { FastListenerExecutor } from \"./types\"\n\n/**\n * 负载均衡执行器,用于在多个监听器中选择执行次数最少的进行调用\n * @param listeners 监听器列表\n * @param message 消息对象\n * @param args 参数列表\n * @param execute 执行函数\n * @returns 返回包含单个执行结果的数组\n * \n * 执行策略:\n * 1. 遍历所有监听器,找出执行次数最少的监听器\n * 2. 由于监听器执行后会自动+1,因此先对所有监听器执行次数-1,以抵消后续的+1\n * 3. 只执行选中的监听器,其他监听器不执行\n */\nexport const balance = (): FastListenerExecutor => {\n return (listeners, message, args, execute) => {\n // 找出listeners里面所有执行器的执行次数最少的项\n let count: number\n let index: number = 0\n listeners.forEach((listener, i) => {\n // 为什么所有监听器的执行次数均减1?\n // 因为监听器执行完毕后会自动+1,但是在balance执行器中,只有一个会监听器会执行,因此在此先减一用来抵消后续的+1\n listener[2]--\n if (count === undefined || count > listener[2]) {\n count = listener[2]\n index = i\n }\n })\n listeners[index][2]++\n return [execute(listeners[index][0], message, args)]\n }\n}","export function isFunction(fn: any): fn is Function {\n return fn && typeof (fn) == \"function\"\n}","export function isString(str: any): str is string {\n return str && typeof (str) === \"string\"\n}","/**\n * \n * \n * 用于包括输入值为可展开的对象\n * \n * \n * 用在emit事件\n * \n * emitter1 = new FastEvent()\n * emitter2 = new FastEvent()\n * \n * emitter1.on(\"xxx\",(message)=>{\n * return emitter2.emit(message)\n * })\n * \n * emitter2.on(\"xxx\",()=>1)\n * emitter2.on(\"xxx\",()=>2)\n * \n * const results = emitter1.emit(\"xxx\")\n * // results == [[1,2]] 而不 [1,2],因为emitter2.emit返回的是一个[]\n * \n * expandable的作用就是对emit结果进行包括,当isExpandable时,在emit内部进行展开\n * \n * \n * \n * \n * emitter1.on(\"xxx\",(message)=>{\n * // 告诉emitter2.emit返回的是一个expandable对象\n * // 然后在内部就展开此对象\n * return emitter2.emit(message)\n * })\n * \n* const results = emitter1.emit(\"xxx\")\n * // results == [1,2]\n * \n * 为了实现对结果数据的展开处理,在emit内部需要对监听器的执行结果进行依次检查\n * 这多了一个迭代操作,为了不影响性能,可以关闭此特性\n * options.expandEmitResults = false\n * \n * \n */\n\nexport const __expandable__ = Symbol.for('__expandable__')\n\nexport function expandable(value: any) {\n value[__expandable__] = true\n return value\n}\n\nexport function isExpandable(value: any) {\n return value && value[__expandable__]\n}","import { TypedFastEventListener, FastEventListenerArgs, TypedFastEventMessage } from \"../types\"\nimport { isString } from \"../utils\"\nimport { isFunction } from \"../utils/isFunction\"\nimport { FastListenerExecutor } from \"./types\"\n\n\nexport type SeriesExecutorOptions = {\n reverse?: boolean // 反向执行监听器\n /**\n * 控制监听器如何返回结果\n * \n * 提供一个reduce函数对所有监听器返回结果进行reduce操作\n * series({\n * onReturns: (result, cur)=>{\n * if(!result) result = []\n * return result.push(cur)\n * }\n * })\n */\n onReturns?: (results: any, cur: any) => any\n // 当调用下一个监听器前执行,返回false或触发错误均不再执行后续的监听器\n // 可以在此修改message\n onNext?: (index: number, previous: any, message: TypedFastEventMessage, args: FastEventListenerArgs, results: any) => boolean\n // 当执行监听器出错时的回调,返回false中止后续执行\n onError?: 'skip' | 'abort' | 'error' | ((e: any, message: TypedFastEventMessage, args: FastEventListenerArgs) => void | 'skip' | 'abort' | 'error')\n}\n\nexport const series = (options?: SeriesExecutorOptions): FastListenerExecutor => {\n const { reverse, onNext, onReturns, onError } = Object.assign({\n reverse: false,\n onError: () => { },\n onNext: () => true,\n onReturns: (_: any, cur: any) => cur\n }, options) as SeriesExecutorOptions\n return async (listeners, message, args, execute) => {\n let results: any = undefined\n let stepResult: any = undefined\n let index: number = 0\n // 全部执行次数-1\n listeners.forEach(listener => listener[2]--)\n for (let i = 0; i < listeners.length; i++) {\n const item = listeners[reverse ? listeners.length - 1 - i : i]\n const listener = item[0] as TypedFastEventListener<any, any, any>\n try {\n if (isFunction(onNext) && onNext(++index, stepResult, message, args, results) === false) {\n break\n }\n stepResult = await execute(listener, message, args, false)\n if (isFunction(onReturns)) {\n results = onReturns(results, stepResult)\n } else {\n results = stepResult\n }\n // 实际执行次数+1\n item[2]++\n } catch (e: any) {\n try {\n const behavior = isString(onError) ? onError : isFunction(onError) && onError!(e, message, args)\n if (behavior === 'skip') {\n continue\n } else if (behavior === 'error') {\n results = e\n break\n } else if (behavior === 'abort') {\n break\n }\n } catch { }\n }\n }\n return results\n }\n\n}","import { TypedFastEventMessage } from \"../types\"\nimport { series, SeriesExecutorOptions } from \"./series\"\nimport { FastListenerExecutor } from \"./types\"\n\nexport type WaterfallExecutorOptions = Omit<SeriesExecutorOptions, 'onError' | 'onReturns' | 'onStep'>\n\n\n/**\n * 创建一个瀑布流执行器,用于按顺序执行监听器,并将前一个监听器的结果传递给下一个监听器\n * 如果出错就不再执行后续的监听器\n * \n * @param options - 执行器配置选项\n * @returns 返回一个 FastListener 执行器实例\n * \n * @remarks\n * - 当任一监听器执行出错时,会中断后续监听器的执行\n * - 每个监听器的执行结果会作为下一个监听器的 payload 参数\n */\nexport const waterfall = (options?: WaterfallExecutorOptions): FastListenerExecutor => {\n return series(Object.assign({}, options, {\n // 出错时不再执行后续的监听器\n onError: 'abort',\n // 将结果作为payload传给下一个监听器\n onNext: (index: number, previous: any, message: TypedFastEventMessage) => {\n message.payload = previous\n }\n }) as unknown as SeriesExecutorOptions)\n}","import { FastListenerExecutor } from \"./types\"\n\n/**\n * \n */\nexport const parallel = (): FastListenerExecutor => {\n return (listeners, message, args, execute) => {\n return listeners.map(listener => execute(listener[0], message, args, true))\n }\n}"]}
|
package/dist/index.d.mts
CHANGED
|
@@ -1,43 +1,52 @@
|
|
|
1
|
-
type FastListenerPipe = (listener:
|
|
1
|
+
type FastListenerPipe = (listener: TypedFastEventListener) => TypedFastEventListener;
|
|
2
2
|
|
|
3
3
|
interface FastEventMeta {
|
|
4
4
|
}
|
|
5
5
|
interface FastEventMessageExtends {
|
|
6
6
|
}
|
|
7
|
-
type FastEventMessage = {
|
|
8
|
-
type:
|
|
9
|
-
payload:
|
|
10
|
-
meta?:
|
|
11
|
-
};
|
|
7
|
+
type FastEventMessage<P = any, M extends Record<string, any> = Record<string, any>, T extends string = string> = {
|
|
8
|
+
type: T;
|
|
9
|
+
payload: P;
|
|
10
|
+
meta?: M & Partial<FastEventMeta>;
|
|
11
|
+
} & FastEventMessageExtends;
|
|
12
12
|
type TypedFastEventMessage<Events extends Record<string, any> = Record<string, any>, M = any> = ({
|
|
13
13
|
[K in keyof Events]: {
|
|
14
14
|
type: Exclude<K, number | symbol>;
|
|
15
15
|
payload: Events[K];
|
|
16
16
|
meta: FastEventMeta & M & Record<string, any>;
|
|
17
17
|
};
|
|
18
|
-
}[Exclude<keyof Events, number | symbol>]) &
|
|
18
|
+
}[Exclude<keyof Events, number | symbol>]) & FastEventMessageExtends;
|
|
19
19
|
type TypedFastEventMessageOptional<Events extends Record<string, any> = Record<string, any>, M = any> = ({
|
|
20
20
|
[K in keyof Events]: {
|
|
21
21
|
type: Exclude<K, number | symbol>;
|
|
22
22
|
payload: Events[K];
|
|
23
23
|
meta?: DeepPartial<FastEventMeta & M & Record<string, any>>;
|
|
24
24
|
};
|
|
25
|
-
}[Exclude<keyof Events, number | symbol>]) &
|
|
25
|
+
}[Exclude<keyof Events, number | symbol>]) & FastEventMessageExtends;
|
|
26
26
|
type FastEventEmitMessage<Events extends Record<string, any> = Record<string, any>, M = any> = ({
|
|
27
27
|
[K in keyof Events]: {
|
|
28
28
|
type: Exclude<K, number | symbol>;
|
|
29
29
|
payload?: Events[K];
|
|
30
30
|
meta?: DeepPartial<FastEventMeta & M & Record<string, any>>;
|
|
31
31
|
};
|
|
32
|
-
}[Exclude<keyof Events, number | symbol>]) &
|
|
33
|
-
type
|
|
32
|
+
}[Exclude<keyof Events, number | symbol>]) & FastEventMessageExtends;
|
|
33
|
+
type TypedFastEventListener<T extends string = string, P = any, M = any, C = any> = (this: C, message: TypedFastEventMessage<{
|
|
34
34
|
[K in T]: P;
|
|
35
35
|
}, M>, args: FastEventListenerArgs<M>) => any | Promise<any>;
|
|
36
|
-
type
|
|
36
|
+
type TypedFastEventAnyListener<Events extends Record<string, any> = Record<string, any>, Meta = never, Context = any> = (this: Context, message: TypedFastEventMessage<Events, Meta>, args: FastEventListenerArgs<Meta>) => any | Promise<any>;
|
|
37
|
+
type FastEventListeners<Events extends Record<string, any> = Record<string, any>, M = any, C = any> = ({
|
|
38
|
+
[K in keyof Events]: TypedFastEventListener<Exclude<K, number | symbol>, Events[K], M, C>;
|
|
39
|
+
});
|
|
40
|
+
type FastEventListener<P = any, M extends Record<string, any> = Record<string, any>, T extends string = string> = (message: FastEventMessage<P, M, T>, args: FastEventListenerArgs<M>) => any | Promise<any>;
|
|
37
41
|
/**
|
|
38
|
-
* [
|
|
42
|
+
* [
|
|
43
|
+
* 监听器函数引用,
|
|
44
|
+
* 需要执行多少次, =0代表不限
|
|
45
|
+
* 实际执行的次数(用于负载均衡时记录)
|
|
46
|
+
* 标签 用于调试一般可以标识监听器类型或任意信息
|
|
47
|
+
* ]
|
|
39
48
|
*/
|
|
40
|
-
type FastListenerMeta = [
|
|
49
|
+
type FastListenerMeta = [TypedFastEventListener<any, any>, number, number, string?];
|
|
41
50
|
type FastListenerNode = {
|
|
42
51
|
__listeners: FastListenerMeta[];
|
|
43
52
|
} & {
|
|
@@ -73,7 +82,7 @@ type FastEventSubscriber = {
|
|
|
73
82
|
* scope.off(subscriber.listener) // 生效
|
|
74
83
|
*
|
|
75
84
|
*/
|
|
76
|
-
listener:
|
|
85
|
+
listener: TypedFastEventListener<any, any, any>;
|
|
77
86
|
};
|
|
78
87
|
type FastListeners = FastListenerNode;
|
|
79
88
|
type FastEventOptions<Meta = Record<string, any>, Context = never> = {
|
|
@@ -83,17 +92,17 @@ type FastEventOptions<Meta = Record<string, any>, Context = never> = {
|
|
|
83
92
|
context: Context;
|
|
84
93
|
ignoreErrors: boolean;
|
|
85
94
|
meta: Meta;
|
|
86
|
-
onAddListener?: (type: string, listener:
|
|
87
|
-
onRemoveListener?: (type: string, listener:
|
|
95
|
+
onAddListener?: (type: string, listener: TypedFastEventListener, options: FastEventListenOptions<Record<string, any>, Meta>) => boolean | FastEventSubscriber | void;
|
|
96
|
+
onRemoveListener?: (type: string, listener: TypedFastEventListener) => void;
|
|
88
97
|
onClearListeners?: () => void;
|
|
89
|
-
onListenerError?: ((error: Error, listener:
|
|
98
|
+
onListenerError?: ((error: Error, listener: TypedFastEventListener, message: TypedFastEventMessage<any, Meta>, args: FastEventListenerArgs<Meta> | undefined) => void);
|
|
90
99
|
onBeforeExecuteListener?: (message: TypedFastEventMessage<any, Meta>, args: FastEventListenerArgs<Meta>) => boolean | void | any[];
|
|
91
100
|
onAfterExecuteListener?: (message: TypedFastEventMessage<any, Meta>, returns: any[], listeners: FastListenerNode[]) => void;
|
|
92
101
|
/**
|
|
93
102
|
* 全局执行器
|
|
94
103
|
*/
|
|
95
104
|
executor?: FastListenerExecutor;
|
|
96
|
-
onMessage?:
|
|
105
|
+
onMessage?: TypedFastEventListener;
|
|
97
106
|
expandEmitResults?: boolean;
|
|
98
107
|
};
|
|
99
108
|
interface FastEvents {
|
|
@@ -108,6 +117,15 @@ type FastEventListenOptions<Events extends Record<string, any> = Record<string,
|
|
|
108
117
|
filter?: (message: TypedFastEventMessage<Events, Meta>, args: FastEventListenerArgs<Meta>) => boolean;
|
|
109
118
|
off?: (message: TypedFastEventMessage<Events, Meta>, args: FastEventListenerArgs<Meta>) => boolean;
|
|
110
119
|
pipes?: FastListenerPipe[];
|
|
120
|
+
/**
|
|
121
|
+
* 为监听器添加一个tag,在监听器注册表中记录,用于调试使用
|
|
122
|
+
*
|
|
123
|
+
* emitter.on(type,listener,{tag:"x"})
|
|
124
|
+
*
|
|
125
|
+
* emitter.getListeners(tag)
|
|
126
|
+
*
|
|
127
|
+
*/
|
|
128
|
+
tag?: string;
|
|
111
129
|
};
|
|
112
130
|
type FastEventListenerArgs<M = Record<string, any>> = {
|
|
113
131
|
retain?: boolean;
|
|
@@ -256,17 +274,17 @@ type Overloads<T> = Unique<T extends {
|
|
|
256
274
|
]>;
|
|
257
275
|
type Dict<V = any> = Record<Exclude<string, number | symbol>, V>;
|
|
258
276
|
|
|
259
|
-
type FastListenerExecutor = (listeners: FastListenerMeta[], message: TypedFastEventMessage, args: FastEventListenerArgs, execute: (listener:
|
|
277
|
+
type FastListenerExecutor = (listeners: FastListenerMeta[], message: TypedFastEventMessage, args: FastEventListenerArgs, execute: (listener: TypedFastEventListener, message: TypedFastEventMessage, args: FastEventListenerArgs, catchErrors?: boolean) => Promise<any> | any) => Promise<any[]> | any[];
|
|
260
278
|
|
|
261
279
|
type FastEventScopeOptions<Meta = Record<string, any>, Context = never> = {
|
|
262
280
|
meta: FastEventScopeMeta & FastEventMeta & Meta;
|
|
263
281
|
context: Context;
|
|
264
282
|
executor?: FastListenerExecutor;
|
|
265
|
-
onMessage?:
|
|
283
|
+
onMessage?: TypedFastEventListener;
|
|
266
284
|
};
|
|
267
|
-
|
|
285
|
+
interface FastEventScopeMeta {
|
|
268
286
|
scope: string;
|
|
269
|
-
}
|
|
287
|
+
}
|
|
270
288
|
declare class FastEventScope<Events extends Record<string, any> = Record<string, any>, Meta extends Record<string, any> = Record<string, any>, Context = never, Types extends keyof Events = keyof Events, FinalMeta extends Record<string, any> = FastEventMeta & FastEventScopeMeta & Meta> {
|
|
271
289
|
__FastEventScope__: boolean;
|
|
272
290
|
private _options;
|
|
@@ -275,6 +293,8 @@ declare class FastEventScope<Events extends Record<string, any> = Record<string,
|
|
|
275
293
|
meta: FinalMeta;
|
|
276
294
|
context: Fallback<Context, typeof this>;
|
|
277
295
|
message: TypedFastEventMessageOptional<Events, FinalMeta>;
|
|
296
|
+
listeners: FastEventListeners<Events, FinalMeta>;
|
|
297
|
+
anyListener: TypedFastEventAnyListener<Events, FinalMeta, Fallback<Context, typeof this>>;
|
|
278
298
|
};
|
|
279
299
|
prefix: string;
|
|
280
300
|
emitter: FastEvent<Events>;
|
|
@@ -304,20 +324,20 @@ declare class FastEventScope<Events extends Record<string, any> = Record<string,
|
|
|
304
324
|
on<T extends Types = Types>(type: T, options?: FastEventListenOptions<Events, FinalMeta>): FastEventSubscriber;
|
|
305
325
|
on<T extends string>(type: T, options?: FastEventListenOptions<Events, FinalMeta>): FastEventSubscriber;
|
|
306
326
|
on(type: '**', options?: FastEventListenOptions<Events, FinalMeta>): FastEventSubscriber;
|
|
307
|
-
on<T extends Types = Types>(type: T, listener:
|
|
308
|
-
on<T extends string>(type: T, listener:
|
|
309
|
-
on(type: '**', listener:
|
|
327
|
+
on<T extends Types = Types>(type: T, listener: TypedFastEventListener<Exclude<T, number | symbol>, Events[T], FinalMeta, Fallback<Context, typeof this>>, options?: FastEventListenOptions): FastEventSubscriber;
|
|
328
|
+
on<T extends string>(type: T, listener: TypedFastEventListener<string, any, FinalMeta, Fallback<Context, typeof this>>, options?: FastEventListenOptions): FastEventSubscriber;
|
|
329
|
+
on(type: '**', listener: TypedFastEventAnyListener<Events, FinalMeta, Fallback<Context, typeof this>>, options?: FastEventListenOptions): FastEventSubscriber;
|
|
310
330
|
once<T extends Types = Types>(type: T, options?: FastEventListenOptions<Events, FinalMeta>): FastEventSubscriber;
|
|
311
331
|
once<T extends string>(type: T, options?: FastEventListenOptions<Events, FinalMeta>): FastEventSubscriber;
|
|
312
|
-
once<T extends Types = Types>(type: T, listener:
|
|
313
|
-
once<T extends string>(type: T, listener:
|
|
332
|
+
once<T extends Types = Types>(type: T, listener: TypedFastEventListener<Exclude<T, number | symbol>, Events[T], FinalMeta, Fallback<Context, typeof this>>, options?: FastEventListenOptions): FastEventSubscriber;
|
|
333
|
+
once<T extends string>(type: T, listener: TypedFastEventListener<string, any, FinalMeta, Fallback<Context, typeof this>>, options?: FastEventListenOptions): FastEventSubscriber;
|
|
314
334
|
onAny(options?: Pick<FastEventListenOptions, 'prepend'>): FastEventSubscriber;
|
|
315
|
-
onAny<P = any>(listener:
|
|
335
|
+
onAny<P = any>(listener: TypedFastEventAnyListener<{
|
|
316
336
|
[K: string]: P;
|
|
317
337
|
}, FinalMeta, Fallback<Context, typeof this>>, options?: Pick<FastEventListenOptions, 'prepend'>): FastEventSubscriber;
|
|
318
|
-
off(listener:
|
|
319
|
-
off(type: string, listener:
|
|
320
|
-
off(type: Types, listener:
|
|
338
|
+
off(listener: TypedFastEventListener<any, any, any>): void;
|
|
339
|
+
off(type: string, listener: TypedFastEventListener<any, any, any>): void;
|
|
340
|
+
off(type: Types, listener: TypedFastEventListener<any, any, any>): void;
|
|
321
341
|
off(type: string): void;
|
|
322
342
|
off(type: Types): void;
|
|
323
343
|
offAll(): void;
|
|
@@ -409,6 +429,8 @@ declare class FastEvent<Events extends Record<string, any> = Record<string, any>
|
|
|
409
429
|
meta: Expand<FastEventMeta & Meta & Record<string, any>>;
|
|
410
430
|
context: Expand<Fallback<Context, typeof this>>;
|
|
411
431
|
message: TypedFastEventMessageOptional<AllEvents, Expand<FastEventMeta & Meta & Record<string, any>>>;
|
|
432
|
+
listeners: FastEventListeners<AllEvents, Expand<FastEventMeta & Meta & Record<string, any>>>;
|
|
433
|
+
anyListener: TypedFastEventAnyListener<AllEvents, Expand<FastEventMeta & Meta & Record<string, any>>, Expand<Fallback<Context, typeof this>>>;
|
|
412
434
|
};
|
|
413
435
|
/**
|
|
414
436
|
* 创建FastEvent实例
|
|
@@ -494,9 +516,9 @@ declare class FastEvent<Events extends Record<string, any> = Record<string, any>
|
|
|
494
516
|
on<T extends Types = Types>(type: T, options?: FastEventListenOptions<AllEvents, Meta>): FastEventSubscriber;
|
|
495
517
|
on<T extends string>(type: T, options?: FastEventListenOptions<AllEvents, Meta>): FastEventSubscriber;
|
|
496
518
|
on(type: '**', options?: FastEventListenOptions<AllEvents, Meta>): FastEventSubscriber;
|
|
497
|
-
on<T extends Types = Types>(type: T, listener:
|
|
498
|
-
on<T extends string>(type: T, listener:
|
|
499
|
-
on(type: '**', listener:
|
|
519
|
+
on<T extends Types = Types>(type: T, listener: TypedFastEventListener<Exclude<T, number | symbol>, AllEvents[T], Meta, Fallback<Context, typeof this>>, options?: FastEventListenOptions<AllEvents, Meta>): FastEventSubscriber;
|
|
520
|
+
on<T extends string>(type: T, listener: TypedFastEventAnyListener<AllEvents, Meta, Fallback<Context, typeof this>>, options?: FastEventListenOptions<AllEvents, Meta>): FastEventSubscriber;
|
|
521
|
+
on(type: '**', listener: TypedFastEventAnyListener<Record<string, any>, Meta, Fallback<Context, typeof this>>, options?: FastEventListenOptions<AllEvents, Meta>): FastEventSubscriber;
|
|
500
522
|
/**
|
|
501
523
|
* 注册一次性事件监听器
|
|
502
524
|
* @param type - 事件类型,支持与on方法相同的格式:
|
|
@@ -520,8 +542,8 @@ declare class FastEvent<Events extends Record<string, any> = Record<string, any>
|
|
|
520
542
|
*/
|
|
521
543
|
once<T extends Types = Types>(type: T, options?: FastEventListenOptions<AllEvents, Meta>): FastEventSubscriber;
|
|
522
544
|
once<T extends string>(type: T, options?: FastEventListenOptions<AllEvents, Meta>): FastEventSubscriber;
|
|
523
|
-
once<T extends Types = Types>(type: T, listener:
|
|
524
|
-
once<T extends string>(type: T, listener:
|
|
545
|
+
once<T extends Types = Types>(type: T, listener: TypedFastEventListener<Exclude<T, number | symbol>, AllEvents[T], Meta, Fallback<Context, typeof this>>, options?: FastEventListenOptions<AllEvents, Meta>): FastEventSubscriber;
|
|
546
|
+
once<T extends string>(type: T, listener: TypedFastEventAnyListener<AllEvents, Meta, Fallback<Context, typeof this>>, options?: FastEventListenOptions<AllEvents, Meta>): FastEventSubscriber;
|
|
525
547
|
/**
|
|
526
548
|
* 注册一个监听器,用于监听所有事件
|
|
527
549
|
* @param listener 事件监听器函数,可以接收任意类型的事件数据
|
|
@@ -537,7 +559,7 @@ declare class FastEvent<Events extends Record<string, any> = Record<string, any>
|
|
|
537
559
|
* ```listener: FastEventAnyListener<AllEvents, Meta, Fallback<Context, typeof this>>): FastEventSubscriber
|
|
538
560
|
*/
|
|
539
561
|
onAny(options?: Omit<FastEventListenOptions<AllEvents, Meta>, 'count'>): FastEventSubscriber;
|
|
540
|
-
onAny<P = any>(listener:
|
|
562
|
+
onAny<P = any>(listener: TypedFastEventAnyListener<Record<string, P>, Meta, Fallback<Context, typeof this>>, options?: Omit<FastEventListenOptions<AllEvents, Meta>, 'count'>): FastEventSubscriber;
|
|
541
563
|
/**
|
|
542
564
|
*
|
|
543
565
|
* 当调用on/once/onAny时如果没有指定监听器,则调用此方法
|
|
@@ -546,9 +568,9 @@ declare class FastEvent<Events extends Record<string, any> = Record<string, any>
|
|
|
546
568
|
*
|
|
547
569
|
*/
|
|
548
570
|
onMessage(message: TypedFastEventMessage<AllEvents, Meta>, args: FastEventListenerArgs<Meta>): void;
|
|
549
|
-
off(listener:
|
|
550
|
-
off(type: string, listener:
|
|
551
|
-
off(type: Types, listener:
|
|
571
|
+
off(listener: TypedFastEventListener<any, any, any>): void;
|
|
572
|
+
off(type: string, listener: TypedFastEventListener<any, any, any>): void;
|
|
573
|
+
off(type: Types, listener: TypedFastEventListener<any, any, any>): void;
|
|
552
574
|
off(type: string): void;
|
|
553
575
|
off(type: Types): void;
|
|
554
576
|
/**
|
|
@@ -715,6 +737,7 @@ declare class FastEvent<Events extends Record<string, any> = Record<string, any>
|
|
|
715
737
|
[K in T]: K extends Types ? AllEvents[K] : any;
|
|
716
738
|
}, Meta>, options?: FastEventListenerArgs<Meta>): R[];
|
|
717
739
|
emit<R = any>(message: FastEventEmitMessage<AllEvents, Meta>, options?: FastEventListenerArgs<Meta>): R[];
|
|
740
|
+
getListeners(type: keyof AllEvents): FastListenerMeta[];
|
|
718
741
|
/**
|
|
719
742
|
* 异步触发事件
|
|
720
743
|
* @param type - 事件类型,可以是字符串或预定义的事件类型
|
|
@@ -860,4 +883,4 @@ declare const FastEventDirectives: {
|
|
|
860
883
|
clearRetain: symbol;
|
|
861
884
|
};
|
|
862
885
|
|
|
863
|
-
export { AbortError, CancelError, type ChangeFieldType, type DeepPartial, type Dict, type Expand, type Fallback, FastEvent,
|
|
886
|
+
export { AbortError, CancelError, type ChangeFieldType, type DeepPartial, type Dict, type Expand, type Fallback, FastEvent, FastEventDirectives, type FastEventEmitMessage, FastEventError, type FastEventListenOptions, type FastEventListener, type FastEventListenerArgs, type FastEventListeners, type FastEventMessage, type FastEventMessageExtends, type FastEventMeta, type FastEventOptions, FastEventScope, type FastEventScopeMeta, type FastEventScopeOptions, type FastEventSubscriber, type FastEvents, type FastListenerMeta, type FastListenerNode, type FastListeners, type Merge, type ObjectKeys, type OptionalItems, type Overloads, type OverrideOptions, type PickScopeEvents, QueueOverflowError, type RequiredItems, type ScopeEvents, TimeoutError, type TypedFastEventAnyListener, type TypedFastEventListener, type TypedFastEventMessage, type TypedFastEventMessageOptional, UnboundError, type Unique, __FastEventScope__, __FastEvent__ };
|