emsdk-env 0.1.0

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/LICENSE ADDED
@@ -0,0 +1,21 @@
1
+ MIT License
2
+
3
+ Copyright (c) Kouji Matsui (@kekyo@mi.kekyo.net)
4
+
5
+ Permission is hereby granted, free of charge, to any person obtaining a copy
6
+ of this software and associated documentation files (the "Software"), to deal
7
+ in the Software without restriction, including without limitation the rights
8
+ to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
9
+ copies of the Software, and to permit persons to whom the Software is
10
+ furnished to do so, subject to the following conditions:
11
+
12
+ The above copyright notice and this permission notice shall be included in all
13
+ copies or substantial portions of the Software.
14
+
15
+ THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16
+ IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17
+ FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
18
+ AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19
+ LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
20
+ OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
21
+ SOFTWARE.
package/README.md ADDED
@@ -0,0 +1,11 @@
1
+ # emsdk-env
2
+
3
+ TODO:
4
+
5
+ ## What is this?
6
+
7
+ TODO:
8
+
9
+ ## License
10
+
11
+ Under MIT.
package/dist/index.cjs ADDED
@@ -0,0 +1,309 @@
1
+ /*!
2
+ * name: emsdk-env
3
+ * version: 0.1.0
4
+ * description: Emscripten environment builder
5
+ * author: Kouji Matsui (@kekyo@mi.kekyo.net)
6
+ * license: MIT
7
+ * repository.url: https://github.com/kekyo/emsdk-env
8
+ * git.commit.hash: 32f73259bc38b9fcc19c26f3012f0b87c28963e4
9
+ */
10
+
11
+ "use strict";
12
+ Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
13
+ const child_process = require("child_process");
14
+ const promises = require("fs/promises");
15
+ const os = require("os");
16
+ const path = require("path");
17
+ const simpleGit = require("simple-git");
18
+ const __NOOP_HANDLER = () => {
19
+ };
20
+ const __NOOP_RELEASABLE = {
21
+ release: __NOOP_HANDLER,
22
+ [Symbol.dispose]: __NOOP_HANDLER
23
+ };
24
+ const toAbortError = (reason) => {
25
+ if (reason instanceof Error) {
26
+ return reason;
27
+ }
28
+ if (typeof reason === "string") {
29
+ return new Error(reason);
30
+ }
31
+ return new Error("Operation aborted");
32
+ };
33
+ const onAbort = (signal, callback) => {
34
+ if (!signal) {
35
+ return __NOOP_RELEASABLE;
36
+ }
37
+ if (signal.aborted) {
38
+ try {
39
+ callback(toAbortError(signal.reason));
40
+ } catch (error) {
41
+ console.warn("AbortHook callback error: ", error);
42
+ }
43
+ return __NOOP_RELEASABLE;
44
+ }
45
+ let abortHandler;
46
+ abortHandler = () => {
47
+ if (abortHandler) {
48
+ const reason = signal.reason;
49
+ signal.removeEventListener("abort", abortHandler);
50
+ abortHandler = void 0;
51
+ try {
52
+ callback(toAbortError(reason));
53
+ } catch (error) {
54
+ console.warn("AbortHook callback error: ", error);
55
+ }
56
+ }
57
+ };
58
+ const release = () => {
59
+ if (abortHandler) {
60
+ signal.removeEventListener("abort", abortHandler);
61
+ abortHandler = void 0;
62
+ }
63
+ };
64
+ signal.addEventListener("abort", abortHandler, { once: true });
65
+ const handle = {
66
+ release,
67
+ [Symbol.dispose]: release
68
+ };
69
+ return handle;
70
+ };
71
+ const defer = (fn) => {
72
+ if (typeof setImmediate === "function") {
73
+ setImmediate(fn);
74
+ } else {
75
+ setTimeout(fn, 0);
76
+ }
77
+ };
78
+ const ABORTED_ERROR$2 = () => new Error("Lock acquisition was aborted");
79
+ const createLockHandle = (releaseCallback) => {
80
+ let isActive = true;
81
+ const release = () => {
82
+ if (!isActive) {
83
+ return;
84
+ }
85
+ isActive = false;
86
+ releaseCallback();
87
+ };
88
+ return {
89
+ get isActive() {
90
+ return isActive;
91
+ },
92
+ release,
93
+ [Symbol.dispose]: release
94
+ };
95
+ };
96
+ const createMutex = (maxConsecutiveCalls = 20) => {
97
+ let isLocked = false;
98
+ const queue = [];
99
+ let count = 0;
100
+ const processQueue = () => {
101
+ var _a;
102
+ if (isLocked || queue.length === 0) {
103
+ return;
104
+ }
105
+ const item = queue.shift();
106
+ if ((_a = item.signal) == null ? void 0 : _a.aborted) {
107
+ item.reject(ABORTED_ERROR$2());
108
+ scheduleNextProcess();
109
+ return;
110
+ }
111
+ isLocked = true;
112
+ const lockHandle = createLockHandle(releaseLock);
113
+ item.resolve(lockHandle);
114
+ };
115
+ const scheduleNextProcess = () => {
116
+ count++;
117
+ if (count >= maxConsecutiveCalls) {
118
+ count = 0;
119
+ defer(processQueue);
120
+ } else {
121
+ processQueue();
122
+ }
123
+ };
124
+ const releaseLock = () => {
125
+ if (!isLocked) {
126
+ return;
127
+ }
128
+ isLocked = false;
129
+ scheduleNextProcess();
130
+ };
131
+ const removeFromQueue = (item) => {
132
+ const index = queue.indexOf(item);
133
+ if (index !== -1) {
134
+ queue.splice(index, 1);
135
+ }
136
+ };
137
+ const lock = async (signal) => {
138
+ if (signal) {
139
+ if (signal.aborted) {
140
+ throw ABORTED_ERROR$2();
141
+ }
142
+ return new Promise((resolve, reject) => {
143
+ const queueItem = {
144
+ resolve: void 0,
145
+ reject: void 0,
146
+ signal
147
+ };
148
+ const abortHandle = onAbort(signal, () => {
149
+ removeFromQueue(queueItem);
150
+ reject(ABORTED_ERROR$2());
151
+ });
152
+ queueItem.resolve = (handle) => {
153
+ abortHandle.release();
154
+ resolve(handle);
155
+ };
156
+ queueItem.reject = (error) => {
157
+ abortHandle.release();
158
+ reject(error);
159
+ };
160
+ queue.push(queueItem);
161
+ processQueue();
162
+ });
163
+ } else {
164
+ return new Promise((resolve, reject) => {
165
+ queue.push({
166
+ resolve,
167
+ reject
168
+ });
169
+ processQueue();
170
+ });
171
+ }
172
+ };
173
+ const result = {
174
+ lock,
175
+ waiter: {
176
+ wait: lock
177
+ },
178
+ get isLocked() {
179
+ return isLocked;
180
+ },
181
+ get pendingCount() {
182
+ return queue.length;
183
+ }
184
+ };
185
+ return result;
186
+ };
187
+ const DEFAULT_REPO_URL = "https://github.com/emscripten-core/emsdk.git";
188
+ const DEFAULT_GIT_REF = "main";
189
+ const DEFAULT_CACHE_DIR = path.join(os.homedir(), ".cache", "emsdk-env");
190
+ const versionMutexes = /* @__PURE__ */ new Map();
191
+ const getVersionMutex = (key) => {
192
+ let mutex = versionMutexes.get(key);
193
+ if (!mutex) {
194
+ mutex = createMutex();
195
+ versionMutexes.set(key, mutex);
196
+ }
197
+ return mutex;
198
+ };
199
+ const ensureNonEmpty = (value, label) => {
200
+ if (value.trim().length === 0) {
201
+ throw new TypeError(`${label} must be a non-empty string.`);
202
+ }
203
+ };
204
+ const sanitizeSegment = (value) => {
205
+ const trimmed = value.trim();
206
+ ensureNonEmpty(trimmed, "targetVersion");
207
+ const sanitized = trimmed.replace(/[^A-Za-z0-9._-]/g, "_");
208
+ if (sanitized === "." || sanitized === ".." || sanitized.length === 0) {
209
+ throw new TypeError("targetVersion results in an unsafe path segment.");
210
+ }
211
+ return sanitized;
212
+ };
213
+ const pathExists = async (targetPath) => {
214
+ try {
215
+ await promises.access(targetPath, promises.constants.F_OK);
216
+ return true;
217
+ } catch (e) {
218
+ return false;
219
+ }
220
+ };
221
+ const runCommand = async (command, args, cwd) => new Promise((resolvePromise, rejectPromise) => {
222
+ const child = child_process.spawn(command, args, {
223
+ cwd,
224
+ stdio: "inherit"
225
+ });
226
+ child.once("error", (error) => {
227
+ rejectPromise(error);
228
+ });
229
+ child.once("close", (code) => {
230
+ if (code === 0) {
231
+ resolvePromise();
232
+ return;
233
+ }
234
+ rejectPromise(
235
+ new Error(
236
+ `Command failed: ${command} ${args.join(" ")} (exit code ${code})`
237
+ )
238
+ );
239
+ });
240
+ });
241
+ const resolveEmsdkCommand = () => process.platform === "win32" ? "emsdk.bat" : "./emsdk";
242
+ const createGitClient = (baseDir, gitPath) => simpleGit.simpleGit({
243
+ baseDir,
244
+ binary: gitPath
245
+ });
246
+ const runEmsdk = async (repoDir, args) => {
247
+ if (process.platform === "win32") {
248
+ await runCommand("cmd", ["/c", "emsdk.bat", ...args], repoDir);
249
+ return;
250
+ }
251
+ await runCommand(resolveEmsdkCommand(), args, repoDir);
252
+ };
253
+ const ensureDirectory = async (targetPath) => {
254
+ await promises.mkdir(targetPath, { recursive: true });
255
+ };
256
+ const isAlreadyExistsError = (error) => error instanceof Error && "code" in error && error.code !== void 0 && ["EEXIST", "ENOTEMPTY", "EISDIR"].includes(
257
+ String(error.code)
258
+ );
259
+ const prepareEmsdk = async (options) => {
260
+ var _a, _b, _c;
261
+ if (!options) {
262
+ throw new TypeError("options must be provided.");
263
+ }
264
+ if (typeof options.targetVersion !== "string") {
265
+ throw new TypeError("targetVersion must be a string.");
266
+ }
267
+ ensureNonEmpty(options.targetVersion, "targetVersion");
268
+ const cacheDir = path.resolve((_a = options.cacheDir) != null ? _a : DEFAULT_CACHE_DIR);
269
+ const repoUrl = (_b = options.repoUrl) != null ? _b : DEFAULT_REPO_URL;
270
+ const gitPath = (_c = options.gitPath) != null ? _c : "git";
271
+ const versionDir = sanitizeSegment(options.targetVersion);
272
+ const finalDir = path.resolve(cacheDir, versionDir);
273
+ const mutex = getVersionMutex(finalDir);
274
+ const lock = await mutex.lock();
275
+ try {
276
+ if (await pathExists(finalDir)) {
277
+ return finalDir;
278
+ }
279
+ await ensureDirectory(cacheDir);
280
+ const tempRoot = await promises.mkdtemp(path.join(cacheDir, ".tmp-"));
281
+ const tempRepoDir = path.join(tempRoot, "emsdk");
282
+ try {
283
+ const git = createGitClient(cacheDir, gitPath);
284
+ await git.clone(repoUrl, tempRepoDir, [
285
+ "--depth",
286
+ "1",
287
+ "--branch",
288
+ DEFAULT_GIT_REF
289
+ ]);
290
+ await runEmsdk(tempRepoDir, ["install", options.targetVersion]);
291
+ try {
292
+ await promises.rename(tempRepoDir, finalDir);
293
+ } catch (error) {
294
+ if (isAlreadyExistsError(error)) {
295
+ return finalDir;
296
+ }
297
+ throw error;
298
+ }
299
+ } finally {
300
+ await promises.rm(tempRoot, { recursive: true, force: true });
301
+ }
302
+ await runEmsdk(finalDir, ["activate", options.targetVersion]);
303
+ return finalDir;
304
+ } finally {
305
+ lock.release();
306
+ }
307
+ };
308
+ exports.prepareEmsdk = prepareEmsdk;
309
+ //# sourceMappingURL=index.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.cjs","sources":["../node_modules/async-primitives/dist/index.mjs","../src/index.ts"],"sourcesContent":["/*!\n * name: async-primitives\n * version: 1.5.0\n * description: A collection of primitive functions for asynchronous operations\n * author: Kouji Matsui (@kekyo@mi.kekyo.net)\n * license: MIT\n * repository.url: https://github.com/kekyo/async-primitives.git\n * git.commit.hash: cd35465b7e9b9945049186e7eaeecc0bfba65766\n */\nconst __NOOP_HANDLER = () => {\n};\nconst __NOOP_RELEASABLE = {\n release: __NOOP_HANDLER,\n [Symbol.dispose]: __NOOP_HANDLER\n};\nconst toAbortError = (reason) => {\n if (reason instanceof Error) {\n return reason;\n }\n if (typeof reason === \"string\") {\n return new Error(reason);\n }\n return new Error(\"Operation aborted\");\n};\nconst onAbort = (signal, callback) => {\n if (!signal) {\n return __NOOP_RELEASABLE;\n }\n if (signal.aborted) {\n try {\n callback(toAbortError(signal.reason));\n } catch (error) {\n console.warn(\"AbortHook callback error: \", error);\n }\n return __NOOP_RELEASABLE;\n }\n let abortHandler;\n abortHandler = () => {\n if (abortHandler) {\n const reason = signal.reason;\n signal.removeEventListener(\"abort\", abortHandler);\n abortHandler = void 0;\n try {\n callback(toAbortError(reason));\n } catch (error) {\n console.warn(\"AbortHook callback error: \", error);\n }\n }\n };\n const release = () => {\n if (abortHandler) {\n signal.removeEventListener(\"abort\", abortHandler);\n abortHandler = void 0;\n }\n };\n signal.addEventListener(\"abort\", abortHandler, { once: true });\n const handle = {\n release,\n [Symbol.dispose]: release\n };\n return handle;\n};\nconst delay = (msec, signal) => {\n if (signal) {\n if (signal.aborted) {\n throw new Error(\"Delay was aborted\");\n }\n return new Promise((resolve, reject) => {\n const abortHandle = onAbort(signal, () => {\n clearTimeout(timeoutId);\n reject(new Error(\"Delay was aborted\"));\n });\n const timeoutId = setTimeout(() => {\n abortHandle.release();\n resolve();\n }, msec);\n });\n } else {\n return new Promise((resolve) => {\n setTimeout(resolve, msec);\n });\n }\n};\nconst defer = (fn) => {\n if (typeof setImmediate === \"function\") {\n setImmediate(fn);\n } else {\n setTimeout(fn, 0);\n }\n};\nconst ABORTED_ERROR$2 = () => new Error(\"Lock acquisition was aborted\");\nconst createLockHandle = (releaseCallback) => {\n let isActive = true;\n const release = () => {\n if (!isActive) {\n return;\n }\n isActive = false;\n releaseCallback();\n };\n return {\n get isActive() {\n return isActive;\n },\n release,\n [Symbol.dispose]: release\n };\n};\nconst createMutex = (maxConsecutiveCalls = 20) => {\n let isLocked = false;\n const queue = [];\n let count = 0;\n const processQueue = () => {\n var _a;\n if (isLocked || queue.length === 0) {\n return;\n }\n const item = queue.shift();\n if ((_a = item.signal) == null ? void 0 : _a.aborted) {\n item.reject(ABORTED_ERROR$2());\n scheduleNextProcess();\n return;\n }\n isLocked = true;\n const lockHandle = createLockHandle(releaseLock);\n item.resolve(lockHandle);\n };\n const scheduleNextProcess = () => {\n count++;\n if (count >= maxConsecutiveCalls) {\n count = 0;\n defer(processQueue);\n } else {\n processQueue();\n }\n };\n const releaseLock = () => {\n if (!isLocked) {\n return;\n }\n isLocked = false;\n scheduleNextProcess();\n };\n const removeFromQueue = (item) => {\n const index = queue.indexOf(item);\n if (index !== -1) {\n queue.splice(index, 1);\n }\n };\n const lock = async (signal) => {\n if (signal) {\n if (signal.aborted) {\n throw ABORTED_ERROR$2();\n }\n return new Promise((resolve, reject) => {\n const queueItem = {\n resolve: void 0,\n reject: void 0,\n signal\n };\n const abortHandle = onAbort(signal, () => {\n removeFromQueue(queueItem);\n reject(ABORTED_ERROR$2());\n });\n queueItem.resolve = (handle) => {\n abortHandle.release();\n resolve(handle);\n };\n queueItem.reject = (error) => {\n abortHandle.release();\n reject(error);\n };\n queue.push(queueItem);\n processQueue();\n });\n } else {\n return new Promise((resolve, reject) => {\n queue.push({\n resolve,\n reject\n });\n processQueue();\n });\n }\n };\n const result = {\n lock,\n waiter: {\n wait: lock\n },\n get isLocked() {\n return isLocked;\n },\n get pendingCount() {\n return queue.length;\n }\n };\n return result;\n};\nconst createDeferred = (signal) => {\n let resolve;\n let reject;\n const promise = new Promise((res, rej) => {\n resolve = res;\n reject = rej;\n });\n const disposer = onAbort(signal, () => {\n const _reject = reject;\n if (_reject) {\n resolve = void 0;\n reject = void 0;\n _reject(new Error(\"Deferred aborted\"));\n }\n });\n return {\n // The promise that resolves to the result\n promise,\n // Resolve the promise with a result\n resolve: (value) => {\n const _resolve = resolve;\n if (_resolve) {\n resolve = void 0;\n reject = void 0;\n disposer.release();\n _resolve(value);\n }\n },\n // Reject the promise with an error\n reject: (error) => {\n const _reject = reject;\n if (_reject) {\n resolve = void 0;\n reject = void 0;\n disposer.release();\n _reject(error);\n }\n }\n };\n};\nconst __NOOP_DUMMY_HANDLE = {\n get isActive() {\n return false;\n },\n release: __NOOP_HANDLER,\n [Symbol.dispose]: __NOOP_HANDLER\n};\nconst createConditional = () => {\n const waiters = [];\n const trigger = () => {\n if (waiters.length >= 1) {\n waiters.shift().resolve();\n }\n };\n const wait = async (signal) => {\n if (signal == null ? void 0 : signal.aborted) {\n throw new Error(\"Conditional aborted\");\n }\n const waiter = createDeferred();\n waiters.push(waiter);\n const disposer = onAbort(signal, () => {\n waiters.splice(waiters.indexOf(waiter), 1);\n waiter.reject(new Error(\"Conditional aborted\"));\n });\n try {\n await waiter.promise;\n } finally {\n disposer.release();\n }\n return __NOOP_DUMMY_HANDLE;\n };\n const result = {\n trigger,\n wait,\n waiter: {\n wait\n }\n };\n return result;\n};\nconst createManuallyConditional = (initialState) => {\n const waiters = [];\n let raised = initialState != null ? initialState : false;\n const trigger = () => {\n raised = false;\n const waiter = waiters.shift();\n if (waiter) {\n waiter.resolve();\n raised = false;\n }\n };\n const raise = () => {\n while (waiters.length >= 1) {\n raised = true;\n waiters.shift().resolve();\n }\n raised = true;\n };\n const drop = () => {\n raised = false;\n };\n const wait = async (signal) => {\n if (raised) {\n return __NOOP_DUMMY_HANDLE;\n }\n if (signal == null ? void 0 : signal.aborted) {\n throw new Error(\"Conditional aborted\");\n }\n const waiter = createDeferred();\n waiters.push(waiter);\n const disposer = onAbort(signal, () => {\n waiters.splice(waiters.indexOf(waiter), 1);\n waiter.reject(new Error(\"Conditional aborted\"));\n });\n try {\n await waiter.promise;\n } finally {\n disposer.release();\n }\n return __NOOP_DUMMY_HANDLE;\n };\n const result = {\n trigger,\n raise,\n drop,\n wait,\n waiter: {\n wait\n }\n };\n return result;\n};\nconst createDeferredGenerator = (options) => {\n const maxItemReserved = options == null ? void 0 : options.maxItemReserved;\n const signal = options == null ? void 0 : options.signal;\n const queue = [];\n const arrived = createManuallyConditional();\n const canReserve = maxItemReserved ? createManuallyConditional(true) : void 0;\n const generator = (async function* () {\n while (true) {\n while (true) {\n const item = queue.shift();\n if (maxItemReserved && queue.length === maxItemReserved - 1) {\n canReserve.raise();\n }\n if (!item) {\n break;\n }\n switch (item.kind) {\n // Yield return a value\n case \"value\":\n yield item.value;\n break;\n // Completed, exit the generator\n case \"completed\":\n return;\n // Error, throw an error\n case \"error\":\n throw item.error;\n }\n if (signal == null ? void 0 : signal.aborted) {\n throw new Error(\"Deferred generator aborted\");\n }\n }\n arrived.drop();\n try {\n await arrived.wait(signal);\n } catch (error) {\n if (error instanceof Error && error.message === \"Conditional aborted\") {\n error.message = \"Deferred generator aborted\";\n }\n throw error;\n }\n }\n })();\n const enqueue = async (item, signal2) => {\n while (true) {\n if (!maxItemReserved || queue.length < maxItemReserved) {\n const remains = queue.push(item);\n if (remains === 1) {\n arrived.raise();\n }\n if (remains === maxItemReserved) {\n canReserve.drop();\n }\n break;\n }\n try {\n await canReserve.wait(signal2);\n } catch (error) {\n if (error instanceof Error && error.message === \"Conditional aborted\") {\n error.message = \"Deferred generator aborted\";\n }\n throw error;\n }\n }\n };\n return {\n // The async generator that yields values\n generator,\n // Yield a value to the generator\n yield: (value, signal2) => enqueue({ kind: \"value\", value }, signal2),\n // Complete the generator (equivalent to return)\n return: (signal2) => enqueue({ kind: \"completed\" }, signal2),\n // Throw an error to the generator\n throw: (error, signal2) => enqueue({ kind: \"error\", error }, signal2)\n };\n};\nconst createLogicalContext = (id) => {\n return { id, data: /* @__PURE__ */ new Map() };\n};\nlet currentLogicalContext = createLogicalContext(Symbol(\"[root]\"));\nconst setCurrentLogicalContext = (context) => {\n currentLogicalContext = context;\n};\nconst trampoline = (adjustment, callback, thisArg, ...args) => {\n const previousLogicalContext = currentLogicalContext;\n currentLogicalContext = adjustment.contextToUse;\n try {\n return callback.call(thisArg, ...args);\n } finally {\n adjustment.contextAfter = currentLogicalContext;\n currentLogicalContext = previousLogicalContext;\n }\n};\nlet isPrepared = false;\nconst prepare = () => {\n if (isPrepared) {\n return;\n }\n isPrepared = true;\n if (typeof globalThis.setTimeout !== \"undefined\") {\n const __setTimeout = globalThis.setTimeout;\n globalThis.setTimeout = ((handler, timeout, ...args) => {\n const capturedLogicalContext = currentLogicalContext;\n return __setTimeout(\n (...args2) => {\n const adjustment = {\n contextToUse: capturedLogicalContext\n };\n trampoline(adjustment, handler, void 0, ...args2);\n },\n timeout,\n ...args\n );\n });\n }\n if (typeof globalThis.setInterval !== \"undefined\") {\n const __setInterval = globalThis.setInterval;\n globalThis.setInterval = ((handler, timeout, ...args) => {\n const capturedLogicalContext = currentLogicalContext;\n return __setInterval(\n (...args2) => {\n const adjustment = {\n contextToUse: capturedLogicalContext\n };\n trampoline(adjustment, handler, void 0, ...args2);\n },\n timeout,\n ...args\n );\n });\n }\n if (typeof globalThis.queueMicrotask !== \"undefined\") {\n const __queueMicrotask = globalThis.queueMicrotask;\n globalThis.queueMicrotask = (callback) => {\n const capturedLogicalContext = currentLogicalContext;\n return __queueMicrotask(() => {\n const adjustment = {\n contextToUse: capturedLogicalContext\n };\n trampoline(adjustment, callback, void 0);\n });\n };\n }\n if (typeof globalThis.setImmediate !== \"undefined\") {\n const __setImmediate = globalThis.setImmediate;\n globalThis.setImmediate = ((callback, ...args) => {\n const capturedLogicalContext = currentLogicalContext;\n return __setImmediate(\n (...callbackArgs) => {\n const adjustment = {\n contextToUse: capturedLogicalContext\n };\n trampoline(adjustment, callback, void 0, ...callbackArgs);\n },\n ...args\n );\n });\n }\n if (typeof process !== \"undefined\" && process.nextTick) {\n const __nextTick = process.nextTick;\n process.nextTick = (callback, ...args) => {\n const capturedLogicalContext = currentLogicalContext;\n return __nextTick(() => {\n const adjustment = {\n contextToUse: capturedLogicalContext\n };\n trampoline(adjustment, callback, void 0, ...args);\n });\n };\n }\n if (typeof Promise !== \"undefined\") {\n const __then = Promise.prototype.then;\n const __catch = Promise.prototype.catch;\n const __finally = Promise.prototype.finally;\n Promise.prototype.then = function(onFulfilled, onRejected) {\n const capturedLogicalContext = currentLogicalContext;\n const resultPromise = __then.call(\n this,\n onFulfilled ? (value) => {\n const adjustment = {\n contextToUse: capturedLogicalContext\n };\n return trampoline(adjustment, onFulfilled, void 0, value);\n } : void 0,\n onRejected ? (reason) => {\n const adjustment = {\n contextToUse: capturedLogicalContext\n };\n return trampoline(adjustment, onRejected, void 0, reason);\n } : void 0\n );\n return resultPromise;\n };\n Promise.prototype.catch = function(onRejected) {\n const capturedLogicalContext = currentLogicalContext;\n const resultPromise = __catch.call(\n this,\n onRejected ? (reason) => {\n const adjustment = {\n contextToUse: capturedLogicalContext\n };\n return trampoline(adjustment, onRejected, void 0, reason);\n } : void 0\n );\n return resultPromise;\n };\n Promise.prototype.finally = function(onFinally) {\n const capturedLogicalContext = currentLogicalContext;\n const resultPromise = __finally.call(\n this,\n onFinally ? () => {\n const adjustment = {\n contextToUse: capturedLogicalContext\n };\n return trampoline(adjustment, onFinally, void 0);\n } : void 0\n );\n return resultPromise;\n };\n }\n if (typeof EventTarget !== \"undefined\" && EventTarget.prototype && EventTarget.prototype.addEventListener) {\n const __eventTargetAddEventListener = EventTarget.prototype.addEventListener;\n EventTarget.prototype.addEventListener = function(type, listener, options) {\n if (listener === null || listener === void 0) {\n return __eventTargetAddEventListener.call(\n this,\n type,\n listener,\n options\n );\n }\n if (typeof listener === \"function\") {\n const capturedLogicalContext = currentLogicalContext;\n const wrappedListener = (event) => {\n const adjustment = {\n contextToUse: capturedLogicalContext\n };\n return trampoline(adjustment, listener, event.currentTarget, event);\n };\n return __eventTargetAddEventListener.call(\n this,\n type,\n wrappedListener,\n options\n );\n } else if (typeof listener === \"object\" && \"handleEvent\" in listener) {\n const capturedLogicalContext = currentLogicalContext;\n const wrappedListener = {\n handleEvent: (event) => {\n const adjustment = {\n contextToUse: capturedLogicalContext\n };\n return trampoline(adjustment, () => listener.handleEvent(event));\n }\n };\n return __eventTargetAddEventListener.call(\n this,\n type,\n wrappedListener,\n options\n );\n }\n return __eventTargetAddEventListener.call(\n this,\n type,\n listener,\n options\n );\n };\n }\n if (typeof Element !== \"undefined\" && Element.prototype && Element.prototype.addEventListener) {\n const __elementAddEventListener = Element.prototype.addEventListener;\n Element.prototype.addEventListener = function(type, listener, options) {\n if (listener === null || listener === void 0) {\n return __elementAddEventListener.call(\n this,\n type,\n listener,\n options\n );\n }\n if (typeof listener === \"function\") {\n const capturedLogicalContext = currentLogicalContext;\n const wrappedListener = (event) => {\n const adjustment = {\n contextToUse: capturedLogicalContext\n };\n return trampoline(adjustment, listener, event.currentTarget, event);\n };\n return __elementAddEventListener.call(\n this,\n type,\n wrappedListener,\n options\n );\n } else if (typeof listener === \"object\" && \"handleEvent\" in listener) {\n const capturedLogicalContext = currentLogicalContext;\n const wrappedListener = {\n handleEvent: (event) => {\n const adjustment = {\n contextToUse: capturedLogicalContext\n };\n return trampoline(adjustment, () => listener.handleEvent(event));\n }\n };\n return __elementAddEventListener.call(\n this,\n type,\n wrappedListener,\n options\n );\n }\n return __elementAddEventListener.call(\n this,\n type,\n listener,\n options\n );\n };\n }\n if (typeof globalThis.requestAnimationFrame !== \"undefined\") {\n const __requestAnimationFrame = globalThis.requestAnimationFrame;\n globalThis.requestAnimationFrame = (callback) => {\n const capturedLogicalContext = currentLogicalContext;\n return __requestAnimationFrame((time) => {\n const adjustment = {\n contextToUse: capturedLogicalContext\n };\n return trampoline(adjustment, callback, void 0, time);\n });\n };\n }\n if (typeof globalThis.XMLHttpRequest !== \"undefined\") {\n const __XMLHttpRequest = globalThis.XMLHttpRequest;\n globalThis.XMLHttpRequest = class extends __XMLHttpRequest {\n constructor() {\n super();\n this._userHandlers = /* @__PURE__ */ new Map();\n const eventHandlerProperties = [\n \"onreadystatechange\",\n \"onloadstart\",\n \"onprogress\",\n \"onabort\",\n \"onerror\",\n \"onload\",\n \"ontimeout\",\n \"onloadend\"\n ];\n eventHandlerProperties.forEach((prop) => {\n Object.defineProperty(this, prop, {\n get: () => this._userHandlers.get(prop) || null,\n set: (newHandler) => {\n this._userHandlers.set(prop, newHandler);\n if (newHandler && typeof newHandler === \"function\") {\n const capturedLogicalContext = currentLogicalContext;\n const wrappedHandler = function(event) {\n const adjustment = {\n contextToUse: capturedLogicalContext\n };\n return trampoline(adjustment, newHandler, this, event);\n };\n const parentProto = Object.getPrototypeOf(\n Object.getPrototypeOf(this)\n );\n const descriptor = Object.getOwnPropertyDescriptor(\n parentProto,\n prop\n );\n if (descriptor && descriptor.set) {\n descriptor.set.call(this, wrappedHandler);\n } else {\n this[`_${prop}`] = wrappedHandler;\n }\n } else {\n const parentProto = Object.getPrototypeOf(\n Object.getPrototypeOf(this)\n );\n const descriptor = Object.getOwnPropertyDescriptor(\n parentProto,\n prop\n );\n if (descriptor && descriptor.set) {\n descriptor.set.call(this, null);\n } else {\n this[`_${prop}`] = null;\n }\n }\n },\n configurable: true,\n enumerable: true\n });\n });\n }\n addEventListener(type, listener, options) {\n const capturedLogicalContext = currentLogicalContext;\n if (!listener) {\n return super.addEventListener(type, listener, options);\n }\n if (typeof listener === \"function\") {\n const wrappedListener = (event) => {\n const adjustment = {\n contextToUse: capturedLogicalContext\n };\n return trampoline(adjustment, listener, event.currentTarget, event);\n };\n return super.addEventListener(type, wrappedListener, options);\n } else if (typeof listener === \"object\" && \"handleEvent\" in listener) {\n const wrappedListener = {\n handleEvent: (event) => {\n const adjustment = {\n contextToUse: capturedLogicalContext\n };\n return trampoline(adjustment, () => listener.handleEvent(event));\n }\n };\n return super.addEventListener(type, wrappedListener, options);\n }\n return super.addEventListener(type, listener, options);\n }\n };\n }\n if (typeof globalThis.WebSocket !== \"undefined\") {\n const __WebSocket = globalThis.WebSocket;\n globalThis.WebSocket = class extends __WebSocket {\n constructor(url, protocols) {\n super(url, protocols);\n this._userHandlers = /* @__PURE__ */ new Map();\n const eventHandlerProperties = [\n \"onopen\",\n \"onmessage\",\n \"onerror\",\n \"onclose\"\n ];\n eventHandlerProperties.forEach((prop) => {\n Object.defineProperty(this, prop, {\n get: () => this._userHandlers.get(prop) || null,\n set: (newHandler) => {\n this._userHandlers.set(prop, newHandler);\n if (newHandler && typeof newHandler === \"function\") {\n const capturedLogicalContext = currentLogicalContext;\n const wrappedHandler = function(event) {\n const adjustment = {\n contextToUse: capturedLogicalContext\n };\n return trampoline(adjustment, newHandler, this, event);\n };\n const parentProto = Object.getPrototypeOf(\n Object.getPrototypeOf(this)\n );\n const descriptor = Object.getOwnPropertyDescriptor(\n parentProto,\n prop\n );\n if (descriptor && descriptor.set) {\n descriptor.set.call(this, wrappedHandler);\n } else {\n this[`_${prop}`] = wrappedHandler;\n }\n } else {\n const parentProto = Object.getPrototypeOf(\n Object.getPrototypeOf(this)\n );\n const descriptor = Object.getOwnPropertyDescriptor(\n parentProto,\n prop\n );\n if (descriptor && descriptor.set) {\n descriptor.set.call(this, null);\n } else {\n this[`_${prop}`] = null;\n }\n }\n },\n configurable: true,\n enumerable: true\n });\n });\n }\n addEventListener(type, listener, options) {\n const capturedLogicalContext = currentLogicalContext;\n if (!listener) {\n return super.addEventListener(type, listener, options);\n }\n if (typeof listener === \"function\") {\n const wrappedListener = (event) => {\n const adjustment = {\n contextToUse: capturedLogicalContext\n };\n return trampoline(adjustment, listener, event.currentTarget, event);\n };\n return super.addEventListener(type, wrappedListener, options);\n } else if (typeof listener === \"object\" && \"handleEvent\" in listener) {\n const wrappedListener = {\n handleEvent: (event) => {\n const adjustment = {\n contextToUse: capturedLogicalContext\n };\n return trampoline(adjustment, () => listener.handleEvent(event));\n }\n };\n return super.addEventListener(type, wrappedListener, options);\n }\n return super.addEventListener(type, listener, options);\n }\n };\n }\n if (typeof globalThis.MutationObserver !== \"undefined\") {\n const __MutationObserver = globalThis.MutationObserver;\n globalThis.MutationObserver = class extends __MutationObserver {\n constructor(callback) {\n const capturedLogicalContext = currentLogicalContext;\n const wrappedCallback = (mutations, observer) => {\n const adjustment = {\n contextToUse: capturedLogicalContext\n };\n return trampoline(\n adjustment,\n callback,\n void 0,\n mutations,\n observer\n );\n };\n super(wrappedCallback);\n }\n };\n }\n if (typeof globalThis.ResizeObserver !== \"undefined\") {\n const __ResizeObserver = globalThis.ResizeObserver;\n globalThis.ResizeObserver = class extends __ResizeObserver {\n constructor(callback) {\n const capturedLogicalContext = currentLogicalContext;\n const wrappedCallback = (entries, observer) => {\n const adjustment = {\n contextToUse: capturedLogicalContext\n };\n return trampoline(adjustment, callback, void 0, entries, observer);\n };\n super(wrappedCallback);\n }\n };\n }\n if (typeof globalThis.IntersectionObserver !== \"undefined\") {\n const __IntersectionObserver = globalThis.IntersectionObserver;\n globalThis.IntersectionObserver = class extends __IntersectionObserver {\n constructor(callback, options) {\n const capturedLogicalContext = currentLogicalContext;\n const wrappedCallback = (entries, observer) => {\n const adjustment = {\n contextToUse: capturedLogicalContext\n };\n return trampoline(adjustment, callback, void 0, entries, observer);\n };\n super(wrappedCallback, options);\n }\n };\n }\n if (typeof globalThis.Worker !== \"undefined\") {\n const __Worker = globalThis.Worker;\n globalThis.Worker = class extends __Worker {\n constructor(scriptURL, options) {\n super(scriptURL, options);\n this._userHandlers = /* @__PURE__ */ new Map();\n const eventHandlerProperties = [\n \"onmessage\",\n \"onmessageerror\",\n \"onerror\"\n ];\n eventHandlerProperties.forEach((prop) => {\n Object.defineProperty(this, prop, {\n get: () => this._userHandlers.get(prop) || null,\n set: (newHandler) => {\n this._userHandlers.set(prop, newHandler);\n if (newHandler && typeof newHandler === \"function\") {\n const capturedLogicalContext = currentLogicalContext;\n const wrappedHandler = function(event) {\n const adjustment = {\n contextToUse: capturedLogicalContext\n };\n return trampoline(adjustment, newHandler, this, event);\n };\n const parentProto = Object.getPrototypeOf(\n Object.getPrototypeOf(this)\n );\n const descriptor = Object.getOwnPropertyDescriptor(\n parentProto,\n prop\n );\n if (descriptor && descriptor.set) {\n descriptor.set.call(this, wrappedHandler);\n } else {\n this[`_${prop}`] = wrappedHandler;\n }\n } else {\n const parentProto = Object.getPrototypeOf(\n Object.getPrototypeOf(this)\n );\n const descriptor = Object.getOwnPropertyDescriptor(\n parentProto,\n prop\n );\n if (descriptor && descriptor.set) {\n descriptor.set.call(this, null);\n } else {\n this[`_${prop}`] = null;\n }\n }\n },\n configurable: true,\n enumerable: true\n });\n });\n }\n addEventListener(type, listener, options) {\n const capturedLogicalContext = currentLogicalContext;\n if (!listener) {\n return super.addEventListener(type, listener, options);\n }\n if (typeof listener === \"function\") {\n const wrappedListener = (event) => {\n const adjustment = {\n contextToUse: capturedLogicalContext\n };\n return trampoline(adjustment, listener, event.currentTarget, event);\n };\n return super.addEventListener(type, wrappedListener, options);\n } else if (typeof listener === \"object\" && \"handleEvent\" in listener) {\n const wrappedListener = {\n handleEvent: (event) => {\n const adjustment = {\n contextToUse: capturedLogicalContext\n };\n return trampoline(adjustment, () => listener.handleEvent(event));\n }\n };\n return super.addEventListener(type, wrappedListener, options);\n }\n return super.addEventListener(type, listener, options);\n }\n };\n }\n if (typeof globalThis.MessagePort !== \"undefined\") {\n const __MessagePort = globalThis.MessagePort;\n const createMessagePortWrapper = (originalPort) => {\n const _userHandlers = /* @__PURE__ */ new Map();\n const eventHandlerProperties = [\"onmessage\", \"onmessageerror\"];\n eventHandlerProperties.forEach((prop) => {\n Object.defineProperty(originalPort, prop, {\n get: () => _userHandlers.get(prop) || null,\n set: (newHandler) => {\n _userHandlers.set(prop, newHandler);\n if (newHandler && typeof newHandler === \"function\") {\n const capturedLogicalContext = currentLogicalContext;\n const wrappedHandler = function(event) {\n const adjustment = {\n contextToUse: capturedLogicalContext\n };\n return trampoline(adjustment, newHandler, this, event);\n };\n const descriptor = Object.getOwnPropertyDescriptor(\n __MessagePort.prototype,\n prop\n );\n if (descriptor && descriptor.set) {\n descriptor.set.call(originalPort, wrappedHandler);\n }\n } else {\n const descriptor = Object.getOwnPropertyDescriptor(\n __MessagePort.prototype,\n prop\n );\n if (descriptor && descriptor.set) {\n descriptor.set.call(originalPort, null);\n }\n }\n },\n configurable: true,\n enumerable: true\n });\n });\n const originalAddEventListener = originalPort.addEventListener;\n originalPort.addEventListener = function(type, listener, options) {\n const capturedLogicalContext = currentLogicalContext;\n if (!listener) {\n return originalAddEventListener.call(\n this,\n type,\n listener,\n options\n );\n }\n if (typeof listener === \"function\") {\n const wrappedListener = (event) => {\n const adjustment = {\n contextToUse: capturedLogicalContext\n };\n return trampoline(adjustment, listener, event.currentTarget, event);\n };\n return originalAddEventListener.call(\n this,\n type,\n wrappedListener,\n options\n );\n } else if (typeof listener === \"object\" && \"handleEvent\" in listener) {\n const wrappedListener = {\n handleEvent: (event) => {\n const adjustment = {\n contextToUse: capturedLogicalContext\n };\n return trampoline(adjustment, () => listener.handleEvent(event));\n }\n };\n return originalAddEventListener.call(\n this,\n type,\n wrappedListener,\n options\n );\n }\n return originalAddEventListener.call(this, type, listener, options);\n };\n return originalPort;\n };\n if (typeof globalThis.MessageChannel !== \"undefined\") {\n const __MessageChannel = globalThis.MessageChannel;\n globalThis.MessageChannel = class extends __MessageChannel {\n constructor() {\n super();\n createMessagePortWrapper(this.port1);\n createMessagePortWrapper(this.port2);\n }\n };\n }\n }\n};\nconst setLogicalContextValue = (key, value) => {\n prepare();\n if (value !== void 0) {\n currentLogicalContext.data.set(key, value);\n } else {\n currentLogicalContext.data.delete(key);\n }\n};\nconst getLogicalContextValue = (key) => {\n prepare();\n return currentLogicalContext.data.get(key);\n};\nconst runOnNewLogicalContext = (prefix, handler) => {\n const previousLogicalContext = currentLogicalContext;\n setCurrentLogicalContext(\n createLogicalContext(Symbol(`${prefix}-${crypto.randomUUID()}`))\n );\n try {\n return handler();\n } finally {\n setCurrentLogicalContext(previousLogicalContext);\n }\n};\nconst getCurrentLogicalContextId = () => {\n prepare();\n return currentLogicalContext.id;\n};\nconst createAsyncLocal = () => {\n const key = Symbol(`async-local-${crypto.randomUUID()}`);\n return {\n setValue: (value) => {\n setLogicalContextValue(key, value);\n },\n getValue: () => {\n return getLogicalContextValue(key);\n }\n };\n};\nconst ABORTED_ERROR$1 = () => new Error(\"Semaphore acquisition was aborted\");\nconst INVALID_COUNT_ERROR = () => new Error(\"Semaphore count must be greater than 0\");\nconst createSemaphoreHandle = (releaseCallback) => {\n let isActive = true;\n const release = () => {\n if (!isActive) {\n return;\n }\n isActive = false;\n releaseCallback();\n };\n return {\n get isActive() {\n return isActive;\n },\n release,\n [Symbol.dispose]: release\n };\n};\nconst createSemaphore = (count, maxConsecutiveCalls = 20) => {\n if (count < 1) {\n throw INVALID_COUNT_ERROR();\n }\n let availableCount = count;\n const queue = [];\n let consecutiveCallCount = 0;\n const processQueue = () => {\n var _a;\n while (availableCount > 0 && queue.length > 0) {\n const item = queue.shift();\n if ((_a = item.signal) == null ? void 0 : _a.aborted) {\n item.reject(ABORTED_ERROR$1());\n continue;\n }\n availableCount--;\n const semaphoreHandle = createSemaphoreHandle(releaseSemaphore);\n item.resolve(semaphoreHandle);\n }\n };\n const scheduleNextProcess = () => {\n consecutiveCallCount++;\n if (consecutiveCallCount >= maxConsecutiveCalls) {\n consecutiveCallCount = 0;\n defer(processQueue);\n } else {\n processQueue();\n }\n };\n const releaseSemaphore = () => {\n availableCount++;\n scheduleNextProcess();\n };\n const removeFromQueue = (item) => {\n const index = queue.indexOf(item);\n if (index !== -1) {\n queue.splice(index, 1);\n }\n };\n const acquire = async (signal) => {\n if (signal) {\n if (signal.aborted) {\n throw ABORTED_ERROR$1();\n }\n if (availableCount > 0) {\n availableCount--;\n return createSemaphoreHandle(releaseSemaphore);\n }\n return new Promise((resolve, reject) => {\n const queueItem = {\n resolve: void 0,\n reject: void 0,\n signal\n };\n const abortHandle = onAbort(signal, () => {\n removeFromQueue(queueItem);\n reject(ABORTED_ERROR$1());\n });\n queueItem.resolve = (handle) => {\n abortHandle.release();\n resolve(handle);\n };\n queueItem.reject = (error) => {\n abortHandle.release();\n reject(error);\n };\n queue.push(queueItem);\n processQueue();\n });\n } else {\n if (availableCount > 0) {\n availableCount--;\n return createSemaphoreHandle(releaseSemaphore);\n }\n return new Promise((resolve, reject) => {\n queue.push({\n resolve,\n reject\n });\n processQueue();\n });\n }\n };\n const result = {\n acquire,\n waiter: {\n wait: acquire\n },\n get availableCount() {\n return availableCount;\n },\n get pendingCount() {\n return queue.length;\n }\n };\n return result;\n};\nconst ABORTED_ERROR = () => new Error(\"Lock acquisition was aborted\");\nconst createReadLockHandle = (releaseCallback) => {\n let isActive = true;\n const release = () => {\n if (!isActive) {\n return;\n }\n isActive = false;\n releaseCallback();\n };\n return {\n get isActive() {\n return isActive;\n },\n release,\n [Symbol.dispose]: release\n };\n};\nconst createWriteLockHandle = (releaseCallback) => {\n let isActive = true;\n const release = () => {\n if (!isActive) {\n return;\n }\n isActive = false;\n releaseCallback();\n };\n return {\n get isActive() {\n return isActive;\n },\n release,\n [Symbol.dispose]: release\n };\n};\nfunction createReaderWriterLock(optionsOrMaxCalls) {\n var _a, _b;\n let policy = \"write-preferring\";\n let maxConsecutiveCalls = 20;\n if (typeof optionsOrMaxCalls === \"number\") {\n maxConsecutiveCalls = optionsOrMaxCalls;\n } else if (optionsOrMaxCalls) {\n policy = (_a = optionsOrMaxCalls.policy) != null ? _a : \"write-preferring\";\n maxConsecutiveCalls = (_b = optionsOrMaxCalls.maxConsecutiveCalls) != null ? _b : 20;\n }\n let currentReaders = 0;\n let hasWriter = false;\n const readQueue = [];\n const writeQueue = [];\n let consecutiveCallCount = 0;\n const processQueues = () => {\n var _a2, _b2, _c, _d;\n if (policy === \"write-preferring\") {\n if (!hasWriter && currentReaders === 0 && writeQueue.length > 0) {\n const item = writeQueue.shift();\n if ((_a2 = item.signal) == null ? void 0 : _a2.aborted) {\n item.reject(ABORTED_ERROR());\n scheduleNextProcess();\n return;\n }\n hasWriter = true;\n const writeLockHandle = createWriteLockHandle(releaseWriteLock);\n item.resolve(writeLockHandle);\n } else if (!hasWriter && writeQueue.length === 0 && readQueue.length > 0) {\n const readersToProcess = [];\n while (readQueue.length > 0) {\n const item = readQueue.shift();\n if ((_b2 = item.signal) == null ? void 0 : _b2.aborted) {\n item.reject(ABORTED_ERROR());\n } else {\n readersToProcess.push(item);\n }\n }\n for (const item of readersToProcess) {\n currentReaders++;\n const readLockHandle = createReadLockHandle(releaseReadLock);\n item.resolve(readLockHandle);\n }\n }\n } else {\n if (!hasWriter && readQueue.length > 0) {\n const readersToProcess = [];\n while (readQueue.length > 0) {\n const item = readQueue.shift();\n if ((_c = item.signal) == null ? void 0 : _c.aborted) {\n item.reject(ABORTED_ERROR());\n } else {\n readersToProcess.push(item);\n }\n }\n for (const item of readersToProcess) {\n currentReaders++;\n const readLockHandle = createReadLockHandle(releaseReadLock);\n item.resolve(readLockHandle);\n }\n } else if (!hasWriter && currentReaders === 0 && writeQueue.length > 0) {\n const item = writeQueue.shift();\n if ((_d = item.signal) == null ? void 0 : _d.aborted) {\n item.reject(ABORTED_ERROR());\n scheduleNextProcess();\n return;\n }\n hasWriter = true;\n const writeLockHandle = createWriteLockHandle(releaseWriteLock);\n item.resolve(writeLockHandle);\n }\n }\n };\n const scheduleNextProcess = () => {\n consecutiveCallCount++;\n if (consecutiveCallCount >= maxConsecutiveCalls) {\n consecutiveCallCount = 0;\n defer(processQueues);\n } else {\n processQueues();\n }\n };\n const releaseReadLock = () => {\n if (currentReaders > 0) {\n currentReaders--;\n if (currentReaders === 0) {\n scheduleNextProcess();\n }\n }\n };\n const releaseWriteLock = () => {\n if (hasWriter) {\n hasWriter = false;\n scheduleNextProcess();\n }\n };\n const removeFromReadQueue = (item) => {\n const index = readQueue.indexOf(item);\n if (index !== -1) {\n readQueue.splice(index, 1);\n }\n };\n const removeFromWriteQueue = (item) => {\n const index = writeQueue.indexOf(item);\n if (index !== -1) {\n writeQueue.splice(index, 1);\n }\n };\n const readLock = async (signal) => {\n if (signal) {\n if (signal.aborted) {\n throw ABORTED_ERROR();\n }\n const canAcquireImmediately = policy === \"read-preferring\" ? !hasWriter : !hasWriter && writeQueue.length === 0;\n if (canAcquireImmediately) {\n currentReaders++;\n return createReadLockHandle(releaseReadLock);\n }\n return new Promise((resolve, reject) => {\n const queueItem = {\n resolve: void 0,\n reject: void 0,\n signal\n };\n const abortHandle = onAbort(signal, () => {\n removeFromReadQueue(queueItem);\n reject(ABORTED_ERROR());\n });\n queueItem.resolve = (handle) => {\n abortHandle.release();\n resolve(handle);\n };\n queueItem.reject = (error) => {\n abortHandle.release();\n reject(error);\n };\n readQueue.push(queueItem);\n processQueues();\n });\n } else {\n const canAcquireImmediately = policy === \"read-preferring\" ? !hasWriter : !hasWriter && writeQueue.length === 0;\n if (canAcquireImmediately) {\n currentReaders++;\n return createReadLockHandle(releaseReadLock);\n }\n return new Promise((resolve, reject) => {\n readQueue.push({\n resolve,\n reject\n });\n processQueues();\n });\n }\n };\n const writeLock = async (signal) => {\n if (signal) {\n if (signal.aborted) {\n throw ABORTED_ERROR();\n }\n if (!hasWriter && currentReaders === 0) {\n hasWriter = true;\n return createWriteLockHandle(releaseWriteLock);\n }\n return new Promise((resolve, reject) => {\n const queueItem = {\n resolve: void 0,\n reject: void 0,\n signal\n };\n const abortHandle = onAbort(signal, () => {\n removeFromWriteQueue(queueItem);\n reject(ABORTED_ERROR());\n });\n queueItem.resolve = (handle) => {\n abortHandle.release();\n resolve(handle);\n };\n queueItem.reject = (error) => {\n abortHandle.release();\n reject(error);\n };\n writeQueue.push(queueItem);\n processQueues();\n });\n } else {\n if (!hasWriter && currentReaders === 0) {\n hasWriter = true;\n return createWriteLockHandle(releaseWriteLock);\n }\n return new Promise((resolve, reject) => {\n writeQueue.push({\n resolve,\n reject\n });\n processQueues();\n });\n }\n };\n const readWaiter = {\n wait: readLock\n };\n const writeWaiter = {\n wait: writeLock\n };\n return {\n readLock,\n writeLock,\n readWaiter,\n writeWaiter,\n get currentReaders() {\n return currentReaders;\n },\n get hasWriter() {\n return hasWriter;\n },\n get pendingReadersCount() {\n return readQueue.length;\n },\n get pendingWritersCount() {\n return writeQueue.length;\n }\n };\n}\nexport {\n createAsyncLocal,\n createMutex as createAsyncLock,\n createConditional,\n createDeferred,\n createDeferredGenerator,\n createManuallyConditional,\n createManuallyConditional as createManuallySignal,\n createMutex,\n createReaderWriterLock,\n createSemaphore,\n createConditional as createSignal,\n defer,\n delay,\n getCurrentLogicalContextId,\n getLogicalContextValue,\n onAbort,\n runOnNewLogicalContext,\n setLogicalContextValue\n};\n//# sourceMappingURL=index.mjs.map\n","// emsdk-env - Emscripten environment builder\n// Copyright (c) Kouji Matsui. (@kekyo@mi.kekyo.net)\n// Under MIT.\n// https://github.com/kekyo/emsdk-env\n\nimport { spawn } from 'child_process';\nimport { constants, access, mkdtemp, mkdir, rename, rm } from 'fs/promises';\nimport { homedir } from 'os';\nimport { join, resolve } from 'path';\nimport { createMutex } from 'async-primitives';\nimport { simpleGit, type SimpleGitOptions } from 'simple-git';\n\nconst DEFAULT_REPO_URL = 'https://github.com/emscripten-core/emsdk.git';\nconst DEFAULT_GIT_REF = 'main';\nconst DEFAULT_CACHE_DIR = join(homedir(), '.cache', 'emsdk-env');\n\nexport type PrepareEmsdkOptions = {\n targetVersion: string;\n cacheDir?: string;\n repoUrl?: string;\n gitPath?: string;\n};\n\nconst versionMutexes = new Map<string, ReturnType<typeof createMutex>>();\n\nconst getVersionMutex = (key: string) => {\n let mutex = versionMutexes.get(key);\n if (!mutex) {\n mutex = createMutex();\n versionMutexes.set(key, mutex);\n }\n return mutex;\n};\n\nconst ensureNonEmpty = (value: string, label: string) => {\n if (value.trim().length === 0) {\n throw new TypeError(`${label} must be a non-empty string.`);\n }\n};\n\nconst sanitizeSegment = (value: string) => {\n const trimmed = value.trim();\n ensureNonEmpty(trimmed, 'targetVersion');\n const sanitized = trimmed.replace(/[^A-Za-z0-9._-]/g, '_');\n if (sanitized === '.' || sanitized === '..' || sanitized.length === 0) {\n throw new TypeError('targetVersion results in an unsafe path segment.');\n }\n return sanitized;\n};\n\nconst pathExists = async (targetPath: string) => {\n try {\n await access(targetPath, constants.F_OK);\n return true;\n } catch {\n return false;\n }\n};\n\nconst runCommand = async (command: string, args: string[], cwd: string) =>\n new Promise<void>((resolvePromise, rejectPromise) => {\n const child = spawn(command, args, {\n cwd,\n stdio: 'inherit',\n });\n child.once('error', (error) => {\n rejectPromise(error);\n });\n child.once('close', (code) => {\n if (code === 0) {\n resolvePromise();\n return;\n }\n rejectPromise(\n new Error(\n `Command failed: ${command} ${args.join(' ')} (exit code ${code})`\n )\n );\n });\n });\n\nconst resolveEmsdkCommand = () =>\n process.platform === 'win32' ? 'emsdk.bat' : './emsdk';\n\nconst createGitClient = (baseDir: string, gitPath: string) =>\n simpleGit({\n baseDir,\n binary: gitPath,\n } satisfies Partial<SimpleGitOptions>);\n\nconst runEmsdk = async (repoDir: string, args: string[]) => {\n if (process.platform === 'win32') {\n await runCommand('cmd', ['/c', 'emsdk.bat', ...args], repoDir);\n return;\n }\n await runCommand(resolveEmsdkCommand(), args, repoDir);\n};\n\nconst ensureDirectory = async (targetPath: string) => {\n await mkdir(targetPath, { recursive: true });\n};\n\nconst isAlreadyExistsError = (error: unknown) =>\n error instanceof Error &&\n 'code' in error &&\n (error as NodeJS.ErrnoException).code !== undefined &&\n ['EEXIST', 'ENOTEMPTY', 'EISDIR'].includes(\n String((error as NodeJS.ErrnoException).code)\n );\n\nexport const prepareEmsdk = async (\n options: PrepareEmsdkOptions\n): Promise<string> => {\n if (!options) {\n throw new TypeError('options must be provided.');\n }\n if (typeof options.targetVersion !== 'string') {\n throw new TypeError('targetVersion must be a string.');\n }\n ensureNonEmpty(options.targetVersion, 'targetVersion');\n\n const cacheDir = resolve(options.cacheDir ?? DEFAULT_CACHE_DIR);\n const repoUrl = options.repoUrl ?? DEFAULT_REPO_URL;\n const gitPath = options.gitPath ?? 'git';\n\n const versionDir = sanitizeSegment(options.targetVersion);\n const finalDir = resolve(cacheDir, versionDir);\n\n const mutex = getVersionMutex(finalDir);\n const lock = await mutex.lock();\n try {\n if (await pathExists(finalDir)) {\n return finalDir;\n }\n\n await ensureDirectory(cacheDir);\n\n const tempRoot = await mkdtemp(join(cacheDir, '.tmp-'));\n const tempRepoDir = join(tempRoot, 'emsdk');\n\n try {\n const git = createGitClient(cacheDir, gitPath);\n await git.clone(repoUrl, tempRepoDir, [\n '--depth',\n '1',\n '--branch',\n DEFAULT_GIT_REF,\n ]);\n await runEmsdk(tempRepoDir, ['install', options.targetVersion]);\n\n try {\n await rename(tempRepoDir, finalDir);\n } catch (error) {\n if (isAlreadyExistsError(error)) {\n return finalDir;\n }\n throw error;\n }\n } finally {\n await rm(tempRoot, { recursive: true, force: true });\n }\n\n await runEmsdk(finalDir, ['activate', options.targetVersion]);\n return finalDir;\n } finally {\n lock.release();\n }\n};\n"],"names":["join","homedir","access","constants","spawn","simpleGit","mkdir","resolve","mkdtemp","rename","rm"],"mappings":"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","x_google_ignoreList":[0]}
@@ -0,0 +1,20 @@
1
+ /*!
2
+ * name: emsdk-env
3
+ * version: 0.1.0
4
+ * description: Emscripten environment builder
5
+ * author: Kouji Matsui (@kekyo@mi.kekyo.net)
6
+ * license: MIT
7
+ * repository.url: https://github.com/kekyo/emsdk-env
8
+ * git.commit.hash: 32f73259bc38b9fcc19c26f3012f0b87c28963e4
9
+ */
10
+
11
+ export declare const prepareEmsdk: (options: PrepareEmsdkOptions) => Promise<string>;
12
+
13
+ export declare type PrepareEmsdkOptions = {
14
+ targetVersion: string;
15
+ cacheDir?: string;
16
+ repoUrl?: string;
17
+ gitPath?: string;
18
+ };
19
+
20
+ export { }
package/dist/index.mjs ADDED
@@ -0,0 +1,309 @@
1
+ /*!
2
+ * name: emsdk-env
3
+ * version: 0.1.0
4
+ * description: Emscripten environment builder
5
+ * author: Kouji Matsui (@kekyo@mi.kekyo.net)
6
+ * license: MIT
7
+ * repository.url: https://github.com/kekyo/emsdk-env
8
+ * git.commit.hash: 32f73259bc38b9fcc19c26f3012f0b87c28963e4
9
+ */
10
+
11
+ import { spawn } from "child_process";
12
+ import { mkdtemp, rename, rm, access, constants, mkdir } from "fs/promises";
13
+ import { homedir } from "os";
14
+ import { join, resolve } from "path";
15
+ import { simpleGit } from "simple-git";
16
+ const __NOOP_HANDLER = () => {
17
+ };
18
+ const __NOOP_RELEASABLE = {
19
+ release: __NOOP_HANDLER,
20
+ [Symbol.dispose]: __NOOP_HANDLER
21
+ };
22
+ const toAbortError = (reason) => {
23
+ if (reason instanceof Error) {
24
+ return reason;
25
+ }
26
+ if (typeof reason === "string") {
27
+ return new Error(reason);
28
+ }
29
+ return new Error("Operation aborted");
30
+ };
31
+ const onAbort = (signal, callback) => {
32
+ if (!signal) {
33
+ return __NOOP_RELEASABLE;
34
+ }
35
+ if (signal.aborted) {
36
+ try {
37
+ callback(toAbortError(signal.reason));
38
+ } catch (error) {
39
+ console.warn("AbortHook callback error: ", error);
40
+ }
41
+ return __NOOP_RELEASABLE;
42
+ }
43
+ let abortHandler;
44
+ abortHandler = () => {
45
+ if (abortHandler) {
46
+ const reason = signal.reason;
47
+ signal.removeEventListener("abort", abortHandler);
48
+ abortHandler = void 0;
49
+ try {
50
+ callback(toAbortError(reason));
51
+ } catch (error) {
52
+ console.warn("AbortHook callback error: ", error);
53
+ }
54
+ }
55
+ };
56
+ const release = () => {
57
+ if (abortHandler) {
58
+ signal.removeEventListener("abort", abortHandler);
59
+ abortHandler = void 0;
60
+ }
61
+ };
62
+ signal.addEventListener("abort", abortHandler, { once: true });
63
+ const handle = {
64
+ release,
65
+ [Symbol.dispose]: release
66
+ };
67
+ return handle;
68
+ };
69
+ const defer = (fn) => {
70
+ if (typeof setImmediate === "function") {
71
+ setImmediate(fn);
72
+ } else {
73
+ setTimeout(fn, 0);
74
+ }
75
+ };
76
+ const ABORTED_ERROR$2 = () => new Error("Lock acquisition was aborted");
77
+ const createLockHandle = (releaseCallback) => {
78
+ let isActive = true;
79
+ const release = () => {
80
+ if (!isActive) {
81
+ return;
82
+ }
83
+ isActive = false;
84
+ releaseCallback();
85
+ };
86
+ return {
87
+ get isActive() {
88
+ return isActive;
89
+ },
90
+ release,
91
+ [Symbol.dispose]: release
92
+ };
93
+ };
94
+ const createMutex = (maxConsecutiveCalls = 20) => {
95
+ let isLocked = false;
96
+ const queue = [];
97
+ let count = 0;
98
+ const processQueue = () => {
99
+ var _a;
100
+ if (isLocked || queue.length === 0) {
101
+ return;
102
+ }
103
+ const item = queue.shift();
104
+ if ((_a = item.signal) == null ? void 0 : _a.aborted) {
105
+ item.reject(ABORTED_ERROR$2());
106
+ scheduleNextProcess();
107
+ return;
108
+ }
109
+ isLocked = true;
110
+ const lockHandle = createLockHandle(releaseLock);
111
+ item.resolve(lockHandle);
112
+ };
113
+ const scheduleNextProcess = () => {
114
+ count++;
115
+ if (count >= maxConsecutiveCalls) {
116
+ count = 0;
117
+ defer(processQueue);
118
+ } else {
119
+ processQueue();
120
+ }
121
+ };
122
+ const releaseLock = () => {
123
+ if (!isLocked) {
124
+ return;
125
+ }
126
+ isLocked = false;
127
+ scheduleNextProcess();
128
+ };
129
+ const removeFromQueue = (item) => {
130
+ const index = queue.indexOf(item);
131
+ if (index !== -1) {
132
+ queue.splice(index, 1);
133
+ }
134
+ };
135
+ const lock = async (signal) => {
136
+ if (signal) {
137
+ if (signal.aborted) {
138
+ throw ABORTED_ERROR$2();
139
+ }
140
+ return new Promise((resolve2, reject) => {
141
+ const queueItem = {
142
+ resolve: void 0,
143
+ reject: void 0,
144
+ signal
145
+ };
146
+ const abortHandle = onAbort(signal, () => {
147
+ removeFromQueue(queueItem);
148
+ reject(ABORTED_ERROR$2());
149
+ });
150
+ queueItem.resolve = (handle) => {
151
+ abortHandle.release();
152
+ resolve2(handle);
153
+ };
154
+ queueItem.reject = (error) => {
155
+ abortHandle.release();
156
+ reject(error);
157
+ };
158
+ queue.push(queueItem);
159
+ processQueue();
160
+ });
161
+ } else {
162
+ return new Promise((resolve2, reject) => {
163
+ queue.push({
164
+ resolve: resolve2,
165
+ reject
166
+ });
167
+ processQueue();
168
+ });
169
+ }
170
+ };
171
+ const result = {
172
+ lock,
173
+ waiter: {
174
+ wait: lock
175
+ },
176
+ get isLocked() {
177
+ return isLocked;
178
+ },
179
+ get pendingCount() {
180
+ return queue.length;
181
+ }
182
+ };
183
+ return result;
184
+ };
185
+ const DEFAULT_REPO_URL = "https://github.com/emscripten-core/emsdk.git";
186
+ const DEFAULT_GIT_REF = "main";
187
+ const DEFAULT_CACHE_DIR = join(homedir(), ".cache", "emsdk-env");
188
+ const versionMutexes = /* @__PURE__ */ new Map();
189
+ const getVersionMutex = (key) => {
190
+ let mutex = versionMutexes.get(key);
191
+ if (!mutex) {
192
+ mutex = createMutex();
193
+ versionMutexes.set(key, mutex);
194
+ }
195
+ return mutex;
196
+ };
197
+ const ensureNonEmpty = (value, label) => {
198
+ if (value.trim().length === 0) {
199
+ throw new TypeError(`${label} must be a non-empty string.`);
200
+ }
201
+ };
202
+ const sanitizeSegment = (value) => {
203
+ const trimmed = value.trim();
204
+ ensureNonEmpty(trimmed, "targetVersion");
205
+ const sanitized = trimmed.replace(/[^A-Za-z0-9._-]/g, "_");
206
+ if (sanitized === "." || sanitized === ".." || sanitized.length === 0) {
207
+ throw new TypeError("targetVersion results in an unsafe path segment.");
208
+ }
209
+ return sanitized;
210
+ };
211
+ const pathExists = async (targetPath) => {
212
+ try {
213
+ await access(targetPath, constants.F_OK);
214
+ return true;
215
+ } catch (e) {
216
+ return false;
217
+ }
218
+ };
219
+ const runCommand = async (command, args, cwd) => new Promise((resolvePromise, rejectPromise) => {
220
+ const child = spawn(command, args, {
221
+ cwd,
222
+ stdio: "inherit"
223
+ });
224
+ child.once("error", (error) => {
225
+ rejectPromise(error);
226
+ });
227
+ child.once("close", (code) => {
228
+ if (code === 0) {
229
+ resolvePromise();
230
+ return;
231
+ }
232
+ rejectPromise(
233
+ new Error(
234
+ `Command failed: ${command} ${args.join(" ")} (exit code ${code})`
235
+ )
236
+ );
237
+ });
238
+ });
239
+ const resolveEmsdkCommand = () => process.platform === "win32" ? "emsdk.bat" : "./emsdk";
240
+ const createGitClient = (baseDir, gitPath) => simpleGit({
241
+ baseDir,
242
+ binary: gitPath
243
+ });
244
+ const runEmsdk = async (repoDir, args) => {
245
+ if (process.platform === "win32") {
246
+ await runCommand("cmd", ["/c", "emsdk.bat", ...args], repoDir);
247
+ return;
248
+ }
249
+ await runCommand(resolveEmsdkCommand(), args, repoDir);
250
+ };
251
+ const ensureDirectory = async (targetPath) => {
252
+ await mkdir(targetPath, { recursive: true });
253
+ };
254
+ const isAlreadyExistsError = (error) => error instanceof Error && "code" in error && error.code !== void 0 && ["EEXIST", "ENOTEMPTY", "EISDIR"].includes(
255
+ String(error.code)
256
+ );
257
+ const prepareEmsdk = async (options) => {
258
+ var _a, _b, _c;
259
+ if (!options) {
260
+ throw new TypeError("options must be provided.");
261
+ }
262
+ if (typeof options.targetVersion !== "string") {
263
+ throw new TypeError("targetVersion must be a string.");
264
+ }
265
+ ensureNonEmpty(options.targetVersion, "targetVersion");
266
+ const cacheDir = resolve((_a = options.cacheDir) != null ? _a : DEFAULT_CACHE_DIR);
267
+ const repoUrl = (_b = options.repoUrl) != null ? _b : DEFAULT_REPO_URL;
268
+ const gitPath = (_c = options.gitPath) != null ? _c : "git";
269
+ const versionDir = sanitizeSegment(options.targetVersion);
270
+ const finalDir = resolve(cacheDir, versionDir);
271
+ const mutex = getVersionMutex(finalDir);
272
+ const lock = await mutex.lock();
273
+ try {
274
+ if (await pathExists(finalDir)) {
275
+ return finalDir;
276
+ }
277
+ await ensureDirectory(cacheDir);
278
+ const tempRoot = await mkdtemp(join(cacheDir, ".tmp-"));
279
+ const tempRepoDir = join(tempRoot, "emsdk");
280
+ try {
281
+ const git = createGitClient(cacheDir, gitPath);
282
+ await git.clone(repoUrl, tempRepoDir, [
283
+ "--depth",
284
+ "1",
285
+ "--branch",
286
+ DEFAULT_GIT_REF
287
+ ]);
288
+ await runEmsdk(tempRepoDir, ["install", options.targetVersion]);
289
+ try {
290
+ await rename(tempRepoDir, finalDir);
291
+ } catch (error) {
292
+ if (isAlreadyExistsError(error)) {
293
+ return finalDir;
294
+ }
295
+ throw error;
296
+ }
297
+ } finally {
298
+ await rm(tempRoot, { recursive: true, force: true });
299
+ }
300
+ await runEmsdk(finalDir, ["activate", options.targetVersion]);
301
+ return finalDir;
302
+ } finally {
303
+ lock.release();
304
+ }
305
+ };
306
+ export {
307
+ prepareEmsdk
308
+ };
309
+ //# sourceMappingURL=index.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.mjs","sources":["../node_modules/async-primitives/dist/index.mjs","../src/index.ts"],"sourcesContent":["/*!\n * name: async-primitives\n * version: 1.5.0\n * description: A collection of primitive functions for asynchronous operations\n * author: Kouji Matsui (@kekyo@mi.kekyo.net)\n * license: MIT\n * repository.url: https://github.com/kekyo/async-primitives.git\n * git.commit.hash: cd35465b7e9b9945049186e7eaeecc0bfba65766\n */\nconst __NOOP_HANDLER = () => {\n};\nconst __NOOP_RELEASABLE = {\n release: __NOOP_HANDLER,\n [Symbol.dispose]: __NOOP_HANDLER\n};\nconst toAbortError = (reason) => {\n if (reason instanceof Error) {\n return reason;\n }\n if (typeof reason === \"string\") {\n return new Error(reason);\n }\n return new Error(\"Operation aborted\");\n};\nconst onAbort = (signal, callback) => {\n if (!signal) {\n return __NOOP_RELEASABLE;\n }\n if (signal.aborted) {\n try {\n callback(toAbortError(signal.reason));\n } catch (error) {\n console.warn(\"AbortHook callback error: \", error);\n }\n return __NOOP_RELEASABLE;\n }\n let abortHandler;\n abortHandler = () => {\n if (abortHandler) {\n const reason = signal.reason;\n signal.removeEventListener(\"abort\", abortHandler);\n abortHandler = void 0;\n try {\n callback(toAbortError(reason));\n } catch (error) {\n console.warn(\"AbortHook callback error: \", error);\n }\n }\n };\n const release = () => {\n if (abortHandler) {\n signal.removeEventListener(\"abort\", abortHandler);\n abortHandler = void 0;\n }\n };\n signal.addEventListener(\"abort\", abortHandler, { once: true });\n const handle = {\n release,\n [Symbol.dispose]: release\n };\n return handle;\n};\nconst delay = (msec, signal) => {\n if (signal) {\n if (signal.aborted) {\n throw new Error(\"Delay was aborted\");\n }\n return new Promise((resolve, reject) => {\n const abortHandle = onAbort(signal, () => {\n clearTimeout(timeoutId);\n reject(new Error(\"Delay was aborted\"));\n });\n const timeoutId = setTimeout(() => {\n abortHandle.release();\n resolve();\n }, msec);\n });\n } else {\n return new Promise((resolve) => {\n setTimeout(resolve, msec);\n });\n }\n};\nconst defer = (fn) => {\n if (typeof setImmediate === \"function\") {\n setImmediate(fn);\n } else {\n setTimeout(fn, 0);\n }\n};\nconst ABORTED_ERROR$2 = () => new Error(\"Lock acquisition was aborted\");\nconst createLockHandle = (releaseCallback) => {\n let isActive = true;\n const release = () => {\n if (!isActive) {\n return;\n }\n isActive = false;\n releaseCallback();\n };\n return {\n get isActive() {\n return isActive;\n },\n release,\n [Symbol.dispose]: release\n };\n};\nconst createMutex = (maxConsecutiveCalls = 20) => {\n let isLocked = false;\n const queue = [];\n let count = 0;\n const processQueue = () => {\n var _a;\n if (isLocked || queue.length === 0) {\n return;\n }\n const item = queue.shift();\n if ((_a = item.signal) == null ? void 0 : _a.aborted) {\n item.reject(ABORTED_ERROR$2());\n scheduleNextProcess();\n return;\n }\n isLocked = true;\n const lockHandle = createLockHandle(releaseLock);\n item.resolve(lockHandle);\n };\n const scheduleNextProcess = () => {\n count++;\n if (count >= maxConsecutiveCalls) {\n count = 0;\n defer(processQueue);\n } else {\n processQueue();\n }\n };\n const releaseLock = () => {\n if (!isLocked) {\n return;\n }\n isLocked = false;\n scheduleNextProcess();\n };\n const removeFromQueue = (item) => {\n const index = queue.indexOf(item);\n if (index !== -1) {\n queue.splice(index, 1);\n }\n };\n const lock = async (signal) => {\n if (signal) {\n if (signal.aborted) {\n throw ABORTED_ERROR$2();\n }\n return new Promise((resolve, reject) => {\n const queueItem = {\n resolve: void 0,\n reject: void 0,\n signal\n };\n const abortHandle = onAbort(signal, () => {\n removeFromQueue(queueItem);\n reject(ABORTED_ERROR$2());\n });\n queueItem.resolve = (handle) => {\n abortHandle.release();\n resolve(handle);\n };\n queueItem.reject = (error) => {\n abortHandle.release();\n reject(error);\n };\n queue.push(queueItem);\n processQueue();\n });\n } else {\n return new Promise((resolve, reject) => {\n queue.push({\n resolve,\n reject\n });\n processQueue();\n });\n }\n };\n const result = {\n lock,\n waiter: {\n wait: lock\n },\n get isLocked() {\n return isLocked;\n },\n get pendingCount() {\n return queue.length;\n }\n };\n return result;\n};\nconst createDeferred = (signal) => {\n let resolve;\n let reject;\n const promise = new Promise((res, rej) => {\n resolve = res;\n reject = rej;\n });\n const disposer = onAbort(signal, () => {\n const _reject = reject;\n if (_reject) {\n resolve = void 0;\n reject = void 0;\n _reject(new Error(\"Deferred aborted\"));\n }\n });\n return {\n // The promise that resolves to the result\n promise,\n // Resolve the promise with a result\n resolve: (value) => {\n const _resolve = resolve;\n if (_resolve) {\n resolve = void 0;\n reject = void 0;\n disposer.release();\n _resolve(value);\n }\n },\n // Reject the promise with an error\n reject: (error) => {\n const _reject = reject;\n if (_reject) {\n resolve = void 0;\n reject = void 0;\n disposer.release();\n _reject(error);\n }\n }\n };\n};\nconst __NOOP_DUMMY_HANDLE = {\n get isActive() {\n return false;\n },\n release: __NOOP_HANDLER,\n [Symbol.dispose]: __NOOP_HANDLER\n};\nconst createConditional = () => {\n const waiters = [];\n const trigger = () => {\n if (waiters.length >= 1) {\n waiters.shift().resolve();\n }\n };\n const wait = async (signal) => {\n if (signal == null ? void 0 : signal.aborted) {\n throw new Error(\"Conditional aborted\");\n }\n const waiter = createDeferred();\n waiters.push(waiter);\n const disposer = onAbort(signal, () => {\n waiters.splice(waiters.indexOf(waiter), 1);\n waiter.reject(new Error(\"Conditional aborted\"));\n });\n try {\n await waiter.promise;\n } finally {\n disposer.release();\n }\n return __NOOP_DUMMY_HANDLE;\n };\n const result = {\n trigger,\n wait,\n waiter: {\n wait\n }\n };\n return result;\n};\nconst createManuallyConditional = (initialState) => {\n const waiters = [];\n let raised = initialState != null ? initialState : false;\n const trigger = () => {\n raised = false;\n const waiter = waiters.shift();\n if (waiter) {\n waiter.resolve();\n raised = false;\n }\n };\n const raise = () => {\n while (waiters.length >= 1) {\n raised = true;\n waiters.shift().resolve();\n }\n raised = true;\n };\n const drop = () => {\n raised = false;\n };\n const wait = async (signal) => {\n if (raised) {\n return __NOOP_DUMMY_HANDLE;\n }\n if (signal == null ? void 0 : signal.aborted) {\n throw new Error(\"Conditional aborted\");\n }\n const waiter = createDeferred();\n waiters.push(waiter);\n const disposer = onAbort(signal, () => {\n waiters.splice(waiters.indexOf(waiter), 1);\n waiter.reject(new Error(\"Conditional aborted\"));\n });\n try {\n await waiter.promise;\n } finally {\n disposer.release();\n }\n return __NOOP_DUMMY_HANDLE;\n };\n const result = {\n trigger,\n raise,\n drop,\n wait,\n waiter: {\n wait\n }\n };\n return result;\n};\nconst createDeferredGenerator = (options) => {\n const maxItemReserved = options == null ? void 0 : options.maxItemReserved;\n const signal = options == null ? void 0 : options.signal;\n const queue = [];\n const arrived = createManuallyConditional();\n const canReserve = maxItemReserved ? createManuallyConditional(true) : void 0;\n const generator = (async function* () {\n while (true) {\n while (true) {\n const item = queue.shift();\n if (maxItemReserved && queue.length === maxItemReserved - 1) {\n canReserve.raise();\n }\n if (!item) {\n break;\n }\n switch (item.kind) {\n // Yield return a value\n case \"value\":\n yield item.value;\n break;\n // Completed, exit the generator\n case \"completed\":\n return;\n // Error, throw an error\n case \"error\":\n throw item.error;\n }\n if (signal == null ? void 0 : signal.aborted) {\n throw new Error(\"Deferred generator aborted\");\n }\n }\n arrived.drop();\n try {\n await arrived.wait(signal);\n } catch (error) {\n if (error instanceof Error && error.message === \"Conditional aborted\") {\n error.message = \"Deferred generator aborted\";\n }\n throw error;\n }\n }\n })();\n const enqueue = async (item, signal2) => {\n while (true) {\n if (!maxItemReserved || queue.length < maxItemReserved) {\n const remains = queue.push(item);\n if (remains === 1) {\n arrived.raise();\n }\n if (remains === maxItemReserved) {\n canReserve.drop();\n }\n break;\n }\n try {\n await canReserve.wait(signal2);\n } catch (error) {\n if (error instanceof Error && error.message === \"Conditional aborted\") {\n error.message = \"Deferred generator aborted\";\n }\n throw error;\n }\n }\n };\n return {\n // The async generator that yields values\n generator,\n // Yield a value to the generator\n yield: (value, signal2) => enqueue({ kind: \"value\", value }, signal2),\n // Complete the generator (equivalent to return)\n return: (signal2) => enqueue({ kind: \"completed\" }, signal2),\n // Throw an error to the generator\n throw: (error, signal2) => enqueue({ kind: \"error\", error }, signal2)\n };\n};\nconst createLogicalContext = (id) => {\n return { id, data: /* @__PURE__ */ new Map() };\n};\nlet currentLogicalContext = createLogicalContext(Symbol(\"[root]\"));\nconst setCurrentLogicalContext = (context) => {\n currentLogicalContext = context;\n};\nconst trampoline = (adjustment, callback, thisArg, ...args) => {\n const previousLogicalContext = currentLogicalContext;\n currentLogicalContext = adjustment.contextToUse;\n try {\n return callback.call(thisArg, ...args);\n } finally {\n adjustment.contextAfter = currentLogicalContext;\n currentLogicalContext = previousLogicalContext;\n }\n};\nlet isPrepared = false;\nconst prepare = () => {\n if (isPrepared) {\n return;\n }\n isPrepared = true;\n if (typeof globalThis.setTimeout !== \"undefined\") {\n const __setTimeout = globalThis.setTimeout;\n globalThis.setTimeout = ((handler, timeout, ...args) => {\n const capturedLogicalContext = currentLogicalContext;\n return __setTimeout(\n (...args2) => {\n const adjustment = {\n contextToUse: capturedLogicalContext\n };\n trampoline(adjustment, handler, void 0, ...args2);\n },\n timeout,\n ...args\n );\n });\n }\n if (typeof globalThis.setInterval !== \"undefined\") {\n const __setInterval = globalThis.setInterval;\n globalThis.setInterval = ((handler, timeout, ...args) => {\n const capturedLogicalContext = currentLogicalContext;\n return __setInterval(\n (...args2) => {\n const adjustment = {\n contextToUse: capturedLogicalContext\n };\n trampoline(adjustment, handler, void 0, ...args2);\n },\n timeout,\n ...args\n );\n });\n }\n if (typeof globalThis.queueMicrotask !== \"undefined\") {\n const __queueMicrotask = globalThis.queueMicrotask;\n globalThis.queueMicrotask = (callback) => {\n const capturedLogicalContext = currentLogicalContext;\n return __queueMicrotask(() => {\n const adjustment = {\n contextToUse: capturedLogicalContext\n };\n trampoline(adjustment, callback, void 0);\n });\n };\n }\n if (typeof globalThis.setImmediate !== \"undefined\") {\n const __setImmediate = globalThis.setImmediate;\n globalThis.setImmediate = ((callback, ...args) => {\n const capturedLogicalContext = currentLogicalContext;\n return __setImmediate(\n (...callbackArgs) => {\n const adjustment = {\n contextToUse: capturedLogicalContext\n };\n trampoline(adjustment, callback, void 0, ...callbackArgs);\n },\n ...args\n );\n });\n }\n if (typeof process !== \"undefined\" && process.nextTick) {\n const __nextTick = process.nextTick;\n process.nextTick = (callback, ...args) => {\n const capturedLogicalContext = currentLogicalContext;\n return __nextTick(() => {\n const adjustment = {\n contextToUse: capturedLogicalContext\n };\n trampoline(adjustment, callback, void 0, ...args);\n });\n };\n }\n if (typeof Promise !== \"undefined\") {\n const __then = Promise.prototype.then;\n const __catch = Promise.prototype.catch;\n const __finally = Promise.prototype.finally;\n Promise.prototype.then = function(onFulfilled, onRejected) {\n const capturedLogicalContext = currentLogicalContext;\n const resultPromise = __then.call(\n this,\n onFulfilled ? (value) => {\n const adjustment = {\n contextToUse: capturedLogicalContext\n };\n return trampoline(adjustment, onFulfilled, void 0, value);\n } : void 0,\n onRejected ? (reason) => {\n const adjustment = {\n contextToUse: capturedLogicalContext\n };\n return trampoline(adjustment, onRejected, void 0, reason);\n } : void 0\n );\n return resultPromise;\n };\n Promise.prototype.catch = function(onRejected) {\n const capturedLogicalContext = currentLogicalContext;\n const resultPromise = __catch.call(\n this,\n onRejected ? (reason) => {\n const adjustment = {\n contextToUse: capturedLogicalContext\n };\n return trampoline(adjustment, onRejected, void 0, reason);\n } : void 0\n );\n return resultPromise;\n };\n Promise.prototype.finally = function(onFinally) {\n const capturedLogicalContext = currentLogicalContext;\n const resultPromise = __finally.call(\n this,\n onFinally ? () => {\n const adjustment = {\n contextToUse: capturedLogicalContext\n };\n return trampoline(adjustment, onFinally, void 0);\n } : void 0\n );\n return resultPromise;\n };\n }\n if (typeof EventTarget !== \"undefined\" && EventTarget.prototype && EventTarget.prototype.addEventListener) {\n const __eventTargetAddEventListener = EventTarget.prototype.addEventListener;\n EventTarget.prototype.addEventListener = function(type, listener, options) {\n if (listener === null || listener === void 0) {\n return __eventTargetAddEventListener.call(\n this,\n type,\n listener,\n options\n );\n }\n if (typeof listener === \"function\") {\n const capturedLogicalContext = currentLogicalContext;\n const wrappedListener = (event) => {\n const adjustment = {\n contextToUse: capturedLogicalContext\n };\n return trampoline(adjustment, listener, event.currentTarget, event);\n };\n return __eventTargetAddEventListener.call(\n this,\n type,\n wrappedListener,\n options\n );\n } else if (typeof listener === \"object\" && \"handleEvent\" in listener) {\n const capturedLogicalContext = currentLogicalContext;\n const wrappedListener = {\n handleEvent: (event) => {\n const adjustment = {\n contextToUse: capturedLogicalContext\n };\n return trampoline(adjustment, () => listener.handleEvent(event));\n }\n };\n return __eventTargetAddEventListener.call(\n this,\n type,\n wrappedListener,\n options\n );\n }\n return __eventTargetAddEventListener.call(\n this,\n type,\n listener,\n options\n );\n };\n }\n if (typeof Element !== \"undefined\" && Element.prototype && Element.prototype.addEventListener) {\n const __elementAddEventListener = Element.prototype.addEventListener;\n Element.prototype.addEventListener = function(type, listener, options) {\n if (listener === null || listener === void 0) {\n return __elementAddEventListener.call(\n this,\n type,\n listener,\n options\n );\n }\n if (typeof listener === \"function\") {\n const capturedLogicalContext = currentLogicalContext;\n const wrappedListener = (event) => {\n const adjustment = {\n contextToUse: capturedLogicalContext\n };\n return trampoline(adjustment, listener, event.currentTarget, event);\n };\n return __elementAddEventListener.call(\n this,\n type,\n wrappedListener,\n options\n );\n } else if (typeof listener === \"object\" && \"handleEvent\" in listener) {\n const capturedLogicalContext = currentLogicalContext;\n const wrappedListener = {\n handleEvent: (event) => {\n const adjustment = {\n contextToUse: capturedLogicalContext\n };\n return trampoline(adjustment, () => listener.handleEvent(event));\n }\n };\n return __elementAddEventListener.call(\n this,\n type,\n wrappedListener,\n options\n );\n }\n return __elementAddEventListener.call(\n this,\n type,\n listener,\n options\n );\n };\n }\n if (typeof globalThis.requestAnimationFrame !== \"undefined\") {\n const __requestAnimationFrame = globalThis.requestAnimationFrame;\n globalThis.requestAnimationFrame = (callback) => {\n const capturedLogicalContext = currentLogicalContext;\n return __requestAnimationFrame((time) => {\n const adjustment = {\n contextToUse: capturedLogicalContext\n };\n return trampoline(adjustment, callback, void 0, time);\n });\n };\n }\n if (typeof globalThis.XMLHttpRequest !== \"undefined\") {\n const __XMLHttpRequest = globalThis.XMLHttpRequest;\n globalThis.XMLHttpRequest = class extends __XMLHttpRequest {\n constructor() {\n super();\n this._userHandlers = /* @__PURE__ */ new Map();\n const eventHandlerProperties = [\n \"onreadystatechange\",\n \"onloadstart\",\n \"onprogress\",\n \"onabort\",\n \"onerror\",\n \"onload\",\n \"ontimeout\",\n \"onloadend\"\n ];\n eventHandlerProperties.forEach((prop) => {\n Object.defineProperty(this, prop, {\n get: () => this._userHandlers.get(prop) || null,\n set: (newHandler) => {\n this._userHandlers.set(prop, newHandler);\n if (newHandler && typeof newHandler === \"function\") {\n const capturedLogicalContext = currentLogicalContext;\n const wrappedHandler = function(event) {\n const adjustment = {\n contextToUse: capturedLogicalContext\n };\n return trampoline(adjustment, newHandler, this, event);\n };\n const parentProto = Object.getPrototypeOf(\n Object.getPrototypeOf(this)\n );\n const descriptor = Object.getOwnPropertyDescriptor(\n parentProto,\n prop\n );\n if (descriptor && descriptor.set) {\n descriptor.set.call(this, wrappedHandler);\n } else {\n this[`_${prop}`] = wrappedHandler;\n }\n } else {\n const parentProto = Object.getPrototypeOf(\n Object.getPrototypeOf(this)\n );\n const descriptor = Object.getOwnPropertyDescriptor(\n parentProto,\n prop\n );\n if (descriptor && descriptor.set) {\n descriptor.set.call(this, null);\n } else {\n this[`_${prop}`] = null;\n }\n }\n },\n configurable: true,\n enumerable: true\n });\n });\n }\n addEventListener(type, listener, options) {\n const capturedLogicalContext = currentLogicalContext;\n if (!listener) {\n return super.addEventListener(type, listener, options);\n }\n if (typeof listener === \"function\") {\n const wrappedListener = (event) => {\n const adjustment = {\n contextToUse: capturedLogicalContext\n };\n return trampoline(adjustment, listener, event.currentTarget, event);\n };\n return super.addEventListener(type, wrappedListener, options);\n } else if (typeof listener === \"object\" && \"handleEvent\" in listener) {\n const wrappedListener = {\n handleEvent: (event) => {\n const adjustment = {\n contextToUse: capturedLogicalContext\n };\n return trampoline(adjustment, () => listener.handleEvent(event));\n }\n };\n return super.addEventListener(type, wrappedListener, options);\n }\n return super.addEventListener(type, listener, options);\n }\n };\n }\n if (typeof globalThis.WebSocket !== \"undefined\") {\n const __WebSocket = globalThis.WebSocket;\n globalThis.WebSocket = class extends __WebSocket {\n constructor(url, protocols) {\n super(url, protocols);\n this._userHandlers = /* @__PURE__ */ new Map();\n const eventHandlerProperties = [\n \"onopen\",\n \"onmessage\",\n \"onerror\",\n \"onclose\"\n ];\n eventHandlerProperties.forEach((prop) => {\n Object.defineProperty(this, prop, {\n get: () => this._userHandlers.get(prop) || null,\n set: (newHandler) => {\n this._userHandlers.set(prop, newHandler);\n if (newHandler && typeof newHandler === \"function\") {\n const capturedLogicalContext = currentLogicalContext;\n const wrappedHandler = function(event) {\n const adjustment = {\n contextToUse: capturedLogicalContext\n };\n return trampoline(adjustment, newHandler, this, event);\n };\n const parentProto = Object.getPrototypeOf(\n Object.getPrototypeOf(this)\n );\n const descriptor = Object.getOwnPropertyDescriptor(\n parentProto,\n prop\n );\n if (descriptor && descriptor.set) {\n descriptor.set.call(this, wrappedHandler);\n } else {\n this[`_${prop}`] = wrappedHandler;\n }\n } else {\n const parentProto = Object.getPrototypeOf(\n Object.getPrototypeOf(this)\n );\n const descriptor = Object.getOwnPropertyDescriptor(\n parentProto,\n prop\n );\n if (descriptor && descriptor.set) {\n descriptor.set.call(this, null);\n } else {\n this[`_${prop}`] = null;\n }\n }\n },\n configurable: true,\n enumerable: true\n });\n });\n }\n addEventListener(type, listener, options) {\n const capturedLogicalContext = currentLogicalContext;\n if (!listener) {\n return super.addEventListener(type, listener, options);\n }\n if (typeof listener === \"function\") {\n const wrappedListener = (event) => {\n const adjustment = {\n contextToUse: capturedLogicalContext\n };\n return trampoline(adjustment, listener, event.currentTarget, event);\n };\n return super.addEventListener(type, wrappedListener, options);\n } else if (typeof listener === \"object\" && \"handleEvent\" in listener) {\n const wrappedListener = {\n handleEvent: (event) => {\n const adjustment = {\n contextToUse: capturedLogicalContext\n };\n return trampoline(adjustment, () => listener.handleEvent(event));\n }\n };\n return super.addEventListener(type, wrappedListener, options);\n }\n return super.addEventListener(type, listener, options);\n }\n };\n }\n if (typeof globalThis.MutationObserver !== \"undefined\") {\n const __MutationObserver = globalThis.MutationObserver;\n globalThis.MutationObserver = class extends __MutationObserver {\n constructor(callback) {\n const capturedLogicalContext = currentLogicalContext;\n const wrappedCallback = (mutations, observer) => {\n const adjustment = {\n contextToUse: capturedLogicalContext\n };\n return trampoline(\n adjustment,\n callback,\n void 0,\n mutations,\n observer\n );\n };\n super(wrappedCallback);\n }\n };\n }\n if (typeof globalThis.ResizeObserver !== \"undefined\") {\n const __ResizeObserver = globalThis.ResizeObserver;\n globalThis.ResizeObserver = class extends __ResizeObserver {\n constructor(callback) {\n const capturedLogicalContext = currentLogicalContext;\n const wrappedCallback = (entries, observer) => {\n const adjustment = {\n contextToUse: capturedLogicalContext\n };\n return trampoline(adjustment, callback, void 0, entries, observer);\n };\n super(wrappedCallback);\n }\n };\n }\n if (typeof globalThis.IntersectionObserver !== \"undefined\") {\n const __IntersectionObserver = globalThis.IntersectionObserver;\n globalThis.IntersectionObserver = class extends __IntersectionObserver {\n constructor(callback, options) {\n const capturedLogicalContext = currentLogicalContext;\n const wrappedCallback = (entries, observer) => {\n const adjustment = {\n contextToUse: capturedLogicalContext\n };\n return trampoline(adjustment, callback, void 0, entries, observer);\n };\n super(wrappedCallback, options);\n }\n };\n }\n if (typeof globalThis.Worker !== \"undefined\") {\n const __Worker = globalThis.Worker;\n globalThis.Worker = class extends __Worker {\n constructor(scriptURL, options) {\n super(scriptURL, options);\n this._userHandlers = /* @__PURE__ */ new Map();\n const eventHandlerProperties = [\n \"onmessage\",\n \"onmessageerror\",\n \"onerror\"\n ];\n eventHandlerProperties.forEach((prop) => {\n Object.defineProperty(this, prop, {\n get: () => this._userHandlers.get(prop) || null,\n set: (newHandler) => {\n this._userHandlers.set(prop, newHandler);\n if (newHandler && typeof newHandler === \"function\") {\n const capturedLogicalContext = currentLogicalContext;\n const wrappedHandler = function(event) {\n const adjustment = {\n contextToUse: capturedLogicalContext\n };\n return trampoline(adjustment, newHandler, this, event);\n };\n const parentProto = Object.getPrototypeOf(\n Object.getPrototypeOf(this)\n );\n const descriptor = Object.getOwnPropertyDescriptor(\n parentProto,\n prop\n );\n if (descriptor && descriptor.set) {\n descriptor.set.call(this, wrappedHandler);\n } else {\n this[`_${prop}`] = wrappedHandler;\n }\n } else {\n const parentProto = Object.getPrototypeOf(\n Object.getPrototypeOf(this)\n );\n const descriptor = Object.getOwnPropertyDescriptor(\n parentProto,\n prop\n );\n if (descriptor && descriptor.set) {\n descriptor.set.call(this, null);\n } else {\n this[`_${prop}`] = null;\n }\n }\n },\n configurable: true,\n enumerable: true\n });\n });\n }\n addEventListener(type, listener, options) {\n const capturedLogicalContext = currentLogicalContext;\n if (!listener) {\n return super.addEventListener(type, listener, options);\n }\n if (typeof listener === \"function\") {\n const wrappedListener = (event) => {\n const adjustment = {\n contextToUse: capturedLogicalContext\n };\n return trampoline(adjustment, listener, event.currentTarget, event);\n };\n return super.addEventListener(type, wrappedListener, options);\n } else if (typeof listener === \"object\" && \"handleEvent\" in listener) {\n const wrappedListener = {\n handleEvent: (event) => {\n const adjustment = {\n contextToUse: capturedLogicalContext\n };\n return trampoline(adjustment, () => listener.handleEvent(event));\n }\n };\n return super.addEventListener(type, wrappedListener, options);\n }\n return super.addEventListener(type, listener, options);\n }\n };\n }\n if (typeof globalThis.MessagePort !== \"undefined\") {\n const __MessagePort = globalThis.MessagePort;\n const createMessagePortWrapper = (originalPort) => {\n const _userHandlers = /* @__PURE__ */ new Map();\n const eventHandlerProperties = [\"onmessage\", \"onmessageerror\"];\n eventHandlerProperties.forEach((prop) => {\n Object.defineProperty(originalPort, prop, {\n get: () => _userHandlers.get(prop) || null,\n set: (newHandler) => {\n _userHandlers.set(prop, newHandler);\n if (newHandler && typeof newHandler === \"function\") {\n const capturedLogicalContext = currentLogicalContext;\n const wrappedHandler = function(event) {\n const adjustment = {\n contextToUse: capturedLogicalContext\n };\n return trampoline(adjustment, newHandler, this, event);\n };\n const descriptor = Object.getOwnPropertyDescriptor(\n __MessagePort.prototype,\n prop\n );\n if (descriptor && descriptor.set) {\n descriptor.set.call(originalPort, wrappedHandler);\n }\n } else {\n const descriptor = Object.getOwnPropertyDescriptor(\n __MessagePort.prototype,\n prop\n );\n if (descriptor && descriptor.set) {\n descriptor.set.call(originalPort, null);\n }\n }\n },\n configurable: true,\n enumerable: true\n });\n });\n const originalAddEventListener = originalPort.addEventListener;\n originalPort.addEventListener = function(type, listener, options) {\n const capturedLogicalContext = currentLogicalContext;\n if (!listener) {\n return originalAddEventListener.call(\n this,\n type,\n listener,\n options\n );\n }\n if (typeof listener === \"function\") {\n const wrappedListener = (event) => {\n const adjustment = {\n contextToUse: capturedLogicalContext\n };\n return trampoline(adjustment, listener, event.currentTarget, event);\n };\n return originalAddEventListener.call(\n this,\n type,\n wrappedListener,\n options\n );\n } else if (typeof listener === \"object\" && \"handleEvent\" in listener) {\n const wrappedListener = {\n handleEvent: (event) => {\n const adjustment = {\n contextToUse: capturedLogicalContext\n };\n return trampoline(adjustment, () => listener.handleEvent(event));\n }\n };\n return originalAddEventListener.call(\n this,\n type,\n wrappedListener,\n options\n );\n }\n return originalAddEventListener.call(this, type, listener, options);\n };\n return originalPort;\n };\n if (typeof globalThis.MessageChannel !== \"undefined\") {\n const __MessageChannel = globalThis.MessageChannel;\n globalThis.MessageChannel = class extends __MessageChannel {\n constructor() {\n super();\n createMessagePortWrapper(this.port1);\n createMessagePortWrapper(this.port2);\n }\n };\n }\n }\n};\nconst setLogicalContextValue = (key, value) => {\n prepare();\n if (value !== void 0) {\n currentLogicalContext.data.set(key, value);\n } else {\n currentLogicalContext.data.delete(key);\n }\n};\nconst getLogicalContextValue = (key) => {\n prepare();\n return currentLogicalContext.data.get(key);\n};\nconst runOnNewLogicalContext = (prefix, handler) => {\n const previousLogicalContext = currentLogicalContext;\n setCurrentLogicalContext(\n createLogicalContext(Symbol(`${prefix}-${crypto.randomUUID()}`))\n );\n try {\n return handler();\n } finally {\n setCurrentLogicalContext(previousLogicalContext);\n }\n};\nconst getCurrentLogicalContextId = () => {\n prepare();\n return currentLogicalContext.id;\n};\nconst createAsyncLocal = () => {\n const key = Symbol(`async-local-${crypto.randomUUID()}`);\n return {\n setValue: (value) => {\n setLogicalContextValue(key, value);\n },\n getValue: () => {\n return getLogicalContextValue(key);\n }\n };\n};\nconst ABORTED_ERROR$1 = () => new Error(\"Semaphore acquisition was aborted\");\nconst INVALID_COUNT_ERROR = () => new Error(\"Semaphore count must be greater than 0\");\nconst createSemaphoreHandle = (releaseCallback) => {\n let isActive = true;\n const release = () => {\n if (!isActive) {\n return;\n }\n isActive = false;\n releaseCallback();\n };\n return {\n get isActive() {\n return isActive;\n },\n release,\n [Symbol.dispose]: release\n };\n};\nconst createSemaphore = (count, maxConsecutiveCalls = 20) => {\n if (count < 1) {\n throw INVALID_COUNT_ERROR();\n }\n let availableCount = count;\n const queue = [];\n let consecutiveCallCount = 0;\n const processQueue = () => {\n var _a;\n while (availableCount > 0 && queue.length > 0) {\n const item = queue.shift();\n if ((_a = item.signal) == null ? void 0 : _a.aborted) {\n item.reject(ABORTED_ERROR$1());\n continue;\n }\n availableCount--;\n const semaphoreHandle = createSemaphoreHandle(releaseSemaphore);\n item.resolve(semaphoreHandle);\n }\n };\n const scheduleNextProcess = () => {\n consecutiveCallCount++;\n if (consecutiveCallCount >= maxConsecutiveCalls) {\n consecutiveCallCount = 0;\n defer(processQueue);\n } else {\n processQueue();\n }\n };\n const releaseSemaphore = () => {\n availableCount++;\n scheduleNextProcess();\n };\n const removeFromQueue = (item) => {\n const index = queue.indexOf(item);\n if (index !== -1) {\n queue.splice(index, 1);\n }\n };\n const acquire = async (signal) => {\n if (signal) {\n if (signal.aborted) {\n throw ABORTED_ERROR$1();\n }\n if (availableCount > 0) {\n availableCount--;\n return createSemaphoreHandle(releaseSemaphore);\n }\n return new Promise((resolve, reject) => {\n const queueItem = {\n resolve: void 0,\n reject: void 0,\n signal\n };\n const abortHandle = onAbort(signal, () => {\n removeFromQueue(queueItem);\n reject(ABORTED_ERROR$1());\n });\n queueItem.resolve = (handle) => {\n abortHandle.release();\n resolve(handle);\n };\n queueItem.reject = (error) => {\n abortHandle.release();\n reject(error);\n };\n queue.push(queueItem);\n processQueue();\n });\n } else {\n if (availableCount > 0) {\n availableCount--;\n return createSemaphoreHandle(releaseSemaphore);\n }\n return new Promise((resolve, reject) => {\n queue.push({\n resolve,\n reject\n });\n processQueue();\n });\n }\n };\n const result = {\n acquire,\n waiter: {\n wait: acquire\n },\n get availableCount() {\n return availableCount;\n },\n get pendingCount() {\n return queue.length;\n }\n };\n return result;\n};\nconst ABORTED_ERROR = () => new Error(\"Lock acquisition was aborted\");\nconst createReadLockHandle = (releaseCallback) => {\n let isActive = true;\n const release = () => {\n if (!isActive) {\n return;\n }\n isActive = false;\n releaseCallback();\n };\n return {\n get isActive() {\n return isActive;\n },\n release,\n [Symbol.dispose]: release\n };\n};\nconst createWriteLockHandle = (releaseCallback) => {\n let isActive = true;\n const release = () => {\n if (!isActive) {\n return;\n }\n isActive = false;\n releaseCallback();\n };\n return {\n get isActive() {\n return isActive;\n },\n release,\n [Symbol.dispose]: release\n };\n};\nfunction createReaderWriterLock(optionsOrMaxCalls) {\n var _a, _b;\n let policy = \"write-preferring\";\n let maxConsecutiveCalls = 20;\n if (typeof optionsOrMaxCalls === \"number\") {\n maxConsecutiveCalls = optionsOrMaxCalls;\n } else if (optionsOrMaxCalls) {\n policy = (_a = optionsOrMaxCalls.policy) != null ? _a : \"write-preferring\";\n maxConsecutiveCalls = (_b = optionsOrMaxCalls.maxConsecutiveCalls) != null ? _b : 20;\n }\n let currentReaders = 0;\n let hasWriter = false;\n const readQueue = [];\n const writeQueue = [];\n let consecutiveCallCount = 0;\n const processQueues = () => {\n var _a2, _b2, _c, _d;\n if (policy === \"write-preferring\") {\n if (!hasWriter && currentReaders === 0 && writeQueue.length > 0) {\n const item = writeQueue.shift();\n if ((_a2 = item.signal) == null ? void 0 : _a2.aborted) {\n item.reject(ABORTED_ERROR());\n scheduleNextProcess();\n return;\n }\n hasWriter = true;\n const writeLockHandle = createWriteLockHandle(releaseWriteLock);\n item.resolve(writeLockHandle);\n } else if (!hasWriter && writeQueue.length === 0 && readQueue.length > 0) {\n const readersToProcess = [];\n while (readQueue.length > 0) {\n const item = readQueue.shift();\n if ((_b2 = item.signal) == null ? void 0 : _b2.aborted) {\n item.reject(ABORTED_ERROR());\n } else {\n readersToProcess.push(item);\n }\n }\n for (const item of readersToProcess) {\n currentReaders++;\n const readLockHandle = createReadLockHandle(releaseReadLock);\n item.resolve(readLockHandle);\n }\n }\n } else {\n if (!hasWriter && readQueue.length > 0) {\n const readersToProcess = [];\n while (readQueue.length > 0) {\n const item = readQueue.shift();\n if ((_c = item.signal) == null ? void 0 : _c.aborted) {\n item.reject(ABORTED_ERROR());\n } else {\n readersToProcess.push(item);\n }\n }\n for (const item of readersToProcess) {\n currentReaders++;\n const readLockHandle = createReadLockHandle(releaseReadLock);\n item.resolve(readLockHandle);\n }\n } else if (!hasWriter && currentReaders === 0 && writeQueue.length > 0) {\n const item = writeQueue.shift();\n if ((_d = item.signal) == null ? void 0 : _d.aborted) {\n item.reject(ABORTED_ERROR());\n scheduleNextProcess();\n return;\n }\n hasWriter = true;\n const writeLockHandle = createWriteLockHandle(releaseWriteLock);\n item.resolve(writeLockHandle);\n }\n }\n };\n const scheduleNextProcess = () => {\n consecutiveCallCount++;\n if (consecutiveCallCount >= maxConsecutiveCalls) {\n consecutiveCallCount = 0;\n defer(processQueues);\n } else {\n processQueues();\n }\n };\n const releaseReadLock = () => {\n if (currentReaders > 0) {\n currentReaders--;\n if (currentReaders === 0) {\n scheduleNextProcess();\n }\n }\n };\n const releaseWriteLock = () => {\n if (hasWriter) {\n hasWriter = false;\n scheduleNextProcess();\n }\n };\n const removeFromReadQueue = (item) => {\n const index = readQueue.indexOf(item);\n if (index !== -1) {\n readQueue.splice(index, 1);\n }\n };\n const removeFromWriteQueue = (item) => {\n const index = writeQueue.indexOf(item);\n if (index !== -1) {\n writeQueue.splice(index, 1);\n }\n };\n const readLock = async (signal) => {\n if (signal) {\n if (signal.aborted) {\n throw ABORTED_ERROR();\n }\n const canAcquireImmediately = policy === \"read-preferring\" ? !hasWriter : !hasWriter && writeQueue.length === 0;\n if (canAcquireImmediately) {\n currentReaders++;\n return createReadLockHandle(releaseReadLock);\n }\n return new Promise((resolve, reject) => {\n const queueItem = {\n resolve: void 0,\n reject: void 0,\n signal\n };\n const abortHandle = onAbort(signal, () => {\n removeFromReadQueue(queueItem);\n reject(ABORTED_ERROR());\n });\n queueItem.resolve = (handle) => {\n abortHandle.release();\n resolve(handle);\n };\n queueItem.reject = (error) => {\n abortHandle.release();\n reject(error);\n };\n readQueue.push(queueItem);\n processQueues();\n });\n } else {\n const canAcquireImmediately = policy === \"read-preferring\" ? !hasWriter : !hasWriter && writeQueue.length === 0;\n if (canAcquireImmediately) {\n currentReaders++;\n return createReadLockHandle(releaseReadLock);\n }\n return new Promise((resolve, reject) => {\n readQueue.push({\n resolve,\n reject\n });\n processQueues();\n });\n }\n };\n const writeLock = async (signal) => {\n if (signal) {\n if (signal.aborted) {\n throw ABORTED_ERROR();\n }\n if (!hasWriter && currentReaders === 0) {\n hasWriter = true;\n return createWriteLockHandle(releaseWriteLock);\n }\n return new Promise((resolve, reject) => {\n const queueItem = {\n resolve: void 0,\n reject: void 0,\n signal\n };\n const abortHandle = onAbort(signal, () => {\n removeFromWriteQueue(queueItem);\n reject(ABORTED_ERROR());\n });\n queueItem.resolve = (handle) => {\n abortHandle.release();\n resolve(handle);\n };\n queueItem.reject = (error) => {\n abortHandle.release();\n reject(error);\n };\n writeQueue.push(queueItem);\n processQueues();\n });\n } else {\n if (!hasWriter && currentReaders === 0) {\n hasWriter = true;\n return createWriteLockHandle(releaseWriteLock);\n }\n return new Promise((resolve, reject) => {\n writeQueue.push({\n resolve,\n reject\n });\n processQueues();\n });\n }\n };\n const readWaiter = {\n wait: readLock\n };\n const writeWaiter = {\n wait: writeLock\n };\n return {\n readLock,\n writeLock,\n readWaiter,\n writeWaiter,\n get currentReaders() {\n return currentReaders;\n },\n get hasWriter() {\n return hasWriter;\n },\n get pendingReadersCount() {\n return readQueue.length;\n },\n get pendingWritersCount() {\n return writeQueue.length;\n }\n };\n}\nexport {\n createAsyncLocal,\n createMutex as createAsyncLock,\n createConditional,\n createDeferred,\n createDeferredGenerator,\n createManuallyConditional,\n createManuallyConditional as createManuallySignal,\n createMutex,\n createReaderWriterLock,\n createSemaphore,\n createConditional as createSignal,\n defer,\n delay,\n getCurrentLogicalContextId,\n getLogicalContextValue,\n onAbort,\n runOnNewLogicalContext,\n setLogicalContextValue\n};\n//# sourceMappingURL=index.mjs.map\n","// emsdk-env - Emscripten environment builder\n// Copyright (c) Kouji Matsui. (@kekyo@mi.kekyo.net)\n// Under MIT.\n// https://github.com/kekyo/emsdk-env\n\nimport { spawn } from 'child_process';\nimport { constants, access, mkdtemp, mkdir, rename, rm } from 'fs/promises';\nimport { homedir } from 'os';\nimport { join, resolve } from 'path';\nimport { createMutex } from 'async-primitives';\nimport { simpleGit, type SimpleGitOptions } from 'simple-git';\n\nconst DEFAULT_REPO_URL = 'https://github.com/emscripten-core/emsdk.git';\nconst DEFAULT_GIT_REF = 'main';\nconst DEFAULT_CACHE_DIR = join(homedir(), '.cache', 'emsdk-env');\n\nexport type PrepareEmsdkOptions = {\n targetVersion: string;\n cacheDir?: string;\n repoUrl?: string;\n gitPath?: string;\n};\n\nconst versionMutexes = new Map<string, ReturnType<typeof createMutex>>();\n\nconst getVersionMutex = (key: string) => {\n let mutex = versionMutexes.get(key);\n if (!mutex) {\n mutex = createMutex();\n versionMutexes.set(key, mutex);\n }\n return mutex;\n};\n\nconst ensureNonEmpty = (value: string, label: string) => {\n if (value.trim().length === 0) {\n throw new TypeError(`${label} must be a non-empty string.`);\n }\n};\n\nconst sanitizeSegment = (value: string) => {\n const trimmed = value.trim();\n ensureNonEmpty(trimmed, 'targetVersion');\n const sanitized = trimmed.replace(/[^A-Za-z0-9._-]/g, '_');\n if (sanitized === '.' || sanitized === '..' || sanitized.length === 0) {\n throw new TypeError('targetVersion results in an unsafe path segment.');\n }\n return sanitized;\n};\n\nconst pathExists = async (targetPath: string) => {\n try {\n await access(targetPath, constants.F_OK);\n return true;\n } catch {\n return false;\n }\n};\n\nconst runCommand = async (command: string, args: string[], cwd: string) =>\n new Promise<void>((resolvePromise, rejectPromise) => {\n const child = spawn(command, args, {\n cwd,\n stdio: 'inherit',\n });\n child.once('error', (error) => {\n rejectPromise(error);\n });\n child.once('close', (code) => {\n if (code === 0) {\n resolvePromise();\n return;\n }\n rejectPromise(\n new Error(\n `Command failed: ${command} ${args.join(' ')} (exit code ${code})`\n )\n );\n });\n });\n\nconst resolveEmsdkCommand = () =>\n process.platform === 'win32' ? 'emsdk.bat' : './emsdk';\n\nconst createGitClient = (baseDir: string, gitPath: string) =>\n simpleGit({\n baseDir,\n binary: gitPath,\n } satisfies Partial<SimpleGitOptions>);\n\nconst runEmsdk = async (repoDir: string, args: string[]) => {\n if (process.platform === 'win32') {\n await runCommand('cmd', ['/c', 'emsdk.bat', ...args], repoDir);\n return;\n }\n await runCommand(resolveEmsdkCommand(), args, repoDir);\n};\n\nconst ensureDirectory = async (targetPath: string) => {\n await mkdir(targetPath, { recursive: true });\n};\n\nconst isAlreadyExistsError = (error: unknown) =>\n error instanceof Error &&\n 'code' in error &&\n (error as NodeJS.ErrnoException).code !== undefined &&\n ['EEXIST', 'ENOTEMPTY', 'EISDIR'].includes(\n String((error as NodeJS.ErrnoException).code)\n );\n\nexport const prepareEmsdk = async (\n options: PrepareEmsdkOptions\n): Promise<string> => {\n if (!options) {\n throw new TypeError('options must be provided.');\n }\n if (typeof options.targetVersion !== 'string') {\n throw new TypeError('targetVersion must be a string.');\n }\n ensureNonEmpty(options.targetVersion, 'targetVersion');\n\n const cacheDir = resolve(options.cacheDir ?? DEFAULT_CACHE_DIR);\n const repoUrl = options.repoUrl ?? DEFAULT_REPO_URL;\n const gitPath = options.gitPath ?? 'git';\n\n const versionDir = sanitizeSegment(options.targetVersion);\n const finalDir = resolve(cacheDir, versionDir);\n\n const mutex = getVersionMutex(finalDir);\n const lock = await mutex.lock();\n try {\n if (await pathExists(finalDir)) {\n return finalDir;\n }\n\n await ensureDirectory(cacheDir);\n\n const tempRoot = await mkdtemp(join(cacheDir, '.tmp-'));\n const tempRepoDir = join(tempRoot, 'emsdk');\n\n try {\n const git = createGitClient(cacheDir, gitPath);\n await git.clone(repoUrl, tempRepoDir, [\n '--depth',\n '1',\n '--branch',\n DEFAULT_GIT_REF,\n ]);\n await runEmsdk(tempRepoDir, ['install', options.targetVersion]);\n\n try {\n await rename(tempRepoDir, finalDir);\n } catch (error) {\n if (isAlreadyExistsError(error)) {\n return finalDir;\n }\n throw error;\n }\n } finally {\n await rm(tempRoot, { recursive: true, force: true });\n }\n\n await runEmsdk(finalDir, ['activate', options.targetVersion]);\n return finalDir;\n } finally {\n lock.release();\n }\n};\n"],"names":["resolve"],"mappings":"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","x_google_ignoreList":[0]}
package/dist/vite.cjs ADDED
@@ -0,0 +1,22 @@
1
+ /*!
2
+ * name: emsdk-env
3
+ * version: 0.1.0
4
+ * description: Emscripten environment builder
5
+ * author: Kouji Matsui (@kekyo@mi.kekyo.net)
6
+ * license: MIT
7
+ * repository.url: https://github.com/kekyo/emsdk-env
8
+ * git.commit.hash: 32f73259bc38b9fcc19c26f3012f0b87c28963e4
9
+ */
10
+
11
+ "use strict";
12
+ const index = require("./index.cjs");
13
+ const emsdkEnv = (options) => ({
14
+ name: "emsdkEnv",
15
+ apply: "build",
16
+ enforce: "pre",
17
+ async buildStart() {
18
+ await index.prepareEmsdk(options);
19
+ }
20
+ });
21
+ module.exports = emsdkEnv;
22
+ //# sourceMappingURL=vite.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"vite.cjs","sources":["../src/vite/index.ts"],"sourcesContent":["// emsdk-env - Emscripten environment builder\n// Copyright (c) Kouji Matsui. (@kekyo@mi.kekyo.net)\n// Under MIT.\n// https://github.com/kekyo/emsdk-env\n\nimport type { Plugin } from 'vite';\nimport { prepareEmsdk } from '../index';\nimport type { PrepareEmsdkOptions } from '../index';\n\nconst emsdkEnv = (options: PrepareEmsdkOptions): Plugin => ({\n name: 'emsdkEnv',\n apply: 'build',\n enforce: 'pre',\n async buildStart() {\n await prepareEmsdk(options);\n },\n});\n\nexport default emsdkEnv;\n"],"names":["prepareEmsdk"],"mappings":";;;;;;;;;;;;AASA,MAAM,WAAW,CAAC,aAA0C;AAAA,EAC1D,MAAM;AAAA,EACN,OAAO;AAAA,EACP,SAAS;AAAA,EACT,MAAM,aAAa;AACjB,UAAMA,MAAAA,aAAa,OAAO;AAAA,EAC5B;AACF;;"}
package/dist/vite.d.ts ADDED
@@ -0,0 +1,23 @@
1
+ /*!
2
+ * name: emsdk-env
3
+ * version: 0.1.0
4
+ * description: Emscripten environment builder
5
+ * author: Kouji Matsui (@kekyo@mi.kekyo.net)
6
+ * license: MIT
7
+ * repository.url: https://github.com/kekyo/emsdk-env
8
+ * git.commit.hash: 32f73259bc38b9fcc19c26f3012f0b87c28963e4
9
+ */
10
+
11
+ import { Plugin } from 'vite';
12
+
13
+ declare const emsdkEnv: (options: PrepareEmsdkOptions) => Plugin;
14
+ export default emsdkEnv;
15
+
16
+ declare type PrepareEmsdkOptions = {
17
+ targetVersion: string;
18
+ cacheDir?: string;
19
+ repoUrl?: string;
20
+ gitPath?: string;
21
+ };
22
+
23
+ export { }
package/dist/vite.mjs ADDED
@@ -0,0 +1,23 @@
1
+ /*!
2
+ * name: emsdk-env
3
+ * version: 0.1.0
4
+ * description: Emscripten environment builder
5
+ * author: Kouji Matsui (@kekyo@mi.kekyo.net)
6
+ * license: MIT
7
+ * repository.url: https://github.com/kekyo/emsdk-env
8
+ * git.commit.hash: 32f73259bc38b9fcc19c26f3012f0b87c28963e4
9
+ */
10
+
11
+ import { prepareEmsdk } from "./index.mjs";
12
+ const emsdkEnv = (options) => ({
13
+ name: "emsdkEnv",
14
+ apply: "build",
15
+ enforce: "pre",
16
+ async buildStart() {
17
+ await prepareEmsdk(options);
18
+ }
19
+ });
20
+ export {
21
+ emsdkEnv as default
22
+ };
23
+ //# sourceMappingURL=vite.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"vite.mjs","sources":["../src/vite/index.ts"],"sourcesContent":["// emsdk-env - Emscripten environment builder\n// Copyright (c) Kouji Matsui. (@kekyo@mi.kekyo.net)\n// Under MIT.\n// https://github.com/kekyo/emsdk-env\n\nimport type { Plugin } from 'vite';\nimport { prepareEmsdk } from '../index';\nimport type { PrepareEmsdkOptions } from '../index';\n\nconst emsdkEnv = (options: PrepareEmsdkOptions): Plugin => ({\n name: 'emsdkEnv',\n apply: 'build',\n enforce: 'pre',\n async buildStart() {\n await prepareEmsdk(options);\n },\n});\n\nexport default emsdkEnv;\n"],"names":[],"mappings":";;;;;;;;;;;AASA,MAAM,WAAW,CAAC,aAA0C;AAAA,EAC1D,MAAM;AAAA,EACN,OAAO;AAAA,EACP,SAAS;AAAA,EACT,MAAM,aAAa;AACjB,UAAM,aAAa,OAAO;AAAA,EAC5B;AACF;"}
package/package.json ADDED
@@ -0,0 +1,74 @@
1
+ {
2
+ "git": {
3
+ "tags": [
4
+ "0.1.0"
5
+ ],
6
+ "branches": [
7
+ "main"
8
+ ],
9
+ "version": "0.1.0",
10
+ "commit": {
11
+ "hash": "32f73259bc38b9fcc19c26f3012f0b87c28963e4",
12
+ "shortHash": "32f7325",
13
+ "date": "2026-02-16T17:30:53+09:00",
14
+ "message": "Initial commit"
15
+ }
16
+ },
17
+ "version": "0.1.0",
18
+ "name": "emsdk-env",
19
+ "description": "Emscripten environment builder",
20
+ "author": "Kouji Matsui (@kekyo@mi.kekyo.net)",
21
+ "license": "MIT",
22
+ "repository": {
23
+ "type": "git",
24
+ "url": "https://github.com/kekyo/emsdk-env"
25
+ },
26
+ "homepage": "https://github.com/kekyo/emsdk-env#readme",
27
+ "keywords": [
28
+ "emsdk",
29
+ "emscripten",
30
+ "vite",
31
+ "cli"
32
+ ],
33
+ "type": "module",
34
+ "main": "./dist/index.mjs",
35
+ "module": "./dist/index.mjs",
36
+ "types": "./dist/index.d.ts",
37
+ "exports": {
38
+ ".": {
39
+ "types": "./dist/index.d.ts",
40
+ "import": "./dist/index.mjs",
41
+ "require": "./dist/index.cjs"
42
+ },
43
+ "./vite": {
44
+ "types": "./dist/vite.d.ts",
45
+ "import": "./dist/vite.mjs",
46
+ "require": "./dist/vite.cjs"
47
+ }
48
+ },
49
+ "files": [
50
+ "dist",
51
+ "LICENSE"
52
+ ],
53
+ "scripts": {
54
+ "build": "vite build",
55
+ "test": "npm run build && vitest run",
56
+ "pack": "npm run build && screw-up pack --pack-destination ./artifacts/"
57
+ },
58
+ "dependencies": {
59
+ "async-primitives": ">=1.5.0",
60
+ "simple-git": ">=3.0.0"
61
+ },
62
+ "peerDependencies": {
63
+ "vite": ">=5.0.0"
64
+ },
65
+ "devDependencies": {
66
+ "@types/node": ">=20.0.0",
67
+ "prettier-max": ">=1.14.0",
68
+ "screw-up": ">=1.26.0",
69
+ "typescript": ">=5.0.0",
70
+ "vite-plugin-dts": ">=4.5.0",
71
+ "vitest": ">=1.0.0"
72
+ },
73
+ "buildDate": "2026-02-18T09:32:56+09:00"
74
+ }