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 +19 -5
- package/dist/index.js +38 -29
- 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;
|
|
@@ -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
|
|
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
|
}
|
|
@@ -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
|
-
|
|
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
|
-
|
|
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
|
-
|
|
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();
|
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.3",
|
|
7
7
|
"type": "module",
|
|
8
8
|
"exports": {
|
|
9
9
|
".": "./dist/index.js",
|