web-background 0.0.10 → 0.0.12

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/README.md CHANGED
@@ -9,8 +9,8 @@ In most cases, You don't have to use it
9
9
  Recommended for long task
10
10
  대부분의 경우 이 모듈을 사용할 필요는 없으나, long task를 처리해야 할 경우 사용할 것을 추천합니다.
11
11
 
12
- Most WebAPIs including DOM APIs are cannot be used Becuase they are run in Web Worker.
13
- WebWorker에서 실행되므로 DOM API를 포함한 대부분의 WebAPI를 사용하지 못합니다.
12
+ Most WebAPIs including DOM APIs are cannot be used.
13
+ DOM API를 포함한 대부분의 WebAPI를 사용하지 못합니다.
14
14
  [Read More](https://developer.mozilla.org/en-US/docs/Web/API/Web_Workers_API)
15
15
 
16
16
  ## Example
@@ -1,3 +1,3 @@
1
- type Result<Payload, ReturnValue> = Payload extends void ? () => ReturnValue : (payload: Payload) => ReturnValue;
2
- export declare function background<Payload = void, ReturnValue = void>(fn: (payload: Payload) => ReturnValue): Result<Payload, ReturnValue>;
1
+ type Result<Payload, ReturnValue> = Payload extends any[] ? (...payloads: Payload) => ReturnValue : (payload: Payload) => ReturnValue;
2
+ export declare function background<Payload extends any[], ReturnValue = void>(fn: (...payloads: Payload) => ReturnValue): Result<Payload, ReturnValue>;
3
3
  export {};
package/dist/index.js CHANGED
@@ -1,37 +1,3 @@
1
- class TypedWorker extends Worker {
2
- postMessage(payload) {
3
- super.postMessage(payload);
4
- }
5
- addEventListener(type, observer) {
6
- super.addEventListener(type, observer);
7
- }
8
- }
9
-
10
- class UtilWorker extends TypedWorker {
11
- constructor(scriptURL, options) {
12
- super(scriptURL, options);
13
- }
14
- subscribe(observer) {
15
- const onMessage = (event) => {
16
- observer(event.data);
17
- };
18
- this.addEventListener('message', onMessage);
19
- return () => {
20
- this.removeEventListener('message', onMessage);
21
- };
22
- }
23
- request(payload) {
24
- return new Promise(resolve => {
25
- const onMessage = ({ data }) => {
26
- resolve(data);
27
- this.removeEventListener('message', onMessage);
28
- };
29
- this.postMessage(payload);
30
- this.addEventListener('message', onMessage);
31
- });
32
- }
33
- }
34
-
35
1
  /******************************************************************************
36
2
  Copyright (c) Microsoft Corporation.
37
3
 
@@ -61,39 +27,98 @@ function __rest(s, e) {
61
27
  return t;
62
28
  }
63
29
 
30
+ function __awaiter(thisArg, _arguments, P, generator) {
31
+ function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
32
+ return new (P || (P = Promise))(function (resolve, reject) {
33
+ function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
34
+ function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
35
+ function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
36
+ step((generator = generator.apply(thisArg, _arguments || [])).next());
37
+ });
38
+ }
39
+
64
40
  typeof SuppressedError === "function" ? SuppressedError : function (error, suppressed, message) {
65
41
  var e = new Error(message);
66
42
  return e.name = "SuppressedError", e.error = error, e.suppressed = suppressed, e;
67
43
  };
68
44
 
45
+ class TypedWorker extends Worker {
46
+ postMessage(payload) {
47
+ super.postMessage(payload);
48
+ }
49
+ addEventListener(type, observer) {
50
+ super.addEventListener(type, observer);
51
+ }
52
+ }
53
+
54
+ class UtilWorker extends TypedWorker {
55
+ constructor(scriptURL, options) {
56
+ super(scriptURL, options);
57
+ }
58
+ subscribe(observer) {
59
+ const onMessage = (event) => {
60
+ observer(event.data);
61
+ };
62
+ this.addEventListener('message', onMessage);
63
+ return () => {
64
+ this.removeEventListener('message', onMessage);
65
+ };
66
+ }
67
+ request(...payloads) {
68
+ return new Promise(resolve => {
69
+ const onMessage = ({ data }) => {
70
+ resolve(data);
71
+ this.removeEventListener('message', onMessage);
72
+ };
73
+ this.postMessage(payloads);
74
+ this.addEventListener('message', onMessage);
75
+ });
76
+ }
77
+ }
78
+
69
79
  class WorkerBuilder {
70
80
  static fromModule(Worker, _a) {
71
81
  var { module } = _a, options = __rest(_a, ["module"]);
72
82
  const code = `
73
83
  self.addEventListener('message', event => {
74
- const result = (${module.toString()})(event.data);
84
+ const result = (${module.toString()})(${module.length > 1 ? '...event.data' : 'event.data'});
75
85
 
76
86
  self.postMessage(result);
77
87
  });
78
88
  `.trim();
79
89
  const blob = new Blob([code]);
80
- return new Worker(URL.createObjectURL(blob), options);
90
+ const url = URL.createObjectURL(blob);
91
+ const worker = new Worker(url, options);
92
+ const originTerminate = worker.terminate;
93
+ worker.terminate = () => {
94
+ originTerminate.call(worker);
95
+ URL.revokeObjectURL(url);
96
+ };
97
+ return worker;
81
98
  }
82
99
  }
83
100
 
101
+ const workerCleanupRegistry = new FinalizationRegistry((heldWorker) => heldWorker.terminate());
102
+
84
103
  function background(fn) {
85
104
  function createWorker() {
86
105
  return WorkerBuilder.fromModule((UtilWorker), { module: fn });
87
106
  }
88
107
  if (typeof window === 'undefined') {
89
- function runWithCreatingWorker(payload) {
90
- const worker = createWorker();
91
- return worker.request.call(worker, payload);
108
+ function runWithCreatingWorker(...payload) {
109
+ return __awaiter(this, void 0, void 0, function* () {
110
+ const worker = createWorker();
111
+ const result = yield worker.request.call(worker, ...payload);
112
+ worker.terminate();
113
+ return result;
114
+ });
92
115
  }
93
116
  return runWithCreatingWorker;
94
117
  }
95
118
  const worker = createWorker();
96
- return worker.request.bind(worker);
119
+ const result = worker.request.bind(worker);
120
+ workerCleanupRegistry.register(result, worker);
121
+ return result;
97
122
  }
98
123
 
99
124
  export { background };
@@ -2,6 +2,5 @@ import { TypedWorker } from "./TypedWorker";
2
2
  export declare class UtilWorker<Payload = never, Result = void> extends TypedWorker<Payload, Result> {
3
3
  constructor(scriptURL: string | URL, options?: WorkerOptions);
4
4
  subscribe(observer: (response: Result) => void): () => void;
5
- request(): Promise<Result>;
6
- request(payload: Payload): Promise<Result>;
5
+ request(...payloads: Payload[]): Promise<Result>;
7
6
  }
@@ -0,0 +1 @@
1
+ export declare const workerCleanupRegistry: FinalizationRegistry<Worker>;
package/package.json CHANGED
@@ -7,7 +7,7 @@
7
7
  "Background",
8
8
  "Web Background"
9
9
  ],
10
- "version": "0.0.10",
10
+ "version": "0.0.12",
11
11
  "main": "dist/index.js",
12
12
  "module": "dist/index.js",
13
13
  "type": "module",