@graphrefly/graphrefly 0.47.1 → 0.47.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.
Files changed (164) hide show
  1. package/dist/base/composition/index.cjs +24 -16
  2. package/dist/base/composition/index.cjs.map +1 -1
  3. package/dist/base/composition/index.js +6 -6
  4. package/dist/base/index.cjs +142 -86
  5. package/dist/base/index.cjs.map +1 -1
  6. package/dist/base/index.js +11 -11
  7. package/dist/base/io/index.cjs +114 -68
  8. package/dist/base/io/index.cjs.map +1 -1
  9. package/dist/base/io/index.js +5 -5
  10. package/dist/base/sources/browser/index.cjs +13 -9
  11. package/dist/base/sources/browser/index.cjs.map +1 -1
  12. package/dist/base/sources/browser/index.js +13 -9
  13. package/dist/base/sources/browser/index.js.map +1 -1
  14. package/dist/base/sources/event/index.cjs +1 -1
  15. package/dist/base/sources/event/index.cjs.map +1 -1
  16. package/dist/base/sources/event/index.js +1 -1
  17. package/dist/base/sources/index.cjs +21 -13
  18. package/dist/base/sources/index.cjs.map +1 -1
  19. package/dist/base/sources/index.js +3 -3
  20. package/dist/base/sources/node/index.cjs +43 -37
  21. package/dist/base/sources/node/index.cjs.map +1 -1
  22. package/dist/base/sources/node/index.js +43 -37
  23. package/dist/base/sources/node/index.js.map +1 -1
  24. package/dist/{chunk-VLAGJZSL.js → chunk-3O3NKZJW.js} +2 -2
  25. package/dist/{chunk-YJ4U2D2C.js → chunk-446I4EGD.js} +9 -7
  26. package/dist/chunk-446I4EGD.js.map +1 -0
  27. package/dist/{chunk-DKNHAICT.js → chunk-5GVURVIG.js} +14 -8
  28. package/dist/chunk-5GVURVIG.js.map +1 -0
  29. package/dist/{chunk-2OB3CEJS.js → chunk-6MRSX3YK.js} +2 -2
  30. package/dist/{chunk-EVYY4X5A.js → chunk-6ZLCPUXS.js} +2 -2
  31. package/dist/{chunk-U225SKB4.js → chunk-7AVQIGF6.js} +61 -10
  32. package/dist/chunk-7AVQIGF6.js.map +1 -0
  33. package/dist/{chunk-7EGRP2VX.js → chunk-7BULJTL6.js} +2 -2
  34. package/dist/{chunk-7EGRP2VX.js.map → chunk-7BULJTL6.js.map} +1 -1
  35. package/dist/{chunk-7ADWWI2T.js → chunk-DDTS7F5O.js} +6 -4
  36. package/dist/chunk-DDTS7F5O.js.map +1 -0
  37. package/dist/{chunk-OCUDSN63.js → chunk-EL5VHUGK.js} +79 -47
  38. package/dist/chunk-EL5VHUGK.js.map +1 -0
  39. package/dist/{chunk-4GYMCUDZ.js → chunk-EP4WVQLX.js} +5 -5
  40. package/dist/{chunk-SOOKUYVM.js → chunk-F7EKHR32.js} +13 -9
  41. package/dist/chunk-F7EKHR32.js.map +1 -0
  42. package/dist/{chunk-RGMTUZCL.js → chunk-FQSQONOU.js} +3 -3
  43. package/dist/{chunk-RAGGHLCV.js → chunk-GUNIRPEJ.js} +8 -6
  44. package/dist/{chunk-RAGGHLCV.js.map → chunk-GUNIRPEJ.js.map} +1 -1
  45. package/dist/{chunk-BU3SEFA5.js → chunk-IOJDYUA7.js} +2 -2
  46. package/dist/{chunk-Y52CS6YA.js → chunk-JA67ZQG2.js} +2 -2
  47. package/dist/{chunk-Y52CS6YA.js.map → chunk-JA67ZQG2.js.map} +1 -1
  48. package/dist/{chunk-DM4OMPWK.js → chunk-KNU73RZW.js} +2 -2
  49. package/dist/{chunk-K7PDZYQE.js → chunk-KRFGO5QH.js} +18 -14
  50. package/dist/{chunk-K7PDZYQE.js.map → chunk-KRFGO5QH.js.map} +1 -1
  51. package/dist/{chunk-Z4YXAUDN.js → chunk-KUFXLAEY.js} +11 -7
  52. package/dist/{chunk-Z4YXAUDN.js.map → chunk-KUFXLAEY.js.map} +1 -1
  53. package/dist/{chunk-YXCPV26R.js → chunk-MS3WPRJR.js} +37 -25
  54. package/dist/chunk-MS3WPRJR.js.map +1 -0
  55. package/dist/{chunk-CXANAIZU.js → chunk-N65E26UL.js} +3 -3
  56. package/dist/{chunk-O3MT7DYI.js → chunk-N6MNJNHB.js} +2 -2
  57. package/dist/{chunk-A7KV5UK4.js → chunk-OXD5LFQP.js} +2 -2
  58. package/dist/{chunk-V4Y3TM7U.js → chunk-PTWADEH3.js} +8 -6
  59. package/dist/chunk-PTWADEH3.js.map +1 -0
  60. package/dist/{chunk-IHTWQEDR.js → chunk-QFE5BQH7.js} +2 -2
  61. package/dist/{chunk-IHTWQEDR.js.map → chunk-QFE5BQH7.js.map} +1 -1
  62. package/dist/{chunk-J5WFUEO4.js → chunk-R6ZCSXKX.js} +3 -3
  63. package/dist/{chunk-PZWISPIQ.js → chunk-S7HN5FHL.js} +17 -11
  64. package/dist/chunk-S7HN5FHL.js.map +1 -0
  65. package/dist/{chunk-RJOG4IJU.js → chunk-T7SP3EYR.js} +18 -12
  66. package/dist/chunk-T7SP3EYR.js.map +1 -0
  67. package/dist/{chunk-4S53H2KR.js → chunk-VAZXUK6G.js} +2 -2
  68. package/dist/{chunk-IJRR6YAI.js → chunk-VLDRAMP7.js} +18 -12
  69. package/dist/chunk-VLDRAMP7.js.map +1 -0
  70. package/dist/{chunk-B4AKFXGE.js → chunk-VNXAF2KE.js} +3 -3
  71. package/dist/{chunk-MTTRCEJT.js → chunk-VP3TIUDF.js} +2 -2
  72. package/dist/{chunk-6XZYT4SW.js → chunk-WGDEBIP4.js} +5 -5
  73. package/dist/{chunk-E5OZPDIW.js → chunk-X7BA5PWG.js} +7 -5
  74. package/dist/chunk-X7BA5PWG.js.map +1 -0
  75. package/dist/compat/index.cjs +1 -1
  76. package/dist/compat/index.cjs.map +1 -1
  77. package/dist/compat/index.js +2 -2
  78. package/dist/compat/nestjs/index.cjs +1 -1
  79. package/dist/compat/nestjs/index.cjs.map +1 -1
  80. package/dist/compat/nestjs/index.js +2 -2
  81. package/dist/index.cjs +283 -142
  82. package/dist/index.cjs.map +1 -1
  83. package/dist/index.js +32 -32
  84. package/dist/presets/ai/index.cjs +42 -26
  85. package/dist/presets/ai/index.cjs.map +1 -1
  86. package/dist/presets/ai/index.js +10 -10
  87. package/dist/presets/harness/index.cjs +53 -33
  88. package/dist/presets/harness/index.cjs.map +1 -1
  89. package/dist/presets/harness/index.js +21 -21
  90. package/dist/presets/index.cjs +76 -48
  91. package/dist/presets/index.cjs.map +1 -1
  92. package/dist/presets/index.js +24 -24
  93. package/dist/presets/resilience/index.cjs +35 -23
  94. package/dist/presets/resilience/index.cjs.map +1 -1
  95. package/dist/presets/resilience/index.js +5 -5
  96. package/dist/solutions/index.cjs +71 -45
  97. package/dist/solutions/index.cjs.map +1 -1
  98. package/dist/solutions/index.js +21 -21
  99. package/dist/{timeout-U5O4ESK3.js → timeout-BEABACRP.js} +2 -2
  100. package/dist/utils/ai/browser.cjs.map +1 -1
  101. package/dist/utils/ai/browser.js +9 -9
  102. package/dist/utils/ai/index.cjs +41 -25
  103. package/dist/utils/ai/index.cjs.map +1 -1
  104. package/dist/utils/ai/index.js +17 -17
  105. package/dist/utils/ai/node.js +3 -3
  106. package/dist/utils/domain-templates/index.cjs +1 -1
  107. package/dist/utils/domain-templates/index.cjs.map +1 -1
  108. package/dist/utils/domain-templates/index.js +2 -2
  109. package/dist/utils/graphspec/index.cjs +1 -1
  110. package/dist/utils/graphspec/index.cjs.map +1 -1
  111. package/dist/utils/graphspec/index.js +2 -2
  112. package/dist/utils/harness/index.cjs +16 -10
  113. package/dist/utils/harness/index.cjs.map +1 -1
  114. package/dist/utils/harness/index.js +1 -1
  115. package/dist/utils/index.cjs +138 -55
  116. package/dist/utils/index.cjs.map +1 -1
  117. package/dist/utils/index.js +21 -21
  118. package/dist/utils/memory/index.cjs +51 -0
  119. package/dist/utils/memory/index.cjs.map +1 -1
  120. package/dist/utils/memory/index.d.cts +58 -9
  121. package/dist/utils/memory/index.d.ts +58 -9
  122. package/dist/utils/memory/index.js +1 -1
  123. package/dist/utils/orchestration/index.cjs +5 -3
  124. package/dist/utils/orchestration/index.cjs.map +1 -1
  125. package/dist/utils/orchestration/index.js +1 -1
  126. package/dist/utils/process/index.js +2 -2
  127. package/dist/utils/reduction/index.cjs +1 -1
  128. package/dist/utils/reduction/index.cjs.map +1 -1
  129. package/dist/utils/reduction/index.js +1 -1
  130. package/dist/utils/resilience/index.cjs +35 -23
  131. package/dist/utils/resilience/index.cjs.map +1 -1
  132. package/dist/utils/resilience/index.js +4 -4
  133. package/dist/utils/surface/index.cjs +1 -1
  134. package/dist/utils/surface/index.cjs.map +1 -1
  135. package/dist/utils/surface/index.js +3 -3
  136. package/package.json +1 -1
  137. package/dist/chunk-7ADWWI2T.js.map +0 -1
  138. package/dist/chunk-DKNHAICT.js.map +0 -1
  139. package/dist/chunk-E5OZPDIW.js.map +0 -1
  140. package/dist/chunk-IJRR6YAI.js.map +0 -1
  141. package/dist/chunk-OCUDSN63.js.map +0 -1
  142. package/dist/chunk-PZWISPIQ.js.map +0 -1
  143. package/dist/chunk-RJOG4IJU.js.map +0 -1
  144. package/dist/chunk-SOOKUYVM.js.map +0 -1
  145. package/dist/chunk-U225SKB4.js.map +0 -1
  146. package/dist/chunk-V4Y3TM7U.js.map +0 -1
  147. package/dist/chunk-YJ4U2D2C.js.map +0 -1
  148. package/dist/chunk-YXCPV26R.js.map +0 -1
  149. /package/dist/{chunk-VLAGJZSL.js.map → chunk-3O3NKZJW.js.map} +0 -0
  150. /package/dist/{chunk-2OB3CEJS.js.map → chunk-6MRSX3YK.js.map} +0 -0
  151. /package/dist/{chunk-EVYY4X5A.js.map → chunk-6ZLCPUXS.js.map} +0 -0
  152. /package/dist/{chunk-4GYMCUDZ.js.map → chunk-EP4WVQLX.js.map} +0 -0
  153. /package/dist/{chunk-RGMTUZCL.js.map → chunk-FQSQONOU.js.map} +0 -0
  154. /package/dist/{chunk-BU3SEFA5.js.map → chunk-IOJDYUA7.js.map} +0 -0
  155. /package/dist/{chunk-DM4OMPWK.js.map → chunk-KNU73RZW.js.map} +0 -0
  156. /package/dist/{chunk-CXANAIZU.js.map → chunk-N65E26UL.js.map} +0 -0
  157. /package/dist/{chunk-O3MT7DYI.js.map → chunk-N6MNJNHB.js.map} +0 -0
  158. /package/dist/{chunk-A7KV5UK4.js.map → chunk-OXD5LFQP.js.map} +0 -0
  159. /package/dist/{chunk-J5WFUEO4.js.map → chunk-R6ZCSXKX.js.map} +0 -0
  160. /package/dist/{chunk-4S53H2KR.js.map → chunk-VAZXUK6G.js.map} +0 -0
  161. /package/dist/{chunk-B4AKFXGE.js.map → chunk-VNXAF2KE.js.map} +0 -0
  162. /package/dist/{chunk-MTTRCEJT.js.map → chunk-VP3TIUDF.js.map} +0 -0
  163. /package/dist/{chunk-6XZYT4SW.js.map → chunk-WGDEBIP4.js.map} +0 -0
  164. /package/dist/{timeout-U5O4ESK3.js.map → timeout-BEABACRP.js.map} +0 -0
