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 +18 -4
- package/dist/index.js +35 -5
- package/dist/index.test.js +10 -3
- package/package.json +1 -1
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
|
|
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
|
|
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
|
|
103
|
+
yield* new Uint8Array(buffer);
|
|
74
104
|
}())
|
|
75
105
|
.loop();
|
|
76
106
|
}
|
package/dist/index.test.js
CHANGED
|
@@ -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(
|
|
30
|
-
expect(values.length).toBe(
|
|
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.
|
|
6
|
+
"version": "0.10.2",
|
|
7
7
|
"type": "module",
|
|
8
8
|
"exports": {
|
|
9
9
|
".": "./dist/index.js",
|