@powerlines/core 0.48.27 → 0.48.29

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 (641) hide show
  1. package/dist/api-DTCbbtSH.d.cts +6 -0
  2. package/dist/api-DTCbbtSH.d.cts.map +1 -0
  3. package/dist/api-DTCbbtSH.d.mts +6 -0
  4. package/dist/api-DTCbbtSH.d.mts.map +1 -0
  5. package/dist/base-context-BmxgDD3S.d.mts +79 -0
  6. package/dist/base-context-BmxgDD3S.d.mts.map +1 -0
  7. package/dist/base-context-mHoSEqHf.d.cts +79 -0
  8. package/dist/base-context-mHoSEqHf.d.cts.map +1 -0
  9. package/dist/{_virtual/_rolldown/runtime.cjs → chunk-C_NdSu1c.cjs} +6 -9
  10. package/dist/commands-DzGd8pnR.d.cts +5 -0
  11. package/dist/commands-DzGd8pnR.d.cts.map +1 -0
  12. package/dist/commands-DzGd8pnR.d.mts +5 -0
  13. package/dist/commands-DzGd8pnR.d.mts.map +1 -0
  14. package/dist/config-BnV_o0Es.d.cts +2461 -0
  15. package/dist/config-BnV_o0Es.d.cts.map +1 -0
  16. package/dist/config-DKeDSykZ.d.cts +138 -0
  17. package/dist/config-DKeDSykZ.d.cts.map +1 -0
  18. package/dist/config-DbOP5nVu.d.mts +138 -0
  19. package/dist/config-DbOP5nVu.d.mts.map +1 -0
  20. package/dist/config-DboKmDhl.d.mts +2461 -0
  21. package/dist/config-DboKmDhl.d.mts.map +1 -0
  22. package/dist/constants/api.cjs +0 -8
  23. package/dist/constants/api.d.cts +2 -6
  24. package/dist/constants/api.d.mts +2 -8
  25. package/dist/constants/api.mjs +0 -8
  26. package/dist/constants/api.mjs.map +1 -1
  27. package/dist/constants/commands.cjs +0 -8
  28. package/dist/constants/commands.d.cts +2 -5
  29. package/dist/constants/commands.d.mts +2 -7
  30. package/dist/constants/commands.mjs +0 -8
  31. package/dist/constants/commands.mjs.map +1 -1
  32. package/dist/constants/devtools.cjs +0 -8
  33. package/dist/constants/devtools.d.cts +2 -13
  34. package/dist/constants/devtools.d.mts +2 -15
  35. package/dist/constants/devtools.mjs +0 -8
  36. package/dist/constants/devtools.mjs.map +1 -1
  37. package/dist/constants/environments.cjs +0 -8
  38. package/dist/constants/environments.d.cts +2 -10
  39. package/dist/constants/environments.d.mts +2 -12
  40. package/dist/constants/environments.mjs +0 -8
  41. package/dist/constants/environments.mjs.map +1 -1
  42. package/dist/constants/extensions.cjs +0 -8
  43. package/dist/constants/extensions.d.cts +2 -5
  44. package/dist/constants/extensions.d.mts +2 -7
  45. package/dist/constants/extensions.mjs +0 -8
  46. package/dist/constants/extensions.mjs.map +1 -1
  47. package/dist/constants/fs.cjs +0 -8
  48. package/dist/constants/fs.d.cts +2 -7
  49. package/dist/constants/fs.d.mts +2 -9
  50. package/dist/constants/fs.mjs +0 -8
  51. package/dist/constants/fs.mjs.map +1 -1
  52. package/dist/constants/hooks.cjs +0 -8
  53. package/dist/constants/hooks.d.cts +2 -5
  54. package/dist/constants/hooks.d.mts +2 -7
  55. package/dist/constants/hooks.mjs +0 -8
  56. package/dist/constants/hooks.mjs.map +1 -1
  57. package/dist/constants/index.cjs +0 -8
  58. package/dist/constants/index.d.cts +10 -10
  59. package/dist/constants/index.d.mts +10 -12
  60. package/dist/constants/index.mjs +0 -8
  61. package/dist/constants/log-level.cjs +0 -8
  62. package/dist/constants/log-level.d.cts +2 -67
  63. package/dist/constants/log-level.d.mts +2 -69
  64. package/dist/constants/log-level.mjs +0 -8
  65. package/dist/constants/log-level.mjs.map +1 -1
  66. package/dist/constants/meta.cjs +0 -8
  67. package/dist/constants/meta.d.cts +2 -6
  68. package/dist/constants/meta.d.mts +2 -8
  69. package/dist/constants/meta.mjs +0 -8
  70. package/dist/constants/meta.mjs.map +1 -1
  71. package/dist/constants/plugin.cjs +0 -8
  72. package/dist/constants/plugin.d.cts +2 -9
  73. package/dist/constants/plugin.d.mts +2 -11
  74. package/dist/constants/plugin.mjs +0 -8
  75. package/dist/constants/plugin.mjs.map +1 -1
  76. package/dist/context/base-context.cjs +2 -10
  77. package/dist/context/base-context.d.cts +2 -81
  78. package/dist/context/base-context.d.mts +2 -83
  79. package/dist/context/base-context.mjs +0 -8
  80. package/dist/context/base-context.mjs.map +1 -1
  81. package/dist/context/context.cjs +2 -10
  82. package/dist/context/context.d.cts +2 -373
  83. package/dist/context/context.d.mts +2 -375
  84. package/dist/context/context.mjs +0 -8
  85. package/dist/context/context.mjs.map +1 -1
  86. package/dist/context/environment-context.cjs +0 -8
  87. package/dist/context/environment-context.d.cts +2 -5
  88. package/dist/context/environment-context.d.cts.map +1 -1
  89. package/dist/context/environment-context.d.mts +2 -7
  90. package/dist/context/environment-context.d.mts.map +1 -1
  91. package/dist/context/environment-context.mjs +0 -8
  92. package/dist/context/environment-context.mjs.map +1 -1
  93. package/dist/context/execution-context.cjs +2 -10
  94. package/dist/context/execution-context.d.cts +2 -6
  95. package/dist/context/execution-context.d.cts.map +1 -1
  96. package/dist/context/execution-context.d.mts +2 -8
  97. package/dist/context/execution-context.d.mts.map +1 -1
  98. package/dist/context/execution-context.mjs +0 -8
  99. package/dist/context/execution-context.mjs.map +1 -1
  100. package/dist/context/index.cjs +0 -8
  101. package/dist/context/index.d.cts +2 -2
  102. package/dist/context/index.d.mts +2 -4
  103. package/dist/context/index.mjs +0 -8
  104. package/dist/context/plugin-context.cjs +0 -8
  105. package/dist/context/plugin-context.d.cts +1 -3
  106. package/dist/context/plugin-context.d.cts.map +1 -1
  107. package/dist/context/plugin-context.d.mts +1 -5
  108. package/dist/context/plugin-context.d.mts.map +1 -1
  109. package/dist/context/plugin-context.mjs +0 -8
  110. package/dist/context/plugin-context.mjs.map +1 -1
  111. package/dist/context-C6oL3mPw.d.mts +368 -0
  112. package/dist/context-C6oL3mPw.d.mts.map +1 -0
  113. package/dist/context-DcY6YqBQ.d.cts +368 -0
  114. package/dist/context-DcY6YqBQ.d.cts.map +1 -0
  115. package/dist/context-helpers-BKxpDArS.d.mts +15 -0
  116. package/dist/context-helpers-BKxpDArS.d.mts.map +1 -0
  117. package/dist/context-helpers-zXovPE7i.d.cts +15 -0
  118. package/dist/context-helpers-zXovPE7i.d.cts.map +1 -0
  119. package/dist/devtools-h0du-bSj.d.cts +13 -0
  120. package/dist/devtools-h0du-bSj.d.cts.map +1 -0
  121. package/dist/devtools-h0du-bSj.d.mts +13 -0
  122. package/dist/devtools-h0du-bSj.d.mts.map +1 -0
  123. package/dist/entry-BC_V2K2U.d.cts +46 -0
  124. package/dist/entry-BC_V2K2U.d.cts.map +1 -0
  125. package/dist/entry-CHIaWcmk.d.mts +46 -0
  126. package/dist/entry-CHIaWcmk.d.mts.map +1 -0
  127. package/dist/environments-BYv_kHRG.d.cts +10 -0
  128. package/dist/environments-BYv_kHRG.d.cts.map +1 -0
  129. package/dist/environments-BYv_kHRG.d.mts +10 -0
  130. package/dist/environments-BYv_kHRG.d.mts.map +1 -0
  131. package/dist/events-NA1XM2Vz.d.cts +10 -0
  132. package/dist/events-NA1XM2Vz.d.cts.map +1 -0
  133. package/dist/events-NA1XM2Vz.d.mts +10 -0
  134. package/dist/events-NA1XM2Vz.d.mts.map +1 -0
  135. package/dist/extensions-ctxXzgay.d.cts +5 -0
  136. package/dist/extensions-ctxXzgay.d.cts.map +1 -0
  137. package/dist/extensions-ctxXzgay.d.mts +5 -0
  138. package/dist/extensions-ctxXzgay.d.mts.map +1 -0
  139. package/dist/file-header-Co9oo7aI.d.cts +41 -0
  140. package/dist/file-header-Co9oo7aI.d.cts.map +1 -0
  141. package/dist/file-header-rHqeXgRV.d.mts +41 -0
  142. package/dist/file-header-rHqeXgRV.d.mts.map +1 -0
  143. package/dist/format-Cf-cgZ-s.d.cts +24 -0
  144. package/dist/format-Cf-cgZ-s.d.cts.map +1 -0
  145. package/dist/format-IQPqgWIe.d.mts +24 -0
  146. package/dist/format-IQPqgWIe.d.mts.map +1 -0
  147. package/dist/fs-BzXT5ZPj.d.cts +7 -0
  148. package/dist/fs-BzXT5ZPj.d.cts.map +1 -0
  149. package/dist/fs-BzXT5ZPj.d.mts +7 -0
  150. package/dist/fs-BzXT5ZPj.d.mts.map +1 -0
  151. package/dist/{schemas/fs.cjs → fs-C2lru696.cjs} +38 -16
  152. package/dist/{schemas/fs.mjs → fs-DqLn15uU.mjs} +2 -10
  153. package/dist/fs-DqLn15uU.mjs.map +1 -0
  154. package/dist/generate-types-CDkVosrS.d.cts +65 -0
  155. package/dist/generate-types-CDkVosrS.d.cts.map +1 -0
  156. package/dist/generate-types-Dw6p3cB_.d.mts +65 -0
  157. package/dist/generate-types-Dw6p3cB_.d.mts.map +1 -0
  158. package/dist/helpers-CrRRFQl5.d.mts +22 -0
  159. package/dist/helpers-CrRRFQl5.d.mts.map +1 -0
  160. package/dist/helpers-DBLIQW3U.d.cts +22 -0
  161. package/dist/helpers-DBLIQW3U.d.cts.map +1 -0
  162. package/dist/hooks-Dhc3ahex.d.cts +5 -0
  163. package/dist/hooks-Dhc3ahex.d.cts.map +1 -0
  164. package/dist/hooks-Dhc3ahex.d.mts +5 -0
  165. package/dist/hooks-Dhc3ahex.d.mts.map +1 -0
  166. package/dist/index-BKZ67WMa.d.cts +1 -0
  167. package/dist/index-BKZ67WMa.d.mts +1 -0
  168. package/dist/index-BVVgDSdq.d.cts +1 -0
  169. package/dist/index-BVVgDSdq.d.mts +1 -0
  170. package/dist/index-Den-MsLx.d.cts +1 -0
  171. package/dist/index-Den-MsLx.d.mts +1 -0
  172. package/dist/index-DmtQKWjk.d.cts +1 -0
  173. package/dist/index-DmtQKWjk.d.mts +1 -0
  174. package/dist/index-LtpXjuJR.d.mts +25 -0
  175. package/dist/index-LtpXjuJR.d.mts.map +1 -0
  176. package/dist/index-_6s0AX1B.d.cts +1 -0
  177. package/dist/index-_6s0AX1B.d.mts +1 -0
  178. package/dist/index-xk4vSgtB.d.cts +25 -0
  179. package/dist/index-xk4vSgtB.d.cts.map +1 -0
  180. package/dist/index.cjs +1 -9
  181. package/dist/index.d.cts +24 -32
  182. package/dist/index.d.mts +24 -34
  183. package/dist/index.mjs +1 -9
  184. package/dist/install-dependencies-CCjZfS9Y.d.mts +12 -0
  185. package/dist/install-dependencies-CCjZfS9Y.d.mts.map +1 -0
  186. package/dist/install-dependencies-CyeYsrfz.d.cts +12 -0
  187. package/dist/install-dependencies-CyeYsrfz.d.cts.map +1 -0
  188. package/dist/lib/config.cjs +2 -10
  189. package/dist/lib/config.d.cts +2 -140
  190. package/dist/lib/config.d.mts +2 -142
  191. package/dist/lib/config.mjs +0 -8
  192. package/dist/lib/config.mjs.map +1 -1
  193. package/dist/lib/context-helpers.cjs +0 -8
  194. package/dist/lib/context-helpers.d.cts +2 -16
  195. package/dist/lib/context-helpers.d.mts +2 -18
  196. package/dist/lib/context-helpers.mjs +0 -8
  197. package/dist/lib/context-helpers.mjs.map +1 -1
  198. package/dist/lib/entry.cjs +0 -8
  199. package/dist/lib/entry.d.cts +2 -47
  200. package/dist/lib/entry.d.mts +2 -49
  201. package/dist/lib/entry.mjs +0 -8
  202. package/dist/lib/entry.mjs.map +1 -1
  203. package/dist/lib/environment.cjs +2 -10
  204. package/dist/lib/environment.d.cts +1 -2
  205. package/dist/lib/environment.d.cts.map +1 -1
  206. package/dist/lib/environment.d.mts +1 -4
  207. package/dist/lib/environment.d.mts.map +1 -1
  208. package/dist/lib/environment.mjs +0 -8
  209. package/dist/lib/environment.mjs.map +1 -1
  210. package/dist/lib/events.cjs +0 -8
  211. package/dist/lib/events.d.cts +2 -10
  212. package/dist/lib/events.d.mts +2 -12
  213. package/dist/lib/events.mjs +0 -8
  214. package/dist/lib/events.mjs.map +1 -1
  215. package/dist/lib/generate-types.cjs +0 -8
  216. package/dist/lib/generate-types.d.cts +2 -66
  217. package/dist/lib/generate-types.d.mts +2 -68
  218. package/dist/lib/generate-types.mjs +0 -8
  219. package/dist/lib/generate-types.mjs.map +1 -1
  220. package/dist/lib/hooks.cjs +2 -10
  221. package/dist/lib/hooks.d.cts +2 -28
  222. package/dist/lib/hooks.d.mts +2 -30
  223. package/dist/lib/hooks.mjs +0 -8
  224. package/dist/lib/hooks.mjs.map +1 -1
  225. package/dist/lib/index.cjs +1 -9
  226. package/dist/lib/index.d.cts +23 -23
  227. package/dist/lib/index.d.mts +23 -25
  228. package/dist/lib/index.mjs +1 -9
  229. package/dist/lib/install-dependencies.cjs +0 -8
  230. package/dist/lib/install-dependencies.d.cts +2 -12
  231. package/dist/lib/install-dependencies.d.mts +2 -14
  232. package/dist/lib/install-dependencies.mjs +0 -8
  233. package/dist/lib/install-dependencies.mjs.map +1 -1
  234. package/dist/lib/meta.cjs +0 -8
  235. package/dist/lib/meta.d.cts +2 -33
  236. package/dist/lib/meta.d.mts +2 -35
  237. package/dist/lib/meta.mjs +0 -8
  238. package/dist/lib/meta.mjs.map +1 -1
  239. package/dist/lib/plugins.cjs +2 -10
  240. package/dist/lib/plugins.d.cts +2 -39
  241. package/dist/lib/plugins.d.mts +2 -41
  242. package/dist/lib/plugins.mjs +0 -8
  243. package/dist/lib/plugins.mjs.map +1 -1
  244. package/dist/lib/resolver.cjs +2 -10
  245. package/dist/lib/resolver.d.cts +2 -20
  246. package/dist/lib/resolver.d.mts +2 -22
  247. package/dist/lib/resolver.mjs +0 -8
  248. package/dist/lib/resolver.mjs.map +1 -1
  249. package/dist/lib/schemas.cjs +1 -9
  250. package/dist/lib/schemas.d.cts +1 -1
  251. package/dist/lib/schemas.d.mts +1 -3
  252. package/dist/lib/schemas.mjs +1 -9
  253. package/dist/lib/streaming-channel.cjs +0 -8
  254. package/dist/lib/streaming-channel.d.cts +2 -126
  255. package/dist/lib/streaming-channel.d.mts +2 -128
  256. package/dist/lib/streaming-channel.mjs +0 -8
  257. package/dist/lib/streaming-channel.mjs.map +1 -1
  258. package/dist/lib/typescript/index.cjs +0 -8
  259. package/dist/lib/typescript/index.d.cts +2 -2
  260. package/dist/lib/typescript/index.d.mts +2 -4
  261. package/dist/lib/typescript/index.mjs +0 -8
  262. package/dist/lib/typescript/ts-morph.cjs +2 -10
  263. package/dist/lib/typescript/ts-morph.d.cts +2 -38
  264. package/dist/lib/typescript/ts-morph.d.mts +2 -40
  265. package/dist/lib/typescript/ts-morph.mjs +0 -8
  266. package/dist/lib/typescript/ts-morph.mjs.map +1 -1
  267. package/dist/lib/typescript/tsconfig.cjs +4 -12
  268. package/dist/lib/typescript/tsconfig.d.cts +2 -77
  269. package/dist/lib/typescript/tsconfig.d.mts +2 -79
  270. package/dist/lib/typescript/tsconfig.mjs +0 -8
  271. package/dist/lib/typescript/tsconfig.mjs.map +1 -1
  272. package/dist/lib/unplugin/helpers.cjs +0 -8
  273. package/dist/lib/unplugin/helpers.d.cts +2 -23
  274. package/dist/lib/unplugin/helpers.d.mts +2 -25
  275. package/dist/lib/unplugin/helpers.mjs +0 -8
  276. package/dist/lib/unplugin/helpers.mjs.map +1 -1
  277. package/dist/lib/unplugin/index.cjs +0 -8
  278. package/dist/lib/unplugin/index.d.cts +3 -3
  279. package/dist/lib/unplugin/index.d.mts +3 -5
  280. package/dist/lib/unplugin/index.mjs +0 -8
  281. package/dist/lib/unplugin/module-resolution.cjs +2 -10
  282. package/dist/lib/unplugin/module-resolution.d.cts +2 -41
  283. package/dist/lib/unplugin/module-resolution.d.mts +2 -43
  284. package/dist/lib/unplugin/module-resolution.mjs +0 -8
  285. package/dist/lib/unplugin/module-resolution.mjs.map +1 -1
  286. package/dist/lib/unplugin/plugin.cjs +0 -8
  287. package/dist/lib/unplugin/plugin.d.cts +2 -40
  288. package/dist/lib/unplugin/plugin.d.mts +2 -42
  289. package/dist/lib/unplugin/plugin.mjs +0 -8
  290. package/dist/lib/unplugin/plugin.mjs.map +1 -1
  291. package/dist/lib/utilities/file-header.cjs +0 -8
  292. package/dist/lib/utilities/file-header.d.cts +2 -41
  293. package/dist/lib/utilities/file-header.d.mts +2 -43
  294. package/dist/lib/utilities/file-header.mjs +0 -8
  295. package/dist/lib/utilities/file-header.mjs.map +1 -1
  296. package/dist/lib/utilities/format.cjs +2 -10
  297. package/dist/lib/utilities/format.d.cts +2 -24
  298. package/dist/lib/utilities/format.d.mts +2 -26
  299. package/dist/lib/utilities/format.mjs +0 -8
  300. package/dist/lib/utilities/format.mjs.map +1 -1
  301. package/dist/lib/utilities/index.cjs +0 -8
  302. package/dist/lib/utilities/index.d.cts +5 -5
  303. package/dist/lib/utilities/index.d.mts +5 -7
  304. package/dist/lib/utilities/index.mjs +0 -8
  305. package/dist/lib/utilities/source-file.cjs +2 -10
  306. package/dist/lib/utilities/source-file.d.cts +2 -30
  307. package/dist/lib/utilities/source-file.d.mts +2 -32
  308. package/dist/lib/utilities/source-file.mjs +0 -8
  309. package/dist/lib/utilities/source-file.mjs.map +1 -1
  310. package/dist/lib/utilities/source-map.cjs +2 -10
  311. package/dist/lib/utilities/source-map.d.cts +2 -16
  312. package/dist/lib/utilities/source-map.d.mts +2 -18
  313. package/dist/lib/utilities/source-map.mjs +0 -8
  314. package/dist/lib/utilities/source-map.mjs.map +1 -1
  315. package/dist/lib/utilities/write-file.cjs +0 -8
  316. package/dist/lib/utilities/write-file.d.cts +2 -15
  317. package/dist/lib/utilities/write-file.d.mts +2 -17
  318. package/dist/lib/utilities/write-file.mjs +0 -8
  319. package/dist/lib/utilities/write-file.mjs.map +1 -1
  320. package/dist/lib/vfs.cjs +3 -11
  321. package/dist/lib/vfs.d.cts +2 -321
  322. package/dist/lib/vfs.d.mts +2 -323
  323. package/dist/lib/vfs.mjs +1 -9
  324. package/dist/lib/vfs.mjs.map +1 -1
  325. package/dist/log-level-BC8g4BBL.d.cts +67 -0
  326. package/dist/log-level-BC8g4BBL.d.cts.map +1 -0
  327. package/dist/log-level-BC8g4BBL.d.mts +67 -0
  328. package/dist/log-level-BC8g4BBL.d.mts.map +1 -0
  329. package/dist/meta-CdDd2ykC.d.cts +33 -0
  330. package/dist/meta-CdDd2ykC.d.cts.map +1 -0
  331. package/dist/meta-CfTCHU_o.d.mts +33 -0
  332. package/dist/meta-CfTCHU_o.d.mts.map +1 -0
  333. package/dist/meta-QA_SN1j3.d.cts +6 -0
  334. package/dist/meta-QA_SN1j3.d.cts.map +1 -0
  335. package/dist/meta-QA_SN1j3.d.mts +6 -0
  336. package/dist/meta-QA_SN1j3.d.mts.map +1 -0
  337. package/dist/module-resolution-CRMNPsdn.d.mts +40 -0
  338. package/dist/module-resolution-CRMNPsdn.d.mts.map +1 -0
  339. package/dist/module-resolution-D-w-EZaK.d.cts +40 -0
  340. package/dist/module-resolution-D-w-EZaK.d.cts.map +1 -0
  341. package/dist/plugin-B_b7XqaN.d.mts +39 -0
  342. package/dist/plugin-B_b7XqaN.d.mts.map +1 -0
  343. package/dist/plugin-CzV-aFwU.d.cts +39 -0
  344. package/dist/plugin-CzV-aFwU.d.cts.map +1 -0
  345. package/dist/plugin-base.cjs +0 -8
  346. package/dist/plugin-base.d.cts +1 -3
  347. package/dist/plugin-base.d.cts.map +1 -1
  348. package/dist/plugin-base.d.mts +1 -5
  349. package/dist/plugin-base.d.mts.map +1 -1
  350. package/dist/plugin-base.mjs +0 -8
  351. package/dist/plugin-base.mjs.map +1 -1
  352. package/dist/plugin-fhBG7SSQ.d.cts +9 -0
  353. package/dist/plugin-fhBG7SSQ.d.cts.map +1 -0
  354. package/dist/plugin-fhBG7SSQ.d.mts +9 -0
  355. package/dist/plugin-fhBG7SSQ.d.mts.map +1 -0
  356. package/dist/plugin-utils/build-helpers.cjs +0 -8
  357. package/dist/plugin-utils/build-helpers.d.cts +1 -2
  358. package/dist/plugin-utils/build-helpers.d.cts.map +1 -1
  359. package/dist/plugin-utils/build-helpers.d.mts +1 -4
  360. package/dist/plugin-utils/build-helpers.d.mts.map +1 -1
  361. package/dist/plugin-utils/build-helpers.mjs +0 -8
  362. package/dist/plugin-utils/build-helpers.mjs.map +1 -1
  363. package/dist/plugin-utils/combine-plugins.cjs +0 -8
  364. package/dist/plugin-utils/combine-plugins.d.cts +1 -1
  365. package/dist/plugin-utils/combine-plugins.d.mts +1 -3
  366. package/dist/plugin-utils/combine-plugins.d.mts.map +1 -1
  367. package/dist/plugin-utils/combine-plugins.mjs +0 -8
  368. package/dist/plugin-utils/combine-plugins.mjs.map +1 -1
  369. package/dist/plugin-utils/context-helpers.cjs +0 -8
  370. package/dist/plugin-utils/context-helpers.d.cts +1 -1
  371. package/dist/plugin-utils/context-helpers.d.mts +1 -3
  372. package/dist/plugin-utils/context-helpers.d.mts.map +1 -1
  373. package/dist/plugin-utils/context-helpers.mjs +0 -8
  374. package/dist/plugin-utils/context-helpers.mjs.map +1 -1
  375. package/dist/plugin-utils/docs-helper.cjs +0 -8
  376. package/dist/plugin-utils/docs-helper.d.mts +0 -2
  377. package/dist/plugin-utils/docs-helper.d.mts.map +1 -1
  378. package/dist/plugin-utils/docs-helper.mjs +0 -8
  379. package/dist/plugin-utils/docs-helper.mjs.map +1 -1
  380. package/dist/plugin-utils/enable-plugin.cjs +0 -8
  381. package/dist/plugin-utils/enable-plugin.d.cts +1 -2
  382. package/dist/plugin-utils/enable-plugin.d.cts.map +1 -1
  383. package/dist/plugin-utils/enable-plugin.d.mts +1 -4
  384. package/dist/plugin-utils/enable-plugin.d.mts.map +1 -1
  385. package/dist/plugin-utils/enable-plugin.mjs +0 -8
  386. package/dist/plugin-utils/enable-plugin.mjs.map +1 -1
  387. package/dist/plugin-utils/extend.cjs +0 -8
  388. package/dist/plugin-utils/extend.d.cts +1 -3
  389. package/dist/plugin-utils/extend.d.cts.map +1 -1
  390. package/dist/plugin-utils/extend.d.mts +1 -5
  391. package/dist/plugin-utils/extend.d.mts.map +1 -1
  392. package/dist/plugin-utils/extend.mjs +0 -8
  393. package/dist/plugin-utils/extend.mjs.map +1 -1
  394. package/dist/plugin-utils/filter.cjs +2 -10
  395. package/dist/plugin-utils/filter.d.cts +1 -1
  396. package/dist/plugin-utils/filter.d.mts +1 -3
  397. package/dist/plugin-utils/filter.d.mts.map +1 -1
  398. package/dist/plugin-utils/filter.mjs +0 -8
  399. package/dist/plugin-utils/filter.mjs.map +1 -1
  400. package/dist/plugin-utils/format-package-json.cjs +0 -8
  401. package/dist/plugin-utils/format-package-json.d.cts +1 -1
  402. package/dist/plugin-utils/format-package-json.d.mts +1 -3
  403. package/dist/plugin-utils/format-package-json.d.mts.map +1 -1
  404. package/dist/plugin-utils/format-package-json.mjs +0 -8
  405. package/dist/plugin-utils/format-package-json.mjs.map +1 -1
  406. package/dist/plugin-utils/format.cjs +0 -8
  407. package/dist/plugin-utils/format.d.mts +0 -2
  408. package/dist/plugin-utils/format.d.mts.map +1 -1
  409. package/dist/plugin-utils/format.mjs +0 -8
  410. package/dist/plugin-utils/format.mjs.map +1 -1
  411. package/dist/plugin-utils/get-config-path.cjs +0 -8
  412. package/dist/plugin-utils/get-config-path.d.cts +1 -1
  413. package/dist/plugin-utils/get-config-path.d.mts +1 -3
  414. package/dist/plugin-utils/get-config-path.d.mts.map +1 -1
  415. package/dist/plugin-utils/get-config-path.mjs +0 -8
  416. package/dist/plugin-utils/get-config-path.mjs.map +1 -1
  417. package/dist/plugin-utils/helpers.cjs +0 -8
  418. package/dist/plugin-utils/helpers.d.cts +1 -5
  419. package/dist/plugin-utils/helpers.d.cts.map +1 -1
  420. package/dist/plugin-utils/helpers.d.mts +1 -7
  421. package/dist/plugin-utils/helpers.d.mts.map +1 -1
  422. package/dist/plugin-utils/helpers.mjs +0 -8
  423. package/dist/plugin-utils/helpers.mjs.map +1 -1
  424. package/dist/plugin-utils/index.cjs +0 -8
  425. package/dist/plugin-utils/index.d.mts +0 -2
  426. package/dist/plugin-utils/index.mjs +0 -8
  427. package/dist/plugin-utils/install.cjs +0 -8
  428. package/dist/plugin-utils/install.d.cts +1 -1
  429. package/dist/plugin-utils/install.d.mts +1 -3
  430. package/dist/plugin-utils/install.d.mts.map +1 -1
  431. package/dist/plugin-utils/install.mjs +0 -8
  432. package/dist/plugin-utils/install.mjs.map +1 -1
  433. package/dist/plugin-utils/logging.cjs +2 -10
  434. package/dist/plugin-utils/logging.d.cts +1 -3
  435. package/dist/plugin-utils/logging.d.cts.map +1 -1
  436. package/dist/plugin-utils/logging.d.mts +1 -5
  437. package/dist/plugin-utils/logging.d.mts.map +1 -1
  438. package/dist/plugin-utils/logging.mjs +0 -8
  439. package/dist/plugin-utils/logging.mjs.map +1 -1
  440. package/dist/plugin-utils/merge.cjs +2 -10
  441. package/dist/plugin-utils/merge.d.cts +1 -3
  442. package/dist/plugin-utils/merge.d.cts.map +1 -1
  443. package/dist/plugin-utils/merge.d.mts +1 -5
  444. package/dist/plugin-utils/merge.d.mts.map +1 -1
  445. package/dist/plugin-utils/merge.mjs +0 -8
  446. package/dist/plugin-utils/merge.mjs.map +1 -1
  447. package/dist/plugin-utils/modules.cjs +0 -8
  448. package/dist/plugin-utils/modules.d.cts +1 -1
  449. package/dist/plugin-utils/modules.d.mts +1 -3
  450. package/dist/plugin-utils/modules.d.mts.map +1 -1
  451. package/dist/plugin-utils/modules.mjs +0 -8
  452. package/dist/plugin-utils/modules.mjs.map +1 -1
  453. package/dist/plugin-utils/paths.cjs +0 -8
  454. package/dist/plugin-utils/paths.d.cts +1 -1
  455. package/dist/plugin-utils/paths.d.mts +1 -3
  456. package/dist/plugin-utils/paths.d.mts.map +1 -1
  457. package/dist/plugin-utils/paths.mjs +0 -8
  458. package/dist/plugin-utils/paths.mjs.map +1 -1
  459. package/dist/plugin-utils/virtual.cjs +0 -8
  460. package/dist/plugin-utils/virtual.d.mts +0 -2
  461. package/dist/plugin-utils/virtual.d.mts.map +1 -1
  462. package/dist/plugin-utils/virtual.mjs +0 -8
  463. package/dist/plugin-utils/virtual.mjs.map +1 -1
  464. package/dist/plugins-DfL1fBZi.d.cts +37 -0
  465. package/dist/plugins-DfL1fBZi.d.cts.map +1 -0
  466. package/dist/plugins-zG2X2LA8.d.mts +37 -0
  467. package/dist/plugins-zG2X2LA8.d.mts.map +1 -0
  468. package/dist/resolver-CdBAh8dA.d.mts +19 -0
  469. package/dist/resolver-CdBAh8dA.d.mts.map +1 -0
  470. package/dist/resolver-CfCl--Eh.d.cts +19 -0
  471. package/dist/resolver-CfCl--Eh.d.cts.map +1 -0
  472. package/dist/{schemas/fs.d.cts → schemas-Zvqwdrw_.d.cts} +2 -2
  473. package/dist/schemas-Zvqwdrw_.d.cts.map +1 -0
  474. package/dist/{schemas/fs.d.mts → schemas-Zvqwdrw_.d.mts} +2 -4
  475. package/dist/schemas-Zvqwdrw_.d.mts.map +1 -0
  476. package/dist/source-file-CLw13fKE.d.mts +30 -0
  477. package/dist/source-file-CLw13fKE.d.mts.map +1 -0
  478. package/dist/source-file-CuuHaBL5.d.cts +30 -0
  479. package/dist/source-file-CuuHaBL5.d.cts.map +1 -0
  480. package/dist/source-map-Cy0aqSpe.d.mts +16 -0
  481. package/dist/source-map-Cy0aqSpe.d.mts.map +1 -0
  482. package/dist/source-map-HU4IoICc.d.cts +16 -0
  483. package/dist/source-map-HU4IoICc.d.cts.map +1 -0
  484. package/dist/storage/base.cjs +0 -8
  485. package/dist/storage/base.d.cts +1 -2
  486. package/dist/storage/base.d.cts.map +1 -1
  487. package/dist/storage/base.d.mts +1 -4
  488. package/dist/storage/base.d.mts.map +1 -1
  489. package/dist/storage/base.mjs +0 -8
  490. package/dist/storage/base.mjs.map +1 -1
  491. package/dist/storage/file-system.cjs +0 -8
  492. package/dist/storage/file-system.d.cts +1 -1
  493. package/dist/storage/file-system.d.mts +1 -3
  494. package/dist/storage/file-system.d.mts.map +1 -1
  495. package/dist/storage/file-system.mjs +0 -8
  496. package/dist/storage/file-system.mjs.map +1 -1
  497. package/dist/storage/helpers.cjs +0 -8
  498. package/dist/storage/helpers.d.mts +0 -2
  499. package/dist/storage/helpers.d.mts.map +1 -1
  500. package/dist/storage/helpers.mjs +0 -8
  501. package/dist/storage/helpers.mjs.map +1 -1
  502. package/dist/storage/index.cjs +0 -8
  503. package/dist/storage/index.d.mts +0 -2
  504. package/dist/storage/index.mjs +0 -8
  505. package/dist/storage/virtual.cjs +0 -8
  506. package/dist/storage/virtual.d.cts +1 -1
  507. package/dist/storage/virtual.d.cts.map +1 -1
  508. package/dist/storage/virtual.d.mts +1 -3
  509. package/dist/storage/virtual.d.mts.map +1 -1
  510. package/dist/storage/virtual.mjs +0 -8
  511. package/dist/storage/virtual.mjs.map +1 -1
  512. package/dist/streaming-channel-CiyFd_6l.d.cts +126 -0
  513. package/dist/streaming-channel-CiyFd_6l.d.cts.map +1 -0
  514. package/dist/streaming-channel-CiyFd_6l.d.mts +126 -0
  515. package/dist/streaming-channel-CiyFd_6l.d.mts.map +1 -0
  516. package/dist/ts-morph-BGgjbOgM.d.cts +38 -0
  517. package/dist/ts-morph-BGgjbOgM.d.cts.map +1 -0
  518. package/dist/ts-morph-zLvdifpA.d.mts +38 -0
  519. package/dist/ts-morph-zLvdifpA.d.mts.map +1 -0
  520. package/dist/tsconfig-DExoZEQ0.d.cts +75 -0
  521. package/dist/tsconfig-DExoZEQ0.d.cts.map +1 -0
  522. package/dist/tsconfig-De09cBeX.d.mts +75 -0
  523. package/dist/tsconfig-De09cBeX.d.mts.map +1 -0
  524. package/dist/vfs-B9Vhnajc.d.cts +320 -0
  525. package/dist/vfs-B9Vhnajc.d.cts.map +1 -0
  526. package/dist/vfs-Dl6nPqdS.d.mts +320 -0
  527. package/dist/vfs-Dl6nPqdS.d.mts.map +1 -0
  528. package/dist/write-file-BVMnXVPo.d.cts +15 -0
  529. package/dist/write-file-BVMnXVPo.d.cts.map +1 -0
  530. package/dist/write-file-CWf9Xxwd.d.mts +15 -0
  531. package/dist/write-file-CWf9Xxwd.d.mts.map +1 -0
  532. package/package.json +17 -17
  533. package/dist/constants/api.d.cts.map +0 -1
  534. package/dist/constants/api.d.mts.map +0 -1
  535. package/dist/constants/commands.d.cts.map +0 -1
  536. package/dist/constants/commands.d.mts.map +0 -1
  537. package/dist/constants/devtools.d.cts.map +0 -1
  538. package/dist/constants/devtools.d.mts.map +0 -1
  539. package/dist/constants/environments.d.cts.map +0 -1
  540. package/dist/constants/environments.d.mts.map +0 -1
  541. package/dist/constants/extensions.d.cts.map +0 -1
  542. package/dist/constants/extensions.d.mts.map +0 -1
  543. package/dist/constants/fs.d.cts.map +0 -1
  544. package/dist/constants/fs.d.mts.map +0 -1
  545. package/dist/constants/hooks.d.cts.map +0 -1
  546. package/dist/constants/hooks.d.mts.map +0 -1
  547. package/dist/constants/log-level.d.cts.map +0 -1
  548. package/dist/constants/log-level.d.mts.map +0 -1
  549. package/dist/constants/meta.d.cts.map +0 -1
  550. package/dist/constants/meta.d.mts.map +0 -1
  551. package/dist/constants/plugin.d.cts.map +0 -1
  552. package/dist/constants/plugin.d.mts.map +0 -1
  553. package/dist/context/base-context.d.cts.map +0 -1
  554. package/dist/context/base-context.d.mts.map +0 -1
  555. package/dist/context/context.d.cts.map +0 -1
  556. package/dist/context/context.d.mts.map +0 -1
  557. package/dist/lib/config.d.cts.map +0 -1
  558. package/dist/lib/config.d.mts.map +0 -1
  559. package/dist/lib/context-helpers.d.cts.map +0 -1
  560. package/dist/lib/context-helpers.d.mts.map +0 -1
  561. package/dist/lib/entry.d.cts.map +0 -1
  562. package/dist/lib/entry.d.mts.map +0 -1
  563. package/dist/lib/events.d.cts.map +0 -1
  564. package/dist/lib/events.d.mts.map +0 -1
  565. package/dist/lib/generate-types.d.cts.map +0 -1
  566. package/dist/lib/generate-types.d.mts.map +0 -1
  567. package/dist/lib/hooks.d.cts.map +0 -1
  568. package/dist/lib/hooks.d.mts.map +0 -1
  569. package/dist/lib/install-dependencies.d.cts.map +0 -1
  570. package/dist/lib/install-dependencies.d.mts.map +0 -1
  571. package/dist/lib/meta.d.cts.map +0 -1
  572. package/dist/lib/meta.d.mts.map +0 -1
  573. package/dist/lib/plugins.d.cts.map +0 -1
  574. package/dist/lib/plugins.d.mts.map +0 -1
  575. package/dist/lib/resolver.d.cts.map +0 -1
  576. package/dist/lib/resolver.d.mts.map +0 -1
  577. package/dist/lib/streaming-channel.d.cts.map +0 -1
  578. package/dist/lib/streaming-channel.d.mts.map +0 -1
  579. package/dist/lib/typescript/ts-morph.d.cts.map +0 -1
  580. package/dist/lib/typescript/ts-morph.d.mts.map +0 -1
  581. package/dist/lib/typescript/tsconfig.d.cts.map +0 -1
  582. package/dist/lib/typescript/tsconfig.d.mts.map +0 -1
  583. package/dist/lib/unplugin/helpers.d.cts.map +0 -1
  584. package/dist/lib/unplugin/helpers.d.mts.map +0 -1
  585. package/dist/lib/unplugin/module-resolution.d.cts.map +0 -1
  586. package/dist/lib/unplugin/module-resolution.d.mts.map +0 -1
  587. package/dist/lib/unplugin/plugin.d.cts.map +0 -1
  588. package/dist/lib/unplugin/plugin.d.mts.map +0 -1
  589. package/dist/lib/utilities/file-header.d.cts.map +0 -1
  590. package/dist/lib/utilities/file-header.d.mts.map +0 -1
  591. package/dist/lib/utilities/format.d.cts.map +0 -1
  592. package/dist/lib/utilities/format.d.mts.map +0 -1
  593. package/dist/lib/utilities/source-file.d.cts.map +0 -1
  594. package/dist/lib/utilities/source-file.d.mts.map +0 -1
  595. package/dist/lib/utilities/source-map.d.cts.map +0 -1
  596. package/dist/lib/utilities/source-map.d.mts.map +0 -1
  597. package/dist/lib/utilities/write-file.d.cts.map +0 -1
  598. package/dist/lib/utilities/write-file.d.mts.map +0 -1
  599. package/dist/lib/vfs.d.cts.map +0 -1
  600. package/dist/lib/vfs.d.mts.map +0 -1
  601. package/dist/schemas/fs.d.cts.map +0 -1
  602. package/dist/schemas/fs.d.mts.map +0 -1
  603. package/dist/schemas/fs.mjs.map +0 -1
  604. package/dist/types/api.d.cts +0 -16
  605. package/dist/types/api.d.cts.map +0 -1
  606. package/dist/types/api.d.mts +0 -18
  607. package/dist/types/api.d.mts.map +0 -1
  608. package/dist/types/config.d.cts +0 -739
  609. package/dist/types/config.d.cts.map +0 -1
  610. package/dist/types/config.d.mts +0 -741
  611. package/dist/types/config.d.mts.map +0 -1
  612. package/dist/types/context.d.cts +0 -682
  613. package/dist/types/context.d.cts.map +0 -1
  614. package/dist/types/context.d.mts +0 -684
  615. package/dist/types/context.d.mts.map +0 -1
  616. package/dist/types/fs.d.cts +0 -538
  617. package/dist/types/fs.d.cts.map +0 -1
  618. package/dist/types/fs.d.mts +0 -540
  619. package/dist/types/fs.d.mts.map +0 -1
  620. package/dist/types/hooks.d.cts +0 -96
  621. package/dist/types/hooks.d.cts.map +0 -1
  622. package/dist/types/hooks.d.mts +0 -98
  623. package/dist/types/hooks.d.mts.map +0 -1
  624. package/dist/types/index.d.cts +0 -9
  625. package/dist/types/index.d.mts +0 -11
  626. package/dist/types/logging.d.cts +0 -145
  627. package/dist/types/logging.d.cts.map +0 -1
  628. package/dist/types/logging.d.mts +0 -147
  629. package/dist/types/logging.d.mts.map +0 -1
  630. package/dist/types/plugin.d.cts +0 -207
  631. package/dist/types/plugin.d.cts.map +0 -1
  632. package/dist/types/plugin.d.mts +0 -209
  633. package/dist/types/plugin.d.mts.map +0 -1
  634. package/dist/types/tsconfig.d.cts +0 -73
  635. package/dist/types/tsconfig.d.cts.map +0 -1
  636. package/dist/types/tsconfig.d.mts +0 -75
  637. package/dist/types/tsconfig.d.mts.map +0 -1
  638. package/dist/types/unplugin.d.cts +0 -22
  639. package/dist/types/unplugin.d.cts.map +0 -1
  640. package/dist/types/unplugin.d.mts +0 -24
  641. package/dist/types/unplugin.d.mts.map +0 -1
