@treenity/core 1.0.48 → 3.0.1

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 (807) hide show
  1. package/README.md +72 -12
  2. package/dist/chain.d.ts +19 -0
  3. package/dist/chain.d.ts.map +1 -0
  4. package/dist/chain.js +59 -0
  5. package/dist/chain.js.map +1 -0
  6. package/dist/client/handle.d.ts +13 -0
  7. package/dist/client/handle.d.ts.map +1 -0
  8. package/dist/client/handle.js +46 -0
  9. package/dist/client/handle.js.map +1 -0
  10. package/dist/client/index.d.ts +21 -0
  11. package/dist/client/index.d.ts.map +1 -0
  12. package/dist/client/index.js +5 -0
  13. package/dist/client/index.js.map +1 -0
  14. package/dist/client/trpc.d.ts +13 -0
  15. package/dist/client/trpc.d.ts.map +1 -0
  16. package/dist/client/trpc.js +79 -0
  17. package/dist/client/trpc.js.map +1 -0
  18. package/dist/client.d.ts +2 -0
  19. package/dist/client.d.ts.map +1 -0
  20. package/dist/client.js +2 -0
  21. package/dist/client.js.map +1 -0
  22. package/dist/comp/handle.d.ts +14 -0
  23. package/dist/comp/handle.d.ts.map +1 -0
  24. package/dist/comp/handle.js +21 -0
  25. package/dist/comp/handle.js.map +1 -0
  26. package/dist/comp/index.d.ts +41 -0
  27. package/dist/comp/index.d.ts.map +1 -0
  28. package/dist/comp/index.js +127 -0
  29. package/dist/comp/index.js.map +1 -0
  30. package/dist/comp/needs.d.ts +26 -0
  31. package/dist/comp/needs.d.ts.map +1 -0
  32. package/dist/comp/needs.js +101 -0
  33. package/dist/comp/needs.js.map +1 -0
  34. package/dist/comp/validate.d.ts +13 -0
  35. package/dist/comp/validate.d.ts.map +1 -0
  36. package/dist/comp/validate.js +117 -0
  37. package/dist/comp/validate.js.map +1 -0
  38. package/dist/comp.d.ts +2 -0
  39. package/dist/comp.d.ts.map +1 -0
  40. package/dist/comp.js +2 -0
  41. package/dist/comp.js.map +1 -0
  42. package/dist/contexts/schema/index.d.ts +7 -0
  43. package/dist/contexts/schema/index.d.ts.map +1 -0
  44. package/dist/contexts/schema/index.js +2 -0
  45. package/dist/contexts/schema/index.js.map +1 -0
  46. package/dist/contexts/schema.d.ts +2 -0
  47. package/dist/contexts/schema.d.ts.map +1 -0
  48. package/dist/contexts/schema.js +2 -0
  49. package/dist/contexts/schema.js.map +1 -0
  50. package/dist/contexts/service/index.d.ts +31 -0
  51. package/dist/contexts/service/index.d.ts.map +1 -0
  52. package/dist/contexts/service/index.js +16 -0
  53. package/dist/contexts/service/index.js.map +1 -0
  54. package/dist/contexts/service.d.ts +1 -14
  55. package/dist/contexts/service.d.ts.map +1 -1
  56. package/dist/contexts/service.js +2 -0
  57. package/dist/contexts/service.js.map +1 -0
  58. package/dist/contexts/telegram/index.d.ts +19 -0
  59. package/dist/contexts/telegram/index.d.ts.map +1 -0
  60. package/dist/contexts/telegram/index.js +89 -0
  61. package/dist/contexts/telegram/index.js.map +1 -0
  62. package/dist/contexts/text/index.d.ts +7 -0
  63. package/dist/contexts/text/index.d.ts.map +1 -0
  64. package/dist/contexts/text/index.js +9 -0
  65. package/dist/contexts/text/index.js.map +1 -0
  66. package/dist/contexts/text.d.ts +2 -0
  67. package/dist/contexts/text.d.ts.map +1 -0
  68. package/dist/contexts/text.js +2 -0
  69. package/dist/contexts/text.js.map +1 -0
  70. package/dist/core/component.d.ts +43 -0
  71. package/dist/core/component.d.ts.map +1 -0
  72. package/dist/core/component.js +101 -0
  73. package/dist/core/component.js.map +1 -0
  74. package/dist/core/context.d.ts +5 -0
  75. package/dist/core/context.d.ts.map +1 -0
  76. package/dist/core/context.js +3 -0
  77. package/dist/core/context.js.map +1 -0
  78. package/dist/core/index.d.ts +5 -0
  79. package/dist/core/index.d.ts.map +1 -0
  80. package/dist/core/index.js +8 -0
  81. package/dist/core/index.js.map +1 -0
  82. package/dist/core/path.d.ts +7 -0
  83. package/dist/core/path.d.ts.map +1 -0
  84. package/dist/core/path.js +41 -0
  85. package/dist/core/path.js.map +1 -0
  86. package/dist/core/registry.d.ts +17 -0
  87. package/dist/core/registry.d.ts.map +1 -0
  88. package/dist/core/registry.js +100 -0
  89. package/dist/core/registry.js.map +1 -0
  90. package/dist/core.d.ts +2 -0
  91. package/dist/core.d.ts.map +1 -0
  92. package/dist/core.js +2 -0
  93. package/dist/core.js.map +1 -0
  94. package/dist/index.d.ts +1 -12
  95. package/dist/index.d.ts.map +1 -1
  96. package/dist/index.js +2 -0
  97. package/dist/index.js.map +1 -0
  98. package/dist/log.d.ts +38 -0
  99. package/dist/log.d.ts.map +1 -0
  100. package/dist/log.js +150 -0
  101. package/dist/log.js.map +1 -0
  102. package/dist/mod/discover.d.ts +4 -0
  103. package/dist/mod/discover.d.ts.map +1 -0
  104. package/dist/mod/discover.js +103 -0
  105. package/dist/mod/discover.js.map +1 -0
  106. package/dist/mod/examples/ticker/seed.d.ts +3 -0
  107. package/dist/mod/examples/ticker/seed.d.ts.map +1 -0
  108. package/dist/mod/examples/ticker/seed.js +16 -0
  109. package/dist/mod/examples/ticker/seed.js.map +1 -0
  110. package/dist/mod/examples/ticker/service.d.ts +2 -0
  111. package/dist/mod/examples/ticker/service.d.ts.map +1 -0
  112. package/dist/mod/examples/ticker/service.js +17 -0
  113. package/dist/mod/examples/ticker/service.js.map +1 -0
  114. package/dist/mod/examples/ticker/types.d.ts +16 -0
  115. package/dist/mod/examples/ticker/types.d.ts.map +1 -0
  116. package/dist/mod/examples/ticker/types.js +20 -0
  117. package/dist/mod/examples/ticker/types.js.map +1 -0
  118. package/dist/mod/examples/ticker/view.d.ts +2 -0
  119. package/dist/mod/examples/ticker/view.d.ts.map +1 -0
  120. package/dist/mod/examples/ticker/view.js +10 -0
  121. package/dist/mod/examples/ticker/view.js.map +1 -0
  122. package/dist/mod/index.d.ts +11 -0
  123. package/dist/mod/index.d.ts.map +1 -0
  124. package/dist/mod/index.js +8 -0
  125. package/dist/mod/index.js.map +1 -0
  126. package/dist/mod/loader.d.ts +19 -0
  127. package/dist/mod/loader.d.ts.map +1 -0
  128. package/dist/mod/loader.js +180 -0
  129. package/dist/mod/loader.js.map +1 -0
  130. package/dist/mod/optimistic.d.ts +34 -0
  131. package/dist/mod/optimistic.d.ts.map +1 -0
  132. package/dist/mod/optimistic.js +176 -0
  133. package/dist/mod/optimistic.js.map +1 -0
  134. package/dist/mod/prefab.d.ts +18 -0
  135. package/dist/mod/prefab.d.ts.map +1 -0
  136. package/dist/mod/prefab.js +42 -0
  137. package/dist/mod/prefab.js.map +1 -0
  138. package/dist/mod/tracking.d.ts +8 -0
  139. package/dist/mod/tracking.d.ts.map +1 -0
  140. package/dist/mod/tracking.js +44 -0
  141. package/dist/mod/tracking.js.map +1 -0
  142. package/dist/mod/types.d.ts +31 -0
  143. package/dist/mod/types.d.ts.map +1 -0
  144. package/dist/mod/types.js +5 -0
  145. package/dist/mod/types.js.map +1 -0
  146. package/dist/mod.d.ts +2 -0
  147. package/dist/mod.d.ts.map +1 -0
  148. package/dist/mod.js +2 -0
  149. package/dist/mod.js.map +1 -0
  150. package/dist/mods/autostart/server.d.ts +2 -0
  151. package/dist/mods/autostart/server.d.ts.map +1 -0
  152. package/dist/mods/autostart/server.js +2 -0
  153. package/dist/mods/autostart/server.js.map +1 -0
  154. package/dist/mods/autostart/service.d.ts +14 -0
  155. package/dist/mods/autostart/service.d.ts.map +1 -0
  156. package/dist/mods/autostart/service.js +88 -0
  157. package/dist/mods/autostart/service.js.map +1 -0
  158. package/dist/mods/clients.d.ts +2 -0
  159. package/dist/mods/clients.d.ts.map +1 -0
  160. package/dist/mods/clients.js +3 -0
  161. package/dist/mods/clients.js.map +1 -0
  162. package/dist/mods/llm/index.d.ts +13 -0
  163. package/dist/mods/llm/index.d.ts.map +1 -0
  164. package/dist/mods/llm/index.js +43 -0
  165. package/dist/mods/llm/index.js.map +1 -0
  166. package/dist/mods/llm/server.d.ts +2 -0
  167. package/dist/mods/llm/server.d.ts.map +1 -0
  168. package/dist/mods/llm/server.js +2 -0
  169. package/dist/mods/llm/server.js.map +1 -0
  170. package/dist/mods/mcp/server.d.ts +2 -0
  171. package/dist/mods/mcp/server.js +2 -0
  172. package/dist/mods/mcp/service.d.ts +1 -0
  173. package/dist/mods/mcp/service.js +16 -0
  174. package/dist/mods/mcp/types.d.ts +4 -0
  175. package/dist/mods/mcp/types.js +6 -0
  176. package/dist/mods/servers.d.ts +4 -0
  177. package/dist/mods/servers.d.ts.map +1 -0
  178. package/dist/mods/servers.js +5 -0
  179. package/dist/mods/servers.js.map +1 -0
  180. package/dist/mods/treenity/agent-port.d.ts +2 -0
  181. package/dist/mods/treenity/agent-port.d.ts.map +1 -0
  182. package/dist/mods/treenity/agent-port.js +76 -0
  183. package/dist/mods/treenity/agent-port.js.map +1 -0
  184. package/dist/mods/treenity/builtins.d.ts +2 -0
  185. package/dist/mods/treenity/builtins.d.ts.map +1 -0
  186. package/dist/mods/treenity/builtins.js +18 -0
  187. package/dist/mods/treenity/builtins.js.map +1 -0
  188. package/dist/mods/treenity/groups.d.ts +2 -0
  189. package/dist/mods/treenity/groups.d.ts.map +1 -0
  190. package/dist/mods/treenity/groups.js +18 -0
  191. package/dist/mods/treenity/groups.js.map +1 -0
  192. package/dist/mods/treenity/logs.d.ts +18 -0
  193. package/dist/mods/treenity/logs.d.ts.map +1 -0
  194. package/dist/mods/treenity/logs.js +17 -0
  195. package/dist/mods/treenity/logs.js.map +1 -0
  196. package/dist/mods/treenity/mod-type.d.ts +2 -0
  197. package/dist/mods/treenity/mod-type.d.ts.map +1 -0
  198. package/dist/mods/treenity/mod-type.js +9 -0
  199. package/dist/mods/treenity/mod-type.js.map +1 -0
  200. package/dist/mods/treenity/seed.d.ts +2 -0
  201. package/dist/mods/treenity/seed.d.ts.map +1 -0
  202. package/dist/mods/treenity/seed.js +55 -0
  203. package/dist/mods/treenity/seed.js.map +1 -0
  204. package/dist/mods/treenity/server.d.ts +7 -0
  205. package/dist/mods/treenity/server.d.ts.map +1 -0
  206. package/dist/mods/treenity/server.js +7 -0
  207. package/dist/mods/treenity/server.js.map +1 -0
  208. package/dist/mods/treenity/system.d.ts +36 -0
  209. package/dist/mods/treenity/system.d.ts.map +1 -0
  210. package/dist/mods/treenity/system.js +61 -0
  211. package/dist/mods/treenity/system.js.map +1 -0
  212. package/dist/mods/uix/client.d.ts +3 -0
  213. package/dist/mods/uix/client.d.ts.map +1 -0
  214. package/dist/mods/uix/client.js +96 -0
  215. package/dist/mods/uix/client.js.map +1 -0
  216. package/dist/mods/uix/compile.d.ts +7 -0
  217. package/dist/mods/uix/compile.d.ts.map +1 -0
  218. package/dist/mods/uix/compile.js +96 -0
  219. package/dist/mods/uix/compile.js.map +1 -0
  220. package/dist/mods/uix/jsx-parser.d.ts +2 -0
  221. package/dist/mods/uix/jsx-parser.d.ts.map +1 -0
  222. package/dist/mods/uix/jsx-parser.js +565 -0
  223. package/dist/mods/uix/jsx-parser.js.map +1 -0
  224. package/dist/mods/uix/verify.d.ts +7 -0
  225. package/dist/mods/uix/verify.d.ts.map +1 -0
  226. package/dist/mods/uix/verify.js +59 -0
  227. package/dist/mods/uix/verify.js.map +1 -0
  228. package/dist/schema/_test-fixture.d.ts +11 -0
  229. package/dist/schema/_test-fixture.d.ts.map +1 -0
  230. package/dist/schema/_test-fixture.js +8 -0
  231. package/dist/schema/_test-fixture.js.map +1 -0
  232. package/dist/schema/catalog.d.ts +23 -0
  233. package/dist/schema/catalog.d.ts.map +1 -0
  234. package/dist/schema/catalog.js +82 -0
  235. package/dist/schema/catalog.js.map +1 -0
  236. package/dist/schema/extract-schemas.d.ts +5 -0
  237. package/dist/schema/extract-schemas.d.ts.map +1 -0
  238. package/dist/schema/extract-schemas.js +444 -0
  239. package/dist/schema/extract-schemas.js.map +1 -0
  240. package/dist/schema/load.d.ts +2 -0
  241. package/dist/schema/load.d.ts.map +1 -0
  242. package/dist/schema/load.js +23 -0
  243. package/dist/schema/load.js.map +1 -0
  244. package/dist/schema/test-fixture.types.d.ts +2 -0
  245. package/dist/schema/test-fixture.types.d.ts.map +1 -0
  246. package/dist/schema/test-fixture.types.js +19 -0
  247. package/dist/schema/test-fixture.types.js.map +1 -0
  248. package/dist/schema/types.d.ts +38 -0
  249. package/dist/schema/types.d.ts.map +1 -0
  250. package/dist/schema/types.js +3 -0
  251. package/dist/schema/types.js.map +1 -0
  252. package/dist/server/actions.d.ts +35 -0
  253. package/dist/server/actions.d.ts.map +1 -0
  254. package/dist/server/actions.js +170 -0
  255. package/dist/server/actions.js.map +1 -0
  256. package/dist/server/agent.d.ts +6 -0
  257. package/dist/server/agent.d.ts.map +1 -0
  258. package/dist/server/agent.js +15 -0
  259. package/dist/server/agent.js.map +1 -0
  260. package/dist/server/auth.d.ts +39 -0
  261. package/dist/server/auth.d.ts.map +1 -0
  262. package/dist/server/auth.js +336 -0
  263. package/dist/server/auth.js.map +1 -0
  264. package/dist/server/client.d.ts +190 -0
  265. package/dist/server/client.d.ts.map +1 -0
  266. package/dist/server/client.js +22 -0
  267. package/dist/server/client.js.map +1 -0
  268. package/dist/server/cookies.d.ts +5 -0
  269. package/dist/server/cookies.d.ts.map +1 -0
  270. package/dist/server/cookies.js +24 -0
  271. package/dist/server/cookies.js.map +1 -0
  272. package/dist/server/doc-index.d.ts +38 -0
  273. package/dist/server/doc-index.d.ts.map +1 -0
  274. package/dist/server/doc-index.js +245 -0
  275. package/dist/server/doc-index.js.map +1 -0
  276. package/dist/server/errors.d.ts +7 -0
  277. package/dist/server/errors.d.ts.map +1 -0
  278. package/dist/server/errors.js +11 -0
  279. package/dist/server/errors.js.map +1 -0
  280. package/dist/server/factory.d.ts +29 -0
  281. package/dist/server/factory.d.ts.map +1 -0
  282. package/dist/server/factory.js +89 -0
  283. package/dist/server/factory.js.map +1 -0
  284. package/dist/server/main.d.ts +2 -0
  285. package/dist/server/main.d.ts.map +1 -0
  286. package/dist/server/main.js +19 -0
  287. package/dist/server/main.js.map +1 -0
  288. package/dist/server/mcp.d.ts +4 -0
  289. package/dist/server/mcp.js +279 -0
  290. package/dist/server/migrate.d.ts +3 -0
  291. package/dist/server/migrate.d.ts.map +1 -0
  292. package/dist/server/migrate.js +56 -0
  293. package/dist/server/migrate.js.map +1 -0
  294. package/dist/server/mod-catalog.d.ts +14 -0
  295. package/dist/server/mod-catalog.d.ts.map +1 -0
  296. package/dist/server/mod-catalog.js +40 -0
  297. package/dist/server/mod-catalog.js.map +1 -0
  298. package/dist/server/mods-mount.d.ts +3 -0
  299. package/dist/server/mods-mount.d.ts.map +1 -0
  300. package/dist/server/mods-mount.js +168 -0
  301. package/dist/server/mods-mount.js.map +1 -0
  302. package/dist/server/mount-adapters.d.ts +9 -0
  303. package/dist/server/mount-adapters.d.ts.map +1 -0
  304. package/dist/server/mount-adapters.js +80 -0
  305. package/dist/server/mount-adapters.js.map +1 -0
  306. package/dist/server/mount.d.ts +3 -0
  307. package/dist/server/mount.d.ts.map +1 -0
  308. package/dist/server/mount.js +195 -0
  309. package/dist/server/mount.js.map +1 -0
  310. package/dist/server/prefab.d.ts +18 -0
  311. package/dist/server/prefab.d.ts.map +1 -0
  312. package/dist/server/prefab.js +72 -0
  313. package/dist/server/prefab.js.map +1 -0
  314. package/dist/server/refs.d.ts +3 -0
  315. package/dist/server/refs.d.ts.map +1 -0
  316. package/dist/server/refs.js +59 -0
  317. package/dist/server/refs.js.map +1 -0
  318. package/dist/server/seed/index.d.ts +6 -0
  319. package/dist/server/seed/index.d.ts.map +1 -0
  320. package/dist/server/seed/index.js +16 -0
  321. package/dist/server/seed/index.js.map +1 -0
  322. package/dist/server/server.d.ts +28 -0
  323. package/dist/server/server.d.ts.map +1 -0
  324. package/dist/server/server.js +127 -0
  325. package/dist/server/server.js.map +1 -0
  326. package/dist/server/sub.d.ts +34 -0
  327. package/dist/server/sub.d.ts.map +1 -0
  328. package/dist/server/sub.js +174 -0
  329. package/dist/server/sub.js.map +1 -0
  330. package/dist/server/trpc.d.ts +199 -0
  331. package/dist/server/trpc.d.ts.map +1 -0
  332. package/dist/server/trpc.js +323 -0
  333. package/dist/server/trpc.js.map +1 -0
  334. package/dist/server/types-mount.d.ts +3 -0
  335. package/dist/server/types-mount.d.ts.map +1 -0
  336. package/dist/server/types-mount.js +144 -0
  337. package/dist/server/types-mount.js.map +1 -0
  338. package/dist/server/validate.d.ts +3 -0
  339. package/dist/server/validate.d.ts.map +1 -0
  340. package/dist/server/validate.js +20 -0
  341. package/dist/server/validate.js.map +1 -0
  342. package/dist/server/volatile.d.ts +11 -0
  343. package/dist/server/volatile.d.ts.map +1 -0
  344. package/dist/server/volatile.js +26 -0
  345. package/dist/server/volatile.js.map +1 -0
  346. package/dist/server/watch.d.ts +23 -0
  347. package/dist/server/watch.d.ts.map +1 -0
  348. package/dist/server/watch.js +178 -0
  349. package/dist/server/watch.js.map +1 -0
  350. package/dist/tree/cache.d.ts +3 -0
  351. package/dist/tree/cache.d.ts.map +1 -0
  352. package/dist/tree/cache.js +48 -0
  353. package/dist/tree/cache.js.map +1 -0
  354. package/dist/tree/fs.d.ts +3 -0
  355. package/dist/tree/fs.d.ts.map +1 -0
  356. package/dist/tree/fs.js +276 -0
  357. package/dist/tree/fs.js.map +1 -0
  358. package/dist/tree/index.d.ts +38 -0
  359. package/dist/tree/index.d.ts.map +1 -0
  360. package/dist/tree/index.js +183 -0
  361. package/dist/tree/index.js.map +1 -0
  362. package/dist/tree/inflight.d.ts +2 -0
  363. package/dist/tree/inflight.d.ts.map +1 -0
  364. package/dist/tree/inflight.js +15 -0
  365. package/dist/tree/inflight.js.map +1 -0
  366. package/dist/tree/json-codec.d.ts +2 -0
  367. package/dist/tree/json-codec.d.ts.map +1 -0
  368. package/dist/tree/json-codec.js +13 -0
  369. package/dist/tree/json-codec.js.map +1 -0
  370. package/dist/tree/mimefs.d.ts +13 -0
  371. package/dist/tree/mimefs.d.ts.map +1 -0
  372. package/dist/tree/mimefs.js +124 -0
  373. package/dist/tree/mimefs.js.map +1 -0
  374. package/dist/tree/mongo.d.ts +5 -0
  375. package/dist/tree/mongo.d.ts.map +1 -0
  376. package/dist/tree/mongo.js +110 -0
  377. package/dist/tree/mongo.js.map +1 -0
  378. package/dist/tree/patch.d.ts +30 -0
  379. package/dist/tree/patch.d.ts.map +1 -0
  380. package/dist/tree/patch.js +112 -0
  381. package/dist/tree/patch.js.map +1 -0
  382. package/dist/tree/query.d.ts +12 -0
  383. package/dist/tree/query.d.ts.map +1 -0
  384. package/dist/tree/query.js +61 -0
  385. package/dist/tree/query.js.map +1 -0
  386. package/dist/tree/repath.d.ts +3 -0
  387. package/dist/tree/repath.d.ts.map +1 -0
  388. package/dist/tree/repath.js +38 -0
  389. package/dist/tree/repath.js.map +1 -0
  390. package/dist/tree-chain.d.ts +19 -0
  391. package/dist/tree-chain.d.ts.map +1 -0
  392. package/dist/tree-chain.js +111 -0
  393. package/dist/tree-chain.js.map +1 -0
  394. package/dist/tree.d.ts +2 -0
  395. package/dist/tree.d.ts.map +1 -0
  396. package/dist/tree.js +2 -0
  397. package/dist/tree.js.map +1 -0
  398. package/dist/uri.d.ts +11 -0
  399. package/dist/uri.d.ts.map +1 -0
  400. package/dist/uri.js +84 -0
  401. package/dist/uri.js.map +1 -0
  402. package/package.json +78 -37
  403. package/src/chain.test.ts +190 -0
  404. package/src/chain.ts +84 -0
  405. package/src/client/client.test.ts +192 -0
  406. package/src/client/handle.ts +53 -0
  407. package/src/client/index.ts +18 -0
  408. package/src/client/trpc.ts +92 -0
  409. package/src/client.ts +1 -0
  410. package/src/comp/CLAUDE.md +14 -0
  411. package/src/comp/handle.ts +36 -0
  412. package/src/comp/index.test.ts +165 -0
  413. package/src/comp/index.ts +186 -0
  414. package/src/comp/needs.test.ts +499 -0
  415. package/src/comp/needs.ts +113 -0
  416. package/src/comp/validate.test.ts +304 -0
  417. package/src/comp/validate.ts +125 -0
  418. package/src/comp.ts +1 -0
  419. package/src/contexts/schema/index.ts +7 -0
  420. package/src/contexts/schema.ts +1 -0
  421. package/src/contexts/service/index.test.ts +323 -0
  422. package/src/contexts/service/index.ts +43 -0
  423. package/src/contexts/service.ts +1 -0
  424. package/src/contexts/telegram/index.ts +115 -0
  425. package/src/contexts/text/index.test.ts +31 -0
  426. package/src/contexts/text/index.ts +18 -0
  427. package/src/contexts/text.ts +1 -0
  428. package/src/core/component.ts +153 -0
  429. package/src/core/context.ts +14 -0
  430. package/src/core/index.test.ts +224 -0
  431. package/src/core/index.ts +9 -0
  432. package/src/core/path.ts +38 -0
  433. package/src/core/registry.ts +112 -0
  434. package/src/core.ts +1 -0
  435. package/src/index.ts +1 -0
  436. package/src/log.test.ts +70 -0
  437. package/src/log.ts +199 -0
  438. package/src/mod/discover.test.ts +133 -0
  439. package/src/mod/discover.ts +100 -0
  440. package/src/mod/docs/00-index.md +19 -0
  441. package/src/mod/docs/01-primitives.md +38 -0
  442. package/src/mod/docs/02-core-api.md +68 -0
  443. package/src/mod/docs/03-registry.md +30 -0
  444. package/src/mod/docs/04-store.md +62 -0
  445. package/src/mod/docs/05-comp.md +111 -0
  446. package/src/mod/docs/06-actions.md +193 -0
  447. package/src/mod/docs/07-realtime.md +108 -0
  448. package/src/mod/docs/08-services.md +35 -0
  449. package/src/mod/docs/09-mounts.md +43 -0
  450. package/src/mod/docs/10-acl.md +60 -0
  451. package/src/mod/docs/11-server.md +62 -0
  452. package/src/mod/docs/12-conventions.md +108 -0
  453. package/src/mod/docs/13-example.md +142 -0
  454. package/src/mod/docs/14-mod-format.md +377 -0
  455. package/src/mod/docs/15-documenting-types.md +156 -0
  456. package/src/mod/examples/ticker/seed.ts +19 -0
  457. package/src/mod/examples/ticker/service.ts +19 -0
  458. package/src/mod/examples/ticker/ticker.test.ts +18 -0
  459. package/src/mod/examples/ticker/types.ts +22 -0
  460. package/src/mod/examples/ticker/view.tsx +19 -0
  461. package/src/mod/index.ts +12 -0
  462. package/src/mod/loader.test.ts +220 -0
  463. package/src/mod/loader.ts +207 -0
  464. package/src/mod/optimistic.test.ts +446 -0
  465. package/src/mod/optimistic.ts +210 -0
  466. package/src/mod/prefab.ts +62 -0
  467. package/src/mod/tracking.test.ts +59 -0
  468. package/src/mod/tracking.ts +51 -0
  469. package/src/mod/types.ts +40 -0
  470. package/src/mod.ts +1 -0
  471. package/src/mods/autostart/CLAUDE.md +6 -0
  472. package/src/mods/autostart/autostart.test.ts +85 -0
  473. package/src/mods/autostart/server.ts +1 -0
  474. package/src/mods/autostart/service.ts +98 -0
  475. package/src/mods/clients.ts +2 -0
  476. package/src/mods/llm/CLAUDE.md +6 -0
  477. package/src/mods/llm/index.ts +57 -0
  478. package/src/mods/llm/llm.test.ts +109 -0
  479. package/src/mods/llm/server.ts +1 -0
  480. package/src/mods/servers.ts +4 -0
  481. package/src/mods/treenity/agent-port.ts +93 -0
  482. package/src/mods/treenity/builtins.ts +21 -0
  483. package/src/mods/treenity/groups.ts +19 -0
  484. package/src/mods/treenity/logs.ts +26 -0
  485. package/src/mods/treenity/mod-type.ts +10 -0
  486. package/src/mods/treenity/seed.ts +58 -0
  487. package/src/mods/treenity/server.ts +6 -0
  488. package/src/mods/treenity/system.ts +70 -0
  489. package/src/mods/uix/CLAUDE.md +7 -0
  490. package/src/mods/uix/client.ts +117 -0
  491. package/src/mods/uix/compile.test.ts +228 -0
  492. package/src/mods/uix/compile.ts +112 -0
  493. package/src/mods/uix/jsx-parser.test.ts +554 -0
  494. package/src/mods/uix/jsx-parser.ts +489 -0
  495. package/src/mods/uix/lazy-load.test.ts +261 -0
  496. package/src/mods/uix/uix-repomix.md +3509 -0
  497. package/src/mods/uix/verify.ts +68 -0
  498. package/src/schema/CLAUDE.md +13 -0
  499. package/src/schema/_test-fixture.ts +12 -0
  500. package/src/schema/catalog.ts +101 -0
  501. package/src/schema/extract-schemas.test.ts +84 -0
  502. package/src/schema/extract-schemas.ts +462 -0
  503. package/src/schema/generated/ai.agent.json +133 -0
  504. package/src/schema/generated/ai.approval.json +105 -0
  505. package/src/schema/generated/ai.approvals.json +24 -0
  506. package/src/schema/generated/ai.assignment.json +28 -0
  507. package/src/schema/generated/ai.plan.json +84 -0
  508. package/src/schema/generated/ai.policy.json +105 -0
  509. package/src/schema/generated/ai.pool.json +37 -0
  510. package/src/schema/generated/ai.thread.json +64 -0
  511. package/src/schema/generated/autostart.json +44 -0
  512. package/src/schema/generated/board.column.json +25 -0
  513. package/src/schema/generated/board.kanban.json +7 -0
  514. package/src/schema/generated/board.task.json +147 -0
  515. package/src/schema/generated/brahman.action.back.json +12 -0
  516. package/src/schema/generated/brahman.action.broadcast.json +31 -0
  517. package/src/schema/generated/brahman.action.call.json +57 -0
  518. package/src/schema/generated/brahman.action.emittext.json +23 -0
  519. package/src/schema/generated/brahman.action.eval.json +23 -0
  520. package/src/schema/generated/brahman.action.file.json +28 -0
  521. package/src/schema/generated/brahman.action.forward.json +29 -0
  522. package/src/schema/generated/brahman.action.getvalue.json +28 -0
  523. package/src/schema/generated/brahman.action.ifelse.json +42 -0
  524. package/src/schema/generated/brahman.action.keywordselect.json +46 -0
  525. package/src/schema/generated/brahman.action.message.json +127 -0
  526. package/src/schema/generated/brahman.action.onerror.json +29 -0
  527. package/src/schema/generated/brahman.action.page.json +22 -0
  528. package/src/schema/generated/brahman.action.params.json +36 -0
  529. package/src/schema/generated/brahman.action.question.json +43 -0
  530. package/src/schema/generated/brahman.action.remove.json +12 -0
  531. package/src/schema/generated/brahman.action.resethistory.json +12 -0
  532. package/src/schema/generated/brahman.action.resetsession.json +12 -0
  533. package/src/schema/generated/brahman.action.selectlang.json +20 -0
  534. package/src/schema/generated/brahman.action.setvalue.json +27 -0
  535. package/src/schema/generated/brahman.action.tag.json +27 -0
  536. package/src/schema/generated/brahman.bot.json +68 -0
  537. package/src/schema/generated/brahman.page.json +25 -0
  538. package/src/schema/generated/brahman.session.json +29 -0
  539. package/src/schema/generated/brahman.user.json +58 -0
  540. package/src/schema/generated/cafe.contact.json +56 -0
  541. package/src/schema/generated/cafe.mail.json +29 -0
  542. package/src/schema/generated/canary.item.json +40 -0
  543. package/src/schema/generated/claude-search.json +20 -0
  544. package/src/schema/generated/craft.product.json +47 -0
  545. package/src/schema/generated/craft.shop.json +94 -0
  546. package/src/schema/generated/craft.subscription.json +27 -0
  547. package/src/schema/generated/default.json +15 -0
  548. package/src/schema/generated/doc.page.json +23 -0
  549. package/src/schema/generated/examples.demo.generator.json +16 -0
  550. package/src/schema/generated/examples.demo.sensor.json +35 -0
  551. package/src/schema/generated/examples.demo.sensor.reading.json +25 -0
  552. package/src/schema/generated/flow.node.action.json +61 -0
  553. package/src/schema/generated/flow.node.code.json +43 -0
  554. package/src/schema/generated/flow.node.condition.json +37 -0
  555. package/src/schema/generated/flow.node.end.json +35 -0
  556. package/src/schema/generated/flow.node.http.json +65 -0
  557. package/src/schema/generated/flow.node.llm.json +67 -0
  558. package/src/schema/generated/flow.node.loop.json +49 -0
  559. package/src/schema/generated/flow.node.start.json +39 -0
  560. package/src/schema/generated/flow.scenario.json +118 -0
  561. package/src/schema/generated/groups.json +20 -0
  562. package/src/schema/generated/grove.attempt.json +199 -0
  563. package/src/schema/generated/grove.path.json +93 -0
  564. package/src/schema/generated/grove.review.json +27 -0
  565. package/src/schema/generated/grove.task.json +164 -0
  566. package/src/schema/generated/intel.scenario.json +58 -0
  567. package/src/schema/generated/intel.signal.json +113 -0
  568. package/src/schema/generated/intel.world.json +15 -0
  569. package/src/schema/generated/landing.block.json +201 -0
  570. package/src/schema/generated/landing.page.json +84 -0
  571. package/src/schema/generated/launcher.json +91 -0
  572. package/src/schema/generated/mcp.server.json +15 -0
  573. package/src/schema/generated/metatron.config.json +119 -0
  574. package/src/schema/generated/metatron.permission.json +36 -0
  575. package/src/schema/generated/metatron.skill.json +36 -0
  576. package/src/schema/generated/metatron.task.json +114 -0
  577. package/src/schema/generated/metatron.template.json +26 -0
  578. package/src/schema/generated/metatron.workspace.json +60 -0
  579. package/src/schema/generated/mindmap.map.json +22 -0
  580. package/src/schema/generated/order.status.json +21 -0
  581. package/src/schema/generated/polyhope.backtest.json +161 -0
  582. package/src/schema/generated/polyhope.feed.json +33 -0
  583. package/src/schema/generated/polyhope.run.json +94 -0
  584. package/src/schema/generated/polyhope.strategy.json +152 -0
  585. package/src/schema/generated/polymax.activity.json +65 -0
  586. package/src/schema/generated/polymax.aggr-feed.json +28 -0
  587. package/src/schema/generated/polymax.aggr.json +20 -0
  588. package/src/schema/generated/polymax.alert.json +56 -0
  589. package/src/schema/generated/polymax.bot-config.json +14 -0
  590. package/src/schema/generated/polymax.bot-status.json +35 -0
  591. package/src/schema/generated/polymax.classification.json +55 -0
  592. package/src/schema/generated/polymax.deposits.json +45 -0
  593. package/src/schema/generated/polymax.holding.json +55 -0
  594. package/src/schema/generated/polymax.identity.json +71 -0
  595. package/src/schema/generated/polymax.lb-entry.json +75 -0
  596. package/src/schema/generated/polymax.leaderboard.json +37 -0
  597. package/src/schema/generated/polymax.market-ref.json +25 -0
  598. package/src/schema/generated/polymax.performance.json +65 -0
  599. package/src/schema/generated/polymax.profile.json +16 -0
  600. package/src/schema/generated/polymax.scan-result.json +50 -0
  601. package/src/schema/generated/polymax.status.json +40 -0
  602. package/src/schema/generated/polymax.tags.json +53 -0
  603. package/src/schema/generated/polymax.trader.json +16 -0
  604. package/src/schema/generated/polymax.wallet-market.json +50 -0
  605. package/src/schema/generated/polymax.wallet-pnl.json +35 -0
  606. package/src/schema/generated/pult.concept.json +53 -0
  607. package/src/schema/generated/pult.config.json +227 -0
  608. package/src/schema/generated/pult.connector.json +72 -0
  609. package/src/schema/generated/pult.market.json +113 -0
  610. package/src/schema/generated/pult.order.json +113 -0
  611. package/src/schema/generated/pult.rete.json +68 -0
  612. package/src/schema/generated/pult.sensor.json +74 -0
  613. package/src/schema/generated/pult.signal.json +54 -0
  614. package/src/schema/generated/pult.synapse.json +93 -0
  615. package/src/schema/generated/pult.trade.json +93 -0
  616. package/src/schema/generated/resim.config.json +34 -0
  617. package/src/schema/generated/resim.function.json +62 -0
  618. package/src/schema/generated/resim.goal.json +22 -0
  619. package/src/schema/generated/resim.resource.json +40 -0
  620. package/src/schema/generated/resim.state.json +48 -0
  621. package/src/schema/generated/resim.world.json +40 -0
  622. package/src/schema/generated/saveme.action.save.json +29 -0
  623. package/src/schema/generated/saveme.message.json +36 -0
  624. package/src/schema/generated/saveme.router.json +31 -0
  625. package/src/schema/generated/sim.agent.json +24 -0
  626. package/src/schema/generated/sim.ai.json +24 -0
  627. package/src/schema/generated/sim.config.json +38 -0
  628. package/src/schema/generated/sim.descriptive.json +26 -0
  629. package/src/schema/generated/sim.events.json +47 -0
  630. package/src/schema/generated/sim.item.json +20 -0
  631. package/src/schema/generated/sim.memory.json +17 -0
  632. package/src/schema/generated/sim.nearby.json +17 -0
  633. package/src/schema/generated/sim.position.json +25 -0
  634. package/src/schema/generated/sim.round.json +64 -0
  635. package/src/schema/generated/sim.world.json +32 -0
  636. package/src/schema/generated/t.agent.port.json +74 -0
  637. package/src/schema/generated/t.coolify.json +50 -0
  638. package/src/schema/generated/t.event.json +46 -0
  639. package/src/schema/generated/t.llm.json +20 -0
  640. package/src/schema/generated/t.logs.json +155 -0
  641. package/src/schema/generated/t.mod.json +27 -0
  642. package/src/schema/generated/t.note.json +31 -0
  643. package/src/schema/generated/t.person.json +36 -0
  644. package/src/schema/generated/t.tenant.json +57 -0
  645. package/src/schema/generated/t.tenant.status.json +42 -0
  646. package/src/schema/generated/t3d.animator.json +46 -0
  647. package/src/schema/generated/t3d.audio.json +58 -0
  648. package/src/schema/generated/t3d.camera.json +50 -0
  649. package/src/schema/generated/t3d.collider.json +84 -0
  650. package/src/schema/generated/t3d.light.json +90 -0
  651. package/src/schema/generated/t3d.line.json +47 -0
  652. package/src/schema/generated/t3d.lod.json +28 -0
  653. package/src/schema/generated/t3d.material.json +131 -0
  654. package/src/schema/generated/t3d.mesh.json +65 -0
  655. package/src/schema/generated/t3d.object.json +64 -0
  656. package/src/schema/generated/t3d.particles.json +109 -0
  657. package/src/schema/generated/t3d.rigidbody.json +81 -0
  658. package/src/schema/generated/t3d.scene.json +7 -0
  659. package/src/schema/generated/t3d.script.json +23 -0
  660. package/src/schema/generated/t3d.text.json +86 -0
  661. package/src/schema/generated/t3d.trail.json +45 -0
  662. package/src/schema/generated/tagger.config.json +115 -0
  663. package/src/schema/generated/tagger.result.json +57 -0
  664. package/src/schema/generated/tagger.tree.json +36 -0
  665. package/src/schema/generated/task.json +96 -0
  666. package/src/schema/generated/test.fixture.json +43 -0
  667. package/src/schema/generated/ticker.config.json +43 -0
  668. package/src/schema/generated/ticker.price.json +20 -0
  669. package/src/schema/generated/todo.item.json +25 -0
  670. package/src/schema/generated/todo.list.json +33 -0
  671. package/src/schema/generated/treenity.system.json +259 -0
  672. package/src/schema/generated/ui.table.json +46 -0
  673. package/src/schema/generated/whisper.audio.json +25 -0
  674. package/src/schema/generated/whisper.checklist.json +17 -0
  675. package/src/schema/generated/whisper.config.json +30 -0
  676. package/src/schema/generated/whisper.inbox.json +24 -0
  677. package/src/schema/generated/whisper.meta.json +35 -0
  678. package/src/schema/generated/whisper.text.json +16 -0
  679. package/src/schema/load.ts +24 -0
  680. package/src/schema/schema.test.ts +86 -0
  681. package/src/schema/test-fixture.types.ts +21 -0
  682. package/src/schema/types.ts +34 -0
  683. package/src/server/CLAUDE.md +26 -0
  684. package/src/server/actions.test.ts +272 -0
  685. package/src/server/actions.ts +274 -0
  686. package/src/server/agent-sub.test.ts +90 -0
  687. package/src/server/agent.test.ts +305 -0
  688. package/src/server/agent.ts +17 -0
  689. package/src/server/api.test.ts +463 -0
  690. package/src/server/auth.test.ts +441 -0
  691. package/src/server/auth.ts +387 -0
  692. package/src/server/client.ts +24 -0
  693. package/src/server/conditions.test.ts +128 -0
  694. package/src/server/cookies.ts +25 -0
  695. package/src/server/coverage.test.ts +827 -0
  696. package/src/server/doc-index.ts +287 -0
  697. package/src/server/e2e.test.ts +967 -0
  698. package/src/server/errors.ts +11 -0
  699. package/src/server/factory.ts +121 -0
  700. package/src/server/main.ts +24 -0
  701. package/src/server/migrate.test.ts +123 -0
  702. package/src/server/migrate.ts +62 -0
  703. package/src/server/mod-catalog.ts +59 -0
  704. package/src/server/mods-mount.ts +177 -0
  705. package/src/server/mount-adapters.ts +87 -0
  706. package/src/server/mount.parametrized.test.ts +52 -0
  707. package/src/server/mount.query.test.ts +127 -0
  708. package/src/server/mount.test.ts +565 -0
  709. package/src/server/mount.ts +208 -0
  710. package/src/server/prefab.test.ts +415 -0
  711. package/src/server/prefab.ts +105 -0
  712. package/src/server/refs.test.ts +82 -0
  713. package/src/server/refs.ts +64 -0
  714. package/src/server/seed/index.ts +24 -0
  715. package/src/server/server.ts +164 -0
  716. package/src/server/stress.test.ts +844 -0
  717. package/src/server/sub.test.ts +55 -0
  718. package/src/server/sub.ts +224 -0
  719. package/src/server/trpc.ts +375 -0
  720. package/src/server/types-mount.ts +142 -0
  721. package/src/server/validate.test.ts +91 -0
  722. package/src/server/validate.ts +22 -0
  723. package/src/server/volatile.test.ts +140 -0
  724. package/src/server/volatile.ts +32 -0
  725. package/src/server/watch.test.ts +594 -0
  726. package/src/server/watch.ts +202 -0
  727. package/src/server/workflow.test.ts +82 -0
  728. package/src/tree/CLAUDE.md +13 -0
  729. package/src/tree/cache.test.ts +213 -0
  730. package/src/tree/cache.ts +51 -0
  731. package/src/tree/fs.test.ts +247 -0
  732. package/src/tree/fs.ts +257 -0
  733. package/src/tree/index.test.ts +190 -0
  734. package/src/tree/index.ts +217 -0
  735. package/src/tree/inflight.ts +15 -0
  736. package/src/tree/json-codec.ts +16 -0
  737. package/src/tree/mimefs.test.ts +289 -0
  738. package/src/tree/mimefs.ts +142 -0
  739. package/src/tree/mongo.ts +125 -0
  740. package/src/tree/patch.test.ts +192 -0
  741. package/src/tree/patch.ts +133 -0
  742. package/src/tree/query.test.ts +110 -0
  743. package/src/tree/query.ts +70 -0
  744. package/src/tree/repath.test.ts +86 -0
  745. package/src/tree/repath.ts +53 -0
  746. package/src/tree-chain.test.ts +716 -0
  747. package/src/tree-chain.ts +150 -0
  748. package/src/tree.ts +1 -0
  749. package/src/uri.test.ts +113 -0
  750. package/src/uri.ts +84 -0
  751. package/CHANGELOG.md +0 -314
  752. package/dist/context.d.ts +0 -41
  753. package/dist/context.d.ts.map +0 -1
  754. package/dist/context.mjs +0 -81
  755. package/dist/context.mjs.map +0 -1
  756. package/dist/contexts/node-engine.d.ts +0 -12
  757. package/dist/contexts/node-engine.d.ts.map +0 -1
  758. package/dist/contexts/node-engine.mjs +0 -7
  759. package/dist/contexts/node-engine.mjs.map +0 -1
  760. package/dist/contexts/noflo/types.d.ts +0 -20
  761. package/dist/contexts/noflo/types.d.ts.map +0 -1
  762. package/dist/contexts/object.d.ts +0 -11
  763. package/dist/contexts/object.d.ts.map +0 -1
  764. package/dist/contexts/object.mjs +0 -15
  765. package/dist/contexts/object.mjs.map +0 -1
  766. package/dist/contexts/proto.d.ts +0 -11
  767. package/dist/contexts/proto.d.ts.map +0 -1
  768. package/dist/contexts/proto.mjs +0 -7
  769. package/dist/contexts/proto.mjs.map +0 -1
  770. package/dist/contexts/react-context.d.ts +0 -21
  771. package/dist/contexts/react-context.d.ts.map +0 -1
  772. package/dist/contexts/react-context.mjs +0 -24
  773. package/dist/contexts/react-context.mjs.map +0 -1
  774. package/dist/contexts/service.mjs +0 -7
  775. package/dist/contexts/service.mjs.map +0 -1
  776. package/dist/get-type-cache.d.ts +0 -2
  777. package/dist/get-type-cache.d.ts.map +0 -1
  778. package/dist/get-type-cache.mjs +0 -7
  779. package/dist/get-type-cache.mjs.map +0 -1
  780. package/dist/index.mjs +0 -10
  781. package/dist/index.mjs.map +0 -1
  782. package/dist/link/link.d.ts +0 -25
  783. package/dist/link/link.d.ts.map +0 -1
  784. package/dist/link/link.mjs +0 -72
  785. package/dist/link/link.mjs.map +0 -1
  786. package/dist/link/link.test.d.ts +0 -2
  787. package/dist/link/link.test.d.ts.map +0 -1
  788. package/dist/loading.d.ts +0 -9
  789. package/dist/loading.d.ts.map +0 -1
  790. package/dist/meta-type.d.ts +0 -58
  791. package/dist/meta-type.d.ts.map +0 -1
  792. package/dist/meta-type.mjs +0 -104
  793. package/dist/meta-type.mjs.map +0 -1
  794. package/dist/meta.d.ts +0 -20
  795. package/dist/meta.d.ts.map +0 -1
  796. package/dist/meta.mjs +0 -16
  797. package/dist/meta.mjs.map +0 -1
  798. package/dist/node/index.d.ts +0 -2
  799. package/dist/node/index.d.ts.map +0 -1
  800. package/dist/node/types.d.ts +0 -37
  801. package/dist/node/types.d.ts.map +0 -1
  802. package/dist/test/context.test.d.ts +0 -2
  803. package/dist/test/context.test.d.ts.map +0 -1
  804. package/dist/types.d.ts +0 -14
  805. package/dist/types.d.ts.map +0 -1
  806. package/dist/types.mjs +0 -16
  807. package/dist/types.mjs.map +0 -1
