json-to-typed
Version:
Build to-typed objects from JSON files.
101 lines (100 loc) • 4.89 kB
JavaScript
var __classPrivateFieldGet = (this && this.__classPrivateFieldGet) || function (receiver, state, kind, f) {
if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a getter");
if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError("Cannot read private member from an object whose class did not declare it");
return kind === "m" ? f : kind === "a" ? f.call(receiver) : f ? f.value : state.get(receiver);
};
var __classPrivateFieldSet = (this && this.__classPrivateFieldSet) || function (receiver, state, value, kind, f) {
if (kind === "m") throw new TypeError("Private method is not writable");
if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a setter");
if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError("Cannot write private member to an object whose class did not declare it");
return (kind === "a" ? f.call(receiver, value) : f ? f.value = value : state.set(receiver, value)), value;
};
var _AwaitLock_acquired, _AwaitLock_waitingResolvers;
// Taken from https://github.com/ide/await-lock/blob/main/src/AwaitLock.ts
/**
* A mutex lock for coordination across async functions
*/
export default class AwaitLock {
constructor() {
_AwaitLock_acquired.set(this, false);
_AwaitLock_waitingResolvers.set(this, new Set());
}
/**
* Whether the lock is currently acquired or not. Accessing this property does not affect the
* status of the lock.
*/
get acquired() {
return __classPrivateFieldGet(this, _AwaitLock_acquired, "f");
}
/**
* Acquires the lock, waiting if necessary for it to become free if it is already locked. The
* returned promise is fulfilled once the lock is acquired.
*
* A timeout (in milliseconds) may be optionally provided. If the lock cannot be acquired before
* the timeout elapses, the returned promise is rejected with an error. The behavior of invalid
* timeout values depends on how `setTimeout` handles those values.
*
* After acquiring the lock, you **must** call `release` when you are done with it.
*/
acquireAsync({ timeout } = {}) {
if (!__classPrivateFieldGet(this, _AwaitLock_acquired, "f")) {
__classPrivateFieldSet(this, _AwaitLock_acquired, true, "f");
return Promise.resolve();
}
if (timeout == null) {
return new Promise((resolve) => {
__classPrivateFieldGet(this, _AwaitLock_waitingResolvers, "f").add(resolve);
});
}
let resolver;
let timer;
return Promise.race([
new Promise((resolve) => {
resolver = () => {
clearTimeout(timer);
resolve();
};
__classPrivateFieldGet(this, _AwaitLock_waitingResolvers, "f").add(resolver);
}),
new Promise((_, reject) => {
timer = setTimeout(() => {
__classPrivateFieldGet(this, _AwaitLock_waitingResolvers, "f").delete(resolver);
reject(new Error(`Timed out waiting for lock`));
}, timeout);
}),
]);
}
/**
* Acquires the lock if it is free and otherwise returns immediately without waiting. Returns
* `true` if the lock was free and is now acquired, and `false` otherwise.
*
* This method differs from calling `acquireAsync` with a zero-millisecond timeout in that it runs
* synchronously without waiting for the JavaScript task queue.
*/
tryAcquire() {
if (!__classPrivateFieldGet(this, _AwaitLock_acquired, "f")) {
__classPrivateFieldSet(this, _AwaitLock_acquired, true, "f");
return true;
}
return false;
}
/**
* Releases the lock and gives it to the next waiting acquirer, if there is one. Each acquirer
* must release the lock exactly once.
*/
release() {
if (!__classPrivateFieldGet(this, _AwaitLock_acquired, "f")) {
throw new Error(`Cannot release an unacquired lock`);
}
if (__classPrivateFieldGet(this, _AwaitLock_waitingResolvers, "f").size > 0) {
// Sets preserve insertion order like a queue
const [resolve] = __classPrivateFieldGet(this, _AwaitLock_waitingResolvers, "f");
__classPrivateFieldGet(this, _AwaitLock_waitingResolvers, "f").delete(resolve);
resolve();
}
else {
__classPrivateFieldSet(this, _AwaitLock_acquired, false, "f");
}
}
}
_AwaitLock_acquired = new WeakMap(), _AwaitLock_waitingResolvers = new WeakMap();