@@ -318,11 +318,13 @@ function withTimeout(source, opts, extraOpts) {
318
318
  if (latestOpts != null) {
319
319
  attachSource();
320
320
  }
321
- return () => {
322
- stopped = true;
323
- timer.cancel();
324
- if (srcUnsub) srcUnsub();
325
- if (optsUnsub) optsUnsub();
321
+ return {
322
+ onDeactivation: () => {
323
+ stopped = true;
324
+ timer.cancel();
325
+ if (srcUnsub) srcUnsub();
326
+ if (optsUnsub) optsUnsub();
327
+ }
326
328
  };
327
329
  },
328
330
  {
@@ -3125,9 +3127,11 @@ function _retrySource(source, opts, emitState) {
3125
3127
  const merged = makeMergedOptsMirror(opts);
3126
3128
  const getCfg = () => resolveRetryConfig(merged.current());
3127
3129
  const inner = _runRetryStateMachine(getCfg, () => source, a, emitState);
3128
- return () => {
3129
- inner();
3130
- merged.unsub();
3130
+ return {
3131
+ onDeactivation: () => {
3132
+ inner();
3133
+ merged.unsub();
3134
+ }
3131
3135
  };
3132
3136
  },
3133
3137
  {
@@ -3151,9 +3155,11 @@ function _retryFactory(factory, opts, emitState) {
3151
3155
  const merged = makeMergedOptsMirror(opts);
3152
3156
  const getCfg = () => resolveRetryConfig(merged.current());
3153
3157
  const inner = _runRetryStateMachine(getCfg, factory, a, emitState);
3154
- return () => {
3155
- inner();
3156
- merged.unsub();
3158
+ return {
3159
+ onDeactivation: () => {
3160
+ inner();
3161
+ merged.unsub();
3162
+ }
3157
3163
  };
3158
3164
  },
3159
3165
  {
@@ -3219,7 +3225,7 @@ function withStatus(src, options) {
3219
3225
  } else a.down([m]);
3220
3226
  }
3221
3227
  });
3222
- return unsub;
3228
+ return { onDeactivation: unsub };
3223
3229
  },
3224
3230
  {
3225
3231
  ...operatorOpts(),
@@ -3444,7 +3450,7 @@ function withBreaker(breaker, options) {
3444
3450
  }
3445
3451
  });
3446
3452
  syncState();
3447
- return unsub;
3453
+ return { onDeactivation: unsub };
3448
3454
  },
