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;
- }
- }
|