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