| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171 | 
							- 'use strict';
 
- Object.defineProperty(exports, '__esModule', {
 
-   value: true
 
- });
 
- exports.default = void 0;
 
- function _defineProperty(obj, key, value) {
 
-   if (key in obj) {
 
-     Object.defineProperty(obj, key, {
 
-       value: value,
 
-       enumerable: true,
 
-       configurable: true,
 
-       writable: true
 
-     });
 
-   } else {
 
-     obj[key] = value;
 
-   }
 
-   return obj;
 
- }
 
- /**
 
-  * Copyright (c) Facebook, Inc. and its affiliates. All Rights Reserved.
 
-  *
 
-  * This source code is licensed under the MIT license found in the
 
-  * LICENSE file in the root directory of this source tree.
 
-  */
 
- /**
 
-  * First-in, First-out task queue that manages a dedicated pool
 
-  * for each worker as well as a shared queue. The FIFO ordering is guaranteed
 
-  * across the worker specific and shared queue.
 
-  */
 
- class FifoQueue {
 
-   constructor() {
 
-     _defineProperty(this, '_workerQueues', []);
 
-     _defineProperty(this, '_sharedQueue', new InternalQueue());
 
-   }
 
-   enqueue(task, workerId) {
 
-     if (workerId == null) {
 
-       this._sharedQueue.enqueue(task);
 
-       return;
 
-     }
 
-     let workerQueue = this._workerQueues[workerId];
 
-     if (workerQueue == null) {
 
-       workerQueue = this._workerQueues[workerId] = new InternalQueue();
 
-     }
 
-     const sharedTop = this._sharedQueue.peekLast();
 
-     const item = {
 
-       previousSharedTask: sharedTop,
 
-       task
 
-     };
 
-     workerQueue.enqueue(item);
 
-   }
 
-   dequeue(workerId) {
 
-     var _this$_workerQueues$w, _workerTop$previousSh, _workerTop$previousSh2;
 
-     const workerTop =
 
-       (_this$_workerQueues$w = this._workerQueues[workerId]) === null ||
 
-       _this$_workerQueues$w === void 0
 
-         ? void 0
 
-         : _this$_workerQueues$w.peek();
 
-     const sharedTaskIsProcessed =
 
-       (_workerTop$previousSh =
 
-         workerTop === null || workerTop === void 0
 
-           ? void 0
 
-           : (_workerTop$previousSh2 = workerTop.previousSharedTask) === null ||
 
-             _workerTop$previousSh2 === void 0
 
-           ? void 0
 
-           : _workerTop$previousSh2.request[1]) !== null &&
 
-       _workerTop$previousSh !== void 0
 
-         ? _workerTop$previousSh
 
-         : true; // Process the top task from the shared queue if
 
-     // - there's no task in the worker specific queue or
 
-     // - if the non-worker-specific task after which this worker specifif task
 
-     //   hasn been queued wasn't processed yet
 
-     if (workerTop != null && sharedTaskIsProcessed) {
 
-       var _this$_workerQueues$w2,
 
-         _this$_workerQueues$w3,
 
-         _this$_workerQueues$w4;
 
-       return (_this$_workerQueues$w2 =
 
-         (_this$_workerQueues$w3 = this._workerQueues[workerId]) === null ||
 
-         _this$_workerQueues$w3 === void 0
 
-           ? void 0
 
-           : (_this$_workerQueues$w4 = _this$_workerQueues$w3.dequeue()) ===
 
-               null || _this$_workerQueues$w4 === void 0
 
-           ? void 0
 
-           : _this$_workerQueues$w4.task) !== null &&
 
-         _this$_workerQueues$w2 !== void 0
 
-         ? _this$_workerQueues$w2
 
-         : null;
 
-     }
 
-     return this._sharedQueue.dequeue();
 
-   }
 
- }
 
- exports.default = FifoQueue;
 
- /**
 
-  * FIFO queue for a single worker / shared queue.
 
-  */
 
- class InternalQueue {
 
-   constructor() {
 
-     _defineProperty(this, '_head', null);
 
-     _defineProperty(this, '_last', null);
 
-   }
 
-   enqueue(value) {
 
-     const item = {
 
-       next: null,
 
-       value
 
-     };
 
-     if (this._last == null) {
 
-       this._head = item;
 
-     } else {
 
-       this._last.next = item;
 
-     }
 
-     this._last = item;
 
-   }
 
-   dequeue() {
 
-     if (this._head == null) {
 
-       return null;
 
-     }
 
-     const item = this._head;
 
-     this._head = item.next;
 
-     if (this._head == null) {
 
-       this._last = null;
 
-     }
 
-     return item.value;
 
-   }
 
-   peek() {
 
-     var _this$_head$value, _this$_head;
 
-     return (_this$_head$value =
 
-       (_this$_head = this._head) === null || _this$_head === void 0
 
-         ? void 0
 
-         : _this$_head.value) !== null && _this$_head$value !== void 0
 
-       ? _this$_head$value
 
-       : null;
 
-   }
 
-   peekLast() {
 
-     var _this$_last$value, _this$_last;
 
-     return (_this$_last$value =
 
-       (_this$_last = this._last) === null || _this$_last === void 0
 
-         ? void 0
 
-         : _this$_last.value) !== null && _this$_last$value !== void 0
 
-       ? _this$_last$value
 
-       : null;
 
-   }
 
- }
 
 
  |