@@ -1,126 +1,2 @@
1
- import { EventEmitter } from "devframe/types";
2
-
3
- //#region src/lib/streaming-channel.d.ts
4
- /**
5
- * Serialized error shape sent over the wire when a stream ends with a failure.
6
- * Stays JSON-safe so the strict-JSON encoder can carry it without coercion.
7
- */
8
- interface StreamErrorPayload {
9
- name: string;
10
- message: string;
11
- }
12
- /**
13
- * Single buffered chunk in the server-side ring buffer.
14
- *
15
- * Sequence numbers start at 1 and increment per write. Subscribers track
16
- * `lastSeenSeq` and ask for `afterSeq` on resubscribe so the server can
17
- * replay any chunks the client missed during a brief disconnect.
18
- */
19
- interface BufferedChunk<T> {
20
- seq: number;
21
- chunk: T;
22
- }
23
- interface StreamSinkEvents<T> {
24
- /** Fired for each `write()`. The RPC layer subscribes and broadcasts. */
25
- chunk: (seq: number, chunk: T) => void;
26
- /** Terminal — fired exactly once per sink lifetime. */
27
- end: (error?: StreamErrorPayload) => void;
28
- }
29
- interface CreateStreamSinkOptions {
30
- id?: string;
31
- /**
32
- * Size of the per-stream ring buffer kept for replay-on-resubscribe.
33
- * `0` (default) disables replay.
34
- */
35
- replayWindow?: number;
36
- }
37
- /**
38
- * Server-side producer handle. Two equivalent surfaces share one piece of
39
- * state: the imperative `write/error/close` triple, and a `WritableStream<T>`
40
- * for `pipeTo`-style consumption.
41
- */
42
- interface StreamSink<T> {
43
- /** Stable id used by clients to subscribe. */
44
- readonly id: string;
45
- /**
46
- * Aborts when the consumer cancels (server-side) or when the transport
47
- * loses every subscriber. Producers should poll `signal.aborted` and exit
48
- * cleanly.
49
- */
50
- readonly signal: AbortSignal;
51
- /** `true` after `close()` / `error()`. Further writes throw. */
52
- readonly closed: boolean;
53
- /** Last allocated sequence number. `0` until the first write. */
54
- readonly lastSeq: number;
55
- write: (chunk: T) => void;
56
- error: (reason: unknown) => void;
57
- close: () => void;
58
- /** External-cancel path. Aborts the signal so handlers can short-circuit. */
59
- abort: (reason?: unknown) => void;
60
- /** `WritableStream<T>` adapter — same in-memory state as the imperative API. */
61
- readonly writable: WritableStream<T>;
62
- /**
63
- * Internal — RPC layer subscribes to receive chunk/end notifications.
64
- * Not part of the public contract; do not call directly.
65
- *
66
- * @internal
67
- */
68
- readonly events: EventEmitter<StreamSinkEvents<T>>;
69
- /**
70
- * Internal — replay buffer. RPC layer reads on (re)subscribe to feed
71
- * missed chunks before going live.
72
- *
73
- * @internal
74
- */
75
- readonly buffer: ReadonlyArray<BufferedChunk<T>>;
76
- }
77
- interface CreateStreamReaderOptions {
78
- id?: string;
79
- /**
80
- * Maximum number of buffered chunks held client-side while the consumer
81
- * isn't draining. On overflow, the oldest chunk is dropped.
82
- */
83
- highWaterMark?: number;
84
- /**
85
- * Called when the chunk queue overflows the high-water mark. The RPC
86
- * layer wires this to a coded warning; the primitive itself is
87
- * RPC-agnostic.
88
- */
89
- onOverflow?: (dropped: number) => void;
90
- /** Called when the consumer cancels — the RPC layer sends `:cancel` upstream. */
91
- onCancel?: () => void;
92
- }
93
- /**
94
- * Client-side consumer handle. Both an `AsyncIterable<T>` (for `for await`)
95
- * and exposes `readable: ReadableStream<T>` (for `pipeTo`). Pick one — they
96
- * share a single internal queue, so concurrent draining will race.
97
- */
98
- interface StreamReader<T> extends AsyncIterable<T> {
99
- readonly id: string;
100
- readonly cancelled: boolean;
101
- readonly done: boolean;
102
- /** Highest `seq` observed. Used for replay on reconnect. */
103
- readonly lastSeenSeq: number;
104
- /** `ReadableStream<T>` adapter for `pipeTo`-style consumption. */
105
- readonly readable: ReadableStream<T>;
106
- cancel: () => void;
107
- /** @internal */
108
- _push: (seq: number, chunk: T) => void;
109
- /** @internal */
110
- _end: (error?: StreamErrorPayload) => void;
111
- }
112
- /**
113
- * Build a server-side stream sink. RPC-agnostic — the RPC host wires
114
- * `events.on('chunk' | 'end')` to broadcast, and reads `buffer` to replay
115
- * for late or reconnecting subscribers.
116
- */
117
- declare function createStreamSink<T>(options?: CreateStreamSinkOptions): StreamSink<T>;
118
- /**
119
- * Build a client-side stream reader. RPC-agnostic — the RPC host calls
120
- * `_push(seq, chunk)` on each incoming chunk and `_end(error?)` on the
121
- * terminal frame. Consumers iterate with `for await` or pipe `readable`.
122
- */
123
- declare function createStreamReader<T>(options?: CreateStreamReaderOptions): StreamReader<T>;
124
- //#endregion
125
- export { BufferedChunk, CreateStreamReaderOptions, CreateStreamSinkOptions, StreamErrorPayload, StreamReader, StreamSink, StreamSinkEvents, createStreamReader, createStreamSink };
126
- //# sourceMappingURL=streaming-channel.d.cts.map
1
+ import { a as StreamReader, c as createStreamReader, i as StreamErrorPayload, l as createStreamSink, n as CreateStreamReaderOptions, o as StreamSink, r as CreateStreamSinkOptions, s as StreamSinkEvents, t as BufferedChunk } from "../streaming-channel-CiyFd_6l.cjs";
2
+ export { BufferedChunk, CreateStreamReaderOptions, CreateStreamSinkOptions, StreamErrorPayload, StreamReader, StreamSink, StreamSinkEvents, createStreamReader, createStreamSink };
@@ -1,128 +1,2 @@
1
- import __tsdown_shims_path from 'node:path';
2
- import __tsdown_shims_url from 'node:url';
3
- import { EventEmitter } from "devframe/types";
4
-
5
- //#region src/lib/streaming-channel.d.ts
6
- /**
7
- * Serialized error shape sent over the wire when a stream ends with a failure.
8
- * Stays JSON-safe so the strict-JSON encoder can carry it without coercion.
9
- */
10
- interface StreamErrorPayload {
11
- name: string;
12
- message: string;
13
- }
14
- /**
15
- * Single buffered chunk in the server-side ring buffer.
16
- *
17
- * Sequence numbers start at 1 and increment per write. Subscribers track
18
- * `lastSeenSeq` and ask for `afterSeq` on resubscribe so the server can
19
- * replay any chunks the client missed during a brief disconnect.
20
- */
21
- interface BufferedChunk<T> {
22
- seq: number;
23
- chunk: T;
24
- }
25
- interface StreamSinkEvents<T> {
26
- /** Fired for each `write()`. The RPC layer subscribes and broadcasts. */
27
- chunk: (seq: number, chunk: T) => void;
28
- /** Terminal — fired exactly once per sink lifetime. */
29
- end: (error?: StreamErrorPayload) => void;
30
- }
31
- interface CreateStreamSinkOptions {
32
- id?: string;
33
- /**
34
- * Size of the per-stream ring buffer kept for replay-on-resubscribe.
35
- * `0` (default) disables replay.
36
- */
37
- replayWindow?: number;
38
- }
39
- /**
40
- * Server-side producer handle. Two equivalent surfaces share one piece of
41
- * state: the imperative `write/error/close` triple, and a `WritableStream<T>`
42
- * for `pipeTo`-style consumption.
43
- */
44
- interface StreamSink<T> {
45
- /** Stable id used by clients to subscribe. */
46
- readonly id: string;
47
- /**
48
- * Aborts when the consumer cancels (server-side) or when the transport
49
- * loses every subscriber. Producers should poll `signal.aborted` and exit
50
- * cleanly.
51
- */
52
- readonly signal: AbortSignal;
53
- /** `true` after `close()` / `error()`. Further writes throw. */
54
- readonly closed: boolean;
55
- /** Last allocated sequence number. `0` until the first write. */
56
- readonly lastSeq: number;
57
- write: (chunk: T) => void;
58
- error: (reason: unknown) => void;
59
- close: () => void;
60
- /** External-cancel path. Aborts the signal so handlers can short-circuit. */
61
- abort: (reason?: unknown) => void;
62
- /** `WritableStream<T>` adapter — same in-memory state as the imperative API. */
63
- readonly writable: WritableStream<T>;
64
- /**
65
- * Internal — RPC layer subscribes to receive chunk/end notifications.
66
- * Not part of the public contract; do not call directly.
67
- *
68
- * @internal
69
- */
70
- readonly events: EventEmitter<StreamSinkEvents<T>>;
71
- /**
72
- * Internal — replay buffer. RPC layer reads on (re)subscribe to feed
73
- * missed chunks before going live.
74
- *
75
- * @internal
76
- */
77
- readonly buffer: ReadonlyArray<BufferedChunk<T>>;
78
- }
79
- interface CreateStreamReaderOptions {
80
- id?: string;
81
- /**
82
- * Maximum number of buffered chunks held client-side while the consumer
83
- * isn't draining. On overflow, the oldest chunk is dropped.
84
- */
85
- highWaterMark?: number;
86
- /**
87
- * Called when the chunk queue overflows the high-water mark. The RPC
88
- * layer wires this to a coded warning; the primitive itself is
89
- * RPC-agnostic.
90
- */
91
- onOverflow?: (dropped: number) => void;
92
- /** Called when the consumer cancels — the RPC layer sends `:cancel` upstream. */
93
- onCancel?: () => void;
94
- }
95
- /**
96
- * Client-side consumer handle. Both an `AsyncIterable<T>` (for `for await`)
97
- * and exposes `readable: ReadableStream<T>` (for `pipeTo`). Pick one — they
98
- * share a single internal queue, so concurrent draining will race.
99
- */
100
- interface StreamReader<T> extends AsyncIterable<T> {
101
- readonly id: string;
102
- readonly cancelled: boolean;
103
- readonly done: boolean;
104
- /** Highest `seq` observed. Used for replay on reconnect. */
105
- readonly lastSeenSeq: number;
106
- /** `ReadableStream<T>` adapter for `pipeTo`-style consumption. */
107
- readonly readable: ReadableStream<T>;
108
- cancel: () => void;
109
- /** @internal */
110
- _push: (seq: number, chunk: T) => void;
111
- /** @internal */
112
- _end: (error?: StreamErrorPayload) => void;
113
- }
114
- /**
115
- * Build a server-side stream sink. RPC-agnostic — the RPC host wires
116
- * `events.on('chunk' | 'end')` to broadcast, and reads `buffer` to replay
117
- * for late or reconnecting subscribers.
118
- */
119
- declare function createStreamSink<T>(options?: CreateStreamSinkOptions): StreamSink<T>;
120
- /**
121
- * Build a client-side stream reader. RPC-agnostic — the RPC host calls
122
- * `_push(seq, chunk)` on each incoming chunk and `_end(error?)` on the
123
- * terminal frame. Consumers iterate with `for await` or pipe `readable`.
124
- */
125
- declare function createStreamReader<T>(options?: CreateStreamReaderOptions): StreamReader<T>;
126
- //#endregion
127
- export { BufferedChunk, CreateStreamReaderOptions, CreateStreamSinkOptions, StreamErrorPayload, StreamReader, StreamSink, StreamSinkEvents, createStreamReader, createStreamSink };
128
- //# sourceMappingURL=streaming-channel.d.mts.map
1
+ import { a as StreamReader, c as createStreamReader, i as StreamErrorPayload, l as createStreamSink, n as CreateStreamReaderOptions, o as StreamSink, r as CreateStreamSinkOptions, s as StreamSinkEvents, t as BufferedChunk } from "../streaming-channel-CiyFd_6l.mjs";
2
+ export { BufferedChunk, CreateStreamReaderOptions, CreateStreamSinkOptions, StreamErrorPayload, StreamReader, StreamSink, StreamSinkEvents, createStreamReader, createStreamSink };
@@ -1,11 +1,3 @@
1
-
2
-
3
- import __tsdown_shims_path from 'node:path'
4
- import __tsdown_shims_url from 'node:url'
5
-
6
- const __TSDOWN_SHIM_FILENAME__ = /* @__PURE__ */ __tsdown_shims_url.fileURLToPath(import.meta.url)
7
- const __TSDOWN_SHIM_DIRNAME__ = /* @__PURE__ */ __tsdown_shims_path.dirname(__TSDOWN_SHIM_FILENAME__)
8
-
9
1
  import { createEventEmitter } from "./events.mjs";
