ciorent 1.0.6 → 1.0.8

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 CHANGED
@@ -38,6 +38,27 @@ export declare const sleep: (ms: number) => Promise<void>;
38
38
  * @param ms - Sleep duration in milliseconds
39
39
  */
40
40
  export declare const sleepSync: (ms: number) => void;
41
+ /**
42
+ * Async `Array.prototype.map`. Mutates the original array.
43
+ *
44
+ * @example
45
+ * await Promise.all(
46
+ * map([task1(), task2(), task3()], (taskResult) => taskResult.debug)
47
+ * );
48
+ *
49
+ * // Map without mutating the original array
50
+ * await Promise.all(
51
+ * map(taskPromises.slice(), (taskResult) => taskResult.debug)
52
+ * );
53
+ */
54
+ export declare const map: <
55
+ T,
56
+ R
57
+ >(arr: Promise<T>[], mapFn: (value: T) => R | Promise<R>) => Promise<R>[];
58
+ /**
59
+ * Async `Array.prototype.find`.
60
+ */
61
+ export declare const find: <T>(arr: Promise<T>[], findFn: (value: T) => boolean | Promise<boolean>) => Promise<T | undefined>;
41
62
  export * as deferred from "./deferred.js";
42
63
  export * as mutex from "./mutex.js";
43
64
  export * as limit from "./rate-limit.js";
package/index.js CHANGED
@@ -1 +1 @@
1
- import{loadedReject,loadedResolve,loadResolve,loadResolvers}from"./utils.js";export let nextTick=Promise.resolve();let getFinishedState=async(s,p)=>{try{await p;s[0]=1}catch(e){s[0]=0;return p}};export let state=async p=>{let res=[2];getFinishedState(res,p);await nextTick;return res[0]};export let isThenable=p=>p!==null&&typeof p===`object`&&!Array.isArray(p)&&typeof p.then===`function`;export let timeout=(p,ms)=>{let promise=new Promise(loadResolvers);setTimeout(loadedResolve,ms);p.then(loadedResolve,loadedReject);return promise};export let sleep=globalThis.Bun?.sleep??globalThis.process?.getBuiltinModule?.(`timers/promises`).setTimeout??(ms=>{let promise=new Promise(loadResolve);setTimeout(loadedResolve,ms);return promise});let sharedBuf=new Int32Array(new SharedArrayBuffer(4));export let sleepSync=globalThis.Bun?.sleepSync??(ms=>{Atomics.wait(sharedBuf,0,0,ms)});export*as deferred from"./deferred.js";export*as mutex from"./mutex.js";export*as limit from"./rate-limit.js";export*as semaphore from"./semaphore.js";export*as signal from"./signal.js";
1
+ import{loadedReject,loadedResolve,loadResolve,loadResolvers}from"./utils.js";export let nextTick=Promise.resolve();let getFinishedState=async(s,p)=>{try{await p;s[0]=1}catch(e){s[0]=0;return p}};export let state=async p=>{let res=[2];getFinishedState(res,p);await nextTick;return res[0]};export let isThenable=p=>p!==null&&typeof p===`object`&&!Array.isArray(p)&&typeof p.then===`function`;export let timeout=(p,ms)=>{let promise=new Promise(loadResolvers);setTimeout(loadedResolve,ms);p.then(loadedResolve,loadedReject);return promise};export let sleep=globalThis.Bun?.sleep??globalThis.process?.getBuiltinModule?.(`timers/promises`).setTimeout??(ms=>{let promise=new Promise(loadResolve);setTimeout(loadedResolve,ms);return promise});let sharedBuf=new Int32Array(new SharedArrayBuffer(4));export let sleepSync=globalThis.Bun?.sleepSync??(ms=>{Atomics.wait(sharedBuf,0,0,ms)});let resolveFind=async(resolve,findFn,promise,counter)=>{try{if(await promise.then(findFn))return resolve(promise);counter[0]--;return}catch{if(--counter[0]===0)resolve();return promise}};export let map=(arr,mapFn)=>{for(let i=0;i<arr.length;i++)arr[i]=arr[i].then(mapFn);return arr};export let find=(arr,findFn)=>{let promise=new Promise(loadResolve);let counter=[arr.length];for(let i=0;i<arr.length;i++)resolveFind(loadedResolve,findFn,arr[i],counter);return promise};export*as deferred from"./deferred.js";export*as mutex from"./mutex.js";export*as limit from"./rate-limit.js";export*as semaphore from"./semaphore.js";export*as signal from"./signal.js";
package/package.json CHANGED
@@ -1 +1 @@
1
- {"name":"ciorent","version":"1.0.6","description":"A lightweight, low-overhead concurrency library","homepage":"https://re-utils.pages.dev/concurrency","repository":{"type":"git","url":"git+https://github.com/re-utils/ciorent.git"},"keywords":["low-overhead","lightweight","concurrency","cross-runtime"],"license":"MIT","type":"module","exports":{"./utils":"./utils.js","./rate-limit":"./rate-limit.js","./signal":"./signal.js","./mutex":"./mutex.js","./deferred":"./deferred.js",".":"./index.js","./semaphore":"./semaphore.js"}}
1
+ {"name":"ciorent","version":"1.0.8","description":"A lightweight, low-overhead concurrency library","homepage":"https://re-utils.pages.dev/concurrency","repository":{"type":"git","url":"git+https://github.com/re-utils/ciorent.git"},"keywords":["low-overhead","lightweight","concurrency","cross-runtime"],"license":"MIT","type":"module","exports":{"./utils":"./utils.js",".":"./index.js","./rate-limit":"./rate-limit.js","./semaphore":"./semaphore.js","./deferred":"./deferred.js","./signal":"./signal.js","./mutex":"./mutex.js"}}
package/semaphore.d.ts CHANGED
@@ -1,10 +1,6 @@
1
1
  import { type Extend } from "./utils.js";