3449
3455
  {
3450
3456
  ...operatorOpts(),
@@ -3597,8 +3603,10 @@ function budgetGate(source, constraints, opts) {
3597
3603
  })
3598
3604
  );
3599
3605
  }
3600
- return () => {
3601
- for (const u of unsubs) u();
3606
+ return {
3607
+ onDeactivation: () => {
3608
+ for (const u of unsubs) u();
3609
+ }
3602
3610
  };
3603
3611
  },
3604
3612
  {
@@ -3728,9 +3736,11 @@ function fallback(source, fb, options) {
3728
3736
  } else a.down([m]);
3729
3737
  }
3730
3738
  });
3731
- return () => {
3732
- sourceUnsub?.();
3733
- fallbackUnsub?.();
3739
+ return {
3740
+ onDeactivation: () => {
3741
+ sourceUnsub?.();
3742
+ fallbackUnsub?.();
3743
+ }
3734
3744
  };
3735
3745
  },
3736
3746
  {
@@ -4183,11 +4193,13 @@ function rateLimiter(source, opts) {
4183
4193
  } else a.down([m]);
4184
4194
  }
4185
4195
  });
4186
- return () => {
4187
- terminated = true;
4188
- timer.cancel();
4189
- unsub();
4190
- optMirror.unsub();
4196
+ return {
4197
+ onDeactivation: () => {
4198
+ terminated = true;
4199
+ timer.cancel();
4200
+ unsub();
4201
+ optMirror.unsub();
4202
+ }
4191
4203
  };
4192
4204
  },
