ctx-core 4.2.0 → 4.3.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/all/rmemo/index.d.ts +1 -5
- package/all/rmemo/index.js +33 -33
- package/all/rmemo/index.test.ts +100 -100
- package/package.json +6 -6
package/all/rmemo/index.d.ts
CHANGED
|
@@ -19,13 +19,9 @@ export type r_rmemo_o_T<val_T> = {
|
|
|
19
19
|
readonly _:val_T
|
|
20
20
|
val:val_T
|
|
21
21
|
go():unknown
|
|
22
|
-
onset(val:val_T):unknown
|
|
23
|
-
refresh():val_T
|
|
24
22
|
}
|
|
25
23
|
export type rw_r_rmemo_o_T<val_T> = {
|
|
26
24
|
_:val_T
|
|
27
25
|
val:val_T
|
|
28
26
|
go():unknown
|
|
29
|
-
|
|
30
|
-
refresh():val_T
|
|
31
|
-
}&r_rmemo_o_T<val_T>
|
|
27
|
+
}
|
package/all/rmemo/index.js
CHANGED
|
@@ -1,49 +1,42 @@
|
|
|
1
|
+
/** @typedef {import('./index.d.ts').rmemo_def_T} */
|
|
1
2
|
/** @typedef {import('./index.d.ts').r_rmemo_T} */
|
|
2
3
|
/** @typedef {import('./index.d.ts').rmemo_subscriber_T} */
|
|
3
4
|
/** @type {WeakRef<r_rmemo_T>} */
|
|
4
|
-
let
|
|
5
|
+
let cur_r
|
|
5
6
|
/** @type {(()=>unknown)[]} */
|
|
6
7
|
let queue = []
|
|
7
8
|
/**
|
|
8
|
-
* @param {
|
|
9
|
+
* @param {rmemo_def_T}rmemo_def
|
|
9
10
|
* @param {rmemo_subscriber_T<unknown>[]}subscriber_a
|
|
10
11
|
* @returns {r_rmemo_T}
|
|
11
12
|
* @private
|
|
12
13
|
*/
|
|
13
|
-
export function r_rmemo_(
|
|
14
|
-
let
|
|
15
|
-
let
|
|
16
|
-
|
|
17
|
-
r_rmemo._f = _f
|
|
18
|
-
r_rmemo._r = _r
|
|
19
|
-
r_rmemo._rS = new Set
|
|
20
|
-
r_rmemo.go = ()=>(r_rmemo(), r_rmemo)
|
|
21
|
-
r_rmemo.onset = ()=>0
|
|
22
|
-
Object.defineProperty(r_rmemo, '_', {
|
|
23
|
-
get() {
|
|
14
|
+
export function r_rmemo_(rmemo_def, ...subscriber_a) {
|
|
15
|
+
let init
|
|
16
|
+
let r_rmemo = {
|
|
17
|
+
get _() {
|
|
24
18
|
if (!('val' in r_rmemo)) {
|
|
25
|
-
let
|
|
26
|
-
|
|
19
|
+
let prev_r = cur_r
|
|
20
|
+
cur_r = r_rmemo._r
|
|
27
21
|
try {
|
|
28
|
-
|
|
22
|
+
init()
|
|
29
23
|
} finally {
|
|
30
|
-
|
|
24
|
+
cur_r = prev_r
|
|
31
25
|
}
|
|
32
26
|
}
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
r_rmemo._rS.add(cur_ref)
|
|
27
|
+
if (cur_r) {
|
|
28
|
+
cur_r.l = cur_r.l < r_rmemo._r.l + 1 ? r_rmemo._r.l + 1 : cur_r.l
|
|
29
|
+
r_rmemo._rs.add(cur_r)
|
|
37
30
|
}
|
|
38
31
|
return r_rmemo.val
|
|
39
32
|
},
|
|
40
|
-
set(val) {
|
|
33
|
+
set _(val) {
|
|
41
34
|
if (val !== r_rmemo.val) {
|
|
42
35
|
r_rmemo.val = val
|
|
43
|
-
r_rmemo.
|
|
36
|
+
r_rmemo._s?.(val)
|
|
44
37
|
let run_queue = !queue[0]
|
|
45
|
-
for (let
|
|
46
|
-
if (!~queue.indexOf(
|
|
38
|
+
for (let r of r_rmemo._rs) {
|
|
39
|
+
if (!~queue.indexOf(r)) queue.push(r)
|
|
47
40
|
}
|
|
48
41
|
if (!r_rmemo._sa) {
|
|
49
42
|
r_rmemo._sa = subscriber_a.map(subscriber=>
|
|
@@ -51,17 +44,24 @@ export function r_rmemo_(_f, ...subscriber_a) {
|
|
|
51
44
|
}
|
|
52
45
|
if (run_queue) {
|
|
53
46
|
// eslint-disable-next-line no-cond-assign
|
|
54
|
-
for (let
|
|
55
|
-
if (queue.some(
|
|
56
|
-
queue.push(
|
|
47
|
+
for (let r; r = queue.shift();) {
|
|
48
|
+
if (queue.some(queue_r=>r.l > queue_r.l)) {
|
|
49
|
+
queue.push(r)
|
|
57
50
|
} else {
|
|
58
|
-
(
|
|
51
|
+
(r.deref() || r_rmemo._rs.delete)(r)
|
|
59
52
|
}
|
|
60
53
|
}
|
|
61
54
|
}
|
|
62
55
|
}
|
|
63
|
-
}
|
|
64
|
-
|
|
56
|
+
},
|
|
57
|
+
go: ()=>(r_rmemo._, r_rmemo),
|
|
58
|
+
get: ()=>r_rmemo._,
|
|
59
|
+
set: val=>r_rmemo._ = val,
|
|
60
|
+
_rs: new Set,
|
|
61
|
+
}
|
|
62
|
+
init = ()=>r_rmemo._ = rmemo_def(r_rmemo)
|
|
63
|
+
r_rmemo._r = new WeakRef(init)
|
|
64
|
+
r_rmemo._r.l = 0
|
|
65
65
|
return r_rmemo
|
|
66
66
|
}
|
|
67
67
|
/**
|
|
@@ -71,8 +71,8 @@ export function r_rmemo_(_f, ...subscriber_a) {
|
|
|
71
71
|
* @private
|
|
72
72
|
*/
|
|
73
73
|
export function rw_rmemo_(init_val, ...subscriber_a) {
|
|
74
|
-
let rw_rmemo = r_rmemo_(
|
|
75
|
-
rw_rmemo.
|
|
74
|
+
let rw_rmemo = r_rmemo_(_rw_rmemo=>_rw_rmemo._v, ...subscriber_a)
|
|
75
|
+
rw_rmemo._s = val=>rw_rmemo._v = val
|
|
76
76
|
rw_rmemo._v = init_val
|
|
77
77
|
return rw_rmemo
|
|
78
78
|
}
|
package/all/rmemo/index.test.ts
CHANGED
|
@@ -10,27 +10,27 @@ test('r_rmemo_|static value', ()=>{
|
|
|
10
10
|
return 'rmemo-value'
|
|
11
11
|
})
|
|
12
12
|
equal(count, 0)
|
|
13
|
-
equal(r_rmemo
|
|
13
|
+
equal(r_rmemo._, 'rmemo-value')
|
|
14
14
|
equal(count, 1)
|
|
15
|
-
equal(r_rmemo
|
|
15
|
+
equal(r_rmemo._, 'rmemo-value')
|
|
16
16
|
equal(count, 1)
|
|
17
17
|
})
|
|
18
18
|
test('rw_rmemo_', ()=>{
|
|
19
19
|
const rw_rmemo = rw_rmemo_('val0')
|
|
20
|
-
equal(rw_rmemo
|
|
21
|
-
rw_rmemo
|
|
22
|
-
equal(rw_rmemo
|
|
20
|
+
equal(rw_rmemo._, 'val0')
|
|
21
|
+
rw_rmemo._ = 'val1'
|
|
22
|
+
equal(rw_rmemo._, 'val1')
|
|
23
23
|
})
|
|
24
24
|
test('r_rmemo_|def function|rmemo$ argument', ()=>{
|
|
25
25
|
const rw_rmemo = rw_rmemo_('val0')
|
|
26
26
|
const r_rmemo:r_rmemo_T<string>&{custom?:string} = r_rmemo_<string>((_rmemo$:r_rmemo_T<string>&{custom?:string})=>
|
|
27
|
-
`${_rmemo$.custom}-${rw_rmemo
|
|
27
|
+
`${_rmemo$.custom}-${rw_rmemo._}`)
|
|
28
28
|
r_rmemo.custom = 'custom_val0'
|
|
29
|
-
equal(r_rmemo
|
|
29
|
+
equal(r_rmemo._, 'custom_val0-val0')
|
|
30
30
|
r_rmemo.custom = 'custom_val1'
|
|
31
|
-
equal(r_rmemo
|
|
32
|
-
rw_rmemo
|
|
33
|
-
equal(r_rmemo
|
|
31
|
+
equal(r_rmemo._, 'custom_val0-val0')
|
|
32
|
+
rw_rmemo._ = 'val1'
|
|
33
|
+
equal(r_rmemo._, 'custom_val1-val1')
|
|
34
34
|
})
|
|
35
35
|
test('rw_rmemo_|async subsubscriber|case 1', async ()=>{
|
|
36
36
|
let resolve:(user:{ id:string })=>void
|
|
@@ -42,21 +42,21 @@ test('rw_rmemo_|async subsubscriber|case 1', async ()=>{
|
|
|
42
42
|
null,
|
|
43
43
|
async (_user$)=>{
|
|
44
44
|
count++
|
|
45
|
-
id
|
|
45
|
+
id$._
|
|
46
46
|
const user:{ id:string } = await new Promise(_resolve=>resolve = _resolve)
|
|
47
|
-
_user
|
|
47
|
+
_user$._ = (user)
|
|
48
48
|
})
|
|
49
49
|
equal(count, 0)
|
|
50
|
-
equal(user
|
|
50
|
+
equal(user$._, null)
|
|
51
51
|
equal(count, 1)
|
|
52
52
|
resolve!(user0)
|
|
53
53
|
await sleep(0)
|
|
54
54
|
equal(count, 1)
|
|
55
|
-
equal(user
|
|
55
|
+
equal(user$._, user0)
|
|
56
56
|
equal(count, 1)
|
|
57
|
-
id
|
|
57
|
+
id$._ = 'id-1'
|
|
58
58
|
equal(count, 2)
|
|
59
|
-
equal(user
|
|
59
|
+
equal(user$._, user0)
|
|
60
60
|
resolve!(user1)
|
|
61
61
|
await sleep(0)
|
|
62
62
|
equal(count, 2)
|
|
@@ -68,18 +68,18 @@ test('rw_rmemo_|async subsubscriber|case 2', async ()=>{
|
|
|
68
68
|
const taskArgumentsCalls:number[][] = []
|
|
69
69
|
const sum$ = rw_rmemo_<null|number>(null,
|
|
70
70
|
async sum$=>{
|
|
71
|
-
taskArgumentsCalls.push([a
|
|
71
|
+
taskArgumentsCalls.push([a$._, b$._])
|
|
72
72
|
for (let i = 0; i < sleepCycles; i++) {
|
|
73
73
|
await Promise.resolve()
|
|
74
74
|
}
|
|
75
|
-
sum
|
|
75
|
+
sum$._ = a$._ + b$._
|
|
76
76
|
})
|
|
77
|
-
equal(sum
|
|
77
|
+
equal(sum$._, null)
|
|
78
78
|
deepStrictEqual(taskArgumentsCalls, [[1, 2]])
|
|
79
|
-
a
|
|
80
|
-
b
|
|
79
|
+
a$._ = 10
|
|
80
|
+
b$._ = 20
|
|
81
81
|
for (let i = 0; i < sleepCycles; i++) {
|
|
82
|
-
equal(sum
|
|
82
|
+
equal(sum$._, null)
|
|
83
83
|
await Promise.resolve()
|
|
84
84
|
deepStrictEqual(taskArgumentsCalls, [
|
|
85
85
|
[1, 2],
|
|
@@ -87,7 +87,7 @@ test('rw_rmemo_|async subsubscriber|case 2', async ()=>{
|
|
|
87
87
|
[10, 20]
|
|
88
88
|
])
|
|
89
89
|
}
|
|
90
|
-
equal(sum
|
|
90
|
+
equal(sum$._, 30)
|
|
91
91
|
deepStrictEqual(taskArgumentsCalls, [
|
|
92
92
|
[1, 2],
|
|
93
93
|
[10, 2],
|
|
@@ -96,94 +96,94 @@ test('rw_rmemo_|async subsubscriber|case 2', async ()=>{
|
|
|
96
96
|
})
|
|
97
97
|
test('r_rmemo_+rw_rmemo_|simple graph', ()=>{
|
|
98
98
|
const base$ = rw_rmemo_('base0')
|
|
99
|
-
const dep0$ = r_rmemo_(()=>base
|
|
100
|
-
const dep1$ = r_rmemo_(()=>dep0
|
|
101
|
-
const dep2$ = r_rmemo_(()=>dep1
|
|
102
|
-
const dep3$ = r_rmemo_(()=>dep2
|
|
103
|
-
const dep4$ = r_rmemo_(()=>dep3
|
|
104
|
-
equal(dep4
|
|
105
|
-
equal(dep3
|
|
106
|
-
equal(dep2
|
|
107
|
-
equal(dep1
|
|
108
|
-
equal(dep0
|
|
109
|
-
equal(base
|
|
110
|
-
base
|
|
111
|
-
equal(base
|
|
112
|
-
equal(dep0
|
|
113
|
-
equal(dep1
|
|
114
|
-
equal(dep2
|
|
115
|
-
equal(dep3
|
|
116
|
-
equal(dep4
|
|
99
|
+
const dep0$ = r_rmemo_(()=>base$._ + '-dep0')
|
|
100
|
+
const dep1$ = r_rmemo_(()=>dep0$._ + '-dep1')
|
|
101
|
+
const dep2$ = r_rmemo_(()=>dep1$._ + '-dep2')
|
|
102
|
+
const dep3$ = r_rmemo_(()=>dep2$._ + '-dep3')
|
|
103
|
+
const dep4$ = r_rmemo_(()=>dep3$._ + '-dep4')
|
|
104
|
+
equal(dep4$._, 'base0-dep0-dep1-dep2-dep3-dep4')
|
|
105
|
+
equal(dep3$._, 'base0-dep0-dep1-dep2-dep3')
|
|
106
|
+
equal(dep2$._, 'base0-dep0-dep1-dep2')
|
|
107
|
+
equal(dep1$._, 'base0-dep0-dep1')
|
|
108
|
+
equal(dep0$._, 'base0-dep0')
|
|
109
|
+
equal(base$._, 'base0')
|
|
110
|
+
base$._ = 'base1'
|
|
111
|
+
equal(base$._, 'base1')
|
|
112
|
+
equal(dep0$._, 'base1-dep0')
|
|
113
|
+
equal(dep1$._, 'base1-dep0-dep1')
|
|
114
|
+
equal(dep2$._, 'base1-dep0-dep1-dep2')
|
|
115
|
+
equal(dep3$._, 'base1-dep0-dep1-dep2-dep3')
|
|
116
|
+
equal(dep4$._, 'base1-dep0-dep1-dep2-dep3-dep4')
|
|
117
117
|
})
|
|
118
118
|
test('prevents diamond dependency problem 1', ()=>{
|
|
119
119
|
const store$ = rw_rmemo_(0)
|
|
120
120
|
const values:string[] = []
|
|
121
|
-
const a$ = r_rmemo_(()=>`a${store
|
|
122
|
-
const b$ = r_rmemo_(()=>a
|
|
123
|
-
const c$ = r_rmemo_(()=>a
|
|
124
|
-
const d$ = r_rmemo_(()=>a
|
|
125
|
-
r_rmemo_(()=>`${b
|
|
121
|
+
const a$ = r_rmemo_(()=>`a${store$._}`)
|
|
122
|
+
const b$ = r_rmemo_(()=>a$._.replace('a', 'b'))
|
|
123
|
+
const c$ = r_rmemo_(()=>a$._.replace('a', 'c'))
|
|
124
|
+
const d$ = r_rmemo_(()=>a$._.replace('a', 'd'))
|
|
125
|
+
r_rmemo_(()=>`${b$._}${c$._}${d$._}`,
|
|
126
126
|
combined$=>
|
|
127
|
-
values.push(combined
|
|
127
|
+
values.push(combined$._)
|
|
128
128
|
).go()
|
|
129
129
|
deepStrictEqual(values, ['b0c0d0'])
|
|
130
|
-
store
|
|
131
|
-
store
|
|
130
|
+
store$._ = 1
|
|
131
|
+
store$._ = 2
|
|
132
132
|
deepStrictEqual(values, ['b0c0d0', 'b1c1d1', 'b2c2d2'])
|
|
133
133
|
})
|
|
134
134
|
test('prevents diamond dependency problem 2', ()=>{
|
|
135
135
|
const store$ = rw_rmemo_(0)
|
|
136
136
|
const values:string[] = []
|
|
137
|
-
const a$ = r_rmemo_(()=>`a${store
|
|
138
|
-
const b$ = r_rmemo_(()=>a
|
|
139
|
-
const c$ = r_rmemo_(()=>b
|
|
140
|
-
const d$ = r_rmemo_(()=>c
|
|
141
|
-
const e$ = r_rmemo_(()=>d
|
|
137
|
+
const a$ = r_rmemo_(()=>`a${store$._}`)
|
|
138
|
+
const b$ = r_rmemo_(()=>a$._.replace('a', 'b'))
|
|
139
|
+
const c$ = r_rmemo_(()=>b$._.replace('b', 'c'))
|
|
140
|
+
const d$ = r_rmemo_(()=>c$._.replace('c', 'd'))
|
|
141
|
+
const e$ = r_rmemo_(()=>d$._.replace('d', 'e'))
|
|
142
142
|
r_rmemo_<string>(
|
|
143
|
-
()=>[a
|
|
144
|
-
|
|
143
|
+
()=>[a$._, e$._].join(''),
|
|
144
|
+
$=>values.push($._)
|
|
145
145
|
).go()
|
|
146
146
|
deepStrictEqual(values, ['a0e0'])
|
|
147
|
-
store
|
|
147
|
+
store$._ = 1
|
|
148
148
|
deepStrictEqual(values, ['a0e0', 'a1e1'])
|
|
149
149
|
})
|
|
150
150
|
test('prevents diamond dependency problem 3', ()=>{
|
|
151
151
|
const store$ = rw_rmemo_(0)
|
|
152
152
|
const values:string[] = []
|
|
153
|
-
const a$ = r_rmemo_(()=>`a${store
|
|
154
|
-
const b$ = r_rmemo_(()=>a
|
|
155
|
-
const c$ = r_rmemo_(()=>b
|
|
156
|
-
const d$ = r_rmemo_(()=>c
|
|
153
|
+
const a$ = r_rmemo_(()=>`a${store$._}`)
|
|
154
|
+
const b$ = r_rmemo_(()=>a$._.replace('a', 'b'))
|
|
155
|
+
const c$ = r_rmemo_(()=>b$._.replace('b', 'c'))
|
|
156
|
+
const d$ = r_rmemo_(()=>c$._.replace('c', 'd'))
|
|
157
157
|
r_rmemo_<string>(
|
|
158
|
-
()=>`${a
|
|
159
|
-
combined$=>values.push(combined
|
|
158
|
+
()=>`${a$._}${b$._}${c$._}${d$._}`,
|
|
159
|
+
combined$=>values.push(combined$._)
|
|
160
160
|
).go()
|
|
161
161
|
deepStrictEqual(values, ['a0b0c0d0'])
|
|
162
|
-
store
|
|
162
|
+
store$._ = 1
|
|
163
163
|
deepStrictEqual(values, ['a0b0c0d0', 'a1b1c1d1'])
|
|
164
164
|
})
|
|
165
165
|
test('autosubscribe: prevents diamond dependency problem 4 (complex)', ()=>{
|
|
166
166
|
const store1$ = rw_rmemo_(0)
|
|
167
167
|
const store2$ = rw_rmemo_(0)
|
|
168
168
|
const values:string[] = []
|
|
169
|
-
const a$ = r_rmemo_(()=>`a${store1
|
|
170
|
-
const b$ = r_rmemo_(()=>`b${store2
|
|
171
|
-
const c$ = r_rmemo_(()=>`c${a
|
|
172
|
-
const d$ = r_rmemo_(()=>`d${a
|
|
173
|
-
const e$ = r_rmemo_(()=>`e${c
|
|
174
|
-
const f$ = r_rmemo_(()=>`f${e
|
|
175
|
-
const g$ = r_rmemo_(()=>`g${f
|
|
169
|
+
const a$ = r_rmemo_(()=>`a${store1$._}`)
|
|
170
|
+
const b$ = r_rmemo_(()=>`b${store2$._}`)
|
|
171
|
+
const c$ = r_rmemo_(()=>`c${a$._}${b$._}`)
|
|
172
|
+
const d$ = r_rmemo_(()=>`d${a$._}`)
|
|
173
|
+
const e$ = r_rmemo_(()=>`e${c$._}${d$._}`)
|
|
174
|
+
const f$ = r_rmemo_(()=>`f${e$._}`)
|
|
175
|
+
const g$ = r_rmemo_(()=>`g${f$._}`)
|
|
176
176
|
r_rmemo_(
|
|
177
|
-
()=>e
|
|
178
|
-
combined1$=>values.push(combined1
|
|
177
|
+
()=>e$._,
|
|
178
|
+
combined1$=>values.push(combined1$._)
|
|
179
179
|
).go()
|
|
180
180
|
r_rmemo_(
|
|
181
|
-
()=>[e
|
|
182
|
-
combined2$=>values.push(combined2
|
|
181
|
+
()=>[e$._, g$._].join(''),
|
|
182
|
+
combined2$=>values.push(combined2$._)
|
|
183
183
|
).go()
|
|
184
184
|
deepStrictEqual(values, ['eca0b0da0', 'eca0b0da0gfeca0b0da0'])
|
|
185
|
-
store1
|
|
186
|
-
store2
|
|
185
|
+
store1$._ = 1
|
|
186
|
+
store2$._ = 2
|
|
187
187
|
deepStrictEqual(values, [
|
|
188
188
|
'eca0b0da0',
|
|
189
189
|
'eca0b0da0gfeca0b0da0',
|
|
@@ -199,62 +199,62 @@ test('prevents diamond dependency problem 5', ()=>{
|
|
|
199
199
|
const lastName$ = rw_rmemo_('Doe')
|
|
200
200
|
const fullName$ = r_rmemo_(()=>{
|
|
201
201
|
events += 'full '
|
|
202
|
-
return `${firstName
|
|
202
|
+
return `${firstName$._} ${lastName$._}`
|
|
203
203
|
})
|
|
204
204
|
const isFirstShort$ = r_rmemo_(()=>{
|
|
205
205
|
events += 'short '
|
|
206
|
-
return firstName
|
|
206
|
+
return firstName$._.length < 10
|
|
207
207
|
})
|
|
208
208
|
const displayName$ = r_rmemo_(
|
|
209
209
|
()=>{
|
|
210
210
|
events += 'display '
|
|
211
|
-
return isFirstShort
|
|
211
|
+
return isFirstShort$._ ? fullName$._ : firstName$._
|
|
212
212
|
}
|
|
213
213
|
)
|
|
214
214
|
equal(events, '')
|
|
215
|
-
equal(displayName
|
|
215
|
+
equal(displayName$._, 'John Doe')
|
|
216
216
|
equal(events, 'display short full ')
|
|
217
|
-
firstName
|
|
218
|
-
equal(displayName
|
|
217
|
+
firstName$._ = 'Benedict'
|
|
218
|
+
equal(displayName$._, 'Benedict Doe')
|
|
219
219
|
equal(events, 'display short full short full display ')
|
|
220
|
-
firstName
|
|
221
|
-
equal(displayName
|
|
220
|
+
firstName$._ = 'Montgomery'
|
|
221
|
+
equal(displayName$._, 'Montgomery')
|
|
222
222
|
equal(events, 'display short full short full display short full display ')
|
|
223
223
|
})
|
|
224
224
|
test('prevents diamond dependency problem 6', ()=>{
|
|
225
225
|
const store1$ = rw_rmemo_(0)
|
|
226
226
|
const store2$ = rw_rmemo_(0)
|
|
227
227
|
const values:string[] = []
|
|
228
|
-
const a$ = r_rmemo_(()=>`a${store1
|
|
229
|
-
const b$ = r_rmemo_(()=>`b${store2
|
|
230
|
-
const c$ = r_rmemo_(()=>b
|
|
228
|
+
const a$ = r_rmemo_(()=>`a${store1$._}`)
|
|
229
|
+
const b$ = r_rmemo_(()=>`b${store2$._}`)
|
|
230
|
+
const c$ = r_rmemo_(()=>b$._.replace('b', 'c'))
|
|
231
231
|
r_rmemo_(
|
|
232
|
-
()=>`${a
|
|
233
|
-
combined$=>values.push(combined
|
|
232
|
+
()=>`${a$._}${c$._}`,
|
|
233
|
+
combined$=>values.push(combined$._)
|
|
234
234
|
).go()
|
|
235
235
|
deepStrictEqual(values, ['a0c0'])
|
|
236
|
-
store1
|
|
236
|
+
store1$._ = 1
|
|
237
237
|
deepStrictEqual(values, ['a0c0', 'a1c0'])
|
|
238
238
|
})
|
|
239
239
|
test('prevents dependency listeners from being out of order', ()=>{
|
|
240
240
|
const base$ = rw_rmemo_(0)
|
|
241
241
|
const a$ = r_rmemo_(()=>{
|
|
242
|
-
return `${base
|
|
242
|
+
return `${base$._}a`
|
|
243
243
|
})
|
|
244
244
|
const values:string[] = []
|
|
245
245
|
const b$ = r_rmemo_(()=>{
|
|
246
|
-
return `${a
|
|
247
|
-
}, b$=>values.push(b
|
|
248
|
-
equal(b
|
|
246
|
+
return `${a$._}b`
|
|
247
|
+
}, b$=>values.push(b$._))
|
|
248
|
+
equal(b$._, '0ab')
|
|
249
249
|
deepStrictEqual(values, ['0ab'])
|
|
250
|
-
equal(a
|
|
251
|
-
base
|
|
250
|
+
equal(a$._, '0a')
|
|
251
|
+
base$._ = 1
|
|
252
252
|
deepStrictEqual(values, ['0ab', '1ab'])
|
|
253
253
|
})
|
|
254
254
|
test('computes initial value when argument is undefined', ()=>{
|
|
255
255
|
const one$ = rw_rmemo_<string|undefined>(undefined)
|
|
256
|
-
const two$ = r_rmemo_(()=>!!one
|
|
257
|
-
equal(one
|
|
258
|
-
equal(two
|
|
256
|
+
const two$ = r_rmemo_(()=>!!one$._)
|
|
257
|
+
equal(one$._, undefined)
|
|
258
|
+
equal(two$._, false)
|
|
259
259
|
})
|
|
260
260
|
test.run()
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "ctx-core",
|
|
3
|
-
"version": "4.
|
|
3
|
+
"version": "4.3.0",
|
|
4
4
|
"description": "ctx-core core library",
|
|
5
5
|
"keywords": [
|
|
6
6
|
"ctx-core",
|
|
@@ -114,7 +114,7 @@
|
|
|
114
114
|
"sinon": "^17.0.1",
|
|
115
115
|
"size-limit": "^11.0.0",
|
|
116
116
|
"ts-node": "^10.9.1",
|
|
117
|
-
"tsx": "^4.
|
|
117
|
+
"tsx": "^4.2.0",
|
|
118
118
|
"typescript": "next",
|
|
119
119
|
"uvu": "^0.5.6"
|
|
120
120
|
},
|
|
@@ -150,28 +150,28 @@
|
|
|
150
150
|
"import": {
|
|
151
151
|
"./rmemo": "{ r_rmemo_ }"
|
|
152
152
|
},
|
|
153
|
-
"limit": "
|
|
153
|
+
"limit": "289 B"
|
|
154
154
|
},
|
|
155
155
|
{
|
|
156
156
|
"name": "r_rmemo_ signal_",
|
|
157
157
|
"import": {
|
|
158
158
|
"./rmemo": "{ rw_rmemo_, r_rmemo_ }"
|
|
159
159
|
},
|
|
160
|
-
"limit": "
|
|
160
|
+
"limit": "318 B"
|
|
161
161
|
},
|
|
162
162
|
{
|
|
163
163
|
"name": "r_rmemo_ signal_ be_ ctx_",
|
|
164
164
|
"import": {
|
|
165
165
|
"./rmemo": "{ rw_rmemo_, r_rmemo_, be_, ctx_ }"
|
|
166
166
|
},
|
|
167
|
-
"limit": "
|
|
167
|
+
"limit": "475 B"
|
|
168
168
|
},
|
|
169
169
|
{
|
|
170
170
|
"name": "r_rmemo_ signal_ be_ ctx_ be_r_rmemo_pair_ be_rw_rmemo_triple_",
|
|
171
171
|
"import": {
|
|
172
172
|
"./rmemo": "{ rw_rmemo_, r_rmemo_, be_, ctx_, be_r_rmemo_pair_, be_rw_rmemo_triple_ }"
|
|
173
173
|
},
|
|
174
|
-
"limit": "
|
|
174
|
+
"limit": "557 B"
|
|
175
175
|
}
|
|
176
176
|
],
|
|
177
177
|
"scripts": {
|