extra-iterator 0.9.2 → 0.10.2

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;
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
  }
@@ -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.2",
7
7
  "type": "module",
8
8
  "exports": {
9
9
  ".": "./dist/index.js",