10
2
  import { nanoid } from "@stryke/unique-id/nanoid-client";
11
3
 
@@ -1 +1 @@
1
- {"version":3,"file":"streaming-channel.mjs","names":[],"sources":["../../src/lib/streaming-channel.ts"],"sourcesContent":["/* -------------------------------------------------------------------\n\n ⚡ Storm Software - Powerlines\n\n This code was released as part of the Powerlines project. Powerlines\n is maintained by Storm Software under the Apache-2.0 license, and is\n free for commercial and private use. For more information, please visit\n our licensing page at https://stormsoftware.com/licenses/projects/powerlines.\n\n Website: https://stormsoftware.com\n Repository: https://github.com/storm-software/powerlines\n Documentation: https://docs.stormsoftware.com/projects/powerlines\n Contact: https://stormsoftware.com/contact\n\n SPDX-License-Identifier: Apache-2.0\n\n ------------------------------------------------------------------- */\n\nimport { nanoid } from \"@stryke/unique-id/nanoid-client\";\nimport type { EventEmitter } from \"devframe/types\";\nimport { createEventEmitter } from \"./events\";\n\n/**\n * Serialized error shape sent over the wire when a stream ends with a failure.\n * Stays JSON-safe so the strict-JSON encoder can carry it without coercion.\n */\nexport interface StreamErrorPayload {\n name: string;\n message: string;\n}\n\n/**\n * Single buffered chunk in the server-side ring buffer.\n *\n * Sequence numbers start at 1 and increment per write. Subscribers track\n * `lastSeenSeq` and ask for `afterSeq` on resubscribe so the server can\n * replay any chunks the client missed during a brief disconnect.\n */\nexport interface BufferedChunk<T> {\n seq: number;\n chunk: T;\n}\n\nexport interface StreamSinkEvents<T> {\n /** Fired for each `write()`. The RPC layer subscribes and broadcasts. */\n chunk: (seq: number, chunk: T) => void;\n /** Terminal — fired exactly once per sink lifetime. */\n end: (error?: StreamErrorPayload) => void;\n}\n\nexport interface CreateStreamSinkOptions {\n id?: string;\n /**\n * Size of the per-stream ring buffer kept for replay-on-resubscribe.\n * `0` (default) disables replay.\n */\n replayWindow?: number;\n}\n\n/**\n * Server-side producer handle. Two equivalent surfaces share one piece of\n * state: the imperative `write/error/close` triple, and a `WritableStream<T>`\n * for `pipeTo`-style consumption.\n */\nexport interface StreamSink<T> {\n /** Stable id used by clients to subscribe. */\n readonly id: string;\n /**\n * Aborts when the consumer cancels (server-side) or when the transport\n * loses every subscriber. Producers should poll `signal.aborted` and exit\n * cleanly.\n */\n readonly signal: AbortSignal;\n /** `true` after `close()` / `error()`. Further writes throw. */\n readonly closed: boolean;\n /** Last allocated sequence number. `0` until the first write. */\n readonly lastSeq: number;\n\n write: (chunk: T) => void;\n error: (reason: unknown) => void;\n close: () => void;\n /** External-cancel path. Aborts the signal so handlers can short-circuit. */\n abort: (reason?: unknown) => void;\n\n /** `WritableStream<T>` adapter — same in-memory state as the imperative API. */\n readonly writable: WritableStream<T>;\n\n /**\n * Internal — RPC layer subscribes to receive chunk/end notifications.\n * Not part of the public contract; do not call directly.\n *\n * @internal\n */\n readonly events: EventEmitter<StreamSinkEvents<T>>;\n\n /**\n * Internal — replay buffer. RPC layer reads on (re)subscribe to feed\n * missed chunks before going live.\n *\n * @internal\n */\n readonly buffer: ReadonlyArray<BufferedChunk<T>>;\n}\n\nexport interface CreateStreamReaderOptions {\n id?: string;\n /**\n * Maximum number of buffered chunks held client-side while the consumer\n * isn't draining. On overflow, the oldest chunk is dropped.\n */\n highWaterMark?: number;\n /**\n * Called when the chunk queue overflows the high-water mark. The RPC\n * layer wires this to a coded warning; the primitive itself is\n * RPC-agnostic.\n */\n onOverflow?: (dropped: number) => void;\n /** Called when the consumer cancels — the RPC layer sends `:cancel` upstream. */\n onCancel?: () => void;\n}\n\n/**\n * Client-side consumer handle. Both an `AsyncIterable<T>` (for `for await`)\n * and exposes `readable: ReadableStream<T>` (for `pipeTo`). Pick one — they\n * share a single internal queue, so concurrent draining will race.\n */\nexport interface StreamReader<T> extends AsyncIterable<T> {\n readonly id: string;\n readonly cancelled: boolean;\n readonly done: boolean;\n /** Highest `seq` observed. Used for replay on reconnect. */\n readonly lastSeenSeq: number;\n /** `ReadableStream<T>` adapter for `pipeTo`-style consumption. */\n readonly readable: ReadableStream<T>;\n\n cancel: () => void;\n\n /** @internal */\n _push: (seq: number, chunk: T) => void;\n /** @internal */\n _end: (error?: StreamErrorPayload) => void;\n}\n\nconst DEFAULT_HIGH_WATER_MARK = 256;\n\nclass StreamClosedError extends Error {\n override name = \"StreamClosedError\";\n}\n\n/**\n * Build a server-side stream sink. RPC-agnostic — the RPC host wires\n * `events.on('chunk' | 'end')` to broadcast, and reads `buffer` to replay\n * for late or reconnecting subscribers.\n */\nexport function createStreamSink<T>(\n options: CreateStreamSinkOptions = {}\n): StreamSink<T> {\n const id = options.id ?? nanoid();\n const replayWindow = Math.max(0, options.replayWindow ?? 0);\n const events = createEventEmitter<StreamSinkEvents<T>>();\n const controller = new AbortController();\n const buffer: BufferedChunk<T>[] = [];\n\n let closed = false;\n let lastSeq = 0;\n\n function write(chunk: T): void {\n if (closed) {\n throw new StreamClosedError(`Cannot write to a closed stream \"${id}\"`);\n }\n lastSeq += 1;\n if (replayWindow > 0) {\n buffer.push({ seq: lastSeq, chunk });\n if (buffer.length > replayWindow)\n buffer.splice(0, buffer.length - replayWindow);\n }\n events.emit(\"chunk\", lastSeq, chunk);\n }\n\n function error(reason: unknown): void {\n if (closed) return;\n closed = true;\n const payload = toErrorPayload(reason);\n controller.abort(reason);\n events.emit(\"end\", payload);\n }\n\n function close(): void {\n if (closed) return;\n closed = true;\n if (!controller.signal.aborted) controller.abort(\"stream closed\");\n events.emit(\"end\", undefined);\n }\n\n function abort(reason?: unknown): void {\n if (closed) return;\n if (!controller.signal.aborted) controller.abort(reason ?? \"aborted\");\n }\n\n const writable = new WritableStream<T>({\n write(chunk) {\n write(chunk);\n },\n close() {\n close();\n },\n abort(reason) {\n error(reason);\n }\n });\n\n return {\n id,\n signal: controller.signal,\n get closed() {\n return closed;\n },\n get lastSeq() {\n return lastSeq;\n },\n write,\n error,\n close,\n abort,\n writable,\n events,\n buffer\n };\n}\n\n/**\n * Build a client-side stream reader. RPC-agnostic — the RPC host calls\n * `_push(seq, chunk)` on each incoming chunk and `_end(error?)` on the\n * terminal frame. Consumers iterate with `for await` or pipe `readable`.\n */\nexport function createStreamReader<T>(\n options: CreateStreamReaderOptions = {}\n): StreamReader<T> {\n const id = options.id ?? nanoid();\n const highWaterMark = Math.max(\n 1,\n options.highWaterMark ?? DEFAULT_HIGH_WATER_MARK\n );\n\n const queue: T[] = [];\n let lastSeenSeq = 0;\n let done = false;\n let cancelled = false;\n let endError: StreamErrorPayload | undefined;\n let pending:\n | {\n resolve: (r: IteratorResult<T>) => void;\n reject: (err: unknown) => void;\n }\n | undefined;\n // Lazily created — accessing `reader.readable` claims the queue for\n // `pipeTo` consumption. While inactive, `_push` only feeds the\n // AsyncIterator path. Mixing the two surfaces is undefined behavior.\n let pullController: ReadableStreamDefaultController<T> | undefined;\n let readableInstance: ReadableStream<T> | undefined;\n\n function drainNext(): void {\n if (!pending) return;\n if (queue.length > 0) {\n const value = queue.shift()!;\n const r = pending;\n pending = undefined;\n r.resolve({ value, done: false });\n return;\n }\n if (done) {\n const r = pending;\n pending = undefined;\n if (endError) {\n const err = new Error(endError.message);\n err.name = endError.name;\n r.reject(err);\n } else {\n r.resolve({ value: undefined, done: true });\n }\n }\n }\n\n function feedReadable(): void {\n if (!pullController) return;\n while (queue.length > 0) {\n const v = queue.shift()!;\n try {\n pullController.enqueue(v);\n } catch {\n // controller closed/errored under us — drop silently; the\n // ReadableStream consumer is gone and we can't push further.\n break;\n }\n }\n if (done && pullController) {\n try {\n if (endError) {\n const err = new Error(endError.message);\n err.name = endError.name;\n pullController.error(err);\n } else {\n pullController.close();\n }\n } catch {\n // already closed\n }\n pullController = undefined;\n }\n }\n\n function push(seq: number, chunk: T): void {\n if (done || cancelled) return;\n if (seq <= lastSeenSeq) return; // dedupe replays we've already seen\n lastSeenSeq = seq;\n queue.push(chunk);\n if (queue.length > highWaterMark) {\n const overflow = queue.length - highWaterMark;\n queue.splice(0, overflow);\n options.onOverflow?.(overflow);\n }\n drainNext();\n if (readableInstance) feedReadable();\n }\n\n function end(error?: StreamErrorPayload): void {\n if (done) return;\n done = true;\n endError = error;\n drainNext();\n if (readableInstance) feedReadable();\n }\n\n function cancel(): void {\n if (cancelled || done) return;\n cancelled = true;\n options.onCancel?.();\n end(undefined);\n }\n\n function getReadable(): ReadableStream<T> {\n if (readableInstance) return readableInstance;\n readableInstance = new ReadableStream<T>({\n start(controller) {\n pullController = controller;\n feedReadable();\n },\n cancel() {\n cancel();\n }\n });\n return readableInstance;\n }\n\n const reader: StreamReader<T> = {\n id,\n get cancelled() {\n return cancelled;\n },\n get done() {\n return done;\n },\n get lastSeenSeq() {\n return lastSeenSeq;\n },\n get readable() {\n return getReadable();\n },\n cancel,\n _push: push,\n _end: end,\n [Symbol.asyncIterator](): AsyncIterator<T> {\n return {\n async next(): Promise<IteratorResult<T>> {\n if (queue.length > 0) {\n return Promise.resolve({ value: queue.shift()!, done: false });\n }\n if (done) {\n if (endError) {\n const err = new Error(endError.message);\n err.name = endError.name;\n return Promise.reject(err);\n }\n return Promise.resolve({\n value: undefined as unknown as T,\n done: true\n });\n }\n return new Promise<IteratorResult<T>>((resolve, reject) => {\n pending = { resolve, reject };\n });\n },\n async return(): Promise<IteratorResult<T>> {\n cancel();\n return Promise.resolve({\n value: undefined as unknown as T,\n done: true\n });\n }\n };\n }\n };\n\n return reader;\n}\n\nfunction toErrorPayload(reason: unknown): StreamErrorPayload {\n if (reason instanceof Error) {\n return { name: reason.name || \"Error\", message: reason.message };\n }\n if (typeof reason === \"string\") {\n return { name: \"Error\", message: reason };\n }\n try {\n return { name: \"Error\", message: JSON.stringify(reason) };\n } catch {\n return { name: \"Error\", message: String(reason) };\n }\n}\n"],"mappings":"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"}
1
+ {"version":3,"file":"streaming-channel.mjs","names":[],"sources":["../../src/lib/streaming-channel.ts"],"sourcesContent":["/* -------------------------------------------------------------------\n\n ⚡ Storm Software - Powerlines\n\n This code was released as part of the Powerlines project. Powerlines\n is maintained by Storm Software under the Apache-2.0 license, and is\n free for commercial and private use. For more information, please visit\n our licensing page at https://stormsoftware.com/licenses/projects/powerlines.\n\n Website: https://stormsoftware.com\n Repository: https://github.com/storm-software/powerlines\n Documentation: https://docs.stormsoftware.com/projects/powerlines\n Contact: https://stormsoftware.com/contact\n\n SPDX-License-Identifier: Apache-2.0\n\n ------------------------------------------------------------------- */\n\nimport { nanoid } from \"@stryke/unique-id/nanoid-client\";\nimport type { EventEmitter } from \"devframe/types\";\nimport { createEventEmitter } from \"./events\";\n\n/**\n * Serialized error shape sent over the wire when a stream ends with a failure.\n * Stays JSON-safe so the strict-JSON encoder can carry it without coercion.\n */\nexport interface StreamErrorPayload {\n name: string;\n message: string;\n}\n\n/**\n * Single buffered chunk in the server-side ring buffer.\n *\n * Sequence numbers start at 1 and increment per write. Subscribers track\n * `lastSeenSeq` and ask for `afterSeq` on resubscribe so the server can\n * replay any chunks the client missed during a brief disconnect.\n */\nexport interface BufferedChunk<T> {\n seq: number;\n chunk: T;\n}\n\nexport interface StreamSinkEvents<T> {\n /** Fired for each `write()`. The RPC layer subscribes and broadcasts. */\n chunk: (seq: number, chunk: T) => void;\n /** Terminal — fired exactly once per sink lifetime. */\n end: (error?: StreamErrorPayload) => void;\n}\n\nexport interface CreateStreamSinkOptions {\n id?: string;\n /**\n * Size of the per-stream ring buffer kept for replay-on-resubscribe.\n * `0` (default) disables replay.\n */\n replayWindow?: number;\n}\n\n/**\n * Server-side producer handle. Two equivalent surfaces share one piece of\n * state: the imperative `write/error/close` triple, and a `WritableStream<T>`\n * for `pipeTo`-style consumption.\n */\nexport interface StreamSink<T> {\n /** Stable id used by clients to subscribe. */\n readonly id: string;\n /**\n * Aborts when the consumer cancels (server-side) or when the transport\n * loses every subscriber. Producers should poll `signal.aborted` and exit\n * cleanly.\n */\n readonly signal: AbortSignal;\n /** `true` after `close()` / `error()`. Further writes throw. */\n readonly closed: boolean;\n /** Last allocated sequence number. `0` until the first write. */\n readonly lastSeq: number;\n\n write: (chunk: T) => void;\n error: (reason: unknown) => void;\n close: () => void;\n /** External-cancel path. Aborts the signal so handlers can short-circuit. */\n abort: (reason?: unknown) => void;\n\n /** `WritableStream<T>` adapter — same in-memory state as the imperative API. */\n readonly writable: WritableStream<T>;\n\n /**\n * Internal — RPC layer subscribes to receive chunk/end notifications.\n * Not part of the public contract; do not call directly.\n *\n * @internal\n */\n readonly events: EventEmitter<StreamSinkEvents<T>>;\n\n /**\n * Internal — replay buffer. RPC layer reads on (re)subscribe to feed\n * missed chunks before going live.\n *\n * @internal\n */\n readonly buffer: ReadonlyArray<BufferedChunk<T>>;\n}\n\nexport interface CreateStreamReaderOptions {\n id?: string;\n /**\n * Maximum number of buffered chunks held client-side while the consumer\n * isn't draining. On overflow, the oldest chunk is dropped.\n */\n highWaterMark?: number;\n /**\n * Called when the chunk queue overflows the high-water mark. The RPC\n * layer wires this to a coded warning; the primitive itself is\n * RPC-agnostic.\n */\n onOverflow?: (dropped: number) => void;\n /** Called when the consumer cancels — the RPC layer sends `:cancel` upstream. */\n onCancel?: () => void;\n}\n\n/**\n * Client-side consumer handle. Both an `AsyncIterable<T>` (for `for await`)\n * and exposes `readable: ReadableStream<T>` (for `pipeTo`). Pick one — they\n * share a single internal queue, so concurrent draining will race.\n */\nexport interface StreamReader<T> extends AsyncIterable<T> {\n readonly id: string;\n readonly cancelled: boolean;\n readonly done: boolean;\n /** Highest `seq` observed. Used for replay on reconnect. */\n readonly lastSeenSeq: number;\n /** `ReadableStream<T>` adapter for `pipeTo`-style consumption. */\n readonly readable: ReadableStream<T>;\n\n cancel: () => void;\n\n /** @internal */\n _push: (seq: number, chunk: T) => void;\n /** @internal */\n _end: (error?: StreamErrorPayload) => void;\n}\n\nconst DEFAULT_HIGH_WATER_MARK = 256;\n\nclass StreamClosedError extends Error {\n override name = \"StreamClosedError\";\n}\n\n/**\n * Build a server-side stream sink. RPC-agnostic — the RPC host wires\n * `events.on('chunk' | 'end')` to broadcast, and reads `buffer` to replay\n * for late or reconnecting subscribers.\n */\nexport function createStreamSink<T>(\n options: CreateStreamSinkOptions = {}\n): StreamSink<T> {\n const id = options.id ?? nanoid();\n const replayWindow = Math.max(0, options.replayWindow ?? 0);\n const events = createEventEmitter<StreamSinkEvents<T>>();\n const controller = new AbortController();\n const buffer: BufferedChunk<T>[] = [];\n\n let closed = false;\n let lastSeq = 0;\n\n function write(chunk: T): void {\n if (closed) {\n throw new StreamClosedError(`Cannot write to a closed stream \"${id}\"`);\n }\n lastSeq += 1;\n if (replayWindow > 0) {\n buffer.push({ seq: lastSeq, chunk });\n if (buffer.length > replayWindow)\n buffer.splice(0, buffer.length - replayWindow);\n }\n events.emit(\"chunk\", lastSeq, chunk);\n }\n\n function error(reason: unknown): void {\n if (closed) return;\n closed = true;\n const payload = toErrorPayload(reason);\n controller.abort(reason);\n events.emit(\"end\", payload);\n }\n\n function close(): void {\n if (closed) return;\n closed = true;\n if (!controller.signal.aborted) controller.abort(\"stream closed\");\n events.emit(\"end\", undefined);\n }\n\n function abort(reason?: unknown): void {\n if (closed) return;\n if (!controller.signal.aborted) controller.abort(reason ?? \"aborted\");\n }\n\n const writable = new WritableStream<T>({\n write(chunk) {\n write(chunk);\n },\n close() {\n close();\n },\n abort(reason) {\n error(reason);\n }\n });\n\n return {\n id,\n signal: controller.signal,\n get closed() {\n return closed;\n },\n get lastSeq() {\n return lastSeq;\n },\n write,\n error,\n close,\n abort,\n writable,\n events,\n buffer\n };\n}\n\n/**\n * Build a client-side stream reader. RPC-agnostic — the RPC host calls\n * `_push(seq, chunk)` on each incoming chunk and `_end(error?)` on the\n * terminal frame. Consumers iterate with `for await` or pipe `readable`.\n */\nexport function createStreamReader<T>(\n options: CreateStreamReaderOptions = {}\n): StreamReader<T> {\n const id = options.id ?? nanoid();\n const highWaterMark = Math.max(\n 1,\n options.highWaterMark ?? DEFAULT_HIGH_WATER_MARK\n );\n\n const queue: T[] = [];\n let lastSeenSeq = 0;\n let done = false;\n let cancelled = false;\n let endError: StreamErrorPayload | undefined;\n let pending:\n | {\n resolve: (r: IteratorResult<T>) => void;\n reject: (err: unknown) => void;\n }\n | undefined;\n // Lazily created — accessing `reader.readable` claims the queue for\n // `pipeTo` consumption. While inactive, `_push` only feeds the\n // AsyncIterator path. Mixing the two surfaces is undefined behavior.\n let pullController: ReadableStreamDefaultController<T> | undefined;\n let readableInstance: ReadableStream<T> | undefined;\n\n function drainNext(): void {\n if (!pending) return;\n if (queue.length > 0) {\n const value = queue.shift()!;\n const r = pending;\n pending = undefined;\n r.resolve({ value, done: false });\n return;\n }\n if (done) {\n const r = pending;\n pending = undefined;\n if (endError) {\n const err = new Error(endError.message);\n err.name = endError.name;\n r.reject(err);\n } else {\n r.resolve({ value: undefined, done: true });\n }\n }\n }\n\n function feedReadable(): void {\n if (!pullController) return;\n while (queue.length > 0) {\n const v = queue.shift()!;\n try {\n pullController.enqueue(v);\n } catch {\n // controller closed/errored under us — drop silently; the\n // ReadableStream consumer is gone and we can't push further.\n break;\n }\n }\n if (done && pullController) {\n try {\n if (endError) {\n const err = new Error(endError.message);\n err.name = endError.name;\n pullController.error(err);\n } else {\n pullController.close();\n }\n } catch {\n // already closed\n }\n pullController = undefined;\n }\n }\n\n function push(seq: number, chunk: T): void {\n if (done || cancelled) return;\n if (seq <= lastSeenSeq) return; // dedupe replays we've already seen\n lastSeenSeq = seq;\n queue.push(chunk);\n if (queue.length > highWaterMark) {\n const overflow = queue.length - highWaterMark;\n queue.splice(0, overflow);\n options.onOverflow?.(overflow);\n }\n drainNext();\n if (readableInstance) feedReadable();\n }\n\n function end(error?: StreamErrorPayload): void {\n if (done) return;\n done = true;\n endError = error;\n drainNext();\n if (readableInstance) feedReadable();\n }\n\n function cancel(): void {\n if (cancelled || done) return;\n cancelled = true;\n options.onCancel?.();\n end(undefined);\n }\n\n function getReadable(): ReadableStream<T> {\n if (readableInstance) return readableInstance;\n readableInstance = new ReadableStream<T>({\n start(controller) {\n pullController = controller;\n feedReadable();\n },\n cancel() {\n cancel();\n }\n });\n return readableInstance;\n }\n\n const reader: StreamReader<T> = {\n id,\n get cancelled() {\n return cancelled;\n },\n get done() {\n return done;\n },\n get lastSeenSeq() {\n return lastSeenSeq;\n },\n get readable() {\n return getReadable();\n },\n cancel,\n _push: push,\n _end: end,\n [Symbol.asyncIterator](): AsyncIterator<T> {\n return {\n async next(): Promise<IteratorResult<T>> {\n if (queue.length > 0) {\n return Promise.resolve({ value: queue.shift()!, done: false });\n }\n if (done) {\n if (endError) {\n const err = new Error(endError.message);\n err.name = endError.name;\n return Promise.reject(err);\n }\n return Promise.resolve({\n value: undefined as unknown as T,\n done: true\n });\n }\n return new Promise<IteratorResult<T>>((resolve, reject) => {\n pending = { resolve, reject };\n });\n },\n async return(): Promise<IteratorResult<T>> {\n cancel();\n return Promise.resolve({\n value: undefined as unknown as T,\n done: true\n });\n }\n };\n }\n };\n\n return reader;\n}\n\nfunction toErrorPayload(reason: unknown): StreamErrorPayload {\n if (reason instanceof Error) {\n return { name: reason.name || \"Error\", message: reason.message };\n }\n if (typeof reason === \"string\") {\n return { name: \"Error\", message: reason };\n }\n try {\n return { name: \"Error\", message: JSON.stringify(reason) };\n } catch {\n return { name: \"Error\", message: String(reason) };\n }\n}\n"],"mappings":"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"}
@@ -1,11 +1,3 @@
1
-
2
-
3
- import __tsdown_shims_path from 'node:path'
4
- import __tsdown_shims_url from 'node:url'
5
-
6
- const __TSDOWN_SHIM_FILENAME__ = /* @__PURE__ */ __tsdown_shims_url.fileURLToPath(import.meta.url)
7
- const __TSDOWN_SHIM_DIRNAME__ = /* @__PURE__ */ __tsdown_shims_path.dirname(__TSDOWN_SHIM_FILENAME__)
8
-
9
1
  Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