4193
4205
  {
@@ -5310,8 +5322,10 @@ function promptNode(adapter, deps, prompt, opts) {
5310
5322
  } catch (err) {
5311
5323
  done = true;
5312
5324
  actions.down([[import_core27.ERROR, err]]);
5313
- return () => {
5314
- abortDispose?.();
5325
+ return {
5326
+ onDeactivation: () => {
5327
+ abortDispose?.();
5328
+ }
5315
5329
  };
5316
5330
  }
5317
5331
  const callNode = (0, import_extra19.fromAny)(invokeResult);
@@ -5369,11 +5383,13 @@ function promptNode(adapter, deps, prompt, opts) {
5369
5383
  }
5370
5384
  }
5371
5385
  });
5372
- return () => {
5373
- cancelled = true;
5374
- sub();
5375
- abortDispose?.();
5376
- abortDispose = void 0;
5386
+ return {
5387
+ onDeactivation: () => {
5388
+ cancelled = true;
5389
+ sub();
5390
+ abortDispose?.();
5391
+ abortDispose = void 0;
5392
+ }
5377
5393
  };
5378
5394
  },
5379
5395
  {
@@ -6250,9 +6266,11 @@ function humanInput(opts) {
6250
6266
  });
6251
6267
  }
6252
6268
  });