2
- type QueueItem = () => void;
2
+ type QueueItem = (value: true) => void;
3
3
  type Queue = [(QueueItem | null)[], len: number, head: number, tail: number];
4
- /**
5
- * Check whether the semaphore queue is full.
6
- */
7
- export declare const full: (qu: Extend<Queue>) => boolean;
8
4
  export type Semaphore = [...Queue, remain: number];
9
5
  /**
10
6
  * Create a semaphore.
@@ -19,16 +15,14 @@ export declare const init: (permits: number, capacity: number) => Semaphore;
19
15
  *
20
16
  * @example
21
17
  *
22
- * if (semaphore.full(sem)) {
18
+ * if (!await semaphore.acquire(sem)) {
23
19
  * // Internal queue is full
24
20
  * }
25
21
  *
26
- * await semaphore.acquire(sem);
27
- *
28
22
  * // Do something and then release the permit.
29
23
  * semaphore.release(sem);
30
24
  */
31
- export declare const acquire: (sem: Extend<Semaphore>) => Promise<void> | void;
25
+ export declare const acquire: (sem: Extend<Semaphore>) => Promise<true> | boolean;
32
26
  /**
33
27
  * Release a permit.
34
28
  *
@@ -36,4 +30,11 @@ export declare const acquire: (sem: Extend<Semaphore>) => Promise<void> | void;
36
30
  * semaphore.release(sem);
37
31
  */
38
32
  export declare const release: (sem: Extend<Semaphore>) => void;
33
+ /**
34
+ * @param task Task to limit
35
+ * @param sem Target semaphore
36
+ * @throws When `sem` internal queue is full
37
+ * @returns The limited function
38
+ */
39
+ export declare const limit: <Fn extends (...args: any[]) => Promise<any>>(task: Fn, sem: Extend<Semaphore>) => Fn;
39
40
  export {};
package/semaphore.js CHANGED
@@ -1 +1 @@
1
- import{loadedResolve,loadResolve}from"./utils.js";let push=(qu,item)=>{let tail=qu[3];qu[3]=tail+1===qu[1]?0:tail+1;qu[0][tail]=item};export let full=qu=>qu[2]===qu[3]&&qu[0][qu[2]]!==null;let pop=qu=>{let head=qu[2];qu[2]=head+1===qu[1]?0:head+1;let val=qu[0][head];qu[0][head]=null;return val};export let init=(permits,capacity)=>[new Array(capacity).fill(null),capacity,0,0,permits];export let acquire=sem=>{if(--sem[4]<0){let promise=new Promise(loadResolve);push(sem,loadedResolve);return promise}};export let release=sem=>{sem[4]++<0&&pop(sem)()};
1
+ import{loadedResolve,loadResolve}from"./utils.js";let push=(qu,item)=>{let tail=qu[3];qu[3]=tail+1===qu[1]?0:tail+1;qu[0][tail]=item};let pop=qu=>{let head=qu[2];qu[2]=head+1===qu[1]?0:head+1;let val=qu[0][head];qu[0][head]=null;return val};export let init=(permits,capacity)=>[new Array(capacity).fill(null),capacity,0,0,permits];export let acquire=sem=>{if(--sem[4]<0){if(sem[0].length+sem[4]<0){sem[4]++;return false}let promise=new Promise(loadResolve);push(sem,loadedResolve);return promise}return true};export let release=sem=>{sem[4]++<0&&pop(sem)(true)};export let limit=(task,sem)=>async(...args)=>{if(--sem[4]<0){if(sem[0].length+sem[4]<0){sem[4]++;return Promise.reject(new Error(`Semaphore internal queue is full`))}let promise=new Promise(loadResolve);push(sem,loadedResolve);await promise}try{return await task(...args)}finally{release(sem)}};