mirror of
https://github.com/logos-messaging/lab.waku.org.git
synced 2026-01-09 01:03:07 +00:00
45 lines
46 KiB
JavaScript
45 lines
46 KiB
JavaScript
"use strict";
|
|
/*
|
|
* ATTENTION: An "eval-source-map" devtool has been used.
|
|
* This devtool is neither made for production nor for readable output files.
|
|
* It uses "eval()" calls to create a separate source file with attached SourceMaps in the browser devtools.
|
|
* If you are trying to read the output file, select a different devtool (https://webpack.js.org/configuration/devtool/)
|
|
* or disable the default devtool with "devtool: false".
|
|
* If you are looking for production-ready output files, see mode: "production" (https://webpack.js.org/configuration/mode/).
|
|
*/
|
|
exports.id = "vendor-chunks/p-queue";
|
|
exports.ids = ["vendor-chunks/p-queue"];
|
|
exports.modules = {
|
|
|
|
/***/ "(ssr)/./node_modules/p-queue/dist/index.js":
|
|
/*!********************************************!*\
|
|
!*** ./node_modules/p-queue/dist/index.js ***!
|
|
\********************************************/
|
|
/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => {
|
|
|
|
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ \"default\": () => (/* binding */ PQueue)\n/* harmony export */ });\n/* harmony import */ var eventemitter3__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! eventemitter3 */ \"(ssr)/./node_modules/eventemitter3/index.mjs\");\n/* harmony import */ var p_timeout__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! p-timeout */ \"(ssr)/./node_modules/p-timeout/index.js\");\n/* harmony import */ var _priority_queue_js__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./priority-queue.js */ \"(ssr)/./node_modules/p-queue/dist/priority-queue.js\");\n\n\n\n/**\nPromise queue with concurrency control.\n*/ class PQueue extends eventemitter3__WEBPACK_IMPORTED_MODULE_0__.EventEmitter {\n #carryoverConcurrencyCount;\n #isIntervalIgnored;\n #intervalCount;\n #intervalCap;\n #interval;\n #intervalEnd;\n #intervalId;\n #timeoutId;\n #queue;\n #queueClass;\n #pending;\n // The `!` is needed because of https://github.com/microsoft/TypeScript/issues/32194\n #concurrency;\n #isPaused;\n #throwOnTimeout;\n // TODO: The `throwOnTimeout` option should affect the return types of `add()` and `addAll()`\n constructor(options){\n super();\n this.#intervalCount = 0;\n this.#intervalEnd = 0;\n this.#pending = 0;\n // eslint-disable-next-line @typescript-eslint/consistent-type-assertions\n options = {\n carryoverConcurrencyCount: false,\n intervalCap: Number.POSITIVE_INFINITY,\n interval: 0,\n concurrency: Number.POSITIVE_INFINITY,\n autoStart: true,\n queueClass: _priority_queue_js__WEBPACK_IMPORTED_MODULE_2__[\"default\"],\n ...options\n };\n if (!(typeof options.intervalCap === \"number\" && options.intervalCap >= 1)) {\n throw new TypeError(`Expected \\`intervalCap\\` to be a number from 1 and up, got \\`${options.intervalCap?.toString() ?? \"\"}\\` (${typeof options.intervalCap})`);\n }\n if (options.interval === undefined || !(Number.isFinite(options.interval) && options.interval >= 0)) {\n throw new TypeError(`Expected \\`interval\\` to be a finite number >= 0, got \\`${options.interval?.toString() ?? \"\"}\\` (${typeof options.interval})`);\n }\n this.#carryoverConcurrencyCount = options.carryoverConcurrencyCount;\n this.#isIntervalIgnored = options.intervalCap === Number.POSITIVE_INFINITY || options.interval === 0;\n this.#intervalCap = options.intervalCap;\n this.#interval = options.interval;\n this.#queue = new options.queueClass();\n this.#queueClass = options.queueClass;\n this.concurrency = options.concurrency;\n this.timeout = options.timeout;\n this.#throwOnTimeout = options.throwOnTimeout === true;\n this.#isPaused = options.autoStart === false;\n }\n get #doesIntervalAllowAnother() {\n return this.#isIntervalIgnored || this.#intervalCount < this.#intervalCap;\n }\n get #doesConcurrentAllowAnother() {\n return this.#pending < this.#concurrency;\n }\n #next() {\n this.#pending--;\n this.#tryToStartAnother();\n this.emit(\"next\");\n }\n #onResumeInterval() {\n this.#onInterval();\n this.#initializeIntervalIfNeeded();\n this.#timeoutId = undefined;\n }\n get #isIntervalPaused() {\n const now = Date.now();\n if (this.#intervalId === undefined) {\n const delay = this.#intervalEnd - now;\n if (delay < 0) {\n // Act as the interval was done\n // We don't need to resume it here because it will be resumed on line 160\n this.#intervalCount = this.#carryoverConcurrencyCount ? this.#pending : 0;\n } else {\n // Act as the interval is pending\n if (this.#timeoutId === undefined) {\n this.#timeoutId = setTimeout(()=>{\n this.#onResumeInterval();\n }, delay);\n }\n return true;\n }\n }\n return false;\n }\n #tryToStartAnother() {\n if (this.#queue.size === 0) {\n // We can clear the interval (\"pause\")\n // Because we can redo it later (\"resume\")\n if (this.#intervalId) {\n clearInterval(this.#intervalId);\n }\n this.#intervalId = undefined;\n this.emit(\"empty\");\n if (this.#pending === 0) {\n this.emit(\"idle\");\n }\n return false;\n }\n if (!this.#isPaused) {\n const canInitializeInterval = !this.#isIntervalPaused;\n if (this.#doesIntervalAllowAnother && this.#doesConcurrentAllowAnother) {\n const job = this.#queue.dequeue();\n if (!job) {\n return false;\n }\n this.emit(\"active\");\n job();\n if (canInitializeInterval) {\n this.#initializeIntervalIfNeeded();\n }\n return true;\n }\n }\n return false;\n }\n #initializeIntervalIfNeeded() {\n if (this.#isIntervalIgnored || this.#intervalId !== undefined) {\n return;\n }\n this.#intervalId = setInterval(()=>{\n this.#onInterval();\n }, this.#interval);\n this.#intervalEnd = Date.now() + this.#interval;\n }\n #onInterval() {\n if (this.#intervalCount === 0 && this.#pending === 0 && this.#intervalId) {\n clearInterval(this.#intervalId);\n this.#intervalId = undefined;\n }\n this.#intervalCount = this.#carryoverConcurrencyCount ? this.#pending : 0;\n this.#processQueue();\n }\n /**\n Executes all queued functions until it reaches the limit.\n */ #processQueue() {\n // eslint-disable-next-line no-empty\n while(this.#tryToStartAnother()){}\n }\n get concurrency() {\n return this.#concurrency;\n }\n set concurrency(newConcurrency) {\n if (!(typeof newConcurrency === \"number\" && newConcurrency >= 1)) {\n throw new TypeError(`Expected \\`concurrency\\` to be a number from 1 and up, got \\`${newConcurrency}\\` (${typeof newConcurrency})`);\n }\n this.#concurrency = newConcurrency;\n this.#processQueue();\n }\n async #throwOnAbort(signal) {\n return new Promise((_resolve, reject)=>{\n signal.addEventListener(\"abort\", ()=>{\n reject(signal.reason);\n }, {\n once: true\n });\n });\n }\n async add(function_, options = {}) {\n options = {\n timeout: this.timeout,\n throwOnTimeout: this.#throwOnTimeout,\n ...options\n };\n return new Promise((resolve, reject)=>{\n this.#queue.enqueue(async ()=>{\n this.#pending++;\n this.#intervalCount++;\n try {\n options.signal?.throwIfAborted();\n let operation = function_({\n signal: options.signal\n });\n if (options.timeout) {\n operation = (0,p_timeout__WEBPACK_IMPORTED_MODULE_1__[\"default\"])(Promise.resolve(operation), {\n milliseconds: options.timeout\n });\n }\n if (options.signal) {\n operation = Promise.race([\n operation,\n this.#throwOnAbort(options.signal)\n ]);\n }\n const result = await operation;\n resolve(result);\n this.emit(\"completed\", result);\n } catch (error) {\n if (error instanceof p_timeout__WEBPACK_IMPORTED_MODULE_1__.TimeoutError && !options.throwOnTimeout) {\n resolve();\n return;\n }\n reject(error);\n this.emit(\"error\", error);\n } finally{\n this.#next();\n }\n }, options);\n this.emit(\"add\");\n this.#tryToStartAnother();\n });\n }\n async addAll(functions, options) {\n return Promise.all(functions.map(async (function_)=>this.add(function_, options)));\n }\n /**\n Start (or resume) executing enqueued tasks within concurrency limit. No need to call this if queue is not paused (via `options.autoStart = false` or by `.pause()` method.)\n */ start() {\n if (!this.#isPaused) {\n return this;\n }\n this.#isPaused = false;\n this.#processQueue();\n return this;\n }\n /**\n Put queue execution on hold.\n */ pause() {\n this.#isPaused = true;\n }\n /**\n Clear the queue.\n */ clear() {\n this.#queue = new this.#queueClass();\n }\n /**\n Can be called multiple times. Useful if you for example add additional items at a later time.\n\n @returns A promise that settles when the queue becomes empty.\n */ async onEmpty() {\n // Instantly resolve if the queue is empty\n if (this.#queue.size === 0) {\n return;\n }\n await this.#onEvent(\"empty\");\n }\n /**\n @returns A promise that settles when the queue size is less than the given limit: `queue.size < limit`.\n\n If you want to avoid having the queue grow beyond a certain size you can `await queue.onSizeLessThan()` before adding a new item.\n\n Note that this only limits the number of items waiting to start. There could still be up to `concurrency` jobs already running that this call does not include in its calculation.\n */ async onSizeLessThan(limit) {\n // Instantly resolve if the queue is empty.\n if (this.#queue.size < limit) {\n return;\n }\n await this.#onEvent(\"next\", ()=>this.#queue.size < limit);\n }\n /**\n The difference with `.onEmpty` is that `.onIdle` guarantees that all work from the queue has finished. `.onEmpty` merely signals that the queue is empty, but it could mean that some promises haven't completed yet.\n\n @returns A promise that settles when the queue becomes empty, and all promises have completed; `queue.size === 0 && queue.pending === 0`.\n */ async onIdle() {\n // Instantly resolve if none pending and if nothing else is queued\n if (this.#pending === 0 && this.#queue.size === 0) {\n return;\n }\n await this.#onEvent(\"idle\");\n }\n async #onEvent(event, filter) {\n return new Promise((resolve)=>{\n const listener = ()=>{\n if (filter && !filter()) {\n return;\n }\n this.off(event, listener);\n resolve();\n };\n this.on(event, listener);\n });\n }\n /**\n Size of the queue, the number of queued items waiting to run.\n */ get size() {\n return this.#queue.size;\n }\n /**\n Size of the queue, filtered by the given options.\n\n For example, this can be used to find the number of items remaining in the queue with a specific priority level.\n */ sizeBy(options) {\n // eslint-disable-next-line unicorn/no-array-callback-reference\n return this.#queue.filter(options).length;\n }\n /**\n Number of running items (no longer in the queue).\n */ get pending() {\n return this.#pending;\n }\n /**\n Whether the queue is currently paused.\n */ get isPaused() {\n return this.#isPaused;\n }\n}\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"(ssr)/./node_modules/p-queue/dist/index.js","mappings":"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","sources":["webpack://flush-notes/./node_modules/p-queue/dist/index.js?7dea"],"sourcesContent":["import { EventEmitter } from 'eventemitter3';\nimport pTimeout, { TimeoutError } from 'p-timeout';\nimport PriorityQueue from './priority-queue.js';\n/**\nPromise queue with concurrency control.\n*/\nexport default class PQueue extends EventEmitter {\n    #carryoverConcurrencyCount;\n    #isIntervalIgnored;\n    #intervalCount = 0;\n    #intervalCap;\n    #interval;\n    #intervalEnd = 0;\n    #intervalId;\n    #timeoutId;\n    #queue;\n    #queueClass;\n    #pending = 0;\n    // The `!` is needed because of https://github.com/microsoft/TypeScript/issues/32194\n    #concurrency;\n    #isPaused;\n    #throwOnTimeout;\n    /**\n    Per-operation timeout in milliseconds. Operations fulfill once `timeout` elapses if they haven't already.\n\n    Applies to each future operation.\n    */\n    timeout;\n    // TODO: The `throwOnTimeout` option should affect the return types of `add()` and `addAll()`\n    constructor(options) {\n        super();\n        // eslint-disable-next-line @typescript-eslint/consistent-type-assertions\n        options = {\n            carryoverConcurrencyCount: false,\n            intervalCap: Number.POSITIVE_INFINITY,\n            interval: 0,\n            concurrency: Number.POSITIVE_INFINITY,\n            autoStart: true,\n            queueClass: PriorityQueue,\n            ...options,\n        };\n        if (!(typeof options.intervalCap === 'number' && options.intervalCap >= 1)) {\n            throw new TypeError(`Expected \\`intervalCap\\` to be a number from 1 and up, got \\`${options.intervalCap?.toString() ?? ''}\\` (${typeof options.intervalCap})`);\n        }\n        if (options.interval === undefined || !(Number.isFinite(options.interval) && options.interval >= 0)) {\n            throw new TypeError(`Expected \\`interval\\` to be a finite number >= 0, got \\`${options.interval?.toString() ?? ''}\\` (${typeof options.interval})`);\n        }\n        this.#carryoverConcurrencyCount = options.carryoverConcurrencyCount;\n        this.#isIntervalIgnored = options.intervalCap === Number.POSITIVE_INFINITY || options.interval === 0;\n        this.#intervalCap = options.intervalCap;\n        this.#interval = options.interval;\n        this.#queue = new options.queueClass();\n        this.#queueClass = options.queueClass;\n        this.concurrency = options.concurrency;\n        this.timeout = options.timeout;\n        this.#throwOnTimeout = options.throwOnTimeout === true;\n        this.#isPaused = options.autoStart === false;\n    }\n    get #doesIntervalAllowAnother() {\n        return this.#isIntervalIgnored || this.#intervalCount < this.#intervalCap;\n    }\n    get #doesConcurrentAllowAnother() {\n        return this.#pending < this.#concurrency;\n    }\n    #next() {\n        this.#pending--;\n        this.#tryToStartAnother();\n        this.emit('next');\n    }\n    #onResumeInterval() {\n        this.#onInterval();\n        this.#initializeIntervalIfNeeded();\n        this.#timeoutId = undefined;\n    }\n    get #isIntervalPaused() {\n        const now = Date.now();\n        if (this.#intervalId === undefined) {\n            const delay = this.#intervalEnd - now;\n            if (delay < 0) {\n                // Act as the interval was done\n                // We don't need to resume it here because it will be resumed on line 160\n                this.#intervalCount = (this.#carryoverConcurrencyCount) ? this.#pending : 0;\n            }\n            else {\n                // Act as the interval is pending\n                if (this.#timeoutId === undefined) {\n                    this.#timeoutId = setTimeout(() => {\n                        this.#onResumeInterval();\n                    }, delay);\n                }\n                return true;\n            }\n        }\n        return false;\n    }\n    #tryToStartAnother() {\n        if (this.#queue.size === 0) {\n            // We can clear the interval (\"pause\")\n            // Because we can redo it later (\"resume\")\n            if (this.#intervalId) {\n                clearInterval(this.#intervalId);\n            }\n            this.#intervalId = undefined;\n            this.emit('empty');\n            if (this.#pending === 0) {\n                this.emit('idle');\n            }\n            return false;\n        }\n        if (!this.#isPaused) {\n            const canInitializeInterval = !this.#isIntervalPaused;\n            if (this.#doesIntervalAllowAnother && this.#doesConcurrentAllowAnother) {\n                const job = this.#queue.dequeue();\n                if (!job) {\n                    return false;\n                }\n                this.emit('active');\n                job();\n                if (canInitializeInterval) {\n                    this.#initializeIntervalIfNeeded();\n                }\n                return true;\n            }\n        }\n        return false;\n    }\n    #initializeIntervalIfNeeded() {\n        if (this.#isIntervalIgnored || this.#intervalId !== undefined) {\n            return;\n        }\n        this.#intervalId = setInterval(() => {\n            this.#onInterval();\n        }, this.#interval);\n        this.#intervalEnd = Date.now() + this.#interval;\n    }\n    #onInterval() {\n        if (this.#intervalCount === 0 && this.#pending === 0 && this.#intervalId) {\n            clearInterval(this.#intervalId);\n            this.#intervalId = undefined;\n        }\n        this.#intervalCount = this.#carryoverConcurrencyCount ? this.#pending : 0;\n        this.#processQueue();\n    }\n    /**\n    Executes all queued functions until it reaches the limit.\n    */\n    #processQueue() {\n        // eslint-disable-next-line no-empty\n        while (this.#tryToStartAnother()) { }\n    }\n    get concurrency() {\n        return this.#concurrency;\n    }\n    set concurrency(newConcurrency) {\n        if (!(typeof newConcurrency === 'number' && newConcurrency >= 1)) {\n            throw new TypeError(`Expected \\`concurrency\\` to be a number from 1 and up, got \\`${newConcurrency}\\` (${typeof newConcurrency})`);\n        }\n        this.#concurrency = newConcurrency;\n        this.#processQueue();\n    }\n    async #throwOnAbort(signal) {\n        return new Promise((_resolve, reject) => {\n            signal.addEventListener('abort', () => {\n                reject(signal.reason);\n            }, { once: true });\n        });\n    }\n    async add(function_, options = {}) {\n        options = {\n            timeout: this.timeout,\n            throwOnTimeout: this.#throwOnTimeout,\n            ...options,\n        };\n        return new Promise((resolve, reject) => {\n            this.#queue.enqueue(async () => {\n                this.#pending++;\n                this.#intervalCount++;\n                try {\n                    options.signal?.throwIfAborted();\n                    let operation = function_({ signal: options.signal });\n                    if (options.timeout) {\n                        operation = pTimeout(Promise.resolve(operation), { milliseconds: options.timeout });\n                    }\n                    if (options.signal) {\n                        operation = Promise.race([operation, this.#throwOnAbort(options.signal)]);\n                    }\n                    const result = await operation;\n                    resolve(result);\n                    this.emit('completed', result);\n                }\n                catch (error) {\n                    if (error instanceof TimeoutError && !options.throwOnTimeout) {\n                        resolve();\n                        return;\n                    }\n                    reject(error);\n                    this.emit('error', error);\n                }\n                finally {\n                    this.#next();\n                }\n            }, options);\n            this.emit('add');\n            this.#tryToStartAnother();\n        });\n    }\n    async addAll(functions, options) {\n        return Promise.all(functions.map(async (function_) => this.add(function_, options)));\n    }\n    /**\n    Start (or resume) executing enqueued tasks within concurrency limit. No need to call this if queue is not paused (via `options.autoStart = false` or by `.pause()` method.)\n    */\n    start() {\n        if (!this.#isPaused) {\n            return this;\n        }\n        this.#isPaused = false;\n        this.#processQueue();\n        return this;\n    }\n    /**\n    Put queue execution on hold.\n    */\n    pause() {\n        this.#isPaused = true;\n    }\n    /**\n    Clear the queue.\n    */\n    clear() {\n        this.#queue = new this.#queueClass();\n    }\n    /**\n    Can be called multiple times. Useful if you for example add additional items at a later time.\n\n    @returns A promise that settles when the queue becomes empty.\n    */\n    async onEmpty() {\n        // Instantly resolve if the queue is empty\n        if (this.#queue.size === 0) {\n            return;\n        }\n        await this.#onEvent('empty');\n    }\n    /**\n    @returns A promise that settles when the queue size is less than the given limit: `queue.size < limit`.\n\n    If you want to avoid having the queue grow beyond a certain size you can `await queue.onSizeLessThan()` before adding a new item.\n\n    Note that this only limits the number of items waiting to start. There could still be up to `concurrency` jobs already running that this call does not include in its calculation.\n    */\n    async onSizeLessThan(limit) {\n        // Instantly resolve if the queue is empty.\n        if (this.#queue.size < limit) {\n            return;\n        }\n        await this.#onEvent('next', () => this.#queue.size < limit);\n    }\n    /**\n    The difference with `.onEmpty` is that `.onIdle` guarantees that all work from the queue has finished. `.onEmpty` merely signals that the queue is empty, but it could mean that some promises haven't completed yet.\n\n    @returns A promise that settles when the queue becomes empty, and all promises have completed; `queue.size === 0 && queue.pending === 0`.\n    */\n    async onIdle() {\n        // Instantly resolve if none pending and if nothing else is queued\n        if (this.#pending === 0 && this.#queue.size === 0) {\n            return;\n        }\n        await this.#onEvent('idle');\n    }\n    async #onEvent(event, filter) {\n        return new Promise(resolve => {\n            const listener = () => {\n                if (filter && !filter()) {\n                    return;\n                }\n                this.off(event, listener);\n                resolve();\n            };\n            this.on(event, listener);\n        });\n    }\n    /**\n    Size of the queue, the number of queued items waiting to run.\n    */\n    get size() {\n        return this.#queue.size;\n    }\n    /**\n    Size of the queue, filtered by the given options.\n\n    For example, this can be used to find the number of items remaining in the queue with a specific priority level.\n    */\n    sizeBy(options) {\n        // eslint-disable-next-line unicorn/no-array-callback-reference\n        return this.#queue.filter(options).length;\n    }\n    /**\n    Number of running items (no longer in the queue).\n    */\n    get pending() {\n        return this.#pending;\n    }\n    /**\n    Whether the queue is currently paused.\n    */\n    get isPaused() {\n        return this.#isPaused;\n    }\n}\n"],"names":["EventEmitter","pTimeout","TimeoutError","PriorityQueue","PQueue","carryoverConcurrencyCount","isIntervalIgnored","intervalCount","intervalCap","interval","intervalEnd","intervalId","timeoutId","queue","queueClass","pending","concurrency","isPaused","throwOnTimeout","constructor","options","Number","POSITIVE_INFINITY","autoStart","TypeError","toString","undefined","isFinite","timeout","doesIntervalAllowAnother","doesConcurrentAllowAnother","next","tryToStartAnother","emit","onResumeInterval","onInterval","initializeIntervalIfNeeded","isIntervalPaused","now","Date","delay","setTimeout","size","clearInterval","canInitializeInterval","job","dequeue","setInterval","processQueue","newConcurrency","throwOnAbort","signal","Promise","_resolve","reject","addEventListener","reason","once","add","function_","resolve","enqueue","throwIfAborted","operation","milliseconds","race","result","error","addAll","functions","all","map","start","pause","clear","onEmpty","onEvent","onSizeLessThan","limit","onIdle","event","filter","listener","off","on","sizeBy","length"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/p-queue/dist/index.js\n");
|
|
|
|
/***/ }),
|
|
|
|
/***/ "(ssr)/./node_modules/p-queue/dist/lower-bound.js":
|
|
/*!**************************************************!*\
|
|
!*** ./node_modules/p-queue/dist/lower-bound.js ***!
|
|
\**************************************************/
|
|
/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => {
|
|
|
|
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ \"default\": () => (/* binding */ lowerBound)\n/* harmony export */ });\n// Port of lower_bound from https://en.cppreference.com/w/cpp/algorithm/lower_bound\n// Used to compute insertion index to keep queue sorted after insertion\nfunction lowerBound(array, value, comparator) {\n let first = 0;\n let count = array.length;\n while(count > 0){\n const step = Math.trunc(count / 2);\n let it = first + step;\n if (comparator(array[it], value) <= 0) {\n first = ++it;\n count -= step + 1;\n } else {\n count = step;\n }\n }\n return first;\n}\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvcC1xdWV1ZS9kaXN0L2xvd2VyLWJvdW5kLmpzIiwibWFwcGluZ3MiOiI7Ozs7QUFBQSxtRkFBbUY7QUFDbkYsdUVBQXVFO0FBQ3hELFNBQVNBLFdBQVdDLEtBQUssRUFBRUMsS0FBSyxFQUFFQyxVQUFVO0lBQ3ZELElBQUlDLFFBQVE7SUFDWixJQUFJQyxRQUFRSixNQUFNSyxNQUFNO0lBQ3hCLE1BQU9ELFFBQVEsRUFBRztRQUNkLE1BQU1FLE9BQU9DLEtBQUtDLEtBQUssQ0FBQ0osUUFBUTtRQUNoQyxJQUFJSyxLQUFLTixRQUFRRztRQUNqQixJQUFJSixXQUFXRixLQUFLLENBQUNTLEdBQUcsRUFBRVIsVUFBVSxHQUFHO1lBQ25DRSxRQUFRLEVBQUVNO1lBQ1ZMLFNBQVNFLE9BQU87UUFDcEIsT0FDSztZQUNERixRQUFRRTtRQUNaO0lBQ0o7SUFDQSxPQUFPSDtBQUNYIiwic291cmNlcyI6WyJ3ZWJwYWNrOi8vZmx1c2gtbm90ZXMvLi9ub2RlX21vZHVsZXMvcC1xdWV1ZS9kaXN0L2xvd2VyLWJvdW5kLmpzPzQ3ZWIiXSwic291cmNlc0NvbnRlbnQiOlsiLy8gUG9ydCBvZiBsb3dlcl9ib3VuZCBmcm9tIGh0dHBzOi8vZW4uY3BwcmVmZXJlbmNlLmNvbS93L2NwcC9hbGdvcml0aG0vbG93ZXJfYm91bmRcbi8vIFVzZWQgdG8gY29tcHV0ZSBpbnNlcnRpb24gaW5kZXggdG8ga2VlcCBxdWV1ZSBzb3J0ZWQgYWZ0ZXIgaW5zZXJ0aW9uXG5leHBvcnQgZGVmYXVsdCBmdW5jdGlvbiBsb3dlckJvdW5kKGFycmF5LCB2YWx1ZSwgY29tcGFyYXRvcikge1xuICAgIGxldCBmaXJzdCA9IDA7XG4gICAgbGV0IGNvdW50ID0gYXJyYXkubGVuZ3RoO1xuICAgIHdoaWxlIChjb3VudCA+IDApIHtcbiAgICAgICAgY29uc3Qgc3RlcCA9IE1hdGgudHJ1bmMoY291bnQgLyAyKTtcbiAgICAgICAgbGV0IGl0ID0gZmlyc3QgKyBzdGVwO1xuICAgICAgICBpZiAoY29tcGFyYXRvcihhcnJheVtpdF0sIHZhbHVlKSA8PSAwKSB7XG4gICAgICAgICAgICBmaXJzdCA9ICsraXQ7XG4gICAgICAgICAgICBjb3VudCAtPSBzdGVwICsgMTtcbiAgICAgICAgfVxuICAgICAgICBlbHNlIHtcbiAgICAgICAgICAgIGNvdW50ID0gc3RlcDtcbiAgICAgICAgfVxuICAgIH1cbiAgICByZXR1cm4gZmlyc3Q7XG59XG4iXSwibmFtZXMiOlsibG93ZXJCb3VuZCIsImFycmF5IiwidmFsdWUiLCJjb21wYXJhdG9yIiwiZmlyc3QiLCJjb3VudCIsImxlbmd0aCIsInN0ZXAiLCJNYXRoIiwidHJ1bmMiLCJpdCJdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/p-queue/dist/lower-bound.js\n");
|
|
|
|
/***/ }),
|
|
|
|
/***/ "(ssr)/./node_modules/p-queue/dist/priority-queue.js":
|
|
/*!*****************************************************!*\
|
|
!*** ./node_modules/p-queue/dist/priority-queue.js ***!
|
|
\*****************************************************/
|
|
/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => {
|
|
|
|
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ \"default\": () => (/* binding */ PriorityQueue)\n/* harmony export */ });\n/* harmony import */ var _lower_bound_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./lower-bound.js */ \"(ssr)/./node_modules/p-queue/dist/lower-bound.js\");\n\nclass PriorityQueue {\n #queue;\n enqueue(run, options) {\n options = {\n priority: 0,\n ...options\n };\n const element = {\n priority: options.priority,\n run\n };\n if (this.size && this.#queue[this.size - 1].priority >= options.priority) {\n this.#queue.push(element);\n return;\n }\n const index = (0,_lower_bound_js__WEBPACK_IMPORTED_MODULE_0__[\"default\"])(this.#queue, element, (a, b)=>b.priority - a.priority);\n this.#queue.splice(index, 0, element);\n }\n dequeue() {\n const item = this.#queue.shift();\n return item?.run;\n }\n filter(options) {\n return this.#queue.filter((element)=>element.priority === options.priority).map((element)=>element.run);\n }\n get size() {\n return this.#queue.length;\n }\n constructor(){\n this.#queue = [];\n }\n}\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvcC1xdWV1ZS9kaXN0L3ByaW9yaXR5LXF1ZXVlLmpzIiwibWFwcGluZ3MiOiI7Ozs7O0FBQTBDO0FBQzNCLE1BQU1DO0lBQ2pCLENBQUNDLEtBQUssQ0FBTTtJQUNaQyxRQUFRQyxHQUFHLEVBQUVDLE9BQU8sRUFBRTtRQUNsQkEsVUFBVTtZQUNOQyxVQUFVO1lBQ1YsR0FBR0QsT0FBTztRQUNkO1FBQ0EsTUFBTUUsVUFBVTtZQUNaRCxVQUFVRCxRQUFRQyxRQUFRO1lBQzFCRjtRQUNKO1FBQ0EsSUFBSSxJQUFJLENBQUNJLElBQUksSUFBSSxJQUFJLENBQUMsQ0FBQ04sS0FBSyxDQUFDLElBQUksQ0FBQ00sSUFBSSxHQUFHLEVBQUUsQ0FBQ0YsUUFBUSxJQUFJRCxRQUFRQyxRQUFRLEVBQUU7WUFDdEUsSUFBSSxDQUFDLENBQUNKLEtBQUssQ0FBQ08sSUFBSSxDQUFDRjtZQUNqQjtRQUNKO1FBQ0EsTUFBTUcsUUFBUVYsMkRBQVVBLENBQUMsSUFBSSxDQUFDLENBQUNFLEtBQUssRUFBRUssU0FBUyxDQUFDSSxHQUFHQyxJQUFNQSxFQUFFTixRQUFRLEdBQUdLLEVBQUVMLFFBQVE7UUFDaEYsSUFBSSxDQUFDLENBQUNKLEtBQUssQ0FBQ1csTUFBTSxDQUFDSCxPQUFPLEdBQUdIO0lBQ2pDO0lBQ0FPLFVBQVU7UUFDTixNQUFNQyxPQUFPLElBQUksQ0FBQyxDQUFDYixLQUFLLENBQUNjLEtBQUs7UUFDOUIsT0FBT0QsTUFBTVg7SUFDakI7SUFDQWEsT0FBT1osT0FBTyxFQUFFO1FBQ1osT0FBTyxJQUFJLENBQUMsQ0FBQ0gsS0FBSyxDQUFDZSxNQUFNLENBQUMsQ0FBQ1YsVUFBWUEsUUFBUUQsUUFBUSxLQUFLRCxRQUFRQyxRQUFRLEVBQUVZLEdBQUcsQ0FBQyxDQUFDWCxVQUFZQSxRQUFRSCxHQUFHO0lBQzlHO0lBQ0EsSUFBSUksT0FBTztRQUNQLE9BQU8sSUFBSSxDQUFDLENBQUNOLEtBQUssQ0FBQ2lCLE1BQU07SUFDN0I7O2FBMUJBLENBQUNqQixLQUFLLEdBQUcsRUFBRTs7QUEyQmYiLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly9mbHVzaC1ub3Rlcy8uL25vZGVfbW9kdWxlcy9wLXF1ZXVlL2Rpc3QvcHJpb3JpdHktcXVldWUuanM/YTc3MyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgbG93ZXJCb3VuZCBmcm9tICcuL2xvd2VyLWJvdW5kLmpzJztcbmV4cG9ydCBkZWZhdWx0IGNsYXNzIFByaW9yaXR5UXVldWUge1xuICAgICNxdWV1ZSA9IFtdO1xuICAgIGVucXVldWUocnVuLCBvcHRpb25zKSB7XG4gICAgICAgIG9wdGlvbnMgPSB7XG4gICAgICAgICAgICBwcmlvcml0eTogMCxcbiAgICAgICAgICAgIC4uLm9wdGlvbnMsXG4gICAgICAgIH07XG4gICAgICAgIGNvbnN0IGVsZW1lbnQgPSB7XG4gICAgICAgICAgICBwcmlvcml0eTogb3B0aW9ucy5wcmlvcml0eSxcbiAgICAgICAgICAgIHJ1bixcbiAgICAgICAgfTtcbiAgICAgICAgaWYgKHRoaXMuc2l6ZSAmJiB0aGlzLiNxdWV1ZVt0aGlzLnNpemUgLSAxXS5wcmlvcml0eSA+PSBvcHRpb25zLnByaW9yaXR5KSB7XG4gICAgICAgICAgICB0aGlzLiNxdWV1ZS5wdXNoKGVsZW1lbnQpO1xuICAgICAgICAgICAgcmV0dXJuO1xuICAgICAgICB9XG4gICAgICAgIGNvbnN0IGluZGV4ID0gbG93ZXJCb3VuZCh0aGlzLiNxdWV1ZSwgZWxlbWVudCwgKGEsIGIpID0+IGIucHJpb3JpdHkgLSBhLnByaW9yaXR5KTtcbiAgICAgICAgdGhpcy4jcXVldWUuc3BsaWNlKGluZGV4LCAwLCBlbGVtZW50KTtcbiAgICB9XG4gICAgZGVxdWV1ZSgpIHtcbiAgICAgICAgY29uc3QgaXRlbSA9IHRoaXMuI3F1ZXVlLnNoaWZ0KCk7XG4gICAgICAgIHJldHVybiBpdGVtPy5ydW47XG4gICAgfVxuICAgIGZpbHRlcihvcHRpb25zKSB7XG4gICAgICAgIHJldHVybiB0aGlzLiNxdWV1ZS5maWx0ZXIoKGVsZW1lbnQpID0+IGVsZW1lbnQucHJpb3JpdHkgPT09IG9wdGlvbnMucHJpb3JpdHkpLm1hcCgoZWxlbWVudCkgPT4gZWxlbWVudC5ydW4pO1xuICAgIH1cbiAgICBnZXQgc2l6ZSgpIHtcbiAgICAgICAgcmV0dXJuIHRoaXMuI3F1ZXVlLmxlbmd0aDtcbiAgICB9XG59XG4iXSwibmFtZXMiOlsibG93ZXJCb3VuZCIsIlByaW9yaXR5UXVldWUiLCJxdWV1ZSIsImVucXVldWUiLCJydW4iLCJvcHRpb25zIiwicHJpb3JpdHkiLCJlbGVtZW50Iiwic2l6ZSIsInB1c2giLCJpbmRleCIsImEiLCJiIiwic3BsaWNlIiwiZGVxdWV1ZSIsIml0ZW0iLCJzaGlmdCIsImZpbHRlciIsIm1hcCIsImxlbmd0aCJdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/p-queue/dist/priority-queue.js\n");
|
|
|
|
/***/ })
|
|
|
|
};
|
|
; |