6253
- return () => {
6254
- promptUnsub();
6255
- respUnsub?.();
6269
+ return {
6270
+ onDeactivation: () => {
6271
+ promptUnsub();
6272
+ respUnsub?.();
6273
+ }
6256
6274
  };
6257
6275
  },
6258
6276
  {
@@ -7613,16 +7631,20 @@ var ToolRegistryGraph = class extends import_graph5.Graph {
7613
7631
  inner = handlerResultToNode(raw, ac.signal);
7614
7632
  } catch (err) {
7615
7633
  actions.down([[import_core44.ERROR, err]]);
7616
- return () => {
7617
- ac.abort();
7634
+ return {
7635
+ onDeactivation: () => {
7636
+ ac.abort();
7637
+ }
7618
7638
  };
7619
7639
  }
7620
7640
  const unsub = inner.subscribe((batch14) => {
7621
7641
  actions.down(batch14);
7622
7642
  });
7623
- return () => {
7624
- ac.abort();
7625
- unsub();
7643
+ return {
7644
+ onDeactivation: () => {
7645
+ ac.abort();
7646
+ unsub();
7647
+ }
7626
7648
  };
7627
7649
  },
7628
7650
  {
@@ -8334,6 +8356,57 @@ function reactiveFactStore(config) {
8334
8356
  );
8335
8357
  graph.add(consolidated, { name: "consolidated" });
8336
8358
  graph.addDisposer((0, import_extra33.keepalive)(consolidated));
8359
+ if (config.decayTrigger) {
8360
+ const decayProcessor = (0, import_core48.node)(
8361
+ config.decay ? [config.decayTrigger, config.decay] : [config.decayTrigger],
8362
+ (batchData, actions, ctx) => {
8363
+ const policy3 = config.decay ? lastOf(batchData[1], ctx.prevData[1]) : void 0;
8364
+ if (!policy3) {
8365
+ actions.emit([]);
8366
+ return;
8367
+ }
8368
+ const now = BigInt((0, import_core48.monotonicNs)());
8369
+ const changes = [];
8370
+ for (const f of allFacts().values()) {
8371
+ if (f.validTo !== void 0) continue;
8372
+ const ageNs = now - f.t_ns;
8373
+ const raw = policy3(f.confidence, ageNs);
8374
+ if (!Number.isFinite(raw)) continue;
8375
+ const next = raw < 0 ? 0 : raw > 1 ? 1 : raw;
8376
+ if (next === f.confidence) continue;
8377
+ changes.push({ id: f.id, next });
8378
+ }
8379
+ const decayed = [];
8380
+ for (const { id, next } of changes) {
8381
+ const idx = findShardOf(id);
8382
+ const fs = idx < 0 ? void 0 : shards[idx].cache;
8383
+ const live = fs?.byId.get(id);
8384
+ if (!live || live.validTo !== void 0) continue;
8385
+ replaceFragment(
8386
+ id,
8387
+ (prev) => prev.validTo !== void 0 ? prev : { ...prev, confidence: next }
8388
+ );
8389
+ decayed.push({ ...live, confidence: next });
8390
+ }
8391
+ if (decayed.length > 0) {
8392
+ events.append({
8393
+ action: "decay",
8394
+ t_ns: (0, import_core48.wallClockNs)(),
8395
+ seq: bumpCursor(seqCursor)
8396
+ });
8397
+ }
8398
+ actions.emit(decayed);
8399
+ },
8400
+ {
8401
+ name: "decay_processor",
8402
+ describeKind: "derived",
8403
+ initial: [],
8404
+ meta: factMeta("decay")
8405
+ }
8406
+ );
8407
+ graph.add(decayProcessor, { name: "decay_processor" });
8408
+ graph.addDisposer((0, import_extra33.keepalive)(decayProcessor));
8409
+ }
8337
8410
  const ingestAudit = (0, import_core48.node)(
8338
8411
  [extractOp],
8339
8412
  (batchData, actions, ctx) => {
@@ -10225,7 +10298,7 @@ function feedback(graph, condition, reentry, opts) {
10225
10298
  }
10226
10299
  }
10227
10300
  });
10228
- return () => unsub();
10301
+ return { onDeactivation: () => unsub() };
10229
10302
  },
10230
10303
  {
10231
10304
  name: feedbackEffectName,
@@ -11413,9 +11486,11 @@ function graphFromSpecReactive(input, adapter, opts) {
11413
11486
  if (cancelled) return;
11414
11487
  actions.down([[import_core60.ERROR, err]]);
11415
11488
  });
11416
- return () => {
11417
- cancelled = true;
11418
- controller.abort();
11489
+ return {
11490
+ onDeactivation: () => {
11491
+ cancelled = true;
11492
+ controller.abort();
11493
+ }
11419
11494
  };
11420
11495
  },
11421
11496
  { describeKind: "producer", ...{ name: "graphFromSpec::call" } }
@@ -11602,9 +11677,11 @@ function suggestStrategyReactive(graph, problem, adapter, opts) {
11602
11677
  if (cancelled) return;
11603
11678
  actions.down([[import_core61.ERROR, err]]);
11604
11679
  });