@@ -0,0 +1,14 @@
1
+ // ── Context ──
2
+
3
+ export type Handler = (...args: any[]) => any;
4
+
5
+ // Typed context handlers — augmented by layers via declaration merging
6
+ // eslint-disable-next-line @typescript-eslint/no-empty-interface
7
+ export interface ContextHandlers<T = any> {
8
+ }
9
+
10
+ export type ContextHandler<C extends string, T = any> = C extends keyof ContextHandlers<T>
11
+ ? ContextHandlers<T>[C]
12
+ : C extends `${infer Base}:${string}`
13
+ ? ContextHandler<Base, T>
14
+ : Handler;
@@ -0,0 +1,224 @@
1
+ import { basename, dirname, isChildPath, join } from '#core/path';
2
+ import assert from 'node:assert/strict';
3
+ import { describe, it } from 'node:test';
4
+ import {
5
+ createNode,
6
+ getComponent,
7
+ getComponents,
8
+ isComponent,
9
+ isRef,
10
+ mapRegistry,
11
+ ref,
12
+ register,
13
+ removeComponent,
14
+ render,
15
+ resolve,
16
+ unregister,
17
+ } from './index';
18
+ import { registerBuiltins } from '#mods/treenity/builtins';
19
+
20
+ const testTypes = ['test.doc', 'test.item', 'test.session', 'test.task'];
21
+
22
+ export function registerTestTypes() {
23
+ for (const t of testTypes)
24
+ register(t, 'schema', () => ({ $id: t, type: 'object' as const, title: t, properties: {} }));
25
+ }
26
+
27
+ registerTestTypes();
28
+
29
+ export function clearRegistry(): void {
30
+ mapRegistry((t, c) => unregister(t, c));
31
+ registerBuiltins();
32
+ registerTestTypes();
33
+ }
34
+
35
+ describe('Node', () => {
36
+ it('creates with type and path', () => {
37
+ const node = createNode('/tasks/1', 'task');
38
+ assert.equal(node.$path, '/tasks/1');
39
+ assert.equal(node.$type, 't.task');
40
+ });
41
+
42
+ it('creates with components', () => {
43
+ const node = createNode('/tasks/1', 'task', {}, {
44
+ info: { $type: 'task', status: 'open' },
45
+ budget: { $type: 'money', amount: 100, currency: 'USD' },
46
+ });
47
+ assert.equal(node.info.$type, 'task');
48
+ assert.equal(node.budget.amount, 100);
49
+ });
50
+
51
+ it('rejects $ prefix in component names', () => {
52
+ assert.throws(() => createNode('/x', 'x', {}, { $bad: { $type: 'x' } }));
53
+ });
54
+ });
55
+
56
+ describe('Component access', () => {
57
+ const node = createNode('/tasks/1', 'task', {}, {
58
+ budget: { $type: 'money', amount: 100, currency: 'USD' },
59
+ estimate: { $type: 'money', amount: 200, currency: 'USD' },
60
+ });
61
+
62
+ it('get by type — node-level match', () => {
63
+ // node.$type is 't.task', getComponent('task') normalizes and matches
64
+ const comp = getComponent(node, 'task');
65
+ assert.equal(comp, node);
66
+ });
67
+
68
+ it('get by type — named component', () => {
69
+ const comp = getComponent(node, 'money');
70
+ assert.ok(comp);
71
+ assert.equal((comp as any).amount, 100); // first match: budget
72
+ });
73
+
74
+ it('get by type with field filter', () => {
75
+ const comp = getComponent(node, 'money', 'estimate');
76
+ assert.ok(comp);
77
+ assert.equal((comp as any).amount, 200);
78
+ });
79
+
80
+ it('returns undefined for missing type', () => {
81
+ assert.equal(getComponent(node, 'nope'), undefined);
82
+ });
83
+
84
+ it('returns undefined for wrong type at field', () => {
85
+ assert.equal(getComponent(node, 'task', 'budget'), undefined);
86
+ });
87
+
88
+ it('find all by type', () => {
89
+ const moneys = getComponents(node, 'money');
90
+ assert.equal(moneys.length, 2);
91
+ assert.deepEqual(moneys.map(([name]) => name).sort(), ['budget', 'estimate']);
92
+ });
93
+
94
+ it('isComponent type guard', () => {
95
+ assert.ok(isComponent(node['budget']));
96
+ assert.ok(!isComponent((node as any)['missing']));
97
+ assert.ok(!isComponent('string'));
98
+ assert.ok(!isComponent(null));
99
+ });
100
+
101
+ it('set and remove', () => {
102
+ const n = createNode('/x', 'x');
103
+ (n as any).tag = { $type: 'tag', value: 'urgent' };
104
+ assert.ok(getComponent(n, 'tag'));
105
+ assert.equal(removeComponent(n, 'tag'), true);
106
+ assert.equal(getComponent(n, 'tag'), undefined);
107
+ assert.equal(removeComponent(n, 'tag'), false);
108
+ });
109
+ });
110
+
111
+ describe('Ref', () => {
112
+ it('creates ref', () => {
113
+ const r = ref('/users/bob');
114
+ assert.equal(r.$type, 'ref');
115
+ assert.equal(r.$ref, '/users/bob');
116
+ });
117
+
118
+ it('detects ref', () => {
119
+ assert.equal(isRef(ref('/x')), true);
120
+ assert.equal(isRef({ $type: 'task' }), false);
121
+ assert.equal(isRef(null), false);
122
+ assert.equal(isRef('string'), false);
123
+ });
124
+ });
125
+
126
+ describe('Path utils', () => {
127
+ it('parentPath', () => {
128
+ assert.equal(dirname('/'), null);
129
+ assert.equal(dirname('/tasks'), '/');
130
+ assert.equal(dirname('/tasks/123'), '/tasks');
131
+ assert.equal(dirname('/a/b/c'), '/a/b');
132
+ });
133
+
134
+ it('nodeName', () => {
135
+ assert.equal(basename('/tasks/123'), '123');
136
+ assert.equal(basename('/tasks'), 'tasks');
137
+ });
138
+
139
+ it('childPath', () => {
140
+ assert.equal(join('/', 'tasks'), '/tasks');
141
+ assert.equal(join('/tasks', '123'), '/tasks/123');
142
+ });
143
+
144
+ it('isChildPath direct', () => {
145
+ assert.equal(isChildPath('/tasks', '/tasks/123'), true);
146
+ assert.equal(isChildPath('/tasks', '/tasks/123/sub'), false);
147
+ assert.equal(isChildPath('/tasks', '/tasks'), false);
148
+ assert.equal(isChildPath('/', '/tasks'), true);
149
+ assert.equal(isChildPath('/', '/tasks/123'), false);
150
+ });
151
+
152
+ it('isChildPath recursive', () => {
153
+ assert.equal(isChildPath('/tasks', '/tasks/123/sub', false), true);
154
+ assert.equal(isChildPath('/', '/tasks/123', false), true);
155
+ });
156
+
157
+ // Regression: /board must not match /boards (prefix overlap without separator)
158
+ it('isChildPath rejects prefix overlap without separator', () => {
159
+ assert.equal(isChildPath('/board', '/boards'), false);
160
+ assert.equal(isChildPath('/board', '/boards/test'), false);
161
+ assert.equal(isChildPath('/board', '/boards/test', false), false);
162
+ assert.equal(isChildPath('/board', '/board/real'), true);
163
+ assert.equal(isChildPath('/board', '/board/real/deep', false), true);
164
+ });
165
+ });
166
+
167
+ describe('Context', () => {
168
+ it('register and resolve exact', () => {
169
+ clearRegistry();
170
+ register('task', 'test', (data) => `<Task ${(data as any).status} />`);
171
+ const handler = resolve('task', 'test');
172
+ assert.ok(handler);
173
+ assert.equal(handler({ $type: 'task', status: 'open' }), '<Task open />');
174
+ });
175
+
176
+ it('fallback from specific to general', () => {
177
+ clearRegistry();
178
+ register('task', 'test', () => 'general');
179
+ register('task', 'test:compact', () => 'compact');
180
+
181
+ assert.equal(resolve('task', 'test:compact')?.({} as any), 'compact');
182
+ assert.equal(resolve('task', 'test:compact:mini')?.({} as any), 'compact');
183
+ assert.equal(resolve('task', 'test')?.({} as any), 'general');
184
+ });
185
+
186
+ it('default wins over stripped context', () => {
187
+ clearRegistry();
188
+ register('default', 'test:compact:mini', () => 'default:mini');
189
+ register('default', 'test', () => 'default');
190
+ register('task', 'test', () => 'general');
191
+ register('task', 'test:compact', () => 'compact');
192
+
193
+ assert.equal(resolve('task', 'test:compact')?.({} as any), 'compact');
194
+ assert.equal(resolve('task', 'test:compact:mini')?.({} as any), 'default:mini');
195
+ assert.equal(resolve('task', 'test')?.({} as any), 'general');
196
+ assert.equal(resolve('unknown', 'test:compact:mini')?.({} as any), 'default:mini');
197
+ assert.equal(resolve('unknown', 'test:compact')?.({} as any), 'default');
198
+ });
199
+
200
+ it('fallback to default', () => {
201
+ clearRegistry();
202
+ register('default', 'test', () => 'default');
203
+ assert.equal(resolve('task', 'test')?.({} as any), 'default');
204
+ assert.equal(resolve('task', 'test:compact')?.({} as any), 'default');
205
+ });
206
+
207
+ it('strip still works without default', () => {
208
+ clearRegistry();
209
+ register('task', 'react', () => 'react');
210
+ assert.equal(resolve('task', 'react:edit:inline')?.({} as any), 'react');
211
+ assert.equal(resolve('task', 'react:edit')?.({} as any), 'react');
212
+ });
213
+
214
+ it('returns null when nothing found', () => {
215
+ clearRegistry();
216
+ assert.equal(resolve('unknown', 'test'), null);
217
+ });
218
+
219
+ it('render throws on missing handler', () => {
220
+ clearRegistry();
221
+ assert.throws(() => render({ $type: 'nope' }, 'react'));
222
+ });
223
+ });
224
+
@@ -0,0 +1,9 @@
1
+ // Treenity Core — Layer 0
2
+ // Node + Component + Context + Ref
3
+ // Zero dependencies. < 500 lines.
4
+
5
+ export * from './component';
6
+ export * from './context';
7
+ export * from './path';
8
+ export * from './registry';
9
+
@@ -0,0 +1,38 @@
1
+ // ── Path utils ──
2
+
3
+ export function dirname(path: string): string | null {
4
+ if (path === '/') return null;
5
+ const idx = path.lastIndexOf('/');
6
+ if (idx <= 0) return '/';
7
+ return path.slice(0, idx);
8
+ }
9
+
10
+ export function basename(path: string): string {
11
+ const idx = path.lastIndexOf('/');
12
+ return idx === -1 ? path : path.slice(idx + 1);
13
+ }
14
+
15
+ export function join(parent: string, name: string): string {
16
+ return parent === '/' ? `/${name}` : `${parent}/${name}`;
17
+ }
18
+
19
+ export function isChildPath(parent: string, candidate: string, directOnly = true): boolean {
20
+ if (candidate === parent) return false;
21
+ // Must match parent + '/' to avoid /board matching /boards
22
+ const prefix = parent === '/' ? '/' : parent + '/';
23
+ if (!candidate.startsWith(prefix)) return false;
24
+ if (directOnly) {
25
+ const rest = candidate.slice(prefix.length);
26
+ return rest.length > 0 && !rest.includes('/');
27
+ }
28
+
29
+ return true;
30
+ }
31
+
32
+ /** Validate a tree path — rejects traversal, double-slash, null bytes */
33
+ export function assertSafePath(path: string): void {
34
+ if (!path.startsWith('/')) throw new Error(`Invalid path: must start with /`);
35
+ if (path.includes('\0')) throw new Error(`Invalid path: null byte`);
36
+ if (path.includes('//')) throw new Error(`Invalid path: double slash`);
37
+ if (path.split('/').some(s => s === '..')) throw new Error(`Invalid path: traversal`);
38
+ }
@@ -0,0 +1,112 @@
1
+ import { type Class, ComponentData, normalizeType, type TypeId } from './component';
2
+ import { ContextHandler, Handler } from './context';
3
+
4
+ const registry = new Map<string, Handler>();
5
+ const metaRegistry = new Map<string, Record<string, unknown>>();
6
+
7
+ // ── Registry subscription — lets React re-render when handlers change ──
8
+ let version = 0;
9
+ const listeners = new Set<() => void>();
10
+ function bump() {
11
+ version++;
12
+ listeners.forEach(cb => cb());
13
+ }
14
+ export function subscribeRegistry(cb: () => void) {
15
+ listeners.add(cb);
16
+ return () => { listeners.delete(cb); };
17
+ }
18
+ export function getRegistryVersion() { return version; }
19
+
20
+ function key(type: string, context: string): string {
21
+ return `${type}@${context}`;
22
+ }
23
+
24
+ export function register<C extends string>(type: string, context: C, handler: ContextHandler<C>, meta?: Record<string, unknown>): void;
25
+ export function register<T, C extends string>(type: Class<T>, context: C, handler: ContextHandler<C, T>, meta?: Record<string, unknown>): void;
26
+ export function register(type: TypeId, context: string, handler: Handler, meta?: Record<string, unknown>): void {
27
+ const k = key(normalizeType(type), context);
28
+ // Sealed: no overrides. In dev (HMR) modules re-execute, so we allow silent replace.
29
+ // In production, duplicate register = bug, caught by tests.
30
+ if (registry.has(k)) return;
31
+ registry.set(k, handler as Handler);
32
+ if (meta) metaRegistry.set(k, meta);
33
+ bump();
34
+ }
35
+
36
+ export function getMeta(type: TypeId, context: string): Record<string, unknown> | null {
37
+ return metaRegistry.get(key(normalizeType(type), context)) ?? null;
38
+ }
39
+
40
+ export function resolve<C extends string>(type: TypeId, context: C, _notifyMiss = true): ContextHandler<C> | null {
41
+ const n = normalizeType(type);
42
+ const exact = registry.get(key(n, context));
43
+ if (exact) return exact as ContextHandler<C>;
44
+
45
+ // Notify miss BEFORE default fallback — async loaders (UIX) start fetching,
46
+ // register when done, bump triggers re-render → next resolve finds exact match
47
+ if (_notifyMiss) missResolvers.get(context)?.(n);
48
+
49
+ const def = registry.get(key(normalizeType('default'), context));
50
+ if (def) return def as ContextHandler<C>;
51
+
52
+ // fallback: strip last segment ("react:compact" → "react")
53
+ const sep = context.lastIndexOf(':');
54
+ if (sep > 0) return resolve(type, context.slice(0, sep) as C, false);
55
+
56
+ return null;
57
+ }
58
+
59
+ // Returns the exact registered handler, no fallback, no miss notification
60
+ export function resolveExact<C extends string>(type: TypeId, context: C): ContextHandler<C> | null {
61
+ return (registry.get(key(normalizeType(type), context)) ?? null) as ContextHandler<C> | null;
62
+ }
63
+
64
+ export function hasMissResolver(context: string): boolean {
65
+ return missResolvers.has(context);
66
+ }
67
+
68
+ export function unregister(type: string, context: string): boolean {
69
+ const k = key(normalizeType(type), context);
70
+ metaRegistry.delete(k);
71
+ const deleted = registry.delete(k);
72
+ if (deleted) bump();
73
+ return deleted;
74
+ }
75
+
76
+ export function mapRegistry<T>(fn: (type: string, context: string) => T | undefined): T[] {
77
+ const result: T[] = [];
78
+ for (const k of registry.keys()) {
79
+ const i = k.lastIndexOf('@');
80
+ const v = fn(k.slice(0, i), k.slice(i + 1));
81
+ if (v !== undefined) result.push(v);
82
+ }
83
+ return result;
84
+ }
85
+
86
+ export function getRegisteredTypes(context?: string): string[] {
87
+ return context
88
+ ? mapRegistry((t, c) => c === context ? t : undefined)
89
+ : [...new Set(mapRegistry(t => t))];
90
+ }
91
+
92
+ export function getContextsForType(type: TypeId): string[] {
93
+ const n = normalizeType(type);
94
+ return mapRegistry((t, c) => t === n ? c : undefined);
95
+ }
96
+
97
+ // ── Resolve miss — per-context extension point for dynamic loaders ──
98
+ // One resolver per context. UIX uses this for 'react' to lazy-load views from type nodes.
99
+ // REVIEW: if more per-context behavior emerges (validate, wrap, fallback), consider
100
+ // evolving into defineContext('react', { onMiss, validate, ... }) trait system.
101
+ const missResolvers = new Map<string, (type: string) => void>();
102
+ export function onResolveMiss(context: string, resolver: (type: string) => void) {
103
+ missResolvers.set(context, resolver);
104
+ }
105
+
106
+ // ── Render (context-aware) ──
107
+
108
+ export function render(data: ComponentData, context: string, ...args: unknown[]): unknown {
109
+ const handler = resolve(data.$type, context);
110
+ if (!handler) throw new Error(`No handler for type "${data.$type}" in context "${context}"`);
111
+ return handler(data, ...args);
112
+ }
package/src/core.ts ADDED
@@ -0,0 +1 @@
1
+ export * from './core/index';
package/src/index.ts ADDED
@@ -0,0 +1 @@
1
+ export * from './core/index';
@@ -0,0 +1,70 @@
1
+ import assert from 'node:assert';
2
+ import { afterEach, beforeEach, describe, it } from 'node:test';
3
+ import { createLogger, setDebug } from './log.js';
4
+
5
+ describe('createLogger', () => {
6
+ const calls: { method: string; args: unknown[] }[] = []
7
+ const originals = { debug: console.debug, info: console.info, warn: console.warn, error: console.error }
8
+
9
+ beforeEach(() => {
10
+ calls.length = 0
11
+ for (const m of ['debug', 'info', 'warn', 'error'] as const) {
12
+ (console as any)[m] = (...args: unknown[]) => calls.push({ method: m, args })
13
+ }
14
+ })
15
+
16
+ afterEach(() => {
17
+ Object.assign(console, originals)
18
+ setDebug('')
19
+ })
20
+
21
+ it('info/warn/error always log with tag', () => {
22
+ const log = createLogger('test')
23
+ log.info('hello')
24
+ log.warn('careful')
25
+ log.error('boom')
26
+
27
+ assert.equal(calls.length, 3)
28
+ assert.deepStrictEqual(calls[0], { method: 'info', args: ['[test]', 'hello'] })
29
+ assert.deepStrictEqual(calls[1], { method: 'warn', args: ['[test]', 'careful'] })
30
+ assert.deepStrictEqual(calls[2], { method: 'error', args: ['[test]', 'boom'] })
31
+ })
32
+
33
+ it('debug is silent by default', () => {
34
+ const log = createLogger('test')
35
+ log.debug('hidden')
36
+ assert.equal(calls.length, 0)
37
+ })
38
+
39
+ it('setDebug enables debug for specific name', () => {
40
+ setDebug('foo')
41
+ const foo = createLogger('foo')
42
+ const bar = createLogger('bar')
43
+
44
+ foo.debug('visible')
45
+ bar.debug('hidden')
46
+
47
+ assert.equal(calls.length, 1)
48
+ assert.deepStrictEqual(calls[0], { method: 'debug', args: ['[foo]', 'visible'] })
49
+ })
50
+
51
+ it('setDebug("*") enables all', () => {
52
+ setDebug('*')
53
+ const log = createLogger('anything')
54
+ log.debug('visible')
55
+ assert.equal(calls.length, 1)
56
+ })
57
+
58
+ it('setDebug with comma-separated names', () => {
59
+ setDebug('a, b')
60
+ const a = createLogger('a')
61
+ const b = createLogger('b')
62
+ const c = createLogger('c')
63
+
64
+ a.debug('yes')
65
+ b.debug('yes')
66
+ c.debug('no')
67
+
68
+ assert.equal(calls.length, 2)
69
+ })
70
+ })
package/src/log.ts ADDED
@@ -0,0 +1,199 @@
1
+ // Unified logging: tree-persisted nodes + ring buffer fallback + debug filter + console intercept
2
+
3
+ import dayjs from 'dayjs'
4
+
5
+ export type LogLevel = 'debug' | 'info' | 'warn' | 'error'
6
+
7
+ export interface LogEntry {
8
+ t: number
9
+ level: LogLevel
10
+ msg: string
11
+ code?: string
12
+ sub?: string
13
+ userId?: string
14
+ method?: string
15
+ path?: string
16
+ }
17
+
18
+ // ── Execution context provider — set by comp/index.ts to avoid circular imports ──
19
+
20
+ type CtxProvider = () => Record<string, unknown> | null
21
+ let _getCtx: CtxProvider = () => null
22
+
23
+ export function setCtxProvider(fn: CtxProvider) { _getCtx = fn }
24
+
25
+ // ── Log listeners ──
26
+
27
+ type OnLog = (entry: LogEntry) => void
28
+ const listeners: OnLog[] = []
29
+
30
+ export function addOnLog(fn: OnLog) { listeners.push(fn) }
31
+
32
+ // ── Timestamp ID: YYMMDD-HHmmss-mmm-NNN ──
33
+
34
+ let lastMs = 0
35
+ let seq = 0
36
+
37
+ export function makeLogPath(): string {
38
+ const now = Date.now()
39
+ if (now === lastMs) {
40
+ seq++
41
+ } else {
42
+ lastMs = now
43
+ seq = 0
44
+ }
45
+
46
+ const stamp = dayjs(now).format('YYMMDD-HHmmss-SSS')
47
+ const sq = String(seq).padStart(3, '0')
48
+
49
+ return `/sys/logs/${stamp}-${sq}`
50
+ }
51
+
52
+ function notify(entry: LogEntry) {
53
+ for (const fn of listeners) fn(entry)
54
+ }
55
+
56
+ // ── Ring buffer (fallback before tree init) ──
57
+
58
+ const MAX = 2000
59
+ const buffer: LogEntry[] = []
60
+ let cursor = 0
61
+ let total = 0
62
+
63
+ function push(level: LogLevel, args: unknown[]) {
64
+ // Extract [tag] → sub
65
+ let sub: string | undefined
66
+ if (typeof args[0] === 'string') {
67
+ const m = args[0].match(/^\[([^\]]+)\]$/)
68
+ if (m) {
69
+ sub = m[1]
70
+ args = args.slice(1)
71
+ }
72
+ }
73
+
74
+ // Extract UPPER_SNAKE code
75
+ let code: string | undefined
76
+ if (args.length > 1 && typeof args[0] === 'string' && /^[A-Z][A-Z0-9_]+$/.test(args[0])) {
77
+ code = args[0]
78
+ args = args.slice(1)
79
+ }
80
+
81
+ const msg = args.map(a => typeof a === 'string' ? a : JSON.stringify(a)).join(' ')
82
+ const ctx = _getCtx()
83
+
84
+ const entry: LogEntry = {
85
+ t: Date.now(),
86
+ level,
87
+ msg,
88
+ code,
89
+ sub,
90
+ userId: ctx?.userId as string | undefined,
91
+ method: ctx?.method as string | undefined,
92
+ path: ctx?.path as string | undefined,
93
+ }
94
+
95
+ if (listeners.length) {
96
+ notify(entry)
97
+ } else {
98
+ if (total < MAX) {
99
+ buffer.push(entry)
100
+ } else {
101
+ buffer[cursor] = entry
102
+ }
103
+ cursor = (cursor + 1) % MAX
104
+ total++
105
+ }
106
+ }
107
+
108
+ /** Get ordered log entries from ring buffer (oldest first) */
109
+ function getOrdered(): LogEntry[] {
110
+ if (total <= MAX) return buffer.slice()
111
+ return [...buffer.slice(cursor), ...buffer.slice(0, cursor)]
112
+ }
113
+
114
+ // ── Query (ring buffer fallback — when tree available, use sift via getChildren) ──
115
+
116
+ export interface LogQuery {
117
+ grep?: string
118
+ level?: LogLevel | LogLevel[]
119
+ head?: number
120
+ tail?: number
121
+ }
122
+
123
+ export function queryLogs(opts: LogQuery = {}): LogEntry[] {
124
+ let entries = getOrdered()
125
+
126
+ if (opts.level) {
127
+ const levels = Array.isArray(opts.level) ? opts.level : [opts.level]
128
+ entries = entries.filter(e => levels.includes(e.level))
129
+ }
130
+
131
+ if (opts.grep) {
132
+ const re = new RegExp(opts.grep, 'i')
133
+ entries = entries.filter(e => re.test(e.msg))
134
+ }
135
+
136
+ if (opts.tail) entries = entries.slice(-opts.tail)
137
+ if (opts.head) entries = entries.slice(0, opts.head)
138
+
139
+ return entries
140
+ }
141
+
142
+ export function logStats() {
143
+ return { buffered: Math.min(total, MAX), total, max: MAX }
144
+ }
145
+
146
+ // ── Debug filter ──
147
+
148
+ const enabled = new Set<string>()
149
+ let all = false
150
+
151
+ export function setDebug(filter: string) {
152
+ enabled.clear()
153
+ all = false
154
+ if (filter === '*') { all = true; return }
155
+ for (const s of filter.split(',')) {
156
+ const t = s.trim()
157
+ if (t) enabled.add(t)
158
+ }
159
+ }
160
+
161
+ if (typeof process !== 'undefined' && process.env?.DEBUG) {
162
+ setDebug(process.env.DEBUG)
163
+ }
164
+
165
+ ;(globalThis as Record<string, unknown>).setDebug = setDebug
166
+
167
+ export function createLogger(name: string) {
168
+ const tag = `[${name}]`
169
+ return {
170
+ debug(...args: unknown[]) { if (all || enabled.has(name)) console.debug(tag, ...args) },
171
+ info(...args: unknown[]) { console.info(tag, ...args) },
172
+ warn(...args: unknown[]) { console.warn(tag, ...args) },
173
+ error(...args: unknown[]) { console.error(tag, ...args) },
174
+ }
175
+ }
176
+
177
+ // ── Console intercept — call once at startup ──
178
+
179
+ let intercepted = false
180
+
181
+ export function interceptConsole() {
182
+ if (intercepted) return
183
+ intercepted = true
184
+
185
+ for (const level of ['debug', 'info', 'warn', 'error'] as const) {
186
+ const orig = console[level]
187
+ console[level] = (...args: unknown[]) => {
188
+ push(level, args)
189
+ orig.apply(console, args)
190
+ }
191
+ }
192
+
193
+ // console.log → info level
194
+ const origLog = console.log
195
+ console.log = (...args: unknown[]) => {
196
+ push('info', args)
197
+ origLog.apply(console, args)
198
+ }
199
+ }