@xylabs/forget 2.13.19 → 2.13.21
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/browser/forget.d.cts +6 -6
- package/dist/browser/forget.d.cts.map +1 -1
- package/dist/browser/forget.d.mts +6 -6
- package/dist/browser/forget.d.mts.map +1 -1
- package/dist/browser/forget.d.ts +6 -6
- package/dist/browser/forget.d.ts.map +1 -1
- package/dist/browser/index.cjs +7 -7
- package/dist/browser/index.cjs.map +1 -1
- package/dist/browser/index.d.cts +1 -2
- package/dist/browser/index.d.cts.map +1 -1
- package/dist/browser/index.d.mts +1 -2
- package/dist/browser/index.d.mts.map +1 -1
- package/dist/browser/index.d.ts +1 -2
- package/dist/browser/index.d.ts.map +1 -1
- package/dist/browser/index.js +7 -7
- package/dist/browser/index.js.map +1 -1
- package/dist/node/forget.d.cts +6 -6
- package/dist/node/forget.d.cts.map +1 -1
- package/dist/node/forget.d.mts +6 -6
- package/dist/node/forget.d.mts.map +1 -1
- package/dist/node/forget.d.ts +6 -6
- package/dist/node/forget.d.ts.map +1 -1
- package/dist/node/index.cjs +7 -7
- package/dist/node/index.cjs.map +1 -1
- package/dist/node/index.d.cts +1 -2
- package/dist/node/index.d.cts.map +1 -1
- package/dist/node/index.d.mts +1 -2
- package/dist/node/index.d.mts.map +1 -1
- package/dist/node/index.d.ts +1 -2
- package/dist/node/index.d.ts.map +1 -1
- package/dist/node/index.js +7 -7
- package/dist/node/index.js.map +1 -1
- package/package.json +9 -5
- package/src/forget.ts +9 -9
- package/src/index.ts +1 -3
|
@@ -2,16 +2,16 @@ export interface ForgetTimeoutConfig {
|
|
|
2
2
|
cancel: () => void;
|
|
3
3
|
delay: number;
|
|
4
4
|
}
|
|
5
|
-
export declare
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
5
|
+
export declare const ForgetPromise: {
|
|
6
|
+
readonly active: boolean;
|
|
7
|
+
activeForgets: number;
|
|
8
|
+
awaitInactive(interval?: number, timeout?: number): Promise<number>;
|
|
9
9
|
/**
|
|
10
10
|
* Used to explicitly launch an async function (or Promise) with awaiting it
|
|
11
11
|
* @param promise The promise to forget
|
|
12
12
|
* @param config Configuration of forget settings
|
|
13
13
|
*/
|
|
14
|
-
|
|
15
|
-
}
|
|
14
|
+
forget<T>(promise: Promise<T>, config?: ForgetTimeoutConfig): void;
|
|
15
|
+
};
|
|
16
16
|
export declare const forget: (promise: Promise<unknown>, timeout?: ForgetTimeoutConfig) => void;
|
|
17
17
|
//# sourceMappingURL=forget.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"forget.d.ts","sourceRoot":"","sources":["../../src/forget.ts"],"names":[],"mappings":"AAEA,MAAM,WAAW,mBAAmB;IAClC,MAAM,EAAE,MAAM,IAAI,CAAA;IAClB,KAAK,EAAE,MAAM,CAAA;CACd;AAED,
|
|
1
|
+
{"version":3,"file":"forget.d.ts","sourceRoot":"","sources":["../../src/forget.ts"],"names":[],"mappings":"AAEA,MAAM,WAAW,mBAAmB;IAClC,MAAM,EAAE,MAAM,IAAI,CAAA;IAClB,KAAK,EAAE,MAAM,CAAA;CACd;AAED,eAAO,MAAM,aAAa;;;+CAOsB,MAAM;IAcpD;;;;OAIG;4CACqC,mBAAmB;CAwC5D,CAAA;AAGD,eAAO,MAAM,MAAM,YAAa,QAAQ,OAAO,CAAC,YAAY,mBAAmB,SAE9E,CAAA"}
|
|
@@ -2,16 +2,16 @@ export interface ForgetTimeoutConfig {
|
|
|
2
2
|
cancel: () => void;
|
|
3
3
|
delay: number;
|
|
4
4
|
}
|
|
5
|
-
export declare
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
5
|
+
export declare const ForgetPromise: {
|
|
6
|
+
readonly active: boolean;
|
|
7
|
+
activeForgets: number;
|
|
8
|
+
awaitInactive(interval?: number, timeout?: number): Promise<number>;
|
|
9
9
|
/**
|
|
10
10
|
* Used to explicitly launch an async function (or Promise) with awaiting it
|
|
11
11
|
* @param promise The promise to forget
|
|
12
12
|
* @param config Configuration of forget settings
|
|
13
13
|
*/
|
|
14
|
-
|
|
15
|
-
}
|
|
14
|
+
forget<T>(promise: Promise<T>, config?: ForgetTimeoutConfig): void;
|
|
15
|
+
};
|
|
16
16
|
export declare const forget: (promise: Promise<unknown>, timeout?: ForgetTimeoutConfig) => void;
|
|
17
17
|
//# sourceMappingURL=forget.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"forget.d.ts","sourceRoot":"","sources":["../../src/forget.ts"],"names":[],"mappings":"AAEA,MAAM,WAAW,mBAAmB;IAClC,MAAM,EAAE,MAAM,IAAI,CAAA;IAClB,KAAK,EAAE,MAAM,CAAA;CACd;AAED,
|
|
1
|
+
{"version":3,"file":"forget.d.ts","sourceRoot":"","sources":["../../src/forget.ts"],"names":[],"mappings":"AAEA,MAAM,WAAW,mBAAmB;IAClC,MAAM,EAAE,MAAM,IAAI,CAAA;IAClB,KAAK,EAAE,MAAM,CAAA;CACd;AAED,eAAO,MAAM,aAAa;;;+CAOsB,MAAM;IAcpD;;;;OAIG;4CACqC,mBAAmB;CAwC5D,CAAA;AAGD,eAAO,MAAM,MAAM,YAAa,QAAQ,OAAO,CAAC,YAAY,mBAAmB,SAE9E,CAAA"}
|
package/dist/browser/forget.d.ts
CHANGED
|
@@ -2,16 +2,16 @@ export interface ForgetTimeoutConfig {
|
|
|
2
2
|
cancel: () => void;
|
|
3
3
|
delay: number;
|
|
4
4
|
}
|
|
5
|
-
export declare
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
5
|
+
export declare const ForgetPromise: {
|
|
6
|
+
readonly active: boolean;
|
|
7
|
+
activeForgets: number;
|
|
8
|
+
awaitInactive(interval?: number, timeout?: number): Promise<number>;
|
|
9
9
|
/**
|
|
10
10
|
* Used to explicitly launch an async function (or Promise) with awaiting it
|
|
11
11
|
* @param promise The promise to forget
|
|
12
12
|
* @param config Configuration of forget settings
|
|
13
13
|
*/
|
|
14
|
-
|
|
15
|
-
}
|
|
14
|
+
forget<T>(promise: Promise<T>, config?: ForgetTimeoutConfig): void;
|
|
15
|
+
};
|
|
16
16
|
export declare const forget: (promise: Promise<unknown>, timeout?: ForgetTimeoutConfig) => void;
|
|
17
17
|
//# sourceMappingURL=forget.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"forget.d.ts","sourceRoot":"","sources":["../../src/forget.ts"],"names":[],"mappings":"AAEA,MAAM,WAAW,mBAAmB;IAClC,MAAM,EAAE,MAAM,IAAI,CAAA;IAClB,KAAK,EAAE,MAAM,CAAA;CACd;AAED,
|
|
1
|
+
{"version":3,"file":"forget.d.ts","sourceRoot":"","sources":["../../src/forget.ts"],"names":[],"mappings":"AAEA,MAAM,WAAW,mBAAmB;IAClC,MAAM,EAAE,MAAM,IAAI,CAAA;IAClB,KAAK,EAAE,MAAM,CAAA;CACd;AAED,eAAO,MAAM,aAAa;;;+CAOsB,MAAM;IAcpD;;;;OAIG;4CACqC,mBAAmB;CAwC5D,CAAA;AAGD,eAAO,MAAM,MAAM,YAAa,QAAQ,OAAO,CAAC,YAAY,mBAAmB,SAE9E,CAAA"}
|
package/dist/browser/index.cjs
CHANGED
|
@@ -27,12 +27,12 @@ module.exports = __toCommonJS(src_exports);
|
|
|
27
27
|
|
|
28
28
|
// src/forget.ts
|
|
29
29
|
var import_delay = require("@xylabs/delay");
|
|
30
|
-
var ForgetPromise =
|
|
31
|
-
|
|
32
|
-
static get active() {
|
|
30
|
+
var ForgetPromise = {
|
|
31
|
+
get active() {
|
|
33
32
|
return this.activeForgets > 0;
|
|
34
|
-
}
|
|
35
|
-
|
|
33
|
+
},
|
|
34
|
+
activeForgets: 0,
|
|
35
|
+
async awaitInactive(interval = 100, timeout) {
|
|
36
36
|
let timeoutRemaining = timeout;
|
|
37
37
|
while (this.active) {
|
|
38
38
|
await (0, import_delay.delay)(interval);
|
|
@@ -44,13 +44,13 @@ var ForgetPromise = class {
|
|
|
44
44
|
}
|
|
45
45
|
}
|
|
46
46
|
return 0;
|
|
47
|
-
}
|
|
47
|
+
},
|
|
48
48
|
/**
|
|
49
49
|
* Used to explicitly launch an async function (or Promise) with awaiting it
|
|
50
50
|
* @param promise The promise to forget
|
|
51
51
|
* @param config Configuration of forget settings
|
|
52
52
|
*/
|
|
53
|
-
|
|
53
|
+
forget(promise, config) {
|
|
54
54
|
let completed = false;
|
|
55
55
|
this.activeForgets++;
|
|
56
56
|
const promiseWrapper = async () => {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/index.ts","../../src/forget.ts"],"sourcesContent":["
|
|
1
|
+
{"version":3,"sources":["../../src/index.ts","../../src/forget.ts"],"sourcesContent":["export { forget, ForgetPromise } from './forget'\n","import { delay } from '@xylabs/delay'\n\nexport interface ForgetTimeoutConfig {\n cancel: () => void\n delay: number\n}\n\nexport const ForgetPromise = {\n get active() {\n return this.activeForgets > 0\n },\n\n activeForgets: 0,\n\n async awaitInactive(interval = 100, timeout?: number) {\n let timeoutRemaining = timeout\n while (this.active) {\n await delay(interval)\n if (timeoutRemaining !== undefined) {\n timeoutRemaining -= interval\n if (timeoutRemaining <= 0) {\n return this.activeForgets\n }\n }\n }\n return 0\n },\n\n /**\n * Used to explicitly launch an async function (or Promise) with awaiting it\n * @param promise The promise to forget\n * @param config Configuration of forget settings\n */\n forget<T>(promise: Promise<T>, config?: ForgetTimeoutConfig) {\n let completed = false\n this.activeForgets++\n\n const promiseWrapper = async () => {\n await promise\n .then(() => {\n this.activeForgets--\n completed = true\n })\n .catch(() => {\n this.activeForgets--\n completed = true\n })\n }\n\n const promises = [promiseWrapper()]\n\n //if there is a timeout, add it to the race\n if (config) {\n const timeoutFunc = async () => {\n await delay(config.delay)\n if (!completed) {\n console.log(`forget promise timeout out after ${config.delay}ms [Cancelling]`)\n config.cancel?.()\n }\n }\n promises.push(timeoutFunc())\n }\n\n const all = Promise.race(promises)\n\n all\n .then(() => {\n return\n })\n .catch(() => {\n return\n })\n },\n}\n\n//used to explicitly launch an async function (or Promise) with awaiting it\nexport const forget = (promise: Promise<unknown>, timeout?: ForgetTimeoutConfig) => {\n ForgetPromise.forget(promise, timeout)\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;;;ACAA,mBAAsB;AAOf,IAAM,gBAAgB;AAAA,EAC3B,IAAI,SAAS;AACX,WAAO,KAAK,gBAAgB;AAAA,EAC9B;AAAA,EAEA,eAAe;AAAA,EAEf,MAAM,cAAc,WAAW,KAAK,SAAkB;AACpD,QAAI,mBAAmB;AACvB,WAAO,KAAK,QAAQ;AAClB,gBAAM,oBAAM,QAAQ;AACpB,UAAI,qBAAqB,QAAW;AAClC,4BAAoB;AACpB,YAAI,oBAAoB,GAAG;AACzB,iBAAO,KAAK;AAAA,QACd;AAAA,MACF;AAAA,IACF;AACA,WAAO;AAAA,EACT;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOA,OAAU,SAAqB,QAA8B;AAC3D,QAAI,YAAY;AAChB,SAAK;AAEL,UAAM,iBAAiB,YAAY;AACjC,YAAM,QACH,KAAK,MAAM;AACV,aAAK;AACL,oBAAY;AAAA,MACd,CAAC,EACA,MAAM,MAAM;AACX,aAAK;AACL,oBAAY;AAAA,MACd,CAAC;AAAA,IACL;AAEA,UAAM,WAAW,CAAC,eAAe,CAAC;AAGlC,QAAI,QAAQ;AACV,YAAM,cAAc,YAAY;AAC9B,kBAAM,oBAAM,OAAO,KAAK;AACxB,YAAI,CAAC,WAAW;AACd,kBAAQ,IAAI,oCAAoC,OAAO,KAAK,iBAAiB;AAC7E,iBAAO,SAAS;AAAA,QAClB;AAAA,MACF;AACA,eAAS,KAAK,YAAY,CAAC;AAAA,IAC7B;AAEA,UAAM,MAAM,QAAQ,KAAK,QAAQ;AAEjC,QACG,KAAK,MAAM;AACV;AAAA,IACF,CAAC,EACA,MAAM,MAAM;AACX;AAAA,IACF,CAAC;AAAA,EACL;AACF;AAGO,IAAM,SAAS,CAAC,SAA2B,YAAkC;AAClF,gBAAc,OAAO,SAAS,OAAO;AACvC;","names":[]}
|
package/dist/browser/index.d.cts
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,aAAa,EAAE,MAAM,UAAU,CAAA
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,aAAa,EAAE,MAAM,UAAU,CAAA"}
|
package/dist/browser/index.d.mts
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,aAAa,EAAE,MAAM,UAAU,CAAA
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,aAAa,EAAE,MAAM,UAAU,CAAA"}
|
package/dist/browser/index.d.ts
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,aAAa,EAAE,MAAM,UAAU,CAAA
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,aAAa,EAAE,MAAM,UAAU,CAAA"}
|
package/dist/browser/index.js
CHANGED
|
@@ -1,11 +1,11 @@
|
|
|
1
1
|
// src/forget.ts
|
|
2
2
|
import { delay } from "@xylabs/delay";
|
|
3
|
-
var ForgetPromise =
|
|
4
|
-
|
|
5
|
-
static get active() {
|
|
3
|
+
var ForgetPromise = {
|
|
4
|
+
get active() {
|
|
6
5
|
return this.activeForgets > 0;
|
|
7
|
-
}
|
|
8
|
-
|
|
6
|
+
},
|
|
7
|
+
activeForgets: 0,
|
|
8
|
+
async awaitInactive(interval = 100, timeout) {
|
|
9
9
|
let timeoutRemaining = timeout;
|
|
10
10
|
while (this.active) {
|
|
11
11
|
await delay(interval);
|
|
@@ -17,13 +17,13 @@ var ForgetPromise = class {
|
|
|
17
17
|
}
|
|
18
18
|
}
|
|
19
19
|
return 0;
|
|
20
|
-
}
|
|
20
|
+
},
|
|
21
21
|
/**
|
|
22
22
|
* Used to explicitly launch an async function (or Promise) with awaiting it
|
|
23
23
|
* @param promise The promise to forget
|
|
24
24
|
* @param config Configuration of forget settings
|
|
25
25
|
*/
|
|
26
|
-
|
|
26
|
+
forget(promise, config) {
|
|
27
27
|
let completed = false;
|
|
28
28
|
this.activeForgets++;
|
|
29
29
|
const promiseWrapper = async () => {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/forget.ts"],"sourcesContent":["import { delay } from '@xylabs/delay'\n\nexport interface ForgetTimeoutConfig {\n cancel: () => void\n delay: number\n}\n\nexport
|
|
1
|
+
{"version":3,"sources":["../../src/forget.ts"],"sourcesContent":["import { delay } from '@xylabs/delay'\n\nexport interface ForgetTimeoutConfig {\n cancel: () => void\n delay: number\n}\n\nexport const ForgetPromise = {\n get active() {\n return this.activeForgets > 0\n },\n\n activeForgets: 0,\n\n async awaitInactive(interval = 100, timeout?: number) {\n let timeoutRemaining = timeout\n while (this.active) {\n await delay(interval)\n if (timeoutRemaining !== undefined) {\n timeoutRemaining -= interval\n if (timeoutRemaining <= 0) {\n return this.activeForgets\n }\n }\n }\n return 0\n },\n\n /**\n * Used to explicitly launch an async function (or Promise) with awaiting it\n * @param promise The promise to forget\n * @param config Configuration of forget settings\n */\n forget<T>(promise: Promise<T>, config?: ForgetTimeoutConfig) {\n let completed = false\n this.activeForgets++\n\n const promiseWrapper = async () => {\n await promise\n .then(() => {\n this.activeForgets--\n completed = true\n })\n .catch(() => {\n this.activeForgets--\n completed = true\n })\n }\n\n const promises = [promiseWrapper()]\n\n //if there is a timeout, add it to the race\n if (config) {\n const timeoutFunc = async () => {\n await delay(config.delay)\n if (!completed) {\n console.log(`forget promise timeout out after ${config.delay}ms [Cancelling]`)\n config.cancel?.()\n }\n }\n promises.push(timeoutFunc())\n }\n\n const all = Promise.race(promises)\n\n all\n .then(() => {\n return\n })\n .catch(() => {\n return\n })\n },\n}\n\n//used to explicitly launch an async function (or Promise) with awaiting it\nexport const forget = (promise: Promise<unknown>, timeout?: ForgetTimeoutConfig) => {\n ForgetPromise.forget(promise, timeout)\n}\n"],"mappings":";AAAA,SAAS,aAAa;AAOf,IAAM,gBAAgB;AAAA,EAC3B,IAAI,SAAS;AACX,WAAO,KAAK,gBAAgB;AAAA,EAC9B;AAAA,EAEA,eAAe;AAAA,EAEf,MAAM,cAAc,WAAW,KAAK,SAAkB;AACpD,QAAI,mBAAmB;AACvB,WAAO,KAAK,QAAQ;AAClB,YAAM,MAAM,QAAQ;AACpB,UAAI,qBAAqB,QAAW;AAClC,4BAAoB;AACpB,YAAI,oBAAoB,GAAG;AACzB,iBAAO,KAAK;AAAA,QACd;AAAA,MACF;AAAA,IACF;AACA,WAAO;AAAA,EACT;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOA,OAAU,SAAqB,QAA8B;AAC3D,QAAI,YAAY;AAChB,SAAK;AAEL,UAAM,iBAAiB,YAAY;AACjC,YAAM,QACH,KAAK,MAAM;AACV,aAAK;AACL,oBAAY;AAAA,MACd,CAAC,EACA,MAAM,MAAM;AACX,aAAK;AACL,oBAAY;AAAA,MACd,CAAC;AAAA,IACL;AAEA,UAAM,WAAW,CAAC,eAAe,CAAC;AAGlC,QAAI,QAAQ;AACV,YAAM,cAAc,YAAY;AAC9B,cAAM,MAAM,OAAO,KAAK;AACxB,YAAI,CAAC,WAAW;AACd,kBAAQ,IAAI,oCAAoC,OAAO,KAAK,iBAAiB;AAC7E,iBAAO,SAAS;AAAA,QAClB;AAAA,MACF;AACA,eAAS,KAAK,YAAY,CAAC;AAAA,IAC7B;AAEA,UAAM,MAAM,QAAQ,KAAK,QAAQ;AAEjC,QACG,KAAK,MAAM;AACV;AAAA,IACF,CAAC,EACA,MAAM,MAAM;AACX;AAAA,IACF,CAAC;AAAA,EACL;AACF;AAGO,IAAM,SAAS,CAAC,SAA2B,YAAkC;AAClF,gBAAc,OAAO,SAAS,OAAO;AACvC;","names":[]}
|
package/dist/node/forget.d.cts
CHANGED
|
@@ -2,16 +2,16 @@ export interface ForgetTimeoutConfig {
|
|
|
2
2
|
cancel: () => void;
|
|
3
3
|
delay: number;
|
|
4
4
|
}
|
|
5
|
-
export declare
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
5
|
+
export declare const ForgetPromise: {
|
|
6
|
+
readonly active: boolean;
|
|
7
|
+
activeForgets: number;
|
|
8
|
+
awaitInactive(interval?: number, timeout?: number): Promise<number>;
|
|
9
9
|
/**
|
|
10
10
|
* Used to explicitly launch an async function (or Promise) with awaiting it
|
|
11
11
|
* @param promise The promise to forget
|
|
12
12
|
* @param config Configuration of forget settings
|
|
13
13
|
*/
|
|
14
|
-
|
|
15
|
-
}
|
|
14
|
+
forget<T>(promise: Promise<T>, config?: ForgetTimeoutConfig): void;
|
|
15
|
+
};
|
|
16
16
|
export declare const forget: (promise: Promise<unknown>, timeout?: ForgetTimeoutConfig) => void;
|
|
17
17
|
//# sourceMappingURL=forget.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"forget.d.ts","sourceRoot":"","sources":["../../src/forget.ts"],"names":[],"mappings":"AAEA,MAAM,WAAW,mBAAmB;IAClC,MAAM,EAAE,MAAM,IAAI,CAAA;IAClB,KAAK,EAAE,MAAM,CAAA;CACd;AAED,
|
|
1
|
+
{"version":3,"file":"forget.d.ts","sourceRoot":"","sources":["../../src/forget.ts"],"names":[],"mappings":"AAEA,MAAM,WAAW,mBAAmB;IAClC,MAAM,EAAE,MAAM,IAAI,CAAA;IAClB,KAAK,EAAE,MAAM,CAAA;CACd;AAED,eAAO,MAAM,aAAa;;;+CAOsB,MAAM;IAcpD;;;;OAIG;4CACqC,mBAAmB;CAwC5D,CAAA;AAGD,eAAO,MAAM,MAAM,YAAa,QAAQ,OAAO,CAAC,YAAY,mBAAmB,SAE9E,CAAA"}
|
package/dist/node/forget.d.mts
CHANGED
|
@@ -2,16 +2,16 @@ export interface ForgetTimeoutConfig {
|
|
|
2
2
|
cancel: () => void;
|
|
3
3
|
delay: number;
|
|
4
4
|
}
|
|
5
|
-
export declare
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
5
|
+
export declare const ForgetPromise: {
|
|
6
|
+
readonly active: boolean;
|
|
7
|
+
activeForgets: number;
|
|
8
|
+
awaitInactive(interval?: number, timeout?: number): Promise<number>;
|
|
9
9
|
/**
|
|
10
10
|
* Used to explicitly launch an async function (or Promise) with awaiting it
|
|
11
11
|
* @param promise The promise to forget
|
|
12
12
|
* @param config Configuration of forget settings
|
|
13
13
|
*/
|
|
14
|
-
|
|
15
|
-
}
|
|
14
|
+
forget<T>(promise: Promise<T>, config?: ForgetTimeoutConfig): void;
|
|
15
|
+
};
|
|
16
16
|
export declare const forget: (promise: Promise<unknown>, timeout?: ForgetTimeoutConfig) => void;
|
|
17
17
|
//# sourceMappingURL=forget.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"forget.d.ts","sourceRoot":"","sources":["../../src/forget.ts"],"names":[],"mappings":"AAEA,MAAM,WAAW,mBAAmB;IAClC,MAAM,EAAE,MAAM,IAAI,CAAA;IAClB,KAAK,EAAE,MAAM,CAAA;CACd;AAED,
|
|
1
|
+
{"version":3,"file":"forget.d.ts","sourceRoot":"","sources":["../../src/forget.ts"],"names":[],"mappings":"AAEA,MAAM,WAAW,mBAAmB;IAClC,MAAM,EAAE,MAAM,IAAI,CAAA;IAClB,KAAK,EAAE,MAAM,CAAA;CACd;AAED,eAAO,MAAM,aAAa;;;+CAOsB,MAAM;IAcpD;;;;OAIG;4CACqC,mBAAmB;CAwC5D,CAAA;AAGD,eAAO,MAAM,MAAM,YAAa,QAAQ,OAAO,CAAC,YAAY,mBAAmB,SAE9E,CAAA"}
|
package/dist/node/forget.d.ts
CHANGED
|
@@ -2,16 +2,16 @@ export interface ForgetTimeoutConfig {
|
|
|
2
2
|
cancel: () => void;
|
|
3
3
|
delay: number;
|
|
4
4
|
}
|
|
5
|
-
export declare
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
5
|
+
export declare const ForgetPromise: {
|
|
6
|
+
readonly active: boolean;
|
|
7
|
+
activeForgets: number;
|
|
8
|
+
awaitInactive(interval?: number, timeout?: number): Promise<number>;
|
|
9
9
|
/**
|
|
10
10
|
* Used to explicitly launch an async function (or Promise) with awaiting it
|
|
11
11
|
* @param promise The promise to forget
|
|
12
12
|
* @param config Configuration of forget settings
|
|
13
13
|
*/
|
|
14
|
-
|
|
15
|
-
}
|
|
14
|
+
forget<T>(promise: Promise<T>, config?: ForgetTimeoutConfig): void;
|
|
15
|
+
};
|
|
16
16
|
export declare const forget: (promise: Promise<unknown>, timeout?: ForgetTimeoutConfig) => void;
|
|
17
17
|
//# sourceMappingURL=forget.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"forget.d.ts","sourceRoot":"","sources":["../../src/forget.ts"],"names":[],"mappings":"AAEA,MAAM,WAAW,mBAAmB;IAClC,MAAM,EAAE,MAAM,IAAI,CAAA;IAClB,KAAK,EAAE,MAAM,CAAA;CACd;AAED,
|
|
1
|
+
{"version":3,"file":"forget.d.ts","sourceRoot":"","sources":["../../src/forget.ts"],"names":[],"mappings":"AAEA,MAAM,WAAW,mBAAmB;IAClC,MAAM,EAAE,MAAM,IAAI,CAAA;IAClB,KAAK,EAAE,MAAM,CAAA;CACd;AAED,eAAO,MAAM,aAAa;;;+CAOsB,MAAM;IAcpD;;;;OAIG;4CACqC,mBAAmB;CAwC5D,CAAA;AAGD,eAAO,MAAM,MAAM,YAAa,QAAQ,OAAO,CAAC,YAAY,mBAAmB,SAE9E,CAAA"}
|
package/dist/node/index.cjs
CHANGED
|
@@ -27,12 +27,12 @@ module.exports = __toCommonJS(src_exports);
|
|
|
27
27
|
|
|
28
28
|
// src/forget.ts
|
|
29
29
|
var import_delay = require("@xylabs/delay");
|
|
30
|
-
var ForgetPromise =
|
|
31
|
-
|
|
32
|
-
static get active() {
|
|
30
|
+
var ForgetPromise = {
|
|
31
|
+
get active() {
|
|
33
32
|
return this.activeForgets > 0;
|
|
34
|
-
}
|
|
35
|
-
|
|
33
|
+
},
|
|
34
|
+
activeForgets: 0,
|
|
35
|
+
async awaitInactive(interval = 100, timeout) {
|
|
36
36
|
let timeoutRemaining = timeout;
|
|
37
37
|
while (this.active) {
|
|
38
38
|
await (0, import_delay.delay)(interval);
|
|
@@ -44,13 +44,13 @@ var ForgetPromise = class {
|
|
|
44
44
|
}
|
|
45
45
|
}
|
|
46
46
|
return 0;
|
|
47
|
-
}
|
|
47
|
+
},
|
|
48
48
|
/**
|
|
49
49
|
* Used to explicitly launch an async function (or Promise) with awaiting it
|
|
50
50
|
* @param promise The promise to forget
|
|
51
51
|
* @param config Configuration of forget settings
|
|
52
52
|
*/
|
|
53
|
-
|
|
53
|
+
forget(promise, config) {
|
|
54
54
|
let completed = false;
|
|
55
55
|
this.activeForgets++;
|
|
56
56
|
const promiseWrapper = async () => {
|
package/dist/node/index.cjs.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/index.ts","../../src/forget.ts"],"sourcesContent":["
|
|
1
|
+
{"version":3,"sources":["../../src/index.ts","../../src/forget.ts"],"sourcesContent":["export { forget, ForgetPromise } from './forget'\n","import { delay } from '@xylabs/delay'\n\nexport interface ForgetTimeoutConfig {\n cancel: () => void\n delay: number\n}\n\nexport const ForgetPromise = {\n get active() {\n return this.activeForgets > 0\n },\n\n activeForgets: 0,\n\n async awaitInactive(interval = 100, timeout?: number) {\n let timeoutRemaining = timeout\n while (this.active) {\n await delay(interval)\n if (timeoutRemaining !== undefined) {\n timeoutRemaining -= interval\n if (timeoutRemaining <= 0) {\n return this.activeForgets\n }\n }\n }\n return 0\n },\n\n /**\n * Used to explicitly launch an async function (or Promise) with awaiting it\n * @param promise The promise to forget\n * @param config Configuration of forget settings\n */\n forget<T>(promise: Promise<T>, config?: ForgetTimeoutConfig) {\n let completed = false\n this.activeForgets++\n\n const promiseWrapper = async () => {\n await promise\n .then(() => {\n this.activeForgets--\n completed = true\n })\n .catch(() => {\n this.activeForgets--\n completed = true\n })\n }\n\n const promises = [promiseWrapper()]\n\n //if there is a timeout, add it to the race\n if (config) {\n const timeoutFunc = async () => {\n await delay(config.delay)\n if (!completed) {\n console.log(`forget promise timeout out after ${config.delay}ms [Cancelling]`)\n config.cancel?.()\n }\n }\n promises.push(timeoutFunc())\n }\n\n const all = Promise.race(promises)\n\n all\n .then(() => {\n return\n })\n .catch(() => {\n return\n })\n },\n}\n\n//used to explicitly launch an async function (or Promise) with awaiting it\nexport const forget = (promise: Promise<unknown>, timeout?: ForgetTimeoutConfig) => {\n ForgetPromise.forget(promise, timeout)\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;;;ACAA,mBAAsB;AAOf,IAAM,gBAAgB;AAAA,EAC3B,IAAI,SAAS;AACX,WAAO,KAAK,gBAAgB;AAAA,EAC9B;AAAA,EAEA,eAAe;AAAA,EAEf,MAAM,cAAc,WAAW,KAAK,SAAkB;AACpD,QAAI,mBAAmB;AACvB,WAAO,KAAK,QAAQ;AAClB,gBAAM,oBAAM,QAAQ;AACpB,UAAI,qBAAqB,QAAW;AAClC,4BAAoB;AACpB,YAAI,oBAAoB,GAAG;AACzB,iBAAO,KAAK;AAAA,QACd;AAAA,MACF;AAAA,IACF;AACA,WAAO;AAAA,EACT;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOA,OAAU,SAAqB,QAA8B;AAC3D,QAAI,YAAY;AAChB,SAAK;AAEL,UAAM,iBAAiB,YAAY;AACjC,YAAM,QACH,KAAK,MAAM;AACV,aAAK;AACL,oBAAY;AAAA,MACd,CAAC,EACA,MAAM,MAAM;AACX,aAAK;AACL,oBAAY;AAAA,MACd,CAAC;AAAA,IACL;AAEA,UAAM,WAAW,CAAC,eAAe,CAAC;AAGlC,QAAI,QAAQ;AACV,YAAM,cAAc,YAAY;AArDtC;AAsDQ,kBAAM,oBAAM,OAAO,KAAK;AACxB,YAAI,CAAC,WAAW;AACd,kBAAQ,IAAI,oCAAoC,OAAO,KAAK,iBAAiB;AAC7E,uBAAO,WAAP;AAAA,QACF;AAAA,MACF;AACA,eAAS,KAAK,YAAY,CAAC;AAAA,IAC7B;AAEA,UAAM,MAAM,QAAQ,KAAK,QAAQ;AAEjC,QACG,KAAK,MAAM;AACV;AAAA,IACF,CAAC,EACA,MAAM,MAAM;AACX;AAAA,IACF,CAAC;AAAA,EACL;AACF;AAGO,IAAM,SAAS,CAAC,SAA2B,YAAkC;AAClF,gBAAc,OAAO,SAAS,OAAO;AACvC;","names":[]}
|
package/dist/node/index.d.cts
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,aAAa,EAAE,MAAM,UAAU,CAAA
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,aAAa,EAAE,MAAM,UAAU,CAAA"}
|
package/dist/node/index.d.mts
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,aAAa,EAAE,MAAM,UAAU,CAAA
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,aAAa,EAAE,MAAM,UAAU,CAAA"}
|
package/dist/node/index.d.ts
CHANGED
package/dist/node/index.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,aAAa,EAAE,MAAM,UAAU,CAAA
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,aAAa,EAAE,MAAM,UAAU,CAAA"}
|
package/dist/node/index.js
CHANGED
|
@@ -1,11 +1,11 @@
|
|
|
1
1
|
// src/forget.ts
|
|
2
2
|
import { delay } from "@xylabs/delay";
|
|
3
|
-
var ForgetPromise =
|
|
4
|
-
|
|
5
|
-
static get active() {
|
|
3
|
+
var ForgetPromise = {
|
|
4
|
+
get active() {
|
|
6
5
|
return this.activeForgets > 0;
|
|
7
|
-
}
|
|
8
|
-
|
|
6
|
+
},
|
|
7
|
+
activeForgets: 0,
|
|
8
|
+
async awaitInactive(interval = 100, timeout) {
|
|
9
9
|
let timeoutRemaining = timeout;
|
|
10
10
|
while (this.active) {
|
|
11
11
|
await delay(interval);
|
|
@@ -17,13 +17,13 @@ var ForgetPromise = class {
|
|
|
17
17
|
}
|
|
18
18
|
}
|
|
19
19
|
return 0;
|
|
20
|
-
}
|
|
20
|
+
},
|
|
21
21
|
/**
|
|
22
22
|
* Used to explicitly launch an async function (or Promise) with awaiting it
|
|
23
23
|
* @param promise The promise to forget
|
|
24
24
|
* @param config Configuration of forget settings
|
|
25
25
|
*/
|
|
26
|
-
|
|
26
|
+
forget(promise, config) {
|
|
27
27
|
let completed = false;
|
|
28
28
|
this.activeForgets++;
|
|
29
29
|
const promiseWrapper = async () => {
|
package/dist/node/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/forget.ts"],"sourcesContent":["import { delay } from '@xylabs/delay'\n\nexport interface ForgetTimeoutConfig {\n cancel: () => void\n delay: number\n}\n\nexport
|
|
1
|
+
{"version":3,"sources":["../../src/forget.ts"],"sourcesContent":["import { delay } from '@xylabs/delay'\n\nexport interface ForgetTimeoutConfig {\n cancel: () => void\n delay: number\n}\n\nexport const ForgetPromise = {\n get active() {\n return this.activeForgets > 0\n },\n\n activeForgets: 0,\n\n async awaitInactive(interval = 100, timeout?: number) {\n let timeoutRemaining = timeout\n while (this.active) {\n await delay(interval)\n if (timeoutRemaining !== undefined) {\n timeoutRemaining -= interval\n if (timeoutRemaining <= 0) {\n return this.activeForgets\n }\n }\n }\n return 0\n },\n\n /**\n * Used to explicitly launch an async function (or Promise) with awaiting it\n * @param promise The promise to forget\n * @param config Configuration of forget settings\n */\n forget<T>(promise: Promise<T>, config?: ForgetTimeoutConfig) {\n let completed = false\n this.activeForgets++\n\n const promiseWrapper = async () => {\n await promise\n .then(() => {\n this.activeForgets--\n completed = true\n })\n .catch(() => {\n this.activeForgets--\n completed = true\n })\n }\n\n const promises = [promiseWrapper()]\n\n //if there is a timeout, add it to the race\n if (config) {\n const timeoutFunc = async () => {\n await delay(config.delay)\n if (!completed) {\n console.log(`forget promise timeout out after ${config.delay}ms [Cancelling]`)\n config.cancel?.()\n }\n }\n promises.push(timeoutFunc())\n }\n\n const all = Promise.race(promises)\n\n all\n .then(() => {\n return\n })\n .catch(() => {\n return\n })\n },\n}\n\n//used to explicitly launch an async function (or Promise) with awaiting it\nexport const forget = (promise: Promise<unknown>, timeout?: ForgetTimeoutConfig) => {\n ForgetPromise.forget(promise, timeout)\n}\n"],"mappings":";AAAA,SAAS,aAAa;AAOf,IAAM,gBAAgB;AAAA,EAC3B,IAAI,SAAS;AACX,WAAO,KAAK,gBAAgB;AAAA,EAC9B;AAAA,EAEA,eAAe;AAAA,EAEf,MAAM,cAAc,WAAW,KAAK,SAAkB;AACpD,QAAI,mBAAmB;AACvB,WAAO,KAAK,QAAQ;AAClB,YAAM,MAAM,QAAQ;AACpB,UAAI,qBAAqB,QAAW;AAClC,4BAAoB;AACpB,YAAI,oBAAoB,GAAG;AACzB,iBAAO,KAAK;AAAA,QACd;AAAA,MACF;AAAA,IACF;AACA,WAAO;AAAA,EACT;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOA,OAAU,SAAqB,QAA8B;AAC3D,QAAI,YAAY;AAChB,SAAK;AAEL,UAAM,iBAAiB,YAAY;AACjC,YAAM,QACH,KAAK,MAAM;AACV,aAAK;AACL,oBAAY;AAAA,MACd,CAAC,EACA,MAAM,MAAM;AACX,aAAK;AACL,oBAAY;AAAA,MACd,CAAC;AAAA,IACL;AAEA,UAAM,WAAW,CAAC,eAAe,CAAC;AAGlC,QAAI,QAAQ;AACV,YAAM,cAAc,YAAY;AArDtC;AAsDQ,cAAM,MAAM,OAAO,KAAK;AACxB,YAAI,CAAC,WAAW;AACd,kBAAQ,IAAI,oCAAoC,OAAO,KAAK,iBAAiB;AAC7E,uBAAO,WAAP;AAAA,QACF;AAAA,MACF;AACA,eAAS,KAAK,YAAY,CAAC;AAAA,IAC7B;AAEA,UAAM,MAAM,QAAQ,KAAK,QAAQ;AAEjC,QACG,KAAK,MAAM;AACV;AAAA,IACF,CAAC,EACA,MAAM,MAAM;AACX;AAAA,IACF,CAAC;AAAA,EACL;AACF;AAGO,IAAM,SAAS,CAAC,SAA2B,YAAkC;AAClF,gBAAc,OAAO,SAAS,OAAO;AACvC;","names":[]}
|
package/package.json
CHANGED
|
@@ -29,18 +29,22 @@
|
|
|
29
29
|
"module": "./dist/node/index.js",
|
|
30
30
|
"homepage": "https://xylabs.com",
|
|
31
31
|
"keywords": [
|
|
32
|
+
"forget",
|
|
32
33
|
"xylabs",
|
|
33
34
|
"utility",
|
|
34
35
|
"typescript",
|
|
35
36
|
"esm"
|
|
36
37
|
],
|
|
37
38
|
"dependencies": {
|
|
38
|
-
"@xylabs/delay": "~2.13.
|
|
39
|
+
"@xylabs/delay": "~2.13.21"
|
|
39
40
|
},
|
|
40
41
|
"devDependencies": {
|
|
41
|
-
"@xylabs/ts-scripts-yarn3": "^3.2.
|
|
42
|
-
"@xylabs/tsconfig": "^3.2.
|
|
43
|
-
"typescript": "^5.3.
|
|
42
|
+
"@xylabs/ts-scripts-yarn3": "^3.2.25",
|
|
43
|
+
"@xylabs/tsconfig": "^3.2.25",
|
|
44
|
+
"typescript": "^5.3.3"
|
|
45
|
+
},
|
|
46
|
+
"engines": {
|
|
47
|
+
"node": ">=18"
|
|
44
48
|
},
|
|
45
49
|
"publishConfig": {
|
|
46
50
|
"access": "public"
|
|
@@ -50,6 +54,6 @@
|
|
|
50
54
|
"url": "https://github.com/xylabs/sdk-js.git"
|
|
51
55
|
},
|
|
52
56
|
"sideEffects": false,
|
|
53
|
-
"version": "2.13.
|
|
57
|
+
"version": "2.13.21",
|
|
54
58
|
"type": "module"
|
|
55
59
|
}
|
package/src/forget.ts
CHANGED
|
@@ -5,14 +5,14 @@ export interface ForgetTimeoutConfig {
|
|
|
5
5
|
delay: number
|
|
6
6
|
}
|
|
7
7
|
|
|
8
|
-
export
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
static get active() {
|
|
8
|
+
export const ForgetPromise = {
|
|
9
|
+
get active() {
|
|
12
10
|
return this.activeForgets > 0
|
|
13
|
-
}
|
|
11
|
+
},
|
|
12
|
+
|
|
13
|
+
activeForgets: 0,
|
|
14
14
|
|
|
15
|
-
|
|
15
|
+
async awaitInactive(interval = 100, timeout?: number) {
|
|
16
16
|
let timeoutRemaining = timeout
|
|
17
17
|
while (this.active) {
|
|
18
18
|
await delay(interval)
|
|
@@ -24,14 +24,14 @@ export class ForgetPromise {
|
|
|
24
24
|
}
|
|
25
25
|
}
|
|
26
26
|
return 0
|
|
27
|
-
}
|
|
27
|
+
},
|
|
28
28
|
|
|
29
29
|
/**
|
|
30
30
|
* Used to explicitly launch an async function (or Promise) with awaiting it
|
|
31
31
|
* @param promise The promise to forget
|
|
32
32
|
* @param config Configuration of forget settings
|
|
33
33
|
*/
|
|
34
|
-
|
|
34
|
+
forget<T>(promise: Promise<T>, config?: ForgetTimeoutConfig) {
|
|
35
35
|
let completed = false
|
|
36
36
|
this.activeForgets++
|
|
37
37
|
|
|
@@ -70,7 +70,7 @@ export class ForgetPromise {
|
|
|
70
70
|
.catch(() => {
|
|
71
71
|
return
|
|
72
72
|
})
|
|
73
|
-
}
|
|
73
|
+
},
|
|
74
74
|
}
|
|
75
75
|
|
|
76
76
|
//used to explicitly launch an async function (or Promise) with awaiting it
|
package/src/index.ts
CHANGED