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.
@@ -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
- onset(val:val_T):unknown
30
- refresh():val_T
31
- }&r_rmemo_o_T<val_T>
27
+ }
@@ -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 cur_ref
5
+ let cur_r
5
6
  /** @type {(()=>unknown)[]} */
6
7
  let queue = []
7
8
  /**
8
- * @param {(r_rmemo:r_rmemo_T<unknown>)=>unknown}_f
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_(_f, ...subscriber_a) {
14
- let r_rmemo = (...arg_a)=>arg_a.length ? r_rmemo._ = arg_a[0] : r_rmemo._
15
- let _r = new WeakRef(()=>r_rmemo._ = _f(r_rmemo))
16
- _r.l = 0
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 prev_ref = cur_ref
26
- cur_ref = _r
19
+ let prev_r = cur_r
20
+ cur_r = r_rmemo._r
27
21
  try {
28
- r_rmemo._ = _f(r_rmemo)
22
+ init()
29
23
  } finally {
30
- cur_ref = prev_ref
24
+ cur_r = prev_r
31
25
  }
32
26
  }
33
- // allow self-referencing
34
- if (cur_ref && cur_ref !== _r) {
35
- cur_ref.l = cur_ref.l < _r.l + 1 ? _r.l + 1 : cur_ref.l
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.onset(val)
36
+ r_rmemo._s?.(val)
44
37
  let run_queue = !queue[0]
45
- for (let ref of r_rmemo._rS) {
46
- if (!~queue.indexOf(ref)) queue.push(ref)
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 ref; ref = queue.shift();) {
55
- if (queue.some(_ref=>ref.l > _ref.l)) {
56
- queue.push(ref)
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
- (ref.deref() || r_rmemo._rS.delete)(ref)
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_(_rsig=>_rsig._v, ...subscriber_a)
75
- rw_rmemo.onset = val=>rw_rmemo._v = val
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
  }
@@ -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(), 'rmemo-value')
13
+ equal(r_rmemo._, 'rmemo-value')
14
14
  equal(count, 1)
15
- equal(r_rmemo(), 'rmemo-value')
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(), 'val0')
21
- rw_rmemo('val1')
22
- equal(rw_rmemo(), 'val1')
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(), 'custom_val0-val0')
29
+ equal(r_rmemo._, 'custom_val0-val0')
30
30
  r_rmemo.custom = 'custom_val1'
31
- equal(r_rmemo(), 'custom_val0-val0')
32
- rw_rmemo('val1')
33
- equal(r_rmemo(), 'custom_val1-val1')
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$(user)
47
+ _user$._ = (user)
48
48
  })
49
49
  equal(count, 0)
50
- equal(user$(), null)
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$(), user0)
55
+ equal(user$._, user0)
56
56
  equal(count, 1)
57
- id$('id-1')
57
+ id$._ = 'id-1'
58
58
  equal(count, 2)
59
- equal(user$(), user0)
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$(), b$()])
71
+ taskArgumentsCalls.push([a$._, b$._])
72
72
  for (let i = 0; i < sleepCycles; i++) {
73
73
  await Promise.resolve()
74
74
  }
75
- sum$(a$() + b$())
75
+ sum$._ = a$._ + b$._
76
76
  })
77
- equal(sum$(), null)
77
+ equal(sum$._, null)
78
78
  deepStrictEqual(taskArgumentsCalls, [[1, 2]])
79
- a$(10)
80
- b$(20)
79
+ a$._ = 10
80
+ b$._ = 20
81
81
  for (let i = 0; i < sleepCycles; i++) {
82
- equal(sum$(), null)
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$(), 30)
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$() + '-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')
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$().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$()}`,
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$(1)
131
- store$(2)
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$().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'))
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$(), e$()].join(''),
144
- combined$=>values.push(combined$())
143
+ ()=>[a$._, e$._].join(''),
144
+ $=>values.push($._)
145
145
  ).go()
146
146
  deepStrictEqual(values, ['a0e0'])
147
- store$(1)
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$().replace('a', 'b'))
155
- const c$ = r_rmemo_(()=>b$().replace('b', 'c'))
156
- const d$ = r_rmemo_(()=>c$().replace('c', 'd'))
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$()}${b$()}${c$()}${d$()}`,
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$(1)
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$()}${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$()}`)
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$(), g$()].join(''),
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$(1)
186
- store2$(2)
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$()} ${lastName$()}`
202
+ return `${firstName$._} ${lastName$._}`
203
203
  })
204
204
  const isFirstShort$ = r_rmemo_(()=>{
205
205
  events += 'short '
206
- return firstName$().length < 10
206
+ return firstName$._.length < 10
207
207
  })
208
208
  const displayName$ = r_rmemo_(
209
209
  ()=>{
210
210
  events += 'display '
211
- return isFirstShort$() ? fullName$() : firstName$()
211
+ return isFirstShort$._ ? fullName$._ : firstName$._
212
212
  }
213
213
  )
214
214
  equal(events, '')
215
- equal(displayName$(), 'John Doe')
215
+ equal(displayName$._, 'John Doe')
216
216
  equal(events, 'display short full ')
217
- firstName$('Benedict')
218
- equal(displayName$(), 'Benedict Doe')
217
+ firstName$._ = 'Benedict'
218
+ equal(displayName$._, 'Benedict Doe')
219
219
  equal(events, 'display short full short full display ')
220
- firstName$('Montgomery')
221
- equal(displayName$(), 'Montgomery')
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$().replace('b', 'c'))
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$()}${c$()}`,
233
- combined$=>values.push(combined$())
232
+ ()=>`${a$._}${c$._}`,
233
+ combined$=>values.push(combined$._)
234
234
  ).go()
235
235
  deepStrictEqual(values, ['a0c0'])
236
- store1$(1)
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$()}a`
242
+ return `${base$._}a`
243
243
  })
244
244
  const values:string[] = []
245
245
  const b$ = r_rmemo_(()=>{
246
- return `${a$()}b`
247
- }, b$=>values.push(b$()))
248
- equal(b$(), '0ab')
246
+ return `${a$._}b`
247
+ }, b$=>values.push(b$._))
248
+ equal(b$._, '0ab')
249
249
  deepStrictEqual(values, ['0ab'])
250
- equal(a$(), '0a')
251
- base$(1)
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$(), undefined)
258
- equal(two$(), false)
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.2.0",
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.1.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": "322 B"
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": "350 B"
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": "509 B"
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": "590 B"
174
+ "limit": "557 B"
175
175
  }
176
176
  ],
177
177
  "scripts": {