10
2
  const require_lib_typescript_ts_morph = require('./ts-morph.cjs');
11
3
  const require_lib_typescript_tsconfig = require('./tsconfig.cjs');
@@ -1,3 +1,3 @@
1
- import { VirtualFileSystemHost, createProgram } from "./ts-morph.cjs";
2
- import { findIncludeMatch, findMatch, getParsedTypeScriptConfig, getTsconfigDtsPath, getTsconfigFilePath, initializeTsconfig, isIncludeMatchFound, isMatchFound, resolveTsconfig, tryTsconfigFilePath } from "./tsconfig.cjs";
1
+ import { n as createProgram, t as VirtualFileSystemHost } from "../../ts-morph-BGgjbOgM.cjs";
2
+ import { a as getTsconfigFilePath, c as isMatchFound, i as getTsconfigDtsPath, l as resolveTsconfig, n as findMatch, o as initializeTsconfig, r as getParsedTypeScriptConfig, s as isIncludeMatchFound, t as findIncludeMatch, u as tryTsconfigFilePath } from "../../tsconfig-DExoZEQ0.cjs";
3
3
  export { VirtualFileSystemHost, createProgram, findIncludeMatch, findMatch, getParsedTypeScriptConfig, getTsconfigDtsPath, getTsconfigFilePath, initializeTsconfig, isIncludeMatchFound, isMatchFound, resolveTsconfig, tryTsconfigFilePath };