11605
- return () => {
11606
- cancelled = true;
11607
- controller.abort();
11680
+ return {
11681
+ onDeactivation: () => {
11682
+ cancelled = true;
11683
+ controller.abort();
11684
+ }
11608
11685
  };
11609
11686
  },
11610
11687
  { describeKind: "producer", ...{ name: "suggestStrategy::call" } }
@@ -14993,9 +15070,11 @@ function actuatorExecutor(config) {
14993
15070
  inner = (0, import_extra49.fromAny)(rawResult, { signal: ac.signal });
14994
15071
  } catch (err) {
14995
15072
  emitOnce(onError(err, item));
14996
- return () => {
14997
- unlinkParent();
14998
- ac.abort();
15073
+ return {
15074
+ onDeactivation: () => {
15075
+ unlinkParent();
15076
+ ac.abort();
15077
+ }
14999
15078
  };
15000
15079
  }
15001
15080
  unsub = inner.subscribe((batch14) => {
@@ -15019,11 +15098,13 @@ function actuatorExecutor(config) {
15019
15098
  unsub();
15020
15099
  unsub = null;
15021
15100
  }
15022
- return () => {
15023
- unlinkParent();
15024
- ac.abort();
15025
- unsub?.();
15026
- unsub = null;
15101
+ return {
15102
+ onDeactivation: () => {
15103
+ unlinkParent();
15104
+ ac.abort();
15105
+ unsub?.();
15106
+ unsub = null;
15107
+ }
15027
15108
  };
15028
15109
  },
15029
15110
  { name: `${name}/inner`, describeKind: "producer" }
@@ -15114,8 +15195,10 @@ function autoSolidify(config) {
15114
15195
  unsub();
15115
15196
  unsub = null;
15116
15197
  }
15117
- return () => {
15118
- tearDown();
15198
+ return {
15199
+ onDeactivation: () => {
15200
+ tearDown();
15201
+ }
15119
15202
  };
15120
15203
  },
15121
15204
  { name, describeKind: "producer" }