extra-iterator 0.9.2 → 0.10.3

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/dist/index.d.ts CHANGED
@@ -36,6 +36,22 @@ export declare class ExtraIterator<T> extends Iterator<T, any, any> {
36
36
  start?: number | undefined;
37
37
  interval?: number | undefined;
38
38
  }): ExtraIterator<number>;
39
+ /**
40
+ * Creates an iterator that yields numbers in a "from-to" range. (exclusive)
41
+ *
42
+ * Chain the returned iterator into the {@link append} method to create an inclusive range. (or {@link prepend} if
43
+ * the range is decremental)
44
+ *
45
+ * The third argument is an optional step that defines the increment (or decrement) between each yielded number.
46
+ *
47
+ * @example
48
+ * ExtraIterator.range(5, 10).toArray() // returns [5, 6, 7, 8, 9]
49
+ * ExtraIterator.range(5, 10).append(10).toArray() // returns [5, 6, 7, 8, 9, 10]
50
+ * ExtraIterator.range(1, 10, 2).toArray() // returns [1, 3, 5, 7, 9]
51
+ * ExtraIterator.range(0, 1, 0.25).toArray() // returns [0, 0.25, 0.5, 0.75]
52
+ * ExtraIterator.range(10, 0, -2).toArray() // returns [10, 8, 6, 4, 2]
53
+ */
54
+ static range(start: number, end: number, step?: number): ExtraIterator<number>;
39
55
  /**
40
56
  * Creates an iterator that repeatedly yields the provided value.
41
57
  *
@@ -45,12 +61,10 @@ export declare class ExtraIterator<T> extends Iterator<T, any, any> {
45
61
  */
46
62
  static repeat<T>(value: T): ExtraIterator<T>;
47
63
  /**
48
- * Generates random cryptographically strong random numbers.
64
+ * Generates an infinite sequence of cryptographically strong random bytes using `crypto.getRandomValues`. Each
65
+ * yielded value is a number in between 0 and 255 (inclusive).
49
66
  *
50
67
  * > ⚠ This iterator is infinite. Use {@link take} method if you want a specific number of values.
51
- *
52
- * @param param0
53
- * @returns
54
68
  */
