@alloy-js/core 0.23.0-dev.1 → 0.23.0-dev.11

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 (337) hide show
  1. package/CHANGELOG.md +0 -22
  2. package/dist/devtools/index.html +80 -0
  3. package/dist/src/binder.d.ts +2 -0
  4. package/dist/src/binder.d.ts.map +1 -1
  5. package/dist/src/binder.js +60 -12
  6. package/dist/src/binder.js.map +1 -1
  7. package/dist/src/components/AccessExpression.d.ts +78 -0
  8. package/dist/src/components/AccessExpression.d.ts.map +1 -0
  9. package/dist/src/components/AccessExpression.js +218 -0
  10. package/dist/src/components/AccessExpression.js.map +1 -0
  11. package/dist/src/components/AccessExpression.test.d.ts +2 -0
  12. package/dist/src/components/AccessExpression.test.d.ts.map +1 -0
  13. package/dist/src/components/AccessExpression.test.js +137 -0
  14. package/dist/src/components/AccessExpression.test.js.map +1 -0
  15. package/dist/src/components/AppendFile.d.ts.map +1 -1
  16. package/dist/src/components/AppendFile.js +14 -3
  17. package/dist/src/components/AppendFile.js.map +1 -1
  18. package/dist/src/components/Block.js +1 -1
  19. package/dist/src/components/Block.js.map +1 -1
  20. package/dist/src/components/Declaration.d.ts.map +1 -1
  21. package/dist/src/components/Declaration.js +2 -1
  22. package/dist/src/components/Declaration.js.map +1 -1
  23. package/dist/src/components/For.d.ts.map +1 -1
  24. package/dist/src/components/For.js +1 -1
  25. package/dist/src/components/For.js.map +1 -1
  26. package/dist/src/components/List.d.ts.map +1 -1
  27. package/dist/src/components/List.js +1 -1
  28. package/dist/src/components/List.js.map +1 -1
  29. package/dist/src/components/Prose.js +2 -2
  30. package/dist/src/components/Prose.js.map +1 -1
  31. package/dist/src/components/Scope.d.ts.map +1 -1
  32. package/dist/src/components/Scope.js +6 -1
  33. package/dist/src/components/Scope.js.map +1 -1
  34. package/dist/src/components/SourceDirectory.d.ts.map +1 -1
  35. package/dist/src/components/SourceDirectory.js +1 -2
  36. package/dist/src/components/SourceDirectory.js.map +1 -1
  37. package/dist/src/components/Switch.d.ts.map +1 -1
  38. package/dist/src/components/Switch.js +1 -1
  39. package/dist/src/components/Switch.js.map +1 -1
  40. package/dist/src/components/TemplateFile.d.ts.map +1 -1
  41. package/dist/src/components/TemplateFile.js +18 -3
  42. package/dist/src/components/TemplateFile.js.map +1 -1
  43. package/dist/src/components/index.d.ts +1 -0
  44. package/dist/src/components/index.d.ts.map +1 -1
  45. package/dist/src/components/index.js +1 -0
  46. package/dist/src/components/index.js.map +1 -1
  47. package/dist/src/content-slot.d.ts.map +1 -1
  48. package/dist/src/content-slot.js +7 -6
  49. package/dist/src/content-slot.js.map +1 -1
  50. package/dist/src/context.d.ts.map +1 -1
  51. package/dist/src/context.js +10 -3
  52. package/dist/src/context.js.map +1 -1
  53. package/dist/src/debug/cli.d.ts +6 -0
  54. package/dist/src/debug/cli.d.ts.map +1 -0
  55. package/dist/src/{debug.js → debug/cli.js} +79 -82
  56. package/dist/src/debug/cli.js.map +1 -0
  57. package/dist/src/debug/diagnostics.test.d.ts +2 -0
  58. package/dist/src/debug/diagnostics.test.d.ts.map +1 -0
  59. package/dist/src/debug/diagnostics.test.js +46 -0
  60. package/dist/src/debug/diagnostics.test.js.map +1 -0
  61. package/dist/src/debug/effects.d.ts +81 -0
  62. package/dist/src/debug/effects.d.ts.map +1 -0
  63. package/dist/src/debug/effects.js +358 -0
  64. package/dist/src/debug/effects.js.map +1 -0
  65. package/dist/src/debug/effects.test.d.ts +2 -0
  66. package/dist/src/debug/effects.test.d.ts.map +1 -0
  67. package/dist/src/debug/effects.test.js +256 -0
  68. package/dist/src/debug/effects.test.js.map +1 -0
  69. package/dist/src/debug/files.d.ts +14 -0
  70. package/dist/src/debug/files.d.ts.map +1 -0
  71. package/dist/src/debug/files.js +29 -0
  72. package/dist/src/debug/files.js.map +1 -0
  73. package/dist/src/debug/files.test.d.ts +2 -0
  74. package/dist/src/debug/files.test.d.ts.map +1 -0
  75. package/dist/src/debug/files.test.js +66 -0
  76. package/dist/src/debug/files.test.js.map +1 -0
  77. package/dist/src/debug/index.d.ts +63 -0
  78. package/dist/src/debug/index.d.ts.map +1 -0
  79. package/dist/src/debug/index.js +71 -0
  80. package/dist/src/debug/index.js.map +1 -0
  81. package/dist/src/debug/message-format.test.d.ts +2 -0
  82. package/dist/src/debug/message-format.test.d.ts.map +1 -0
  83. package/dist/src/debug/message-format.test.js +700 -0
  84. package/dist/src/debug/message-format.test.js.map +1 -0
  85. package/dist/src/debug/render-tree-orphans.test.d.ts +2 -0
  86. package/dist/src/debug/render-tree-orphans.test.d.ts.map +1 -0
  87. package/dist/src/debug/render-tree-orphans.test.js +297 -0
  88. package/dist/src/debug/render-tree-orphans.test.js.map +1 -0
  89. package/dist/src/debug/render.d.ts +57 -0
  90. package/dist/src/debug/render.d.ts.map +1 -0
  91. package/dist/src/debug/render.js +472 -0
  92. package/dist/src/debug/render.js.map +1 -0
  93. package/dist/src/debug/render.test.d.ts +2 -0
  94. package/dist/src/debug/render.test.d.ts.map +1 -0
  95. package/dist/src/debug/render.test.js +291 -0
  96. package/dist/src/debug/render.test.js.map +1 -0
  97. package/dist/src/debug/serialize.d.ts +9 -0
  98. package/dist/src/debug/serialize.d.ts.map +1 -0
  99. package/dist/src/debug/serialize.js +70 -0
  100. package/dist/src/debug/serialize.js.map +1 -0
  101. package/dist/src/debug/symbols.d.ts +16 -0
  102. package/dist/src/debug/symbols.d.ts.map +1 -0
  103. package/dist/src/debug/symbols.js +196 -0
  104. package/dist/src/debug/symbols.js.map +1 -0
  105. package/dist/src/debug/symbols.test.d.ts +2 -0
  106. package/dist/src/debug/symbols.test.d.ts.map +1 -0
  107. package/dist/src/debug/symbols.test.js +93 -0
  108. package/dist/src/debug/symbols.test.js.map +1 -0
  109. package/dist/src/debug/trace-writer.d.ts +55 -0
  110. package/dist/src/debug/trace-writer.d.ts.map +1 -0
  111. package/dist/src/debug/trace-writer.js +658 -0
  112. package/dist/src/debug/trace-writer.js.map +1 -0
  113. package/dist/src/debug/trace.d.ts +342 -0
  114. package/dist/src/debug/trace.d.ts.map +1 -0
  115. package/dist/src/debug/trace.js +446 -0
  116. package/dist/src/debug/trace.js.map +1 -0
  117. package/dist/src/devtools/devtools-protocol.d.ts +389 -0
  118. package/dist/src/devtools/devtools-protocol.d.ts.map +1 -0
  119. package/dist/src/devtools/devtools-protocol.js +2 -0
  120. package/dist/src/devtools/devtools-protocol.js.map +1 -0
  121. package/dist/src/devtools/devtools-server.browser.d.ts +23 -0
  122. package/dist/src/devtools/devtools-server.browser.d.ts.map +1 -0
  123. package/dist/src/devtools/devtools-server.browser.js +33 -0
  124. package/dist/src/devtools/devtools-server.browser.js.map +1 -0
  125. package/dist/src/devtools/devtools-server.d.ts +66 -0
  126. package/dist/src/devtools/devtools-server.d.ts.map +1 -0
  127. package/dist/src/devtools/devtools-server.js +444 -0
  128. package/dist/src/devtools/devtools-server.js.map +1 -0
  129. package/dist/src/devtools/devtools-transport.d.ts +23 -0
  130. package/dist/src/devtools/devtools-transport.d.ts.map +1 -0
  131. package/dist/src/devtools/devtools-transport.js +114 -0
  132. package/dist/src/devtools/devtools-transport.js.map +1 -0
  133. package/dist/src/devtools-entry.browser.d.ts +4 -0
  134. package/dist/src/devtools-entry.browser.d.ts.map +1 -0
  135. package/dist/src/devtools-entry.browser.js +2 -0
  136. package/dist/src/devtools-entry.browser.js.map +1 -0
  137. package/dist/src/devtools-entry.d.ts +4 -0
  138. package/dist/src/devtools-entry.d.ts.map +1 -0
  139. package/dist/src/devtools-entry.js +2 -0
  140. package/dist/src/devtools-entry.js.map +1 -0
  141. package/dist/src/diagnostics.d.ts +34 -0
  142. package/dist/src/diagnostics.d.ts.map +1 -0
  143. package/dist/src/diagnostics.js +89 -0
  144. package/dist/src/diagnostics.js.map +1 -0
  145. package/dist/src/index.d.ts +3 -2
  146. package/dist/src/index.d.ts.map +1 -1
  147. package/dist/src/index.js +3 -2
  148. package/dist/src/index.js.map +1 -1
  149. package/dist/src/print-hook.d.ts +14 -0
  150. package/dist/src/print-hook.d.ts.map +1 -0
  151. package/dist/src/print-hook.js +10 -0
  152. package/dist/src/print-hook.js.map +1 -0
  153. package/dist/src/reactive-union-set.d.ts.map +1 -1
  154. package/dist/src/reactive-union-set.js +28 -3
  155. package/dist/src/reactive-union-set.js.map +1 -1
  156. package/dist/src/reactivity.d.ts +60 -7
  157. package/dist/src/reactivity.d.ts.map +1 -1
  158. package/dist/src/reactivity.js +308 -39
  159. package/dist/src/reactivity.js.map +1 -1
  160. package/dist/src/render-stack.d.ts +18 -1
  161. package/dist/src/render-stack.d.ts.map +1 -1
  162. package/dist/src/render-stack.js +61 -1
  163. package/dist/src/render-stack.js.map +1 -1
  164. package/dist/src/render.d.ts +8 -15
  165. package/dist/src/render.d.ts.map +1 -1
  166. package/dist/src/render.js +424 -109
  167. package/dist/src/render.js.map +1 -1
  168. package/dist/src/resource.d.ts.map +1 -1
  169. package/dist/src/resource.js +5 -0
  170. package/dist/src/resource.js.map +1 -1
  171. package/dist/src/scheduler.d.ts +13 -0
  172. package/dist/src/scheduler.d.ts.map +1 -1
  173. package/dist/src/scheduler.js +150 -13
  174. package/dist/src/scheduler.js.map +1 -1
  175. package/dist/src/symbols/basic-symbol.d.ts.map +1 -1
  176. package/dist/src/symbols/basic-symbol.js +6 -1
  177. package/dist/src/symbols/basic-symbol.js.map +1 -1
  178. package/dist/src/symbols/decl.d.ts.map +1 -1
  179. package/dist/src/symbols/decl.js +5 -1
  180. package/dist/src/symbols/decl.js.map +1 -1
  181. package/dist/src/symbols/output-scope.d.ts +2 -1
  182. package/dist/src/symbols/output-scope.d.ts.map +1 -1
  183. package/dist/src/symbols/output-scope.js +13 -8
  184. package/dist/src/symbols/output-scope.js.map +1 -1
  185. package/dist/src/symbols/output-symbol.d.ts +1 -0
  186. package/dist/src/symbols/output-symbol.d.ts.map +1 -1
  187. package/dist/src/symbols/output-symbol.js +25 -8
  188. package/dist/src/symbols/output-symbol.js.map +1 -1
  189. package/dist/src/symbols/symbol-flow.d.ts.map +1 -1
  190. package/dist/src/symbols/symbol-flow.js +24 -8
  191. package/dist/src/symbols/symbol-flow.js.map +1 -1
  192. package/dist/src/symbols/symbol-slot.d.ts.map +1 -1
  193. package/dist/src/symbols/symbol-slot.js +15 -0
  194. package/dist/src/symbols/symbol-slot.js.map +1 -1
  195. package/dist/src/symbols/symbol-slot.test.d.ts +2 -0
  196. package/dist/src/symbols/symbol-slot.test.d.ts.map +1 -0
  197. package/dist/src/symbols/symbol-slot.test.js +35 -0
  198. package/dist/src/symbols/symbol-slot.test.js.map +1 -0
  199. package/dist/src/symbols/symbol-table.d.ts.map +1 -1
  200. package/dist/src/symbols/symbol-table.js +6 -5
  201. package/dist/src/symbols/symbol-table.js.map +1 -1
  202. package/dist/src/trace.d.ts +2 -0
  203. package/dist/src/trace.d.ts.map +1 -0
  204. package/dist/src/trace.js +2 -0
  205. package/dist/src/trace.js.map +1 -0
  206. package/dist/src/tracer.d.ts +2 -228
  207. package/dist/src/tracer.d.ts.map +1 -1
  208. package/dist/src/tracer.js +5 -298
  209. package/dist/src/tracer.js.map +1 -1
  210. package/dist/src/utils.d.ts.map +1 -1
  211. package/dist/src/utils.js +17 -9
  212. package/dist/src/utils.js.map +1 -1
  213. package/dist/test/components/append-file.test.d.ts.map +1 -1
  214. package/dist/test/components/append-file.test.js +18 -10
  215. package/dist/test/components/append-file.test.js.map +1 -1
  216. package/dist/test/components/template-file.test.d.ts.map +1 -1
  217. package/dist/test/components/template-file.test.js +6 -4
  218. package/dist/test/components/template-file.test.js.map +1 -1
  219. package/dist/test/lazy-isempty.test.d.ts +2 -0
  220. package/dist/test/lazy-isempty.test.d.ts.map +1 -0
  221. package/dist/test/lazy-isempty.test.js +89 -0
  222. package/dist/test/lazy-isempty.test.js.map +1 -0
  223. package/dist/test/reactive-union-set-disposers.test.d.ts +2 -0
  224. package/dist/test/reactive-union-set-disposers.test.d.ts.map +1 -0
  225. package/dist/test/reactive-union-set-disposers.test.js +98 -0
  226. package/dist/test/reactive-union-set-disposers.test.js.map +1 -0
  227. package/dist/test/reactivity/shallow-reactive.test.d.ts +2 -0
  228. package/dist/test/reactivity/shallow-reactive.test.d.ts.map +1 -0
  229. package/dist/test/reactivity/shallow-reactive.test.js +52 -0
  230. package/dist/test/reactivity/shallow-reactive.test.js.map +1 -0
  231. package/dist/test/rendering/basic.test.js +3 -0
  232. package/dist/test/rendering/basic.test.js.map +1 -1
  233. package/dist/test/rendering/print-render-stack.test.d.ts.map +1 -1
  234. package/dist/test/rendering/print-render-stack.test.js +91 -98
  235. package/dist/test/rendering/print-render-stack.test.js.map +1 -1
  236. package/dist/test/scheduler-extended.test.d.ts +2 -0
  237. package/dist/test/scheduler-extended.test.d.ts.map +1 -0
  238. package/dist/test/scheduler-extended.test.js +96 -0
  239. package/dist/test/scheduler-extended.test.js.map +1 -0
  240. package/dist/test/scheduler.test.d.ts +2 -0
  241. package/dist/test/scheduler.test.d.ts.map +1 -0
  242. package/dist/test/scheduler.test.js +46 -0
  243. package/dist/test/scheduler.test.js.map +1 -0
  244. package/dist/testing/create-test-wrapper.d.ts +1 -1
  245. package/dist/testing/create-test-wrapper.d.ts.map +1 -1
  246. package/dist/testing/create-test-wrapper.js +1 -1
  247. package/dist/testing/create-test-wrapper.js.map +1 -1
  248. package/dist/testing/devtools-utils.d.ts +35 -0
  249. package/dist/testing/devtools-utils.d.ts.map +1 -0
  250. package/dist/testing/devtools-utils.js +162 -0
  251. package/dist/testing/devtools-utils.js.map +1 -0
  252. package/dist/testing/extend-expect.d.ts.map +1 -1
  253. package/dist/testing/extend-expect.js +63 -1
  254. package/dist/testing/extend-expect.js.map +1 -1
  255. package/dist/testing/render.d.ts +2 -2
  256. package/dist/testing/render.d.ts.map +1 -1
  257. package/dist/testing/render.js +2 -2
  258. package/dist/testing/render.js.map +1 -1
  259. package/dist/tsconfig.tsbuildinfo +1 -1
  260. package/package.json +21 -7
  261. package/scripts/copy-devtools-ui.mjs +26 -0
  262. package/src/binder.ts +117 -53
  263. package/src/components/AccessExpression.test.tsx +132 -0
  264. package/src/components/AccessExpression.tsx +344 -0
  265. package/src/components/AppendFile.tsx +14 -9
  266. package/src/components/Block.tsx +1 -1
  267. package/src/components/Declaration.tsx +2 -1
  268. package/src/components/For.tsx +14 -10
  269. package/src/components/List.tsx +7 -4
  270. package/src/components/Prose.tsx +1 -1
  271. package/src/components/Scope.tsx +6 -1
  272. package/src/components/SourceDirectory.tsx +1 -2
  273. package/src/components/Switch.tsx +11 -7
  274. package/src/components/TemplateFile.tsx +18 -9
  275. package/src/components/index.tsx +1 -0
  276. package/src/content-slot.tsx +7 -7
  277. package/src/context.ts +17 -6
  278. package/src/{debug.ts → debug/cli.ts} +114 -125
  279. package/src/debug/diagnostics.test.tsx +56 -0
  280. package/src/debug/effects.test.tsx +301 -0
  281. package/src/debug/effects.ts +531 -0
  282. package/src/debug/files.test.tsx +76 -0
  283. package/src/debug/files.ts +40 -0
  284. package/src/debug/index.ts +132 -0
  285. package/src/debug/message-format.test.tsx +759 -0
  286. package/src/debug/render-tree-orphans.test.tsx +344 -0
  287. package/src/debug/render.test.tsx +357 -0
  288. package/src/debug/render.ts +698 -0
  289. package/src/debug/serialize.ts +85 -0
  290. package/src/debug/symbols.test.tsx +105 -0
  291. package/src/debug/symbols.ts +322 -0
  292. package/src/debug/trace-writer.ts +969 -0
  293. package/src/debug/trace.ts +309 -0
  294. package/src/devtools/devtools-protocol.ts +497 -0
  295. package/src/devtools/devtools-server.browser.ts +62 -0
  296. package/src/devtools/devtools-server.ts +468 -0
  297. package/src/devtools/devtools-transport.ts +154 -0
  298. package/src/devtools-entry.browser.ts +48 -0
  299. package/src/devtools-entry.ts +48 -0
  300. package/src/diagnostics.ts +150 -0
  301. package/src/index.ts +2 -7
  302. package/src/print-hook.ts +22 -0
  303. package/src/reactive-union-set.ts +85 -44
  304. package/src/reactivity.ts +396 -58
  305. package/src/render-stack.ts +73 -1
  306. package/src/render.ts +544 -161
  307. package/src/resource.ts +28 -19
  308. package/src/scheduler.ts +209 -14
  309. package/src/symbols/basic-symbol.ts +6 -1
  310. package/src/symbols/decl.ts +5 -1
  311. package/src/symbols/output-scope.ts +21 -13
  312. package/src/symbols/output-symbol.ts +34 -14
  313. package/src/symbols/symbol-flow.ts +76 -39
  314. package/src/symbols/symbol-slot.test.tsx +41 -0
  315. package/src/symbols/symbol-slot.tsx +47 -20
  316. package/src/symbols/symbol-table.ts +6 -10
  317. package/src/trace.ts +1 -0
  318. package/src/tracer.ts +13 -242
  319. package/src/utils.tsx +31 -21
  320. package/temp/api.json +5700 -3015
  321. package/test/components/append-file.test.tsx +36 -29
  322. package/test/components/template-file.test.tsx +11 -11
  323. package/test/lazy-isempty.test.tsx +106 -0
  324. package/test/reactive-union-set-disposers.test.tsx +112 -0
  325. package/test/reactivity/shallow-reactive.test.tsx +56 -0
  326. package/test/rendering/basic.test.tsx +4 -0
  327. package/test/rendering/print-render-stack.test.tsx +52 -43
  328. package/test/scheduler-extended.test.tsx +122 -0
  329. package/test/scheduler.test.tsx +50 -0
  330. package/testing/create-test-wrapper.tsx +1 -1
  331. package/testing/devtools-utils.ts +245 -0
  332. package/testing/extend-expect.ts +89 -0
  333. package/testing/render.ts +2 -2
  334. package/testing/vitest.d.ts +9 -0
  335. package/dist/src/debug.d.ts +0 -14
  336. package/dist/src/debug.d.ts.map +0 -1
  337. package/dist/src/debug.js.map +0 -1
