2022-05-12 17:25:46 -04:00
|
|
|
"use strict";
|
|
|
|
Object.defineProperty(exports, "__esModule", { value: true });
|
2022-05-04 21:30:48 -04:00
|
|
|
/**
|
|
|
|
* Run a task in a fixed period loop.
|
|
|
|
*/
|
2022-05-12 17:25:46 -04:00
|
|
|
class TaskLooper {
|
2022-05-04 21:30:48 -04:00
|
|
|
/**
|
|
|
|
* Build the looper with a function to invoke on a fixed period loop.
|
|
|
|
*
|
|
|
|
* @param {function} fn - the async function to invoke
|
|
|
|
*/
|
|
|
|
constructor(fn) {
|
|
|
|
this._fn = fn;
|
|
|
|
this._isStarted = false;
|
|
|
|
this._isLooping = false;
|
|
|
|
}
|
|
|
|
/**
|
|
|
|
* Start the task loop.
|
|
|
|
*
|
|
|
|
* @param {int} periodInMs the loop period in milliseconds
|
|
|
|
*/
|
|
|
|
start(periodInMs) {
|
2023-10-02 08:16:54 -04:00
|
|
|
if (periodInMs <= 0)
|
|
|
|
throw new Error("Looper period must be greater than 0 ms");
|
2022-05-04 21:30:48 -04:00
|
|
|
if (this._isStarted)
|
|
|
|
return;
|
|
|
|
this._isStarted = true;
|
|
|
|
this._runLoop(periodInMs);
|
|
|
|
}
|
|
|
|
/**
|
|
|
|
* Stop the task loop.
|
|
|
|
*/
|
|
|
|
stop() {
|
|
|
|
if (!this._isStarted)
|
|
|
|
throw new Error("Cannot stop TaskLooper because it's not started");
|
|
|
|
this._isStarted = false;
|
|
|
|
clearTimeout(this._timeout);
|
|
|
|
this._timeout = undefined;
|
|
|
|
}
|
|
|
|
async _runLoop(periodInMs) {
|
|
|
|
this._isLooping = true;
|
|
|
|
while (this._isStarted) {
|
|
|
|
const startTime = Date.now();
|
|
|
|
await this._fn();
|
|
|
|
if (this._isStarted)
|
|
|
|
await new Promise((resolve) => { this._timeout = setTimeout(resolve, periodInMs - (Date.now() - startTime)); });
|
|
|
|
}
|
|
|
|
this._isLooping = false;
|
|
|
|
}
|
|
|
|
}
|
2022-05-12 17:25:46 -04:00
|
|
|
exports.default = TaskLooper;
|
2022-05-04 21:30:48 -04:00
|
|
|
//# sourceMappingURL=TaskLooper.js.map
|