@@ -1,5 +1,3 @@
1
- import __tsdown_shims_path from 'node:path';
2
- import __tsdown_shims_url from 'node:url';
3
- import { VirtualFileSystemHost, createProgram } from "./ts-morph.mjs";
4
- import { findIncludeMatch, findMatch, getParsedTypeScriptConfig, getTsconfigDtsPath, getTsconfigFilePath, initializeTsconfig, isIncludeMatchFound, isMatchFound, resolveTsconfig, tryTsconfigFilePath } from "./tsconfig.mjs";
1
+ import { n as createProgram, t as VirtualFileSystemHost } from "../../ts-morph-zLvdifpA.mjs";
2
+ import { a as getTsconfigFilePath, c as isMatchFound, i as getTsconfigDtsPath, l as resolveTsconfig, n as findMatch, o as initializeTsconfig, r as getParsedTypeScriptConfig, s as isIncludeMatchFound, t as findIncludeMatch, u as tryTsconfigFilePath } from "../../tsconfig-De09cBeX.mjs";
5
3
  export { VirtualFileSystemHost, createProgram, findIncludeMatch, findMatch, getParsedTypeScriptConfig, getTsconfigDtsPath, getTsconfigFilePath, initializeTsconfig, isIncludeMatchFound, isMatchFound, resolveTsconfig, tryTsconfigFilePath };
