@jcoreio/abortable 1.0.0 → 1.0.2
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.map +1 -1
- package/index.js +5 -5
- package/index.js.map +1 -1
- package/index.mjs +5 -5
- package/index.mjs.map +1 -1
- package/package.json +1 -1
- package/src/index.ts +6 -5
package/index.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["src/index.ts"],"names":[],"mappings":"AAAA,eAAO,MAAM,aAAa,oBACoC,CAAA;AAI9D,wBAAgB,SAAS,CAAC,CAAC,EACzB,OAAO,EAAE,OAAO,CAAC,CAAC,CAAC,EACnB,MAAM,EAAE,WAAW,GAAG,SAAS,GAC9B,OAAO,CAAC,CAAC,CAAC,
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["src/index.ts"],"names":[],"mappings":"AAAA,eAAO,MAAM,aAAa,oBACoC,CAAA;AAI9D,wBAAgB,SAAS,CAAC,CAAC,EACzB,OAAO,EAAE,OAAO,CAAC,CAAC,CAAC,EACnB,MAAM,EAAE,WAAW,GAAG,SAAS,GAC9B,OAAO,CAAC,CAAC,CAAC,CA6BZ"}
|
package/index.js
CHANGED
|
@@ -12,10 +12,6 @@ var noop = function noop() {};
|
|
|
12
12
|
function abortable(promise, signal) {
|
|
13
13
|
if (!signal) return promise;
|
|
14
14
|
return new Promise(function (resolve, reject) {
|
|
15
|
-
if (signal.aborted) {
|
|
16
|
-
reject(newAbortError());
|
|
17
|
-
return;
|
|
18
|
-
}
|
|
19
15
|
var cleanup = function cleanup() {
|
|
20
16
|
var callbacks = {
|
|
21
17
|
resolve: resolve,
|
|
@@ -36,12 +32,16 @@ function abortable(promise, signal) {
|
|
|
36
32
|
var onAbort = function onAbort() {
|
|
37
33
|
return cleanup().reject(newAbortError());
|
|
38
34
|
};
|
|
39
|
-
signal.addEventListener('abort', onAbort);
|
|
40
35
|
promise.then(function (value) {
|
|
41
36
|
return cleanup().resolve(value);
|
|
42
37
|
}, function (error) {
|
|
43
38
|
return cleanup().reject(error);
|
|
44
39
|
});
|
|
40
|
+
if (signal.aborted) {
|
|
41
|
+
reject(newAbortError());
|
|
42
|
+
} else {
|
|
43
|
+
signal.addEventListener('abort', onAbort);
|
|
44
|
+
}
|
|
45
45
|
});
|
|
46
46
|
}
|
|
47
47
|
//# sourceMappingURL=index.js.map
|
package/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","names":["newAbortError","exports","DOMException","noop","abortable","promise","signal","Promise","resolve","reject","
|
|
1
|
+
{"version":3,"file":"index.js","names":["newAbortError","exports","DOMException","noop","abortable","promise","signal","Promise","resolve","reject","cleanup","callbacks","removeEventListener","onAbort","then","value","error","aborted","addEventListener"],"sources":["src/index.ts"],"sourcesContent":["export const newAbortError = () =>\n new DOMException('This operation was aborted', 'AbortError')\n\nconst noop = () => {}\n\nexport function abortable<T>(\n promise: Promise<T>,\n signal: AbortSignal | undefined\n): Promise<T> {\n if (!signal) return promise\n return new Promise<T>((resolve, reject) => {\n const cleanup = () => {\n const callbacks = { resolve, reject }\n // Prevent memory leaks. If the input promise never resolves, then the handlers\n // below would retain this enclosing Promise's resolve and reject callbacks,\n // which would retain the enclosing Promise and anything waiting on it.\n // By replacing references to these callbacks, we enable the enclosing Promise to\n // be garbage collected\n resolve = noop\n reject = noop\n // Memory could also leak if the signal never aborts, unless we remove the abort\n // handler\n signal.removeEventListener('abort', onAbort)\n return callbacks\n }\n const onAbort = () => cleanup().reject(newAbortError())\n\n promise.then(\n (value) => cleanup().resolve(value),\n (error) => cleanup().reject(error)\n )\n if (signal.aborted) {\n reject(newAbortError())\n } else {\n signal.addEventListener('abort', onAbort)\n }\n })\n}\n"],"mappings":";;;;;;;AAAO,IAAMA,aAAa,GAAAC,OAAA,CAAAD,aAAA,GAAG,SAAhBA,aAAaA,CAAA;EAAA,OACxB,IAAIE,YAAY,CAAC,4BAA4B,EAAE,YAAY,CAAC;AAAA;AAE9D,IAAMC,IAAI,GAAG,SAAPA,IAAIA,CAAA,EAAS,CAAC,CAAC;AAEd,SAASC,SAASA,CACvBC,OAAmB,EACnBC,MAA+B,EACnB;EACZ,IAAI,CAACA,MAAM,EAAE,OAAOD,OAAO;EAC3B,OAAO,IAAIE,OAAO,CAAI,UAACC,OAAO,EAAEC,MAAM,EAAK;IACzC,IAAMC,OAAO,GAAG,SAAVA,OAAOA,CAAA,EAAS;MACpB,IAAMC,SAAS,GAAG;QAAEH,OAAO,EAAPA,OAAO;QAAEC,MAAM,EAANA;MAAO,CAAC;MACrC;MACA;MACA;MACA;MACA;MACAD,OAAO,GAAGL,IAAI;MACdM,MAAM,GAAGN,IAAI;MACb;MACA;MACAG,MAAM,CAACM,mBAAmB,CAAC,OAAO,EAAEC,OAAO,CAAC;MAC5C,OAAOF,SAAS;IAClB,CAAC;IACD,IAAME,OAAO,GAAG,SAAVA,OAAOA,CAAA;MAAA,OAASH,OAAO,CAAC,CAAC,CAACD,MAAM,CAACT,aAAa,CAAC,CAAC,CAAC;IAAA;IAEvDK,OAAO,CAACS,IAAI,CACV,UAACC,KAAK;MAAA,OAAKL,OAAO,CAAC,CAAC,CAACF,OAAO,CAACO,KAAK,CAAC;IAAA,GACnC,UAACC,KAAK;MAAA,OAAKN,OAAO,CAAC,CAAC,CAACD,MAAM,CAACO,KAAK,CAAC;IAAA,CACpC,CAAC;IACD,IAAIV,MAAM,CAACW,OAAO,EAAE;MAClBR,MAAM,CAACT,aAAa,CAAC,CAAC,CAAC;IACzB,CAAC,MAAM;MACLM,MAAM,CAACY,gBAAgB,CAAC,OAAO,EAAEL,OAAO,CAAC;IAC3C;EACF,CAAC,CAAC;AACJ","ignoreList":[]}
|
package/index.mjs
CHANGED
|
@@ -3,10 +3,6 @@ const noop = () => {};
|
|
|
3
3
|
export function abortable(promise, signal) {
|
|
4
4
|
if (!signal) return promise;
|
|
5
5
|
return new Promise((resolve, reject) => {
|
|
6
|
-
if (signal.aborted) {
|
|
7
|
-
reject(newAbortError());
|
|
8
|
-
return;
|
|
9
|
-
}
|
|
10
6
|
const cleanup = () => {
|
|
11
7
|
const callbacks = {
|
|
12
8
|
resolve,
|
|
@@ -25,8 +21,12 @@ export function abortable(promise, signal) {
|
|
|
25
21
|
return callbacks;
|
|
26
22
|
};
|
|
27
23
|
const onAbort = () => cleanup().reject(newAbortError());
|
|
28
|
-
signal.addEventListener('abort', onAbort);
|
|
29
24
|
promise.then(value => cleanup().resolve(value), error => cleanup().reject(error));
|
|
25
|
+
if (signal.aborted) {
|
|
26
|
+
reject(newAbortError());
|
|
27
|
+
} else {
|
|
28
|
+
signal.addEventListener('abort', onAbort);
|
|
29
|
+
}
|
|
30
30
|
});
|
|
31
31
|
}
|
|
32
32
|
//# sourceMappingURL=index.mjs.map
|
package/index.mjs.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.mjs","names":["newAbortError","DOMException","noop","abortable","promise","signal","Promise","resolve","reject","
|
|
1
|
+
{"version":3,"file":"index.mjs","names":["newAbortError","DOMException","noop","abortable","promise","signal","Promise","resolve","reject","cleanup","callbacks","removeEventListener","onAbort","then","value","error","aborted","addEventListener"],"sources":["src/index.ts"],"sourcesContent":["export const newAbortError = () =>\n new DOMException('This operation was aborted', 'AbortError')\n\nconst noop = () => {}\n\nexport function abortable<T>(\n promise: Promise<T>,\n signal: AbortSignal | undefined\n): Promise<T> {\n if (!signal) return promise\n return new Promise<T>((resolve, reject) => {\n const cleanup = () => {\n const callbacks = { resolve, reject }\n // Prevent memory leaks. If the input promise never resolves, then the handlers\n // below would retain this enclosing Promise's resolve and reject callbacks,\n // which would retain the enclosing Promise and anything waiting on it.\n // By replacing references to these callbacks, we enable the enclosing Promise to\n // be garbage collected\n resolve = noop\n reject = noop\n // Memory could also leak if the signal never aborts, unless we remove the abort\n // handler\n signal.removeEventListener('abort', onAbort)\n return callbacks\n }\n const onAbort = () => cleanup().reject(newAbortError())\n\n promise.then(\n (value) => cleanup().resolve(value),\n (error) => cleanup().reject(error)\n )\n if (signal.aborted) {\n reject(newAbortError())\n } else {\n signal.addEventListener('abort', onAbort)\n }\n })\n}\n"],"mappings":"AAAA,OAAO,MAAMA,aAAa,GAAGA,CAAA,KAC3B,IAAIC,YAAY,CAAC,4BAA4B,EAAE,YAAY,CAAC;AAE9D,MAAMC,IAAI,GAAGA,CAAA,KAAM,CAAC,CAAC;AAErB,OAAO,SAASC,SAASA,CACvBC,OAAmB,EACnBC,MAA+B,EACnB;EACZ,IAAI,CAACA,MAAM,EAAE,OAAOD,OAAO;EAC3B,OAAO,IAAIE,OAAO,CAAI,CAACC,OAAO,EAAEC,MAAM,KAAK;IACzC,MAAMC,OAAO,GAAGA,CAAA,KAAM;MACpB,MAAMC,SAAS,GAAG;QAAEH,OAAO;QAAEC;MAAO,CAAC;MACrC;MACA;MACA;MACA;MACA;MACAD,OAAO,GAAGL,IAAI;MACdM,MAAM,GAAGN,IAAI;MACb;MACA;MACAG,MAAM,CAACM,mBAAmB,CAAC,OAAO,EAAEC,OAAO,CAAC;MAC5C,OAAOF,SAAS;IAClB,CAAC;IACD,MAAME,OAAO,GAAGA,CAAA,KAAMH,OAAO,CAAC,CAAC,CAACD,MAAM,CAACR,aAAa,CAAC,CAAC,CAAC;IAEvDI,OAAO,CAACS,IAAI,CACTC,KAAK,IAAKL,OAAO,CAAC,CAAC,CAACF,OAAO,CAACO,KAAK,CAAC,EAClCC,KAAK,IAAKN,OAAO,CAAC,CAAC,CAACD,MAAM,CAACO,KAAK,CACnC,CAAC;IACD,IAAIV,MAAM,CAACW,OAAO,EAAE;MAClBR,MAAM,CAACR,aAAa,CAAC,CAAC,CAAC;IACzB,CAAC,MAAM;MACLK,MAAM,CAACY,gBAAgB,CAAC,OAAO,EAAEL,OAAO,CAAC;IAC3C;EACF,CAAC,CAAC;AACJ","ignoreList":[]}
|
package/package.json
CHANGED
package/src/index.ts
CHANGED
|
@@ -9,10 +9,6 @@ export function abortable<T>(
|
|
|
9
9
|
): Promise<T> {
|
|
10
10
|
if (!signal) return promise
|
|
11
11
|
return new Promise<T>((resolve, reject) => {
|
|
12
|
-
if (signal.aborted) {
|
|
13
|
-
reject(newAbortError())
|
|
14
|
-
return
|
|
15
|
-
}
|
|
16
12
|
const cleanup = () => {
|
|
17
13
|
const callbacks = { resolve, reject }
|
|
18
14
|
// Prevent memory leaks. If the input promise never resolves, then the handlers
|
|
@@ -28,10 +24,15 @@ export function abortable<T>(
|
|
|
28
24
|
return callbacks
|
|
29
25
|
}
|
|
30
26
|
const onAbort = () => cleanup().reject(newAbortError())
|
|
31
|
-
|
|
27
|
+
|
|
32
28
|
promise.then(
|
|
33
29
|
(value) => cleanup().resolve(value),
|
|
34
30
|
(error) => cleanup().reject(error)
|
|
35
31
|
)
|
|
32
|
+
if (signal.aborted) {
|
|
33
|
+
reject(newAbortError())
|
|
34
|
+
} else {
|
|
35
|
+
signal.addEventListener('abort', onAbort)
|
|
36
|
+
}
|
|
36
37
|
})
|
|
37
38
|
}
|