ciorent 0.11.0 → 0.12.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/index.d.ts +7 -7
- package/index.js +1 -1
- package/package.json +1 -1
- package/semaphore.d.ts +14 -0
- package/semaphore.js +1 -1
- package/signal.js +1 -1
- package/latch.d.ts +0 -20
- package/latch.js +0 -1
package/index.d.ts
CHANGED
@@ -10,17 +10,18 @@
|
|
10
10
|
*/
|
11
11
|
export declare const nextTick: Promise<void>;
|
12
12
|
/**
|
13
|
+
* Get the state of a promise on next tick:
|
14
|
+
* - `0`: Input promise rejected
|
15
|
+
* - `1`: Input promise resolves
|
16
|
+
* - `2`: Input promise pending
|
17
|
+
*/
|
18
|
+
export declare const state: (p: Promise<any>) => Promise<0 | 1 | 2>;
|
19
|
+
/**
|
13
20
|
* Sleep for a duration.
|
14
21
|
* @param ms - Sleep duration in milliseconds
|
15
22
|
*/
|
16
23
|
export declare const sleep: (ms: number) => Promise<void>;
|
17
24
|
/**
|
18
|
-
* Timeout a promise after ms milliseconds
|
19
|
-
* @param promise - Target promise to timeout
|
20
|
-
* @param ms - Timeout duration
|
21
|
-
*/
|
22
|
-
export declare const timeout: <T>(promise: Promise<T>, ms: number) => Promise<T | void>;
|
23
|
-
/**
|
24
25
|
* Sleep for a duration synchronously.
|
25
26
|
*
|
26
27
|
* This method blocks the current thread.
|
@@ -30,6 +31,5 @@ export declare const timeout: <T>(promise: Promise<T>, ms: number) => Promise<T
|
|
30
31
|
*/
|
31
32
|
export declare const sleepSync: (ms: number) => void;
|
32
33
|
export * as signal from "./signal.js";
|
33
|
-
export * as latch from "./latch.js";
|
34
34
|
export * as rateLimit from "./rate-limit.js";
|
35
35
|
export * as semaphore from "./semaphore.js";
|
package/index.js
CHANGED
@@ -1 +1 @@
|
|
1
|
-
export let nextTick=Promise.resolve();export let sleep=globalThis.Bun?.sleep??globalThis.process?.getBuiltinModule?.(`timers/promises`).setTimeout??(e=>new Promise(r=>{setTimeout(r,e)}));
|
1
|
+
export let nextTick=Promise.resolve();export let state=async r=>{let i=2;r.then(()=>{i=1},e=>{i=0;return Promise.reject(e)});await nextTick;return i};export let sleep=globalThis.Bun?.sleep??globalThis.process?.getBuiltinModule?.(`timers/promises`).setTimeout??(e=>new Promise(r=>{setTimeout(r,e)}));let sharedBuf=new Int32Array(new SharedArrayBuffer(4));export let sleepSync=globalThis.Bun?.sleepSync??(e=>{Atomics.wait(sharedBuf,0,0,e)});export*as signal from"./signal.js";export*as rateLimit from"./rate-limit.js";export*as semaphore from"./semaphore.js";
|
package/package.json
CHANGED
package/semaphore.d.ts
CHANGED
@@ -21,3 +21,17 @@ export declare const acquire: (s: Semaphore) => Promise<void> | void;
|
|
21
21
|
* Signal to the semaphore to release access
|
22
22
|
*/
|
23
23
|
export declare const release: (s: Semaphore) => void;
|
24
|
+
/**
|
25
|
+
* Control concurrency of a task with a semaphore
|
26
|
+
*/
|
27
|
+
export declare const control: <T extends (...args: any[]) => Promise<any>>(task: T, s: Semaphore) => T;
|
28
|
+
/**
|
29
|
+
* Set maximum concurrency for a task (fast path)
|
30
|
+
*/
|
31
|
+
export declare const permits: <T extends (...args: any[]) => Promise<any>>(task: T, permits: number) => T;
|
32
|
+
/**
|
33
|
+
* Queue a task
|
34
|
+
* @param s
|
35
|
+
* @param task
|
36
|
+
*/
|
37
|
+
export declare const queue: <R>(s: Semaphore, task: () => Promise<R>) => Promise<R>;
|
package/semaphore.js
CHANGED
@@ -1 +1 @@
|
|
1
|
-
export let init=e=>{let
|
1
|
+
export let init=e=>{let r=[,];let i=[r,r,e,e=>{i[0]=i[0][0]=[,e]}];return i};export let acquire=e=>{if(--e[2]<0)return new Promise(e[3])};export let release=e=>{if(e[2]++<0)(e[1]=e[1][0])[1]()};export let control=(e,r)=>async(...a)=>{if(--r[2]<0)await new Promise(r[3]);try{return await e(...a)}finally{release(r)}};export let permits=(r,i)=>control(r,init(i));export let queue=async(e,r)=>{if(--e[2]<0)await new Promise(e[3]);try{return await r()}finally{release(e)}};
|
package/signal.js
CHANGED
@@ -1 +1 @@
|
|
1
|
-
import{sleep}from".";export let init=()=>[false];export let any=(...e)=>{let a=[false];for(let o=0;o<e.length;o++)e[o].push(a);return a};export let aborted=e=>e[0];export let abort=e=>{if(!e[0]){e[0]=true;if(e.length>1)for(let a=1;a<e.length;a++)abort(e[a])}};export let abortAfter=async(a,o)=>{await sleep(a);abort(o)};export let timeout=e=>{let a=[false];abortAfter(e,a);return a};
|
1
|
+
import{sleep}from"./index.js";export let init=()=>[false];export let any=(...e)=>{let a=[false];for(let o=0;o<e.length;o++)e[o].push(a);return a};export let aborted=e=>e[0];export let abort=e=>{if(!e[0]){e[0]=true;if(e.length>1)for(let a=1;a<e.length;a++)abort(e[a])}};export let abortAfter=async(a,o)=>{await sleep(a);abort(o)};export let timeout=e=>{let a=[false];abortAfter(e,a);return a};
|
package/latch.d.ts
DELETED
@@ -1,20 +0,0 @@
|
|
1
|
-
/**
|
2
|
-
* Describe a latch
|
3
|
-
*/
|
4
|
-
export type Latch = [p: Promise<void> | void, res: () => void, cb: (res: () => void) => void];
|
5
|
-
export declare const init: <T>() => Latch;
|
6
|
-
/**
|
7
|
-
* Reclose the latch
|
8
|
-
* @param c
|
9
|
-
*/
|
10
|
-
export declare const close: (c: Latch) => void;
|
11
|
-
/**
|
12
|
-
* Open the latch
|
13
|
-
* @param c
|
14
|
-
*/
|
15
|
-
export declare const open: (c: Latch) => void;
|
16
|
-
/**
|
17
|
-
* Wait for the latch to open
|
18
|
-
* @param c
|
19
|
-
*/
|
20
|
-
export declare const wait: (c: Latch) => Promise<void> | void;
|
package/latch.js
DELETED
@@ -1 +0,0 @@
|
|
1
|
-
export let init=()=>{let e=[,,r=>{e[1]=r}];close(e);return e};export let close=e=>{if(e[0]==null)e[0]=new Promise(e[2])};export let open=e=>{e[1]();e[0]=void 0};export let wait=e=>e[0];
|