@@ -1,11 +1,3 @@
1
-
2
-
3
- import __tsdown_shims_path from 'node:path'
4
- import __tsdown_shims_url from 'node:url'
5
-
6
- const __TSDOWN_SHIM_FILENAME__ = /* @__PURE__ */ __tsdown_shims_url.fileURLToPath(import.meta.url)
7
- const __TSDOWN_SHIM_DIRNAME__ = /* @__PURE__ */ __tsdown_shims_path.dirname(__TSDOWN_SHIM_FILENAME__)
8
-
9
1
  import { VirtualFileSystemHost, createProgram } from "./ts-morph.mjs";
10
2
  import { findIncludeMatch, findMatch, getParsedTypeScriptConfig, getTsconfigDtsPath, getTsconfigFilePath, initializeTsconfig, isIncludeMatchFound, isMatchFound, resolveTsconfig, tryTsconfigFilePath } from "./tsconfig.mjs";
11
3
 
@@ -1,15 +1,7 @@
1
-
2
-
3
- import __tsdown_shims_path from 'node:path'
4
- import __tsdown_shims_url from 'node:url'
5
-
6
- const __TSDOWN_SHIM_FILENAME__ = /* @__PURE__ */ __tsdown_shims_url.fileURLToPath(import.meta.url)
7
- const __TSDOWN_SHIM_DIRNAME__ = /* @__PURE__ */ __tsdown_shims_path.dirname(__TSDOWN_SHIM_FILENAME__)
8
-
9
1
  Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
