@just-io/utils 1.3.0 → 1.5.0
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/cjs/deep-map.js +55 -16
- package/dist/mjs/deep-map.js +54 -12
- package/dist/types/deep-map.d.ts +9 -5
- package/dist/types/event-emitter.d.ts +1 -0
- package/package.json +1 -1
package/dist/cjs/deep-map.js
CHANGED
|
@@ -10,16 +10,21 @@ var __classPrivateFieldSet = (this && this.__classPrivateFieldSet) || function (
|
|
|
10
10
|
if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError("Cannot write private member to an object whose class did not declare it");
|
|
11
11
|
return (kind === "a" ? f.call(receiver, value) : f ? f.value = value : state.set(receiver, value)), value;
|
|
12
12
|
};
|
|
13
|
-
var _DeepMap_instances, _DeepMap_rootNode, _DeepMap_entries;
|
|
13
|
+
var _DeepMap_instances, _DeepMap_rootNode, _DeepMap_node, _DeepMap_entries;
|
|
14
14
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
15
15
|
exports.DeepMap = void 0;
|
|
16
16
|
class DeepMap extends Map {
|
|
17
|
-
constructor() {
|
|
18
|
-
super(
|
|
17
|
+
constructor(iterable) {
|
|
18
|
+
super();
|
|
19
19
|
_DeepMap_instances.add(this);
|
|
20
20
|
_DeepMap_rootNode.set(this, {
|
|
21
21
|
children: new Map(),
|
|
22
22
|
});
|
|
23
|
+
if (iterable) {
|
|
24
|
+
for (const entry of iterable) {
|
|
25
|
+
this.set(entry[0], entry[1]);
|
|
26
|
+
}
|
|
27
|
+
}
|
|
23
28
|
}
|
|
24
29
|
clear() {
|
|
25
30
|
__classPrivateFieldSet(this, _DeepMap_rootNode, {
|
|
@@ -28,7 +33,7 @@ class DeepMap extends Map {
|
|
|
28
33
|
}
|
|
29
34
|
set(keys, value) {
|
|
30
35
|
let node = __classPrivateFieldGet(this, _DeepMap_rootNode, "f");
|
|
31
|
-
for (const key of keys) {
|
|
36
|
+
for (const key of (Array.isArray(keys) ? keys : [keys])) {
|
|
32
37
|
if (!node.children.has(key)) {
|
|
33
38
|
node.children.set(key, {
|
|
34
39
|
children: new Map(),
|
|
@@ -40,18 +45,12 @@ class DeepMap extends Map {
|
|
|
40
45
|
return this;
|
|
41
46
|
}
|
|
42
47
|
get(keys) {
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
if (!node.children.has(key)) {
|
|
46
|
-
return undefined;
|
|
47
|
-
}
|
|
48
|
-
node = node.children.get(key);
|
|
49
|
-
}
|
|
50
|
-
return node.value;
|
|
48
|
+
var _a;
|
|
49
|
+
return (_a = __classPrivateFieldGet(this, _DeepMap_instances, "m", _DeepMap_node).call(this, keys)) === null || _a === void 0 ? void 0 : _a.value;
|
|
51
50
|
}
|
|
52
51
|
has(keys) {
|
|
53
52
|
let node = __classPrivateFieldGet(this, _DeepMap_rootNode, "f");
|
|
54
|
-
for (const key of keys) {
|
|
53
|
+
for (const key of (Array.isArray(keys) ? keys : [keys])) {
|
|
55
54
|
if (!node.children.has(key)) {
|
|
56
55
|
return false;
|
|
57
56
|
}
|
|
@@ -62,7 +61,7 @@ class DeepMap extends Map {
|
|
|
62
61
|
delete(keys) {
|
|
63
62
|
let node = __classPrivateFieldGet(this, _DeepMap_rootNode, "f");
|
|
64
63
|
const entries = [[undefined, __classPrivateFieldGet(this, _DeepMap_rootNode, "f")]];
|
|
65
|
-
for (const key of keys) {
|
|
64
|
+
for (const key of (Array.isArray(keys) ? keys : [keys])) {
|
|
66
65
|
if (!node.children.has(key)) {
|
|
67
66
|
return false;
|
|
68
67
|
}
|
|
@@ -80,11 +79,42 @@ class DeepMap extends Map {
|
|
|
80
79
|
}
|
|
81
80
|
return true;
|
|
82
81
|
}
|
|
83
|
-
|
|
82
|
+
take(keys) {
|
|
84
83
|
const value = this.get(keys);
|
|
85
84
|
this.delete(keys);
|
|
86
85
|
return value;
|
|
87
86
|
}
|
|
87
|
+
clone(keys) {
|
|
88
|
+
const node = __classPrivateFieldGet(this, _DeepMap_instances, "m", _DeepMap_node).call(this, keys);
|
|
89
|
+
const map = new DeepMap();
|
|
90
|
+
if (node) {
|
|
91
|
+
for (const entry of __classPrivateFieldGet(this, _DeepMap_instances, "m", _DeepMap_entries).call(this, node, [])) {
|
|
92
|
+
map.set(entry[0], entry[1]);
|
|
93
|
+
}
|
|
94
|
+
}
|
|
95
|
+
return map;
|
|
96
|
+
}
|
|
97
|
+
extract(keys) {
|
|
98
|
+
const node = __classPrivateFieldGet(this, _DeepMap_instances, "m", _DeepMap_node).call(this, keys);
|
|
99
|
+
const map = new DeepMap();
|
|
100
|
+
if (node) {
|
|
101
|
+
for (const entry of __classPrivateFieldGet(this, _DeepMap_instances, "m", _DeepMap_entries).call(this, node, [])) {
|
|
102
|
+
map.set(entry[0], entry[1]);
|
|
103
|
+
}
|
|
104
|
+
if (node.value !== undefined) {
|
|
105
|
+
map.set([], node.value);
|
|
106
|
+
}
|
|
107
|
+
node.children = new Map();
|
|
108
|
+
node.value = undefined;
|
|
109
|
+
}
|
|
110
|
+
return map;
|
|
111
|
+
}
|
|
112
|
+
append(keys, iterable) {
|
|
113
|
+
for (const entry of iterable) {
|
|
114
|
+
this.set((Array.isArray(keys) ? keys : [keys]).concat(entry[0]), entry[1]);
|
|
115
|
+
}
|
|
116
|
+
return this;
|
|
117
|
+
}
|
|
88
118
|
get size() {
|
|
89
119
|
let count = 0;
|
|
90
120
|
for (const {} of __classPrivateFieldGet(this, _DeepMap_instances, "m", _DeepMap_entries).call(this, __classPrivateFieldGet(this, _DeepMap_rootNode, "f"), [])) {
|
|
@@ -97,7 +127,16 @@ class DeepMap extends Map {
|
|
|
97
127
|
callbackfn(entry[1], entry[0], this);
|
|
98
128
|
}
|
|
99
129
|
}
|
|
100
|
-
[(_DeepMap_rootNode = new WeakMap(), _DeepMap_instances = new WeakSet(),
|
|
130
|
+
[(_DeepMap_rootNode = new WeakMap(), _DeepMap_instances = new WeakSet(), _DeepMap_node = function _DeepMap_node(keys) {
|
|
131
|
+
let node = __classPrivateFieldGet(this, _DeepMap_rootNode, "f");
|
|
132
|
+
for (const key of (Array.isArray(keys) ? keys : [keys])) {
|
|
133
|
+
if (!node.children.has(key)) {
|
|
134
|
+
return undefined;
|
|
135
|
+
}
|
|
136
|
+
node = node.children.get(key);
|
|
137
|
+
}
|
|
138
|
+
return node;
|
|
139
|
+
}, _DeepMap_entries = function* _DeepMap_entries(node, key) {
|
|
101
140
|
if (node.value !== undefined) {
|
|
102
141
|
yield [key, node.value];
|
|
103
142
|
}
|
package/dist/mjs/deep-map.js
CHANGED
|
@@ -2,6 +2,24 @@ export class DeepMap extends Map {
|
|
|
2
2
|
#rootNode = {
|
|
3
3
|
children: new Map(),
|
|
4
4
|
};
|
|
5
|
+
constructor(iterable) {
|
|
6
|
+
super();
|
|
7
|
+
if (iterable) {
|
|
8
|
+
for (const entry of iterable) {
|
|
9
|
+
this.set(entry[0], entry[1]);
|
|
10
|
+
}
|
|
11
|
+
}
|
|
12
|
+
}
|
|
13
|
+
#node(keys) {
|
|
14
|
+
let node = this.#rootNode;
|
|
15
|
+
for (const key of (Array.isArray(keys) ? keys : [keys])) {
|
|
16
|
+
if (!node.children.has(key)) {
|
|
17
|
+
return undefined;
|
|
18
|
+
}
|
|
19
|
+
node = node.children.get(key);
|
|
20
|
+
}
|
|
21
|
+
return node;
|
|
22
|
+
}
|
|
5
23
|
*#entries(node, key) {
|
|
6
24
|
if (node.value !== undefined) {
|
|
7
25
|
yield [key, node.value];
|
|
@@ -17,7 +35,7 @@ export class DeepMap extends Map {
|
|
|
17
35
|
}
|
|
18
36
|
set(keys, value) {
|
|
19
37
|
let node = this.#rootNode;
|
|
20
|
-
for (const key of keys) {
|
|
38
|
+
for (const key of (Array.isArray(keys) ? keys : [keys])) {
|
|
21
39
|
if (!node.children.has(key)) {
|
|
22
40
|
node.children.set(key, {
|
|
23
41
|
children: new Map(),
|
|
@@ -29,18 +47,11 @@ export class DeepMap extends Map {
|
|
|
29
47
|
return this;
|
|
30
48
|
}
|
|
31
49
|
get(keys) {
|
|
32
|
-
|
|
33
|
-
for (const key of keys) {
|
|
34
|
-
if (!node.children.has(key)) {
|
|
35
|
-
return undefined;
|
|
36
|
-
}
|
|
37
|
-
node = node.children.get(key);
|
|
38
|
-
}
|
|
39
|
-
return node.value;
|
|
50
|
+
return this.#node(keys)?.value;
|
|
40
51
|
}
|
|
41
52
|
has(keys) {
|
|
42
53
|
let node = this.#rootNode;
|
|
43
|
-
for (const key of keys) {
|
|
54
|
+
for (const key of (Array.isArray(keys) ? keys : [keys])) {
|
|
44
55
|
if (!node.children.has(key)) {
|
|
45
56
|
return false;
|
|
46
57
|
}
|
|
@@ -51,7 +62,7 @@ export class DeepMap extends Map {
|
|
|
51
62
|
delete(keys) {
|
|
52
63
|
let node = this.#rootNode;
|
|
53
64
|
const entries = [[undefined, this.#rootNode]];
|
|
54
|
-
for (const key of keys) {
|
|
65
|
+
for (const key of (Array.isArray(keys) ? keys : [keys])) {
|
|
55
66
|
if (!node.children.has(key)) {
|
|
56
67
|
return false;
|
|
57
68
|
}
|
|
@@ -69,11 +80,42 @@ export class DeepMap extends Map {
|
|
|
69
80
|
}
|
|
70
81
|
return true;
|
|
71
82
|
}
|
|
72
|
-
|
|
83
|
+
take(keys) {
|
|
73
84
|
const value = this.get(keys);
|
|
74
85
|
this.delete(keys);
|
|
75
86
|
return value;
|
|
76
87
|
}
|
|
88
|
+
clone(keys) {
|
|
89
|
+
const node = this.#node(keys);
|
|
90
|
+
const map = new DeepMap();
|
|
91
|
+
if (node) {
|
|
92
|
+
for (const entry of this.#entries(node, [])) {
|
|
93
|
+
map.set(entry[0], entry[1]);
|
|
94
|
+
}
|
|
95
|
+
}
|
|
96
|
+
return map;
|
|
97
|
+
}
|
|
98
|
+
extract(keys) {
|
|
99
|
+
const node = this.#node(keys);
|
|
100
|
+
const map = new DeepMap();
|
|
101
|
+
if (node) {
|
|
102
|
+
for (const entry of this.#entries(node, [])) {
|
|
103
|
+
map.set(entry[0], entry[1]);
|
|
104
|
+
}
|
|
105
|
+
if (node.value !== undefined) {
|
|
106
|
+
map.set([], node.value);
|
|
107
|
+
}
|
|
108
|
+
node.children = new Map();
|
|
109
|
+
node.value = undefined;
|
|
110
|
+
}
|
|
111
|
+
return map;
|
|
112
|
+
}
|
|
113
|
+
append(keys, iterable) {
|
|
114
|
+
for (const entry of iterable) {
|
|
115
|
+
this.set((Array.isArray(keys) ? keys : [keys]).concat(entry[0]), entry[1]);
|
|
116
|
+
}
|
|
117
|
+
return this;
|
|
118
|
+
}
|
|
77
119
|
get size() {
|
|
78
120
|
let count = 0;
|
|
79
121
|
for (const {} of this.#entries(this.#rootNode, [])) {
|
package/dist/types/deep-map.d.ts
CHANGED
|
@@ -1,11 +1,15 @@
|
|
|
1
1
|
export declare class DeepMap<K, V> extends Map<K[], V> {
|
|
2
2
|
#private;
|
|
3
|
+
constructor(iterable?: Iterable<readonly [K[], V]> | null);
|
|
3
4
|
clear(): void;
|
|
4
|
-
set(keys: K[], value: V): this;
|
|
5
|
-
get(keys: K[]): V | undefined;
|
|
6
|
-
has(keys: K[]): boolean;
|
|
7
|
-
delete(keys: K[]): boolean;
|
|
8
|
-
|
|
5
|
+
set(keys: K[] | K, value: V): this;
|
|
6
|
+
get(keys: K[] | K): V | undefined;
|
|
7
|
+
has(keys: K[] | K): boolean;
|
|
8
|
+
delete(keys: K[] | K): boolean;
|
|
9
|
+
take(keys: K[] | K): V | undefined;
|
|
10
|
+
clone(keys: K[] | K): DeepMap<K, V>;
|
|
11
|
+
extract(keys: K[] | K): DeepMap<K, V>;
|
|
12
|
+
append(keys: K[] | K, iterable: Iterable<readonly [K[], V]>): this;
|
|
9
13
|
get size(): number;
|
|
10
14
|
forEach(callbackfn: (value: V, key: K[], map: Map<K[], V>) => void): void;
|
|
11
15
|
[Symbol.iterator](): MapIterator<[K[], V]>;
|
|
@@ -31,5 +31,6 @@ export declare class EventEmitter<E extends EventMap> implements Eventable<E> {
|
|
|
31
31
|
once<K extends keyof E>(event: K, subscriber: Subscriber<E[K]>): this;
|
|
32
32
|
off<K extends keyof E>(event: K, subscriber: Subscriber<E[K]>): boolean;
|
|
33
33
|
emit<K extends keyof E>(event: K, ...args: E[K]): void;
|
|
34
|
+
emit(...eventList: EventList<E>): void;
|
|
34
35
|
clear(): void;
|
|
35
36
|
}
|