1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768 |
- "use strict";
- const TupleSet = require("./TupleSet");
- class TupleQueue {
-
- constructor(items) {
-
- this._set = new TupleSet(items);
-
- this._iterator = this._set[Symbol.iterator]();
- }
-
- get length() {
- return this._set.size;
- }
-
- enqueue(...item) {
- this._set.add(...item);
- }
-
- dequeue() {
- const result = this._iterator.next();
- if (result.done) {
- if (this._set.size > 0) {
- this._iterator = this._set[Symbol.iterator]();
- const value = (this._iterator.next().value);
- this._set.delete(...value);
- return value;
- }
- return;
- }
- this._set.delete(... (result.value));
- return result.value;
- }
- }
- module.exports = TupleQueue;
|