10
- const require_runtime = require('../../_virtual/_rolldown/runtime.cjs');
2
+ const require_chunk = require('../../chunk-C_NdSu1c.cjs');
11
3
  let defu = require("defu");
12
- defu = require_runtime.__toESM(defu, 1);
4
+ defu = require_chunk.__toESM(defu, 1);
13
5
  let ts_morph = require("ts-morph");
14
6
 
15
7
  //#region src/lib/typescript/ts-morph.ts
@@ -1,38 +1,2 @@
1
- import { Context } from "../../types/context.cjs";
2
- import { FileSystemHost, InMemoryFileSystemHost, Project, ProjectOptions, RuntimeDirEntry } from "ts-morph";
3
-
4
- //#region src/lib/typescript/ts-morph.d.ts
5
- declare class VirtualFileSystemHost extends InMemoryFileSystemHost implements FileSystemHost {
6
- #private;
7
- constructor(context: Context);
8
- deleteSync(path: string): void;
9
- readDirSync(dirPath: string): RuntimeDirEntry[];
10
- readFile(filePath: string): Promise<string>;
11
- readFileSync(filePath: string): string;
12
- writeFile(filePath: string, fileText: string): Promise<void>;
13
- writeFileSync(filePath: string, fileText: string): void;
14
- mkdir(dirPath: string): Promise<void>;
15
- mkdirSync(dirPath: string): void;
16
- move(srcPath: string, destPath: string): Promise<void>;
17
- moveSync(srcPath: string, destPath: string): void;
18
- copy(srcPath: string, destPath: string): Promise<void>;
19
- copySync(srcPath: string, destPath: string): void;
20
- fileExists(filePath: string): Promise<boolean>;
21
- fileExistsSync(filePath: string): boolean;
22
- directoryExists(dirPath: string): Promise<boolean>;
23
- directoryExistsSync(dirPath: string): boolean;
24
- realpathSync(path: string): string;
25
- getCurrentDirectory(): string;
26
- glob(patterns: ReadonlyArray<string>): Promise<string[]>;
27
- globSync(patterns: ReadonlyArray<string>): string[];
28
- }
29
- /**
30
- * Create a ts-morph {@link Project} instance used for type reflection and module manipulation during processing
31
- *
32
- * @param context - The Powerlines context
33
- * @returns A ts-morph {@link Project} instance
34
- */
35
- declare function createProgram(context: Context, override: Partial<ProjectOptions>): Project;
36
- //#endregion
37
- export { VirtualFileSystemHost, createProgram };
38
- //# sourceMappingURL=ts-morph.d.cts.map
1
+ import { n as createProgram, t as VirtualFileSystemHost } from "../../ts-morph-BGgjbOgM.cjs";
2
+ export { VirtualFileSystemHost, createProgram };
@@ -1,40 +1,2 @@
1
- import __tsdown_shims_path from 'node:path';
2
- import __tsdown_shims_url from 'node:url';
3
- import { Context } from "../../types/context.mjs";
4
- import { FileSystemHost, InMemoryFileSystemHost, Project, ProjectOptions, RuntimeDirEntry } from "ts-morph";
5
-
6
- //#region src/lib/typescript/ts-morph.d.ts
7
- declare class VirtualFileSystemHost extends InMemoryFileSystemHost implements FileSystemHost {
8
- #private;
9
- constructor(context: Context);
10
- deleteSync(path: string): void;
11
- readDirSync(dirPath: string): RuntimeDirEntry[];
12
- readFile(filePath: string): Promise<string>;
13
- readFileSync(filePath: string): string;
14
- writeFile(filePath: string, fileText: string): Promise<void>;
15
- writeFileSync(filePath: string, fileText: string): void;
16
- mkdir(dirPath: string): Promise<void>;
17
- mkdirSync(dirPath: string): void;
18
- move(srcPath: string, destPath: string): Promise<void>;
19
- moveSync(srcPath: string, destPath: string): void;
20
- copy(srcPath: string, destPath: string): Promise<void>;
21
- copySync(srcPath: string, destPath: string): void;
22
- fileExists(filePath: string): Promise<boolean>;
23
- fileExistsSync(filePath: string): boolean;
24
- directoryExists(dirPath: string): Promise<boolean>;
25
- directoryExistsSync(dirPath: string): boolean;
26
- realpathSync(path: string): string;
27
- getCurrentDirectory(): string;
28
- glob(patterns: ReadonlyArray<string>): Promise<string[]>;
29
- globSync(patterns: ReadonlyArray<string>): string[];
30
- }
31
- /**
32
- * Create a ts-morph {@link Project} instance used for type reflection and module manipulation during processing
33
- *
34
- * @param context - The Powerlines context
35
- * @returns A ts-morph {@link Project} instance
36
- */
37
- declare function createProgram(context: Context, override: Partial<ProjectOptions>): Project;
38
- //#endregion
39
- export { VirtualFileSystemHost, createProgram };
40
- //# sourceMappingURL=ts-morph.d.mts.map
1
+ import { n as createProgram, t as VirtualFileSystemHost } from "../../ts-morph-zLvdifpA.mjs";
2
+ export { VirtualFileSystemHost, createProgram };
@@ -1,11 +1,3 @@
1
-
2
-
3
- import __tsdown_shims_path from 'node:path'
4
- import __tsdown_shims_url from 'node:url'
5
-
6
- const __TSDOWN_SHIM_FILENAME__ = /* @__PURE__ */ __tsdown_shims_url.fileURLToPath(import.meta.url)
7
- const __TSDOWN_SHIM_DIRNAME__ = /* @__PURE__ */ __tsdown_shims_path.dirname(__TSDOWN_SHIM_FILENAME__)
8
-
9
1
  import defu from "defu";