@@ -0,0 +1,309 @@
1
+ /**
2
+ * Trace helpers and configuration.
3
+ */
4
+ import type { ServerToClientMessage } from "../devtools/devtools-protocol.js";
5
+ import { isDevtoolsEnabled } from "../devtools/devtools-server.js";
6
+ import { untrack } from "../reactivity.js";
7
+ import { initTrace, isTraceEnabled } from "./trace-writer.js";
8
+
9
+ export { isDevtoolsEnabled } from "../devtools/devtools-server.js";
10
+ export { isTraceEnabled } from "./trace-writer.js";
11
+
12
+ /**
13
+ * Returns true when any debug instrumentation is active:
14
+ * devtools, console trace, or ALLOY_DEBUG_TRACE.
15
+ */
16
+ export function isDebugEnabled(): boolean {
17
+ return isDevtoolsEnabled() || isConsoleTraceEnabled() || isTraceEnabled();
18
+ }
19
+
20
+ // ─────────────────────────────────────────────────────────────────────────────
21
+ // Environment configuration
22
+ // ─────────────────────────────────────────────────────────────────────────────
23
+
24
+ const traceEnv = process.env.ALLOY_TRACE ?? "";
25
+ const tracePhases = new Set<string>(
26
+ traceEnv === "" ? [] : traceEnv.split(",").map((t) => t.trim()),
27
+ );
28
+
29
+ const debuggerIdsEnv = process.env.ALLOY_BREAK_ON_DID ?? "";
30
+ const debuggerIds = new Set<number>();
31
+ debuggerIdsEnv.split(",").forEach((id) => {
32
+ const num = parseInt(id, 10);
33
+ if (!isNaN(num)) {
34
+ debuggerIds.add(num);
35
+ }
36
+ });
37
+
38
+ /** Parse the ALLOY_BREAK_ON_DID environment variable into a set of IDs. */
39
+ export function parseBreakOnIds(): Set<number> {
40
+ const env = process.env.ALLOY_BREAK_ON_DID ?? "";
41
+ const ids = new Set<number>();
42
+ env.split(",").forEach((id) => {
43
+ const num = parseInt(id, 10);
44
+ if (!isNaN(num)) {
45
+ ids.add(num);
46
+ }
47
+ });
48
+ return ids;
49
+ }
50
+
51
+ /** Returns true if console tracing is enabled for the given phase (or any phase if not specified). */
52
+ export function isConsoleTraceEnabled(phase?: string): boolean {
53
+ if (tracePhases.size === 0) return false;
54
+ if (!phase) return true;
55
+ const [area, subarea] = phase.split(".");
56
+ return tracePhases.has(area) || (subarea ? tracePhases.has(phase) : false);
57
+ }
58
+
59
+ if (tracePhases.size > 0) {
60
+ // eslint-disable-next-line no-console
61
+ console.log(
62
+ "Tracing enabled for phases:",
63
+ Array.from(tracePhases).join(", "),
64
+ );
65
+ }
66
+
67
+ // Initialize SQLite trace writer if ALLOY_DEBUG_TRACE is set
68
+ const traceDbEnv = process.env.ALLOY_DEBUG_TRACE;
69
+ if (traceDbEnv) {
70
+ const traceDbPath =
71
+ traceDbEnv === "1" || traceDbEnv === "true" ? "alloy-trace.db" : traceDbEnv;
72
+ try {
73
+ await initTrace(traceDbPath);
74
+ } catch (e) {
75
+ // eslint-disable-next-line no-console
76
+ console.warn(`Failed to initialize trace database at ${traceDbPath}:`, e);
77
+ }
78
+ }
79
+
80
+ // ─────────────────────────────────────────────────────────────────────────────
81
+ // Trace phases
82
+ // ─────────────────────────────────────────────────────────────────────────────
83
+
84
+ interface Color {
85
+ r: number;
86
+ g: number;
87
+ b: number;
88
+ }
89
+
90
+ export interface TracePhaseInfo {
91
+ area: string;
92
+ subarea: string;
93
+ bg: Color;
94
+ }
95
+
96
+ export const TracePhase = {
97
+ scope: {
98
+ update: { area: "scope", subarea: "update", bg: { r: 0, g: 255, b: 100 } },
99
+ create: { area: "scope", subarea: "create", bg: { r: 0, g: 150, b: 100 } },
100
+ delete: { area: "scope", subarea: "delete", bg: { r: 150, g: 0, b: 50 } },
101
+ copySymbols: {
102
+ area: "scope",
103
+ subarea: "copySymbols",
104
+ bg: { r: 0, g: 100, b: 100 },
105
+ },
106
+ moveSymbols: {
107
+ area: "scope",
108
+ subarea: "moveSymbols",
109
+ bg: { r: 0, g: 100, b: 100 },
110
+ },
111
+ },
112
+ symbol: {
113
+ update: { area: "symbol", subarea: "update", bg: { r: 0, g: 0, b: 255 } },
114
+ resolve: { area: "symbol", subarea: "resolve", bg: { r: 0, g: 0, b: 200 } },
115
+ create: { area: "symbol", subarea: "create", bg: { r: 0, g: 0, b: 150 } },
116
+ flow: { area: "symbol", subarea: "flow", bg: { r: 0, g: 0, b: 100 } },
117
+ addToScope: {
118
+ area: "symbol",
119
+ subarea: "addToScope",
120
+ bg: { r: 0, g: 0, b: 50 },
121
+ },
122
+ instantiate: {
123
+ area: "symbol",
124
+ subarea: "instantiate",
125
+ bg: { r: 0, g: 0, b: 25 },
126
+ },
127
+ clone: { area: "symbol", subarea: "clone", bg: { r: 0, g: 0, b: 25 } },
128
+ delete: { area: "symbol", subarea: "delete", bg: { r: 100, g: 0, b: 100 } },
129
+ removeFromScope: {
130
+ area: "symbol",
131
+ subarea: "removeFromScope",
132
+ bg: { r: 50, g: 0, b: 50 },
133
+ },
134
+ },
135
+ resolve: {
136
+ success: {
137
+ area: "resolve",
138
+ subarea: "success",
139
+ bg: { r: 0, g: 255, b: 0 },
140
+ },
141
+ pending: {
142
+ area: "resolve",
143
+ subarea: "pending",
144
+ bg: { r: 255, g: 255, b: 0 },
145
+ },
146
+ failure: {
147
+ area: "resolve",
148
+ subarea: "failure",
149
+ bg: { r: 100, g: 50, b: 50 },
150
+ },
151
+ },
152
+ effect: {
153
+ schedule: {
154
+ area: "effect",
155
+ subarea: "schedule",
156
+ bg: { r: 100, g: 100, b: 0 },
157
+ },
158
+ track: { area: "effect", subarea: "track", bg: { r: 75, g: 75, b: 0 } },
159
+ trigger: { area: "effect", subarea: "trigger", bg: { r: 50, g: 50, b: 0 } },
160
+ effectAdded: {
161
+ area: "effect",
162
+ subarea: "effectAdded",
163
+ bg: { r: 75, g: 100, b: 0 },
164
+ },
165
+ effectUpdated: {
166
+ area: "effect",
167
+ subarea: "effectUpdated",
168
+ bg: { r: 75, g: 75, b: 0 },
169
+ },
170
+ refAdded: {
171
+ area: "effect",
172
+ subarea: "refAdded",
173
+ bg: { r: 100, g: 75, b: 0 },
174
+ },
175
+ },
176
+ render: {
177
+ worker: { area: "render", subarea: "worker", bg: { r: 100, g: 50, b: 0 } },
178
+ appendChild: {
179
+ area: "render",
180
+ subarea: "appendChild",
181
+ bg: { r: 100, g: 50, b: 0 },
182
+ },
183
+ appendTextNode: {
184
+ area: "render",
185
+ subarea: "appendChild.textNode",
186
+ bg: { r: 100, g: 50, b: 0 },
187
+ },
188
+ appendCachedFragment: {
189
+ area: "render",
190
+ subarea: "appendChild.cachedFragment",
191
+ bg: { r: 100, g: 50, b: 0 },
192
+ },
193
+ appendCustomContext: {
194
+ area: "render",
195
+ subarea: "appendChild.customContext",
196
+ bg: { r: 100, g: 50, b: 0 },
197
+ },
198
+ appendPrintHook: {
199
+ area: "render",
200
+ subarea: "appendChild.printHook",
201
+ bg: { r: 100, g: 50, b: 0 },
202
+ },
203
+ appendComponent: {
204
+ area: "render",
205
+ subarea: "appendChild.component",
206
+ bg: { r: 100, g: 50, b: 0 },
207
+ },
208
+ appendMemo: {
209
+ area: "render",
210
+ subarea: "appendChild.memo",
211
+ bg: { r: 100, g: 50, b: 0 },
212
+ },
213
+ renderEffect: {
214
+ area: "render",
215
+ subarea: "renderEffect",
216
+ bg: { r: 100, g: 50, b: 0 },
217
+ },
218
+ },
219
+ } as const;
220
+
221
+ // ─────────────────────────────────────────────────────────────────────────────
222
+ // Console formatting utilities
223
+ // ─────────────────────────────────────────────────────────────────────────────
224
+
225
+ export interface TextFormat {
226
+ fg?: Color;
227
+ bg?: Color;
228
+ bold?: boolean;
229
+ }
230
+
231
+ export function colorText(text: string, fmt?: TextFormat): string {
232
+ if (!fmt) return text;
233
+ const codes: string[] = [];
234
+ if (fmt.bold) codes.push("1");
235
+ if (fmt.fg) codes.push(`38;2;${fmt.fg.r};${fmt.fg.g};${fmt.fg.b}`);
236
+ if (fmt.bg) codes.push(`48;2;${fmt.bg.r};${fmt.bg.g};${fmt.bg.b}`);
237
+ if (codes.length === 0) return text;
238
+ return `\x1b[${codes.join(";")}m${text}\x1b[0m`;
239
+ }
240
+
241
+ // ─────────────────────────────────────────────────────────────────────────────
242
+ // Low-level trace API
243
+ // ─────────────────────────────────────────────────────────────────────────────
244
+
245
+ let traceCount = 0;
246
+
247
+ function shouldTracePhase(area: string, subarea: string): boolean {
248
+ return (
249
+ isConsoleTraceEnabled(area) || isConsoleTraceEnabled(area + "." + subarea)
250
+ );
251
+ }
252
+
253
+ function shouldTrace(phase: TracePhaseInfo): boolean {
254
+ return shouldTracePhase(phase.area, phase.subarea);
255
+ }
256
+
257
+ export function traceType(phase: TracePhaseInfo): string {
258
+ return `${phase.area}:${phase.subarea}`;
259
+ }
260
+
261
+ export function logDevtoolsMessage(
262
+ message: ServerToClientMessage | { type: string; [key: string]: unknown },
263
+ ) {
264
+ if (!isConsoleTraceEnabled()) return;
265
+ const type = String(message.type ?? "");
266
+ const colonIndex = type.indexOf(":");
267
+ if (colonIndex === -1) return;
268
+ const area = type.slice(0, colonIndex);
269
+ const subarea = type.slice(colonIndex + 1);
270
+ if (!area || !subarea) return;
271
+ if (!shouldTracePhase(area, subarea)) return;
272
+ // eslint-disable-next-line no-console
273
+ console.log("devtools:", message.type, message);
274
+ }
275
+
276
+ /**
277
+ * Low-level trace function for emitting console output.
278
+ * Use the `debug` object methods for most use cases.
279
+ */
280
+ export function trace(
281
+ phase: TracePhaseInfo,
282
+ cb: () => string,
283
+ triggerIds: Set<number> = new Set(),
284
+ ): void {
285
+ if (shouldTrace(phase)) {
286
+ if (triggerIds.size === 0) {
287
+ const id = traceCount++;
288
+ triggerIds.add(id);
289
+ if (debuggerIds.has(id)) {
290
+ // eslint-disable-next-line no-debugger
291
+ debugger;
292
+ }
293
+ }
294
+
295
+ const areaTag = ` ${phase.area}:${phase.subarea} `;
296
+ const message = untrack(cb);
297
+ // eslint-disable-next-line no-console
298
+ console.log(
299
+ colorText(areaTag, { ...phase, bold: true }) +
300
+ " " +
301
+ colorText("[" + [...triggerIds].join(",") + "]", {
302
+ fg: { r: 50, g: 50, b: 50 },
303
+ }) +
304
+ " " +
305
+ message +
306
+ "\n",
307
+ );
308
+ }
309
+ }