55
69
  static random({ bufferSize }?: {
56
70
  bufferSize?: number | undefined;
@@ -310,7 +324,7 @@ export declare class ExtraIterator<T> extends Iterator<T, any, any> {
310
324
  * .toArray()
311
325
  * // returns { even: [2, 4], odd: [1, 3, 5] }
312
326
  */
313
- groupBy<K extends string | symbol>(callbackfn: (value: T, index: number) => K): Record<K, T[]>;
327
+ groupBy<K extends string | symbol>(callbackfn: (value: T, index: number) => K): Partial<Record<K, T[]>>;
314
328
  /**
315
329
  * Groups elements into separate arrays and returns a Map containing each group.
316
330
  *
package/dist/index.js CHANGED
@@ -44,6 +44,38 @@ export class ExtraIterator extends Iterator {
44
44
  }
45
45
  }());
46
46
  }
47
+ /**
48
+ * Creates an iterator that yields numbers in a "from-to" range. (exclusive)
49
+ *
50
+ * Chain the returned iterator into the {@link append} method to create an inclusive range. (or {@link prepend} if
51
+ * the range is decremental)
52
+ *
53
+ * The third argument is an optional step that defines the increment (or decrement) between each yielded number.
54
+ *
55
+ * @example
56
+ * ExtraIterator.range(5, 10).toArray() // returns [5, 6, 7, 8, 9]
57
+ * ExtraIterator.range(5, 10).append(10).toArray() // returns [5, 6, 7, 8, 9, 10]
58
+ * ExtraIterator.range(1, 10, 2).toArray() // returns [1, 3, 5, 7, 9]
59
+ * ExtraIterator.range(0, 1, 0.25).toArray() // returns [0, 0.25, 0.5, 0.75]
60
+ * ExtraIterator.range(10, 0, -2).toArray() // returns [10, 8, 6, 4, 2]
61
+ */
62
+ static range(start, end, step = 1) {
63
+ return ExtraIterator.from(function* () {
64
+ if (Math.abs(step) < Number.EPSILON) {
65
+ throw new Error('Failed to create range. Cause: Range step cannot be 0.');
66
+ }
67
+ else if (step > 0) {
68
+ for (let i = start; i < end; i += step) {
69
+ yield i;
70
+ }
71
+ }
72
+ else {
73
+ for (let i = start; i > end; i += step) {
74
+ yield i;
75
+ }
76
+ }
77
+ }());
78
+ }
47
79
  /**
48
80
  * Creates an iterator that repeatedly yields the provided value.
49
81
  *
@@ -59,18 +91,16 @@ export class ExtraIterator extends Iterator {
59
91
  }());
60
92
  }
61
93
  /**
62
- * Generates random cryptographically strong random numbers.
94
+ * Generates an infinite sequence of cryptographically strong random bytes using `crypto.getRandomValues`. Each
95
+ * yielded value is a number in between 0 and 255 (inclusive).
63
96
  *
64
97
  * > ⚠ This iterator is infinite. Use {@link take} method if you want a specific number of values.
65
- *
66
- * @param param0
67
- * @returns
68
98
  */
69
99
  static random({ bufferSize = 1024 } = {}) {
70
100
  const buffer = new Uint8Array(bufferSize);
71
101
  return new ExtraIterator(function* () {
72
102
  globalThis.crypto.getRandomValues(buffer);
73
- yield* new Float64Array(buffer);
103
+ yield* new Uint8Array(buffer);
74
104
  }())
75
105
  .loop();
76
106
  }
@@ -550,15 +580,7 @@ export class ExtraIterator extends Iterator {
550
580
  * // returns { even: [2, 4], odd: [1, 3, 5] }
551
581
  */
552
582
  groupBy(callbackfn) {
553
- const result = Object.create(null);
554
- for (let index = 0, next; next = this.next(), !next.done; index++) {
555
- const key = callbackfn(next.value, index);
556
- if (!result[key]) {
557
- result[key] = [];
558
- }
559
- result[key].push(next.value);
560
- }
561
- return result;
583
+ return this.collect(items => Object.groupBy(items, callbackfn));
562
584
  }
563
585
  /**
564
586
  * Groups elements into separate arrays and returns a Map containing each group.
@@ -570,26 +592,13 @@ export class ExtraIterator extends Iterator {
570
592
  * This method is similart to {@link groupBy}, but the returned object is a Map instead of a plain object.
571
593
  */
572
594
  toMap(callbackfn) {
573
- const result = new Map();
574
- for (let index = 0, next; next = this.next(), !next.done; index++) {
575
- const key = callbackfn(next.value, index);
576
- const array = result.get(key);
577
- if (!array) {
578
- result.set(key, [next.value]);
579
- }
580
- else {
581
- array.push(next.value);
582
- }
583
- }
584
- return result;
595
+ return this.collect(items => Map.groupBy(items, callbackfn));
585
596
  }
586
597
  /**
587
598
  * Creates a set containing all the values yielded by this iterator.
588
599
  */
589
600
  toSet() {
590
- const result = new Set();
591
- this.forEach(value => result.add(value));
592
- return result;
601
+ return new Set(this);
593
602
  }
594
603
  toChainOfResponsibilityFunction(invokeHandler) {
595
604
  const handlers = this.toArray();
@@ -26,9 +26,9 @@ describe('ExtraIterator', () => {
26
26
  expect(iterator.toArray()).toEqual(['x', 'x', 'x']);
27
27
  });
28
28
  it('should yield random values', () => {
29
- const values = ExtraIterator.random().take(5).toArray();
30
- expect(values.length).toBe(5);
31
- expect(values.every(value => typeof value === 'number')).toBe(true);
29
+ const values = ExtraIterator.random().take(10000).toArray();
30
+ expect(values.length).toBe(10000);
31
+ expect(values.every(value => typeof value === 'number' && value >= 0 && value < 256)).toBe(true);
32
32
  });
33
33
  it('should filter values based on a predicate', () => {
34
34
  const iterator = ExtraIterator.from([1, 2, 3, 4]).filter(x => x % 2 === 0);
@@ -195,4 +195,11 @@ describe('ExtraIterator', () => {
195
195
  const iterator = ExtraIterator.from([1, 2, 3]).loop(3);
196
196
  expect(iterator.toArray()).toEqual([1, 2, 3, 1, 2, 3, 1, 2, 3]);
197
197
  });
198
+ it('should iterate over ranges', () => {
199
+ expect(ExtraIterator.range(5, 10).toArray()).toEqual([5, 6, 7, 8, 9]);
200
+ expect(ExtraIterator.range(5, 10).append(10).toArray()).toEqual([5, 6, 7, 8, 9, 10]);
201
+ expect(ExtraIterator.range(1, 10, 2).toArray()).toEqual([1, 3, 5, 7, 9]);
202
+ expect(ExtraIterator.range(0, 1, 0.25).toArray()).toEqual([0, 0.25, 0.5, 0.75]);
203
+ expect(ExtraIterator.range(10, 0, -2).toArray()).toEqual([10, 8, 6, 4, 2]);
204
+ });
198
205
  });
package/package.json CHANGED
@@ -3,7 +3,7 @@
3
3
  "description": "An extension of the Iterator class with additional utility helper functions.",
4
4
  "author": "Leonardo Raele <leonardoraele@gmail.com>",
5
5
  "license": "MIT",
6
- "version": "0.9.2",
6
+ "version": "0.10.3",
7
7
  "type": "module",
8
8
  "exports": {
9
9
  ".": "./dist/index.js",