10
2
  import { InMemoryFileSystemHost, Project } from "ts-morph";
11
3
 
@@ -1 +1 @@
1
- {"version":3,"file":"ts-morph.mjs","names":["#context"],"sources":["../../../src/lib/typescript/ts-morph.ts"],"sourcesContent":["/* -------------------------------------------------------------------\n\n ⚡ Storm Software - Powerlines\n\n This code was released as part of the Powerlines project. Powerlines\n is maintained by Storm Software under the Apache-2.0 license, and is\n free for commercial and private use. For more information, please visit\n our licensing page at https://stormsoftware.com/licenses/projects/powerlines.\n\n Website: https://stormsoftware.com\n Repository: https://github.com/storm-software/powerlines\n Documentation: https://docs.stormsoftware.com/projects/powerlines\n Contact: https://stormsoftware.com/contact\n\n SPDX-License-Identifier: Apache-2.0\n\n ------------------------------------------------------------------- */\n\nimport defu from \"defu\";\nimport {\n CompilerOptions,\n FileSystemHost,\n InMemoryFileSystemHost,\n Project,\n ProjectOptions,\n RuntimeDirEntry\n} from \"ts-morph\";\nimport type { Context } from \"../../types/context\";\n\nexport class VirtualFileSystemHost\n extends InMemoryFileSystemHost\n implements FileSystemHost\n{\n #context: Context;\n\n public constructor(context: Context) {\n super();\n\n this.#context = context;\n }\n\n public override deleteSync(path: string) {\n this.#context.fs.removeSync(path);\n }\n\n public override readDirSync(dirPath: string): RuntimeDirEntry[] {\n if (!this.#context.fs.isDirectorySync(dirPath)) {\n return [];\n }\n\n return this.#context.fs.listSync(dirPath).reduce((ret, entry) => {\n const fullPath = this.#context.fs.resolveSync(entry);\n if (fullPath) {\n ret.push({\n name: entry,\n isDirectory: this.#context.fs.isDirectorySync(fullPath),\n isFile: this.#context.fs.isFileSync(fullPath),\n isSymlink: false\n });\n }\n\n return ret;\n }, [] as RuntimeDirEntry[]);\n }\n\n public override async readFile(filePath: string) {\n if (!this.#context.fs.isFileSync(filePath)) {\n return \"\";\n }\n\n return (await this.#context.fs.read(filePath))!;\n }\n\n public override readFileSync(filePath: string) {\n if (!this.#context.fs.isFileSync(filePath)) {\n return \"\";\n }\n\n return this.#context.fs.readSync(filePath)!;\n }\n\n public override async writeFile(filePath: string, fileText: string) {\n return this.#context.fs.write(filePath, fileText);\n }\n\n public override writeFileSync(filePath: string, fileText: string) {\n this.#context.fs.writeSync(filePath, fileText);\n }\n\n public override async mkdir(dirPath: string) {\n await this.#context.fs.mkdir(dirPath);\n }\n\n public override mkdirSync(dirPath: string) {\n this.#context.fs.mkdirSync(dirPath);\n }\n\n public override async move(srcPath: string, destPath: string) {\n await this.#context.fs.move(srcPath, destPath);\n }\n\n public override moveSync(srcPath: string, destPath: string) {\n this.#context.fs.moveSync(srcPath, destPath);\n }\n\n public override async copy(srcPath: string, destPath: string) {\n await this.#context.fs.copy(srcPath, destPath);\n }\n\n public override copySync(srcPath: string, destPath: string) {\n this.#context.fs.copySync(srcPath, destPath);\n }\n\n public override async fileExists(filePath: string) {\n return this.#context.fs.isFile(filePath);\n }\n\n public override fileExistsSync(filePath: string) {\n return this.#context.fs.isFileSync(filePath);\n }\n\n public override async directoryExists(dirPath: string) {\n return this.#context.fs.isDirectory(dirPath);\n }\n\n public override directoryExistsSync(dirPath: string): boolean {\n return this.#context.fs.isDirectorySync(dirPath);\n }\n\n public override realpathSync(path: string) {\n return this.#context.fs.resolveSync(path) || path;\n }\n\n public override getCurrentDirectory() {\n return this.#context.config.cwd;\n }\n\n public override async glob(\n patterns: ReadonlyArray<string>\n ): Promise<string[]> {\n return this.#context.fs.glob(patterns as string[]);\n }\n\n public override globSync(patterns: ReadonlyArray<string>): string[] {\n return this.#context.fs.globSync(patterns as string[]);\n }\n}\n\n/**\n * Create a ts-morph {@link Project} instance used for type reflection and module manipulation during processing\n *\n * @param context - The Powerlines context\n * @returns A ts-morph {@link Project} instance\n */\nexport function createProgram(\n context: Context,\n override: Partial<ProjectOptions>\n): Project {\n context.debug(\n `Creating ts-morph Project instance with configuration from: ${\n context.tsconfig.tsconfigFilePath\n }.`\n );\n\n const project = new Project(\n defu(override ?? {}, {\n skipAddingFilesFromTsConfig: false,\n tsConfigFilePath: context.tsconfig.tsconfigFilePath,\n fileSystem: new VirtualFileSystemHost(context),\n compilerOptions: defu(context.tsconfig.options ?? {}, {\n lib: [\"lib.esnext.full.d.ts\"]\n }) as CompilerOptions\n })\n );\n\n return project;\n}\n"],"mappings":"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"}
1
+ {"version":3,"file":"ts-morph.mjs","names":["#context"],"sources":["../../../src/lib/typescript/ts-morph.ts"],"sourcesContent":["/* -------------------------------------------------------------------\n\n ⚡ Storm Software - Powerlines\n\n This code was released as part of the Powerlines project. Powerlines\n is maintained by Storm Software under the Apache-2.0 license, and is\n free for commercial and private use. For more information, please visit\n our licensing page at https://stormsoftware.com/licenses/projects/powerlines.\n\n Website: https://stormsoftware.com\n Repository: https://github.com/storm-software/powerlines\n Documentation: https://docs.stormsoftware.com/projects/powerlines\n Contact: https://stormsoftware.com/contact\n\n SPDX-License-Identifier: Apache-2.0\n\n ------------------------------------------------------------------- */\n\nimport defu from \"defu\";\nimport {\n CompilerOptions,\n FileSystemHost,\n InMemoryFileSystemHost,\n Project,\n ProjectOptions,\n RuntimeDirEntry\n} from \"ts-morph\";\nimport type { Context } from \"../../types/context\";\n\nexport class VirtualFileSystemHost\n extends InMemoryFileSystemHost\n implements FileSystemHost\n{\n #context: Context;\n\n public constructor(context: Context) {\n super();\n\n this.#context = context;\n }\n\n public override deleteSync(path: string) {\n this.#context.fs.removeSync(path);\n }\n\n public override readDirSync(dirPath: string): RuntimeDirEntry[] {\n if (!this.#context.fs.isDirectorySync(dirPath)) {\n return [];\n }\n\n return this.#context.fs.listSync(dirPath).reduce((ret, entry) => {\n const fullPath = this.#context.fs.resolveSync(entry);\n if (fullPath) {\n ret.push({\n name: entry,\n isDirectory: this.#context.fs.isDirectorySync(fullPath),\n isFile: this.#context.fs.isFileSync(fullPath),\n isSymlink: false\n });\n }\n\n return ret;\n }, [] as RuntimeDirEntry[]);\n }\n\n public override async readFile(filePath: string) {\n if (!this.#context.fs.isFileSync(filePath)) {\n return \"\";\n }\n\n return (await this.#context.fs.read(filePath))!;\n }\n\n public override readFileSync(filePath: string) {\n if (!this.#context.fs.isFileSync(filePath)) {\n return \"\";\n }\n\n return this.#context.fs.readSync(filePath)!;\n }\n\n public override async writeFile(filePath: string, fileText: string) {\n return this.#context.fs.write(filePath, fileText);\n }\n\n public override writeFileSync(filePath: string, fileText: string) {\n this.#context.fs.writeSync(filePath, fileText);\n }\n\n public override async mkdir(dirPath: string) {\n await this.#context.fs.mkdir(dirPath);\n }\n\n public override mkdirSync(dirPath: string) {\n this.#context.fs.mkdirSync(dirPath);\n }\n\n public override async move(srcPath: string, destPath: string) {\n await this.#context.fs.move(srcPath, destPath);\n }\n\n public override moveSync(srcPath: string, destPath: string) {\n this.#context.fs.moveSync(srcPath, destPath);\n }\n\n public override async copy(srcPath: string, destPath: string) {\n await this.#context.fs.copy(srcPath, destPath);\n }\n\n public override copySync(srcPath: string, destPath: string) {\n this.#context.fs.copySync(srcPath, destPath);\n }\n\n public override async fileExists(filePath: string) {\n return this.#context.fs.isFile(filePath);\n }\n\n public override fileExistsSync(filePath: string) {\n return this.#context.fs.isFileSync(filePath);\n }\n\n public override async directoryExists(dirPath: string) {\n return this.#context.fs.isDirectory(dirPath);\n }\n\n public override directoryExistsSync(dirPath: string): boolean {\n return this.#context.fs.isDirectorySync(dirPath);\n }\n\n public override realpathSync(path: string) {\n return this.#context.fs.resolveSync(path) || path;\n }\n\n public override getCurrentDirectory() {\n return this.#context.config.cwd;\n }\n\n public override async glob(\n patterns: ReadonlyArray<string>\n ): Promise<string[]> {\n return this.#context.fs.glob(patterns as string[]);\n }\n\n public override globSync(patterns: ReadonlyArray<string>): string[] {\n return this.#context.fs.globSync(patterns as string[]);\n }\n}\n\n/**\n * Create a ts-morph {@link Project} instance used for type reflection and module manipulation during processing\n *\n * @param context - The Powerlines context\n * @returns A ts-morph {@link Project} instance\n */\nexport function createProgram(\n context: Context,\n override: Partial<ProjectOptions>\n): Project {\n context.debug(\n `Creating ts-morph Project instance with configuration from: ${\n context.tsconfig.tsconfigFilePath\n }.`\n );\n\n const project = new Project(\n defu(override ?? {}, {\n skipAddingFilesFromTsConfig: false,\n tsConfigFilePath: context.tsconfig.tsconfigFilePath,\n fileSystem: new VirtualFileSystemHost(context),\n compilerOptions: defu(context.tsconfig.options ?? {}, {\n lib: [\"lib.esnext.full.d.ts\"]\n }) as CompilerOptions\n })\n );\n\n return project;\n}\n"],"mappings":"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"}
@@ -1,28 +1,20 @@
1
-
2
-
3
- import __tsdown_shims_path from 'node:path'
4
- import __tsdown_shims_url from 'node:url'
5
-
6
- const __TSDOWN_SHIM_FILENAME__ = /* @__PURE__ */ __tsdown_shims_url.fileURLToPath(import.meta.url)
7
- const __TSDOWN_SHIM_DIRNAME__ = /* @__PURE__ */ __tsdown_shims_path.dirname(__TSDOWN_SHIM_FILENAME__)
8
-
9
1
  Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
10
- const require_runtime = require('../../_virtual/_rolldown/runtime.cjs');
2
+ const require_chunk = require('../../chunk-C_NdSu1c.cjs');
11
3
  let _stryke_fs_exists = require("@stryke/fs/exists");
12
4
  let _stryke_fs_json = require("@stryke/fs/json");
13
5
  let _stryke_path_append = require("@stryke/path/append");
14
6
  let _stryke_path_file_path_fns = require("@stryke/path/file-path-fns");
15
7
  let _stryke_path_join_paths = require("@stryke/path/join-paths");
16
8
  let defu = require("defu");
17
- defu = require_runtime.__toESM(defu, 1);
9
+ defu = require_chunk.__toESM(defu, 1);
18
10
  let _stryke_string_format_title_case = require("@stryke/string-format/title-case");
19
11
  let chalk = require("chalk");
20
- chalk = require_runtime.__toESM(chalk, 1);
12
+ chalk = require_chunk.__toESM(chalk, 1);
21
13
  let _stryke_fs_package_fns = require("@stryke/fs/package-fns");
22
14
  let _donedeal0_superdiff = require("@donedeal0/superdiff");
23
15
  let _stryke_json_storm_json = require("@stryke/json/storm-json");
24
16
  let typescript = require("typescript");
25
- typescript = require_runtime.__toESM(typescript, 1);
17
+ typescript = require_chunk.__toESM(typescript, 1);
26
18
 
27
19
  //#region src/lib/typescript/tsconfig.ts
28
20
  function getTsconfigDtsPath(context) {