1234567891011121314151617181920212223242526272829303132333435 |
- "use strict";
- const DoublyLinkedList = require("./DoublyLinkedList");
- const Deque = require("./Deque");
- /**
- * Sort of a internal queue for holding the waiting
- * resource requets for a given "priority".
- * Also handles managing timeouts rejections on items (is this the best place for this?)
- * This is the last point where we know which queue a resourceRequest is in
- *
- */
- class Queue extends Deque {
- /**
- * Adds the obj to the end of the list for this slot
- * we completely override the parent method because we need access to the
- * node for our rejection handler
- * @param {any} resourceRequest [description]
- */
- push(resourceRequest) {
- const node = DoublyLinkedList.createNode(resourceRequest);
- resourceRequest.promise.catch(this._createTimeoutRejectionHandler(node));
- this._list.insertEnd(node);
- }
- _createTimeoutRejectionHandler(node) {
- return reason => {
- if (reason.name === "TimeoutError") {
- this._list.remove(node);
- }
- };
- }
- }
- module.exports = Queue;
|