25 lines
18 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/it-parallel";
exports.ids = ["vendor-chunks/it-parallel"];
exports.modules = {
/***/ "(ssr)/./node_modules/it-parallel/dist/src/index.js":
/*!****************************************************!*\
!*** ./node_modules/it-parallel/dist/src/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 */ parallel)\n/* harmony export */ });\n/* harmony import */ var p_defer__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! p-defer */ \"(ssr)/./node_modules/p-defer/index.js\");\n/**\n * @packageDocumentation\n *\n * Takes an (async) iterable that emits promise-returning functions, invokes them in parallel up to the concurrency limit and emits the results as they become available, optionally in the same order as the input\n *\n * @example\n *\n * ```javascript\n * import parallel from 'it-parallel'\n * import all from 'it-all'\n * import delay from 'delay'\n *\n * // This can also be an iterator, async iterator, generator, etc\n * const input = [\n * async () => {\n * console.info('start 1')\n * await delay(500)\n *\n * console.info('end 1')\n * return 1\n * },\n * async () => {\n * console.info('start 2')\n * await delay(200)\n *\n * console.info('end 2')\n * return 2\n * },\n * async () => {\n * console.info('start 3')\n * await delay(100)\n *\n * console.info('end 3')\n * return 3\n * }\n * ]\n *\n * const result = await all(parallel(input, {\n * concurrency: 2\n * }))\n *\n * // output:\n * // start 1\n * // start 2\n * // end 2\n * // start 3\n * // end 3\n * // end 1\n *\n * console.info(result) // [2, 3, 1]\n * ```\n *\n * If order is important, pass `ordered: true` as an option:\n *\n * ```javascript\n * const result = await all(parallel(input, {\n * concurrency: 2,\n * ordered: true\n * }))\n *\n * // output:\n * // start 1\n * // start 2\n * // end 2\n * // start 3\n * // end 3\n * // end 1\n *\n * console.info(result) // [1, 2, 3]\n * ```\n */ \nconst CustomEvent = globalThis.CustomEvent ?? Event;\n/**\n * Takes an (async) iterator that emits promise-returning functions,\n * invokes them in parallel and emits the results as they become available but\n * in the same order as the input\n */ async function* parallel(source, options = {}) {\n let concurrency = options.concurrency ?? Infinity;\n if (concurrency < 1) {\n concurrency = Infinity;\n }\n const ordered = options.ordered == null ? false : options.ordered;\n const emitter = new EventTarget();\n const ops = [];\n let slotAvailable = (0,p_defer__WEBPACK_IMPORTED_MODULE_0__[\"default\"])();\n let resultAvailable = (0,p_defer__WEBPACK_IMPORTED_MODULE_0__[\"default\"])();\n let sourceFinished = false;\n let sourceErr;\n let opErred = false;\n emitter.addEventListener(\"task-complete\", ()=>{\n resultAvailable.resolve();\n });\n void Promise.resolve().then(async ()=>{\n try {\n for await (const task of source){\n if (ops.length === concurrency) {\n slotAvailable = (0,p_defer__WEBPACK_IMPORTED_MODULE_0__[\"default\"])();\n await slotAvailable.promise;\n }\n if (opErred) {\n break;\n }\n const op = {\n done: false\n };\n ops.push(op);\n task().then((result)=>{\n op.done = true;\n op.ok = true;\n op.value = result;\n emitter.dispatchEvent(new CustomEvent(\"task-complete\"));\n }, (err)=>{\n op.done = true;\n op.err = err;\n emitter.dispatchEvent(new CustomEvent(\"task-complete\"));\n });\n }\n sourceFinished = true;\n emitter.dispatchEvent(new CustomEvent(\"task-complete\"));\n } catch (err) {\n sourceErr = err;\n emitter.dispatchEvent(new CustomEvent(\"task-complete\"));\n }\n });\n function valuesAvailable() {\n if (ordered) {\n return ops[0]?.done;\n }\n return Boolean(ops.find((op)=>op.done));\n }\n function* yieldOrderedValues() {\n while(ops.length > 0 && ops[0].done){\n const op = ops[0];\n ops.shift();\n if (op.ok) {\n yield op.value;\n } else {\n // allow the source to exit\n opErred = true;\n slotAvailable.resolve();\n throw op.err;\n }\n slotAvailable.resolve();\n }\n }\n function* yieldUnOrderedValues() {\n // more values can become available while we wait for `yield`\n // to return control to this function\n while(valuesAvailable()){\n for(let i = 0; i < ops.length; i++){\n if (ops[i].done) {\n const op = ops[i];\n ops.splice(i, 1);\n i--;\n if (op.ok) {\n yield op.value;\n } else {\n opErred = true;\n slotAvailable.resolve();\n throw op.err;\n }\n slotAvailable.resolve();\n }\n }\n }\n }\n while(true){\n if (!valuesAvailable()) {\n resultAvailable = (0,p_defer__WEBPACK_IMPORTED_MODULE_0__[\"default\"])();\n await resultAvailable.promise;\n }\n if (sourceErr != null) {\n // the source threw an error, propagate it\n throw sourceErr;\n }\n if (ordered) {\n yield* yieldOrderedValues();\n } else {\n yield* yieldUnOrderedValues();\n }\n if (sourceFinished && ops.length === 0) {\n break;\n }\n }\n} //# sourceMappingURL=index.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"(ssr)/./node_modules/it-parallel/dist/src/index.js","mappings":";;;;;AAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CAsEC,GAC2B;AAC5B,MAAMC,cAAcC,WAAWD,WAAW,IAAIE;AAC9C;;;;CAIC,GACc,gBAAgBC,SAASC,MAAM,EAAEC,UAAU,CAAC,CAAC;IACxD,IAAIC,cAAcD,QAAQC,WAAW,IAAIC;IACzC,IAAID,cAAc,GAAG;QACjBA,cAAcC;IAClB;IACA,MAAMC,UAAUH,QAAQG,OAAO,IAAI,OAAO,QAAQH,QAAQG,OAAO;IACjE,MAAMC,UAAU,IAAIC;IACpB,MAAMC,MAAM,EAAE;IACd,IAAIC,gBAAgBb,mDAAKA;IACzB,IAAIc,kBAAkBd,mDAAKA;IAC3B,IAAIe,iBAAiB;IACrB,IAAIC;IACJ,IAAIC,UAAU;IACdP,QAAQQ,gBAAgB,CAAC,iBAAiB;QACtCJ,gBAAgBK,OAAO;IAC3B;IACA,KAAKC,QAAQD,OAAO,GAAGE,IAAI,CAAC;QACxB,IAAI;YACA,WAAW,MAAMC,QAAQjB,OAAQ;gBAC7B,IAAIO,IAAIW,MAAM,KAAKhB,aAAa;oBAC5BM,gBAAgBb,mDAAKA;oBACrB,MAAMa,cAAcW,OAAO;gBAC/B;gBACA,IAAIP,SAAS;oBACT;gBACJ;gBACA,MAAMQ,KAAK;oBACPC,MAAM;gBACV;gBACAd,IAAIe,IAAI,CAACF;gBACTH,OACKD,IAAI,CAACO,CAAAA;oBACNH,GAAGC,IAAI,GAAG;oBACVD,GAAGI,EAAE,GAAG;oBACRJ,GAAGK,KAAK,GAAGF;oBACXlB,QAAQqB,aAAa,CAAC,IAAI9B,YAAY;gBAC1C,GAAG+B,CAAAA;oBACCP,GAAGC,IAAI,GAAG;oBACVD,GAAGO,GAAG,GAAGA;oBACTtB,QAAQqB,aAAa,CAAC,IAAI9B,YAAY;gBAC1C;YACJ;YACAc,iBAAiB;YACjBL,QAAQqB,aAAa,CAAC,IAAI9B,YAAY;QAC1C,EACA,OAAO+B,KAAK;YACRhB,YAAYgB;YACZtB,QAAQqB,aAAa,CAAC,IAAI9B,YAAY;QAC1C;IACJ;IACA,SAASgC;QACL,IAAIxB,SAAS;YACT,OAAOG,GAAG,CAAC,EAAE,EAAEc;QACnB;QACA,OAAOQ,QAAQtB,IAAIuB,IAAI,CAACV,CAAAA,KAAMA,GAAGC,IAAI;IACzC;IACA,UAAUU;QACN,MAAO,IAAKb,MAAM,GAAG,KAAMX,GAAG,CAAC,EAAE,CAACc,IAAI,CAAE;YACpC,MAAMD,KAAKb,GAAG,CAAC,EAAE;YACjBA,IAAIyB,KAAK;YACT,IAAIZ,GAAGI,EAAE,EAAE;gBACP,MAAMJ,GAAGK,KAAK;YAClB,OACK;gBACD,2BAA2B;gBAC3Bb,UAAU;gBACVJ,cAAcM,OAAO;gBACrB,MAAMM,GAAGO,GAAG;YAChB;YACAnB,cAAcM,OAAO;QACzB;IACJ;IACA,UAAUmB;QACN,6DAA6D;QAC7D,qCAAqC;QACrC,MAAOL,kBAAmB;YACtB,IAAK,IAAIM,IAAI,GAAGA,IAAI3B,IAAIW,MAAM,EAAEgB,IAAK;gBACjC,IAAI3B,GAAG,CAAC2B,EAAE,CAACb,IAAI,EAAE;oBACb,MAAMD,KAAKb,GAAG,CAAC2B,EAAE;oBACjB3B,IAAI4B,MAAM,CAACD,GAAG;oBACdA;oBACA,IAAId,GAAGI,EAAE,EAAE;wBACP,MAAMJ,GAAGK,KAAK;oBAClB,OACK;wBACDb,UAAU;wBACVJ,cAAcM,OAAO;wBACrB,MAAMM,GAAGO,GAAG;oBAChB;oBACAnB,cAAcM,OAAO;gBACzB;YACJ;QACJ;IACJ;IACA,MAAO,KAAM;QACT,IAAI,CAACc,mBAAmB;YACpBnB,kBAAkBd,mDAAKA;YACvB,MAAMc,gBAAgBU,OAAO;QACjC;QACA,IAAIR,aAAa,MAAM;YACnB,0CAA0C;YAC1C,MAAMA;QACV;QACA,IAAIP,SAAS;YACT,OAAO2B;QACX,OACK;YACD,OAAOE;QACX;QACA,IAAIvB,kBAAkBH,IAAIW,MAAM,KAAK,GAAG;YAEpC;QACJ;IACJ;AACJ,EACA,iCAAiC","sources":["webpack://flush-notes/./node_modules/it-parallel/dist/src/index.js?aa55"],"sourcesContent":["/**\n * @packageDocumentation\n *\n * Takes an (async) iterable that emits promise-returning functions, invokes them in parallel up to the concurrency limit and emits the results as they become available, optionally in the same order as the input\n *\n * @example\n *\n * ```javascript\n * import parallel from 'it-parallel'\n * import all from 'it-all'\n * import delay from 'delay'\n *\n * // This can also be an iterator, async iterator, generator, etc\n * const input = [\n *   async () => {\n *     console.info('start 1')\n *     await delay(500)\n *\n *     console.info('end 1')\n *     return 1\n *   },\n *   async () => {\n *     console.info('start 2')\n *     await delay(200)\n *\n *     console.info('end 2')\n *     return 2\n *   },\n *   async () => {\n *     console.info('start 3')\n *     await delay(100)\n *\n *     console.info('end 3')\n *     return 3\n *   }\n * ]\n *\n * const result = await all(parallel(input, {\n *   concurrency: 2\n * }))\n *\n * // output:\n * // start 1\n * // start 2\n * // end 2\n * // start 3\n * // end 3\n * // end 1\n *\n * console.info(result) // [2, 3, 1]\n * ```\n *\n * If order is important, pass `ordered: true` as an option:\n *\n * ```javascript\n * const result = await all(parallel(input, {\n *   concurrency: 2,\n *   ordered: true\n * }))\n *\n * // output:\n * // start 1\n * // start 2\n * // end 2\n * // start 3\n * // end 3\n * // end 1\n *\n * console.info(result) // [1, 2, 3]\n * ```\n */\nimport defer from 'p-defer';\nconst CustomEvent = globalThis.CustomEvent ?? Event;\n/**\n * Takes an (async) iterator that emits promise-returning functions,\n * invokes them in parallel and emits the results as they become available but\n * in the same order as the input\n */\nexport default async function* parallel(source, options = {}) {\n    let concurrency = options.concurrency ?? Infinity;\n    if (concurrency < 1) {\n        concurrency = Infinity;\n    }\n    const ordered = options.ordered == null ? false : options.ordered;\n    const emitter = new EventTarget();\n    const ops = [];\n    let slotAvailable = defer();\n    let resultAvailable = defer();\n    let sourceFinished = false;\n    let sourceErr;\n    let opErred = false;\n    emitter.addEventListener('task-complete', () => {\n        resultAvailable.resolve();\n    });\n    void Promise.resolve().then(async () => {\n        try {\n            for await (const task of source) {\n                if (ops.length === concurrency) {\n                    slotAvailable = defer();\n                    await slotAvailable.promise;\n                }\n                if (opErred) {\n                    break;\n                }\n                const op = {\n                    done: false\n                };\n                ops.push(op);\n                task()\n                    .then(result => {\n                    op.done = true;\n                    op.ok = true;\n                    op.value = result;\n                    emitter.dispatchEvent(new CustomEvent('task-complete'));\n                }, err => {\n                    op.done = true;\n                    op.err = err;\n                    emitter.dispatchEvent(new CustomEvent('task-complete'));\n                });\n            }\n            sourceFinished = true;\n            emitter.dispatchEvent(new CustomEvent('task-complete'));\n        }\n        catch (err) {\n            sourceErr = err;\n            emitter.dispatchEvent(new CustomEvent('task-complete'));\n        }\n    });\n    function valuesAvailable() {\n        if (ordered) {\n            return ops[0]?.done;\n        }\n        return Boolean(ops.find(op => op.done));\n    }\n    function* yieldOrderedValues() {\n        while ((ops.length > 0) && ops[0].done) {\n            const op = ops[0];\n            ops.shift();\n            if (op.ok) {\n                yield op.value;\n            }\n            else {\n                // allow the source to exit\n                opErred = true;\n                slotAvailable.resolve();\n                throw op.err;\n            }\n            slotAvailable.resolve();\n        }\n    }\n    function* yieldUnOrderedValues() {\n        // more values can become available while we wait for `yield`\n        // to return control to this function\n        while (valuesAvailable()) {\n            for (let i = 0; i < ops.length; i++) {\n                if (ops[i].done) {\n                    const op = ops[i];\n                    ops.splice(i, 1);\n                    i--;\n                    if (op.ok) {\n                        yield op.value;\n                    }\n                    else {\n                        opErred = true;\n                        slotAvailable.resolve();\n                        throw op.err;\n                    }\n                    slotAvailable.resolve();\n                }\n            }\n        }\n    }\n    while (true) {\n        if (!valuesAvailable()) {\n            resultAvailable = defer();\n            await resultAvailable.promise;\n        }\n        if (sourceErr != null) {\n            // the source threw an error, propagate it\n            throw sourceErr;\n        }\n        if (ordered) {\n            yield* yieldOrderedValues();\n        }\n        else {\n            yield* yieldUnOrderedValues();\n        }\n        if (sourceFinished && ops.length === 0) {\n            // not waiting for any results and no more tasks so we are done\n            break;\n        }\n    }\n}\n//# sourceMappingURL=index.js.map"],"names":["defer","CustomEvent","globalThis","Event","parallel","source","options","concurrency","Infinity","ordered","emitter","EventTarget","ops","slotAvailable","resultAvailable","sourceFinished","sourceErr","opErred","addEventListener","resolve","Promise","then","task","length","promise","op","done","push","result","ok","value","dispatchEvent","err","valuesAvailable","Boolean","find","yieldOrderedValues","shift","yieldUnOrderedValues","i","splice"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/it-parallel/dist/src/index.js\n");
/***/ })
};
;