index.js 949 B

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869
  1. class Node {
  2. /// value;
  3. /// next;
  4. constructor(value) {
  5. this.value = value;
  6. // TODO: Remove this when targeting Node.js 12.
  7. this.next = undefined;
  8. }
  9. }
  10. class Queue {
  11. // TODO: Use private class fields when targeting Node.js 12.
  12. // #_head;
  13. // #_tail;
  14. // #_size;
  15. constructor() {
  16. this.clear();
  17. }
  18. enqueue(value) {
  19. const node = new Node(value);
  20. if (this._head) {
  21. this._tail.next = node;
  22. this._tail = node;
  23. } else {
  24. this._head = node;
  25. this._tail = node;
  26. }
  27. this._size++;
  28. }
  29. dequeue() {
  30. const current = this._head;
  31. if (!current) {
  32. return;
  33. }
  34. this._head = this._head.next;
  35. this._size--;
  36. return current.value;
  37. }
  38. clear() {
  39. this._head = undefined;
  40. this._tail = undefined;
  41. this._size = 0;
  42. }
  43. get size() {
  44. return this._size;
  45. }
  46. * [Symbol.iterator]() {
  47. let current = this._head;
  48. while (current) {
  49. yield current.value;
  50. current = current.next;
  51. }
  52. }
  53. }
  54. module.exports = Queue;