@jcoreio/abortable 1.0.2 → 1.0.4

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.mts ADDED
@@ -0,0 +1,3 @@
1
+ export declare const newAbortError: () => DOMException;
2
+ export declare function abortable<T>(promise: Promise<T>, signal: AbortSignal | undefined): Promise<T>;
3
+ //# sourceMappingURL=index.d.mts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.mts","names":["newAbortError","DOMException","abortable","promise","Promise","T","signal","AbortSignal"],"sources":["src/index.ts"],"sourcesContent":[null],"mappings":"AAAA,qBAAaA,aAAa,QAAAC,YACoC;AAI9D,wBAAgBC,SAAS,CAAC,CAAC,CAAAA,CACzBC,OAAO,EAAEC,OAAO,CAACC,CAAC,CAAC,EACnBC,MAAM,EAAEC,WAAW,GAAG,SAAS,GAC9BH,OAAO,CAACC,CAAC,CAAC","ignoreList":[]}
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,CA6BZ"}
1
+ {"version":3,"file":"index.d.ts","names":["newAbortError","DOMException","abortable","promise","Promise","T","signal","AbortSignal"],"sources":["src/index.ts"],"sourcesContent":[null],"mappings":"AAAA,qBAAaA,aAAa,QAAAC,YACoC;AAI9D,wBAAgBC,SAAS,CAAC,CAAC,CAAAA,CACzBC,OAAO,EAAEC,OAAO,CAACC,CAAC,CAAC,EACnBC,MAAM,EAAEC,WAAW,GAAG,SAAS,GAC9BH,OAAO,CAACC,CAAC,CAAC","ignoreList":[]}
package/index.js CHANGED
@@ -11,6 +11,12 @@ var newAbortError = exports.newAbortError = function newAbortError() {
11
11
  var noop = function noop() {};
12
12
  function abortable(promise, signal) {
13
13
  if (!signal) return promise;
14
+ if (signal.aborted) {
15
+ // prevent unhandled rejection
16
+ promise["catch"](function () {});
17
+ // eslint-disable-next-line @typescript-eslint/prefer-promise-reject-errors
18
+ return Promise.reject(signal.reason);
19
+ }
14
20
  return new Promise(function (resolve, reject) {
15
21
  var cleanup = function cleanup() {
16
22
  var callbacks = {
@@ -30,18 +36,14 @@ function abortable(promise, signal) {
30
36
  return callbacks;
31
37
  };
32
38
  var onAbort = function onAbort() {
33
- return cleanup().reject(newAbortError());
39
+ return cleanup().reject(signal.reason);
34
40
  };
35
41
  promise.then(function (value) {
36
42
  return cleanup().resolve(value);
37
43
  }, function (error) {
38
44
  return cleanup().reject(error);
39
45
  });
40
- if (signal.aborted) {
41
- reject(newAbortError());
42
- } else {
43
- signal.addEventListener('abort', onAbort);
44
- }
46
+ signal.addEventListener('abort', onAbort);
45
47
  });
46
48
  }
47
49
  //# 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","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":[]}
1
+ {"version":3,"file":"index.js","names":["newAbortError","exports","DOMException","noop","abortable","promise","signal","aborted","Promise","reject","reason","resolve","cleanup","callbacks","removeEventListener","onAbort","then","value","error","addEventListener"],"sources":["src/index.ts"],"sourcesContent":[null],"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,IAAIC,MAAM,CAACC,OAAO,EAAE;IAClB;IACAF,OAAO,SAAM,CAAC,YAAM,CAAC,CAAC,CAAC;IACvB;IACA,OAAOG,OAAO,CAACC,MAAM,CAACH,MAAM,CAACI,MAAM,CAAC;EACtC;EACA,OAAO,IAAIF,OAAO,CAAI,UAACG,OAAO,EAAEF,MAAM,EAAK;IACzC,IAAMG,OAAO,GAAG,SAAVA,OAAOA,CAAA,EAAS;MACpB,IAAMC,SAAS,GAAG;QAAEF,OAAO,EAAPA,OAAO;QAAEF,MAAM,EAANA;MAAO,CAAC;MACrC;MACA;MACA;MACA;MACA;MACAE,OAAO,GAAGR,IAAI;MACdM,MAAM,GAAGN,IAAI;MACb;MACA;MACAG,MAAM,CAACQ,mBAAmB,CAAC,OAAO,EAAEC,OAAO,CAAC;MAC5C,OAAOF,SAAS;IAClB,CAAC;IACD,IAAME,OAAO,GAAG,SAAVA,OAAOA,CAAA;MAAA,OAASH,OAAO,CAAC,CAAC,CAACH,MAAM,CAACH,MAAM,CAACI,MAAM,CAAC;IAAA;IAErDL,OAAO,CAACW,IAAI,CACV,UAACC,KAAK;MAAA,OAAKL,OAAO,CAAC,CAAC,CAACD,OAAO,CAACM,KAAK,CAAC;IAAA,GACnC,UAACC,KAAc;MAAA,OAAKN,OAAO,CAAC,CAAC,CAACH,MAAM,CAACS,KAAK,CAAC;IAAA,CAC7C,CAAC;IACDZ,MAAM,CAACa,gBAAgB,CAAC,OAAO,EAAEJ,OAAO,CAAC;EAC3C,CAAC,CAAC;AACJ","ignoreList":[]}
package/index.mjs CHANGED
@@ -2,6 +2,12 @@ export const newAbortError = () => new DOMException('This operation was aborted'
2
2
  const noop = () => {};
3
3
  export function abortable(promise, signal) {
4
4
  if (!signal) return promise;
5
+ if (signal.aborted) {
6
+ // prevent unhandled rejection
7
+ promise.catch(() => {});
8
+ // eslint-disable-next-line @typescript-eslint/prefer-promise-reject-errors
9
+ return Promise.reject(signal.reason);
10
+ }
5
11
  return new Promise((resolve, reject) => {
6
12
  const cleanup = () => {
7
13
  const callbacks = {
@@ -20,13 +26,9 @@ export function abortable(promise, signal) {
20
26
  signal.removeEventListener('abort', onAbort);
21
27
  return callbacks;
22
28
  };
23
- const onAbort = () => cleanup().reject(newAbortError());
29
+ const onAbort = () => cleanup().reject(signal.reason);
24
30
  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
- }
31
+ signal.addEventListener('abort', onAbort);
30
32
  });
31
33
  }
32
34
  //# 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","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":[]}
1
+ {"version":3,"file":"index.mjs","names":["newAbortError","DOMException","noop","abortable","promise","signal","aborted","catch","Promise","reject","reason","resolve","cleanup","callbacks","removeEventListener","onAbort","then","value","error","addEventListener"],"sources":["src/index.ts"],"sourcesContent":[null],"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,IAAIC,MAAM,CAACC,OAAO,EAAE;IAClB;IACAF,OAAO,CAACG,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC;IACvB;IACA,OAAOC,OAAO,CAACC,MAAM,CAACJ,MAAM,CAACK,MAAM,CAAC;EACtC;EACA,OAAO,IAAIF,OAAO,CAAI,CAACG,OAAO,EAAEF,MAAM,KAAK;IACzC,MAAMG,OAAO,GAAGA,CAAA,KAAM;MACpB,MAAMC,SAAS,GAAG;QAAEF,OAAO;QAAEF;MAAO,CAAC;MACrC;MACA;MACA;MACA;MACA;MACAE,OAAO,GAAGT,IAAI;MACdO,MAAM,GAAGP,IAAI;MACb;MACA;MACAG,MAAM,CAACS,mBAAmB,CAAC,OAAO,EAAEC,OAAO,CAAC;MAC5C,OAAOF,SAAS;IAClB,CAAC;IACD,MAAME,OAAO,GAAGA,CAAA,KAAMH,OAAO,CAAC,CAAC,CAACH,MAAM,CAACJ,MAAM,CAACK,MAAM,CAAC;IAErDN,OAAO,CAACY,IAAI,CACTC,KAAK,IAAKL,OAAO,CAAC,CAAC,CAACD,OAAO,CAACM,KAAK,CAAC,EAClCC,KAAc,IAAKN,OAAO,CAAC,CAAC,CAACH,MAAM,CAACS,KAAK,CAC5C,CAAC;IACDb,MAAM,CAACc,gBAAgB,CAAC,OAAO,EAAEJ,OAAO,CAAC;EAC3C,CAAC,CAAC;AACJ","ignoreList":[]}
package/package.json CHANGED
@@ -17,7 +17,7 @@
17
17
  "abort",
18
18
  "promise"
19
19
  ],
20
- "version": "1.0.2",
20
+ "version": "1.0.4",
21
21
  "sideEffects": false,
22
22
  "engines": {
23
23
  "node": ">=16"
@@ -28,14 +28,17 @@
28
28
  "exports": {
29
29
  "./package.json": "./package.json",
30
30
  ".": {
31
- "types": "./index.d.ts",
31
+ "types": {
32
+ "import": "./index.d.mts",
33
+ "default": "./index.d.ts"
34
+ },
32
35
  "import": "./index.mjs",
33
36
  "default": "./index.js"
34
37
  }
35
38
  },
36
- "packageManager": "pnpm@8.11.0",
39
+ "packageManager": "pnpm@10.6.5",
37
40
  "dependencies": {},
38
41
  "@jcoreio/toolchain": {
39
- "migratedVersion": "4.12.3"
42
+ "migratedVersion": "5.8.8"
40
43
  }
41
44
  }
package/src/index.ts CHANGED
@@ -8,6 +8,12 @@ export function abortable<T>(
8
8
  signal: AbortSignal | undefined
9
9
  ): Promise<T> {
10
10
  if (!signal) return promise
11
+ if (signal.aborted) {
12
+ // prevent unhandled rejection
13
+ promise.catch(() => {})
14
+ // eslint-disable-next-line @typescript-eslint/prefer-promise-reject-errors
15
+ return Promise.reject(signal.reason)
16
+ }
11
17
  return new Promise<T>((resolve, reject) => {
12
18
  const cleanup = () => {
13
19
  const callbacks = { resolve, reject }
@@ -23,16 +29,12 @@ export function abortable<T>(
23
29
  signal.removeEventListener('abort', onAbort)
24
30
  return callbacks
25
31
  }
26
- const onAbort = () => cleanup().reject(newAbortError())
32
+ const onAbort = () => cleanup().reject(signal.reason)
27
33
 
28
34
  promise.then(
29
35
  (value) => cleanup().resolve(value),
30
- (error) => cleanup().reject(error)
36
+ (error: unknown) => cleanup().reject(error)
31
37
  )
32
- if (signal.aborted) {
33
- reject(newAbortError())
34
- } else {
35
- signal.addEventListener('abort', onAbort)
36
- }
38
+ signal.addEventListener('abort', onAbort)
37
39
  })
38
40
  }