codecane 1.0.394 → 1.0.396

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 (571) hide show
  1. package/package.json +21 -70
  2. package/scripts/codebuff-wrapper.js +39 -0
  3. package/scripts/install.js +104 -0
  4. package/dist/__tests__/display.test.d.ts +0 -1
  5. package/dist/__tests__/display.test.js +0 -174
  6. package/dist/__tests__/display.test.js.map +0 -1
  7. package/dist/background-process-manager.d.ts +0 -50
  8. package/dist/background-process-manager.js +0 -364
  9. package/dist/background-process-manager.js.map +0 -1
  10. package/dist/browser-runner.d.ts +0 -35
  11. package/dist/browser-runner.js +0 -689
  12. package/dist/browser-runner.js.map +0 -1
  13. package/dist/chat-storage.d.ts +0 -2
  14. package/dist/chat-storage.js +0 -98
  15. package/dist/chat-storage.js.map +0 -1
  16. package/dist/checkpoints/checkpoint-manager.d.ts +0 -94
  17. package/dist/checkpoints/checkpoint-manager.js +0 -291
  18. package/dist/checkpoints/checkpoint-manager.js.map +0 -1
  19. package/dist/checkpoints/file-manager.d.ts +0 -72
  20. package/dist/checkpoints/file-manager.js +0 -443
  21. package/dist/checkpoints/file-manager.js.map +0 -1
  22. package/dist/cli-definitions.d.ts +0 -9
  23. package/dist/cli-definitions.js +0 -66
  24. package/dist/cli-definitions.js.map +0 -1
  25. package/dist/cli-handlers/api-key.d.ts +0 -25
  26. package/dist/cli-handlers/api-key.js +0 -66
  27. package/dist/cli-handlers/api-key.js.map +0 -1
  28. package/dist/cli-handlers/checkpoint.d.ts +0 -19
  29. package/dist/cli-handlers/checkpoint.js +0 -221
  30. package/dist/cli-handlers/checkpoint.js.map +0 -1
  31. package/dist/cli-handlers/diff.d.ts +0 -2
  32. package/dist/cli-handlers/diff.js +0 -31
  33. package/dist/cli-handlers/diff.js.map +0 -1
  34. package/dist/cli-handlers/easter-egg.d.ts +0 -1
  35. package/dist/cli-handlers/easter-egg.js +0 -126
  36. package/dist/cli-handlers/easter-egg.js.map +0 -1
  37. package/dist/cli-handlers/inititalization-flow.d.ts +0 -1
  38. package/dist/cli-handlers/inititalization-flow.js +0 -25
  39. package/dist/cli-handlers/inititalization-flow.js.map +0 -1
  40. package/dist/cli.d.ts +0 -68
  41. package/dist/cli.js +0 -777
  42. package/dist/cli.js.map +0 -1
  43. package/dist/client.d.ts +0 -91
  44. package/dist/client.js +0 -1325
  45. package/dist/client.js.map +0 -1
  46. package/dist/code-map/languages.d.ts +0 -12
  47. package/dist/code-map/languages.d.ts.map +0 -1
  48. package/dist/code-map/languages.js +0 -130
  49. package/dist/code-map/languages.js.map +0 -1
  50. package/dist/code-map/parse.d.ts +0 -22
  51. package/dist/code-map/parse.d.ts.map +0 -1
  52. package/dist/code-map/parse.js +0 -180
  53. package/dist/code-map/parse.js.map +0 -1
  54. package/dist/code-map/test-langs/test.d.ts +0 -12
  55. package/dist/code-map/test-langs/test.d.ts.map +0 -1
  56. package/dist/code-map/test-langs/test.js +0 -23
  57. package/dist/code-map/test-langs/test.js.map +0 -1
  58. package/dist/code-map/tree-sitter-queries/readme.md +0 -23
  59. package/dist/code-map/tree-sitter-queries/tree-sitter-c-tags.scm +0 -16
  60. package/dist/code-map/tree-sitter-queries/tree-sitter-c_sharp-tags.scm +0 -23
  61. package/dist/code-map/tree-sitter-queries/tree-sitter-cpp-tags.scm +0 -29
  62. package/dist/code-map/tree-sitter-queries/tree-sitter-go-tags.scm +0 -26
  63. package/dist/code-map/tree-sitter-queries/tree-sitter-java-tags.scm +0 -19
  64. package/dist/code-map/tree-sitter-queries/tree-sitter-javascript-tags.scm +0 -16
  65. package/dist/code-map/tree-sitter-queries/tree-sitter-php-tags.scm +0 -23
  66. package/dist/code-map/tree-sitter-queries/tree-sitter-python-tags.scm +0 -12
  67. package/dist/code-map/tree-sitter-queries/tree-sitter-ruby-tags.scm +0 -58
  68. package/dist/code-map/tree-sitter-queries/tree-sitter-rust-tags.scm +0 -26
  69. package/dist/code-map/tree-sitter-queries/tree-sitter-typescript-tags.scm +0 -22
  70. package/dist/code-map/tsconfig.tsbuildinfo +0 -1
  71. package/dist/common/actions.d.ts +0 -2673
  72. package/dist/common/actions.d.ts.map +0 -1
  73. package/dist/common/actions.js +0 -167
  74. package/dist/common/actions.js.map +0 -1
  75. package/dist/common/analytics.d.ts +0 -6
  76. package/dist/common/analytics.d.ts.map +0 -1
  77. package/dist/common/analytics.js +0 -60
  78. package/dist/common/analytics.js.map +0 -1
  79. package/dist/common/api-keys/constants.d.ts +0 -9
  80. package/dist/common/api-keys/constants.d.ts.map +0 -1
  81. package/dist/common/api-keys/constants.js +0 -26
  82. package/dist/common/api-keys/constants.js.map +0 -1
  83. package/dist/common/api-keys/crypto.d.ts +0 -25
  84. package/dist/common/api-keys/crypto.d.ts.map +0 -1
  85. package/dist/common/api-keys/crypto.js +0 -186
  86. package/dist/common/api-keys/crypto.js.map +0 -1
  87. package/dist/common/browser-actions.d.ts +0 -4416
  88. package/dist/common/browser-actions.d.ts.map +0 -1
  89. package/dist/common/browser-actions.js +0 -343
  90. package/dist/common/browser-actions.js.map +0 -1
  91. package/dist/common/constants/analytics-events.d.ts +0 -29
  92. package/dist/common/constants/analytics-events.d.ts.map +0 -1
  93. package/dist/common/constants/analytics-events.js +0 -37
  94. package/dist/common/constants/analytics-events.js.map +0 -1
  95. package/dist/common/constants/grant-priorities.d.ts +0 -3
  96. package/dist/common/constants/grant-priorities.d.ts.map +0 -1
  97. package/dist/common/constants/grant-priorities.js +0 -11
  98. package/dist/common/constants/grant-priorities.js.map +0 -1
  99. package/dist/common/constants/tools.d.ts +0 -21
  100. package/dist/common/constants/tools.d.ts.map +0 -1
  101. package/dist/common/constants/tools.js +0 -48
  102. package/dist/common/constants/tools.js.map +0 -1
  103. package/dist/common/constants.d.ts +0 -149
  104. package/dist/common/constants.d.ts.map +0 -1
  105. package/dist/common/constants.js +0 -234
  106. package/dist/common/constants.js.map +0 -1
  107. package/dist/common/db/drizzle.config.d.ts +0 -3
  108. package/dist/common/db/drizzle.config.d.ts.map +0 -1
  109. package/dist/common/db/drizzle.config.js +0 -17
  110. package/dist/common/db/drizzle.config.js.map +0 -1
  111. package/dist/common/db/env.d.mts +0 -4
  112. package/dist/common/db/env.mjs +0 -26
  113. package/dist/common/db/env.mjs.map +0 -1
  114. package/dist/common/db/index.d.ts +0 -7
  115. package/dist/common/db/index.d.ts.map +0 -1
  116. package/dist/common/db/index.js +0 -35
  117. package/dist/common/db/index.js.map +0 -1
  118. package/dist/common/db/schema.d.ts +0 -2449
  119. package/dist/common/db/schema.d.ts.map +0 -1
  120. package/dist/common/db/schema.js +0 -310
  121. package/dist/common/db/schema.js.map +0 -1
  122. package/dist/common/db/transaction.d.ts +0 -13
  123. package/dist/common/db/transaction.d.ts.map +0 -1
  124. package/dist/common/db/transaction.js +0 -36
  125. package/dist/common/db/transaction.js.map +0 -1
  126. package/dist/common/env.d.mts +0 -13
  127. package/dist/common/env.mjs +0 -43
  128. package/dist/common/env.mjs.map +0 -1
  129. package/dist/common/json-config/__tests__/constants.test.d.ts +0 -2
  130. package/dist/common/json-config/__tests__/constants.test.d.ts.map +0 -1
  131. package/dist/common/json-config/__tests__/constants.test.js +0 -273
  132. package/dist/common/json-config/__tests__/constants.test.js.map +0 -1
  133. package/dist/common/json-config/__tests__/stringify-schema.test.d.ts +0 -2
  134. package/dist/common/json-config/__tests__/stringify-schema.test.d.ts.map +0 -1
  135. package/dist/common/json-config/__tests__/stringify-schema.test.js +0 -66
  136. package/dist/common/json-config/__tests__/stringify-schema.test.js.map +0 -1
  137. package/dist/common/json-config/constants.d.ts +0 -138
  138. package/dist/common/json-config/constants.d.ts.map +0 -1
  139. package/dist/common/json-config/constants.js +0 -78
  140. package/dist/common/json-config/constants.js.map +0 -1
  141. package/dist/common/json-config/stringify-schema.d.ts +0 -10
  142. package/dist/common/json-config/stringify-schema.d.ts.map +0 -1
  143. package/dist/common/json-config/stringify-schema.js +0 -131
  144. package/dist/common/json-config/stringify-schema.js.map +0 -1
  145. package/dist/common/project-file-tree.d.ts +0 -12
  146. package/dist/common/project-file-tree.d.ts.map +0 -1
  147. package/dist/common/project-file-tree.js +0 -212
  148. package/dist/common/project-file-tree.js.map +0 -1
  149. package/dist/common/src/actions.d.ts +0 -2673
  150. package/dist/common/src/actions.d.ts.map +0 -1
  151. package/dist/common/src/actions.js +0 -167
  152. package/dist/common/src/actions.js.map +0 -1
  153. package/dist/common/src/analytics.d.ts +0 -6
  154. package/dist/common/src/analytics.d.ts.map +0 -1
  155. package/dist/common/src/analytics.js +0 -60
  156. package/dist/common/src/analytics.js.map +0 -1
  157. package/dist/common/src/api-keys/constants.d.ts +0 -9
  158. package/dist/common/src/api-keys/constants.d.ts.map +0 -1
  159. package/dist/common/src/api-keys/constants.js +0 -26
  160. package/dist/common/src/api-keys/constants.js.map +0 -1
  161. package/dist/common/src/api-keys/crypto.d.ts +0 -25
  162. package/dist/common/src/api-keys/crypto.d.ts.map +0 -1
  163. package/dist/common/src/api-keys/crypto.js +0 -186
  164. package/dist/common/src/api-keys/crypto.js.map +0 -1
  165. package/dist/common/src/browser-actions.d.ts +0 -4416
  166. package/dist/common/src/browser-actions.d.ts.map +0 -1
  167. package/dist/common/src/browser-actions.js +0 -343
  168. package/dist/common/src/browser-actions.js.map +0 -1
  169. package/dist/common/src/constants/analytics-events.d.ts +0 -28
  170. package/dist/common/src/constants/analytics-events.d.ts.map +0 -1
  171. package/dist/common/src/constants/analytics-events.js +0 -36
  172. package/dist/common/src/constants/analytics-events.js.map +0 -1
  173. package/dist/common/src/constants/grant-priorities.d.ts +0 -3
  174. package/dist/common/src/constants/grant-priorities.d.ts.map +0 -1
  175. package/dist/common/src/constants/grant-priorities.js +0 -11
  176. package/dist/common/src/constants/grant-priorities.js.map +0 -1
  177. package/dist/common/src/constants/tools.d.ts +0 -20
  178. package/dist/common/src/constants/tools.d.ts.map +0 -1
  179. package/dist/common/src/constants/tools.js +0 -47
  180. package/dist/common/src/constants/tools.js.map +0 -1
  181. package/dist/common/src/constants.d.ts +0 -152
  182. package/dist/common/src/constants.d.ts.map +0 -1
  183. package/dist/common/src/constants.js +0 -222
  184. package/dist/common/src/constants.js.map +0 -1
  185. package/dist/common/src/db/drizzle.config.d.ts +0 -3
  186. package/dist/common/src/db/drizzle.config.d.ts.map +0 -1
  187. package/dist/common/src/db/drizzle.config.js +0 -17
  188. package/dist/common/src/db/drizzle.config.js.map +0 -1
  189. package/dist/common/src/db/index.d.ts +0 -7
  190. package/dist/common/src/db/index.d.ts.map +0 -1
  191. package/dist/common/src/db/index.js +0 -35
  192. package/dist/common/src/db/index.js.map +0 -1
  193. package/dist/common/src/db/schema.d.ts +0 -2289
  194. package/dist/common/src/db/schema.d.ts.map +0 -1
  195. package/dist/common/src/db/schema.js +0 -296
  196. package/dist/common/src/db/schema.js.map +0 -1
  197. package/dist/common/src/db/transaction.d.ts +0 -13
  198. package/dist/common/src/db/transaction.d.ts.map +0 -1
  199. package/dist/common/src/db/transaction.js +0 -36
  200. package/dist/common/src/db/transaction.js.map +0 -1
  201. package/dist/common/src/json-config/__tests__/constants.test.d.ts +0 -2
  202. package/dist/common/src/json-config/__tests__/constants.test.d.ts.map +0 -1
  203. package/dist/common/src/json-config/__tests__/constants.test.js +0 -273
  204. package/dist/common/src/json-config/__tests__/constants.test.js.map +0 -1
  205. package/dist/common/src/json-config/__tests__/stringify-schema.test.d.ts +0 -2
  206. package/dist/common/src/json-config/__tests__/stringify-schema.test.d.ts.map +0 -1
  207. package/dist/common/src/json-config/__tests__/stringify-schema.test.js +0 -66
  208. package/dist/common/src/json-config/__tests__/stringify-schema.test.js.map +0 -1
  209. package/dist/common/src/json-config/constants.d.ts +0 -138
  210. package/dist/common/src/json-config/constants.d.ts.map +0 -1
  211. package/dist/common/src/json-config/constants.js +0 -78
  212. package/dist/common/src/json-config/constants.js.map +0 -1
  213. package/dist/common/src/json-config/stringify-schema.d.ts +0 -10
  214. package/dist/common/src/json-config/stringify-schema.d.ts.map +0 -1
  215. package/dist/common/src/json-config/stringify-schema.js +0 -131
  216. package/dist/common/src/json-config/stringify-schema.js.map +0 -1
  217. package/dist/common/src/project-file-tree.d.ts +0 -12
  218. package/dist/common/src/project-file-tree.d.ts.map +0 -1
  219. package/dist/common/src/project-file-tree.js +0 -212
  220. package/dist/common/src/project-file-tree.js.map +0 -1
  221. package/dist/common/src/types/agent-state.d.ts +0 -227
  222. package/dist/common/src/types/agent-state.d.ts.map +0 -1
  223. package/dist/common/src/types/agent-state.js +0 -34
  224. package/dist/common/src/types/agent-state.js.map +0 -1
  225. package/dist/common/src/types/grant.d.ts +0 -3
  226. package/dist/common/src/types/grant.d.ts.map +0 -1
  227. package/dist/common/src/types/grant.js +0 -11
  228. package/dist/common/src/types/grant.js.map +0 -1
  229. package/dist/common/src/types/message.d.ts +0 -320
  230. package/dist/common/src/types/message.d.ts.map +0 -1
  231. package/dist/common/src/types/message.js +0 -60
  232. package/dist/common/src/types/message.js.map +0 -1
  233. package/dist/common/src/types/organization.d.ts +0 -106
  234. package/dist/common/src/types/organization.d.ts.map +0 -1
  235. package/dist/common/src/types/organization.js +0 -3
  236. package/dist/common/src/types/organization.js.map +0 -1
  237. package/dist/common/src/types/referral.d.ts +0 -3
  238. package/dist/common/src/types/referral.d.ts.map +0 -1
  239. package/dist/common/src/types/referral.js +0 -5
  240. package/dist/common/src/types/referral.js.map +0 -1
  241. package/dist/common/src/types/tools.d.ts +0 -6
  242. package/dist/common/src/types/tools.d.ts.map +0 -1
  243. package/dist/common/src/types/tools.js +0 -3
  244. package/dist/common/src/types/tools.js.map +0 -1
  245. package/dist/common/src/types/usage.d.ts +0 -41
  246. package/dist/common/src/types/usage.d.ts.map +0 -1
  247. package/dist/common/src/types/usage.js +0 -16
  248. package/dist/common/src/types/usage.js.map +0 -1
  249. package/dist/common/src/util/__tests__/messages.test.d.ts +0 -2
  250. package/dist/common/src/util/__tests__/messages.test.d.ts.map +0 -1
  251. package/dist/common/src/util/__tests__/messages.test.js +0 -70
  252. package/dist/common/src/util/__tests__/messages.test.js.map +0 -1
  253. package/dist/common/src/util/__tests__/saxy.test.d.ts +0 -2
  254. package/dist/common/src/util/__tests__/saxy.test.d.ts.map +0 -1
  255. package/dist/common/src/util/__tests__/saxy.test.js +0 -906
  256. package/dist/common/src/util/__tests__/saxy.test.js.map +0 -1
  257. package/dist/common/src/util/__tests__/string.test.d.ts +0 -2
  258. package/dist/common/src/util/__tests__/string.test.d.ts.map +0 -1
  259. package/dist/common/src/util/__tests__/string.test.js +0 -82
  260. package/dist/common/src/util/__tests__/string.test.js.map +0 -1
  261. package/dist/common/src/util/array.d.ts +0 -7
  262. package/dist/common/src/util/array.d.ts.map +0 -1
  263. package/dist/common/src/util/array.js +0 -32
  264. package/dist/common/src/util/array.js.map +0 -1
  265. package/dist/common/src/util/changes.d.ts +0 -9
  266. package/dist/common/src/util/changes.d.ts.map +0 -1
  267. package/dist/common/src/util/changes.js +0 -87
  268. package/dist/common/src/util/changes.js.map +0 -1
  269. package/dist/common/src/util/credentials.d.ts +0 -26
  270. package/dist/common/src/util/credentials.d.ts.map +0 -1
  271. package/dist/common/src/util/credentials.js +0 -24
  272. package/dist/common/src/util/credentials.js.map +0 -1
  273. package/dist/common/src/util/currency.d.ts +0 -15
  274. package/dist/common/src/util/currency.d.ts.map +0 -1
  275. package/dist/common/src/util/currency.js +0 -23
  276. package/dist/common/src/util/currency.js.map +0 -1
  277. package/dist/common/src/util/dates.d.ts +0 -11
  278. package/dist/common/src/util/dates.d.ts.map +0 -1
  279. package/dist/common/src/util/dates.js +0 -22
  280. package/dist/common/src/util/dates.js.map +0 -1
  281. package/dist/common/src/util/file.d.ts +0 -163
  282. package/dist/common/src/util/file.d.ts.map +0 -1
  283. package/dist/common/src/util/file.js +0 -192
  284. package/dist/common/src/util/file.js.map +0 -1
  285. package/dist/common/src/util/git.d.ts +0 -7
  286. package/dist/common/src/util/git.d.ts.map +0 -1
  287. package/dist/common/src/util/git.js +0 -81
  288. package/dist/common/src/util/git.js.map +0 -1
  289. package/dist/common/src/util/logger.d.ts +0 -9
  290. package/dist/common/src/util/logger.d.ts.map +0 -1
  291. package/dist/common/src/util/logger.js +0 -52
  292. package/dist/common/src/util/logger.js.map +0 -1
  293. package/dist/common/src/util/lru-cache.d.ts +0 -31
  294. package/dist/common/src/util/lru-cache.d.ts.map +0 -1
  295. package/dist/common/src/util/lru-cache.js +0 -68
  296. package/dist/common/src/util/lru-cache.js.map +0 -1
  297. package/dist/common/src/util/messages.d.ts +0 -12
  298. package/dist/common/src/util/messages.d.ts.map +0 -1
  299. package/dist/common/src/util/messages.js +0 -81
  300. package/dist/common/src/util/messages.js.map +0 -1
  301. package/dist/common/src/util/min-heap.d.ts +0 -16
  302. package/dist/common/src/util/min-heap.d.ts.map +0 -1
  303. package/dist/common/src/util/min-heap.js +0 -73
  304. package/dist/common/src/util/min-heap.js.map +0 -1
  305. package/dist/common/src/util/object.d.ts +0 -19
  306. package/dist/common/src/util/object.d.ts.map +0 -1
  307. package/dist/common/src/util/object.js +0 -91
  308. package/dist/common/src/util/object.js.map +0 -1
  309. package/dist/common/src/util/patch.d.ts +0 -2
  310. package/dist/common/src/util/patch.d.ts.map +0 -1
  311. package/dist/common/src/util/patch.js +0 -215
  312. package/dist/common/src/util/patch.js.map +0 -1
  313. package/dist/common/src/util/promise.d.ts +0 -17
  314. package/dist/common/src/util/promise.d.ts.map +0 -1
  315. package/dist/common/src/util/promise.js +0 -51
  316. package/dist/common/src/util/promise.js.map +0 -1
  317. package/dist/common/src/util/random.d.ts +0 -2
  318. package/dist/common/src/util/random.d.ts.map +0 -1
  319. package/dist/common/src/util/random.js +0 -17
  320. package/dist/common/src/util/random.js.map +0 -1
  321. package/dist/common/src/util/referral.d.ts +0 -2
  322. package/dist/common/src/util/referral.d.ts.map +0 -1
  323. package/dist/common/src/util/referral.js +0 -6
  324. package/dist/common/src/util/referral.js.map +0 -1
  325. package/dist/common/src/util/saxy.d.ts +0 -179
  326. package/dist/common/src/util/saxy.d.ts.map +0 -1
  327. package/dist/common/src/util/saxy.js +0 -548
  328. package/dist/common/src/util/saxy.js.map +0 -1
  329. package/dist/common/src/util/string.d.ts +0 -80
  330. package/dist/common/src/util/string.d.ts.map +0 -1
  331. package/dist/common/src/util/string.js +0 -264
  332. package/dist/common/src/util/string.js.map +0 -1
  333. package/dist/common/src/util/stripe.d.ts +0 -4
  334. package/dist/common/src/util/stripe.d.ts.map +0 -1
  335. package/dist/common/src/util/stripe.js +0 -22
  336. package/dist/common/src/util/stripe.js.map +0 -1
  337. package/dist/common/src/util/sync-failure.d.ts +0 -2
  338. package/dist/common/src/util/sync-failure.d.ts.map +0 -1
  339. package/dist/common/src/util/sync-failure.js +0 -57
  340. package/dist/common/src/util/sync-failure.js.map +0 -1
  341. package/dist/common/src/websockets/websocket-client.d.ts +0 -43
  342. package/dist/common/src/websockets/websocket-client.d.ts.map +0 -1
  343. package/dist/common/src/websockets/websocket-client.js +0 -216
  344. package/dist/common/src/websockets/websocket-client.js.map +0 -1
  345. package/dist/common/src/websockets/websocket-schema.d.ts +0 -5159
  346. package/dist/common/src/websockets/websocket-schema.d.ts.map +0 -1
  347. package/dist/common/src/websockets/websocket-schema.js +0 -55
  348. package/dist/common/src/websockets/websocket-schema.js.map +0 -1
  349. package/dist/common/tsconfig.tsbuildinfo +0 -1
  350. package/dist/common/types/agent-state.d.ts +0 -227
  351. package/dist/common/types/agent-state.d.ts.map +0 -1
  352. package/dist/common/types/agent-state.js +0 -34
  353. package/dist/common/types/agent-state.js.map +0 -1
  354. package/dist/common/types/grant.d.ts +0 -3
  355. package/dist/common/types/grant.d.ts.map +0 -1
  356. package/dist/common/types/grant.js +0 -11
  357. package/dist/common/types/grant.js.map +0 -1
  358. package/dist/common/types/message.d.ts +0 -320
  359. package/dist/common/types/message.d.ts.map +0 -1
  360. package/dist/common/types/message.js +0 -60
  361. package/dist/common/types/message.js.map +0 -1
  362. package/dist/common/types/organization.d.ts +0 -106
  363. package/dist/common/types/organization.d.ts.map +0 -1
  364. package/dist/common/types/organization.js +0 -3
  365. package/dist/common/types/organization.js.map +0 -1
  366. package/dist/common/types/referral.d.ts +0 -3
  367. package/dist/common/types/referral.d.ts.map +0 -1
  368. package/dist/common/types/referral.js +0 -5
  369. package/dist/common/types/referral.js.map +0 -1
  370. package/dist/common/types/tools.d.ts +0 -6
  371. package/dist/common/types/tools.d.ts.map +0 -1
  372. package/dist/common/types/tools.js +0 -3
  373. package/dist/common/types/tools.js.map +0 -1
  374. package/dist/common/types/usage.d.ts +0 -41
  375. package/dist/common/types/usage.d.ts.map +0 -1
  376. package/dist/common/types/usage.js +0 -16
  377. package/dist/common/types/usage.js.map +0 -1
  378. package/dist/common/util/__tests__/messages.test.d.ts +0 -2
  379. package/dist/common/util/__tests__/messages.test.d.ts.map +0 -1
  380. package/dist/common/util/__tests__/messages.test.js +0 -70
  381. package/dist/common/util/__tests__/messages.test.js.map +0 -1
  382. package/dist/common/util/__tests__/saxy.test.d.ts +0 -2
  383. package/dist/common/util/__tests__/saxy.test.d.ts.map +0 -1
  384. package/dist/common/util/__tests__/saxy.test.js +0 -906
  385. package/dist/common/util/__tests__/saxy.test.js.map +0 -1
  386. package/dist/common/util/__tests__/string.test.d.ts +0 -2
  387. package/dist/common/util/__tests__/string.test.d.ts.map +0 -1
  388. package/dist/common/util/__tests__/string.test.js +0 -82
  389. package/dist/common/util/__tests__/string.test.js.map +0 -1
  390. package/dist/common/util/array.d.ts +0 -7
  391. package/dist/common/util/array.d.ts.map +0 -1
  392. package/dist/common/util/array.js +0 -32
  393. package/dist/common/util/array.js.map +0 -1
  394. package/dist/common/util/changes.d.ts +0 -9
  395. package/dist/common/util/changes.d.ts.map +0 -1
  396. package/dist/common/util/changes.js +0 -87
  397. package/dist/common/util/changes.js.map +0 -1
  398. package/dist/common/util/credentials.d.ts +0 -26
  399. package/dist/common/util/credentials.d.ts.map +0 -1
  400. package/dist/common/util/credentials.js +0 -24
  401. package/dist/common/util/credentials.js.map +0 -1
  402. package/dist/common/util/currency.d.ts +0 -15
  403. package/dist/common/util/currency.d.ts.map +0 -1
  404. package/dist/common/util/currency.js +0 -23
  405. package/dist/common/util/currency.js.map +0 -1
  406. package/dist/common/util/dates.d.ts +0 -11
  407. package/dist/common/util/dates.d.ts.map +0 -1
  408. package/dist/common/util/dates.js +0 -22
  409. package/dist/common/util/dates.js.map +0 -1
  410. package/dist/common/util/file.d.ts +0 -168
  411. package/dist/common/util/file.d.ts.map +0 -1
  412. package/dist/common/util/file.js +0 -215
  413. package/dist/common/util/file.js.map +0 -1
  414. package/dist/common/util/git.d.ts +0 -7
  415. package/dist/common/util/git.d.ts.map +0 -1
  416. package/dist/common/util/git.js +0 -81
  417. package/dist/common/util/git.js.map +0 -1
  418. package/dist/common/util/logger.d.ts +0 -9
  419. package/dist/common/util/logger.d.ts.map +0 -1
  420. package/dist/common/util/logger.js +0 -52
  421. package/dist/common/util/logger.js.map +0 -1
  422. package/dist/common/util/lru-cache.d.ts +0 -31
  423. package/dist/common/util/lru-cache.d.ts.map +0 -1
  424. package/dist/common/util/lru-cache.js +0 -68
  425. package/dist/common/util/lru-cache.js.map +0 -1
  426. package/dist/common/util/messages.d.ts +0 -12
  427. package/dist/common/util/messages.d.ts.map +0 -1
  428. package/dist/common/util/messages.js +0 -81
  429. package/dist/common/util/messages.js.map +0 -1
  430. package/dist/common/util/min-heap.d.ts +0 -16
  431. package/dist/common/util/min-heap.d.ts.map +0 -1
  432. package/dist/common/util/min-heap.js +0 -73
  433. package/dist/common/util/min-heap.js.map +0 -1
  434. package/dist/common/util/object.d.ts +0 -19
  435. package/dist/common/util/object.d.ts.map +0 -1
  436. package/dist/common/util/object.js +0 -91
  437. package/dist/common/util/object.js.map +0 -1
  438. package/dist/common/util/patch.d.ts +0 -2
  439. package/dist/common/util/patch.d.ts.map +0 -1
  440. package/dist/common/util/patch.js +0 -215
  441. package/dist/common/util/patch.js.map +0 -1
  442. package/dist/common/util/promise.d.ts +0 -17
  443. package/dist/common/util/promise.d.ts.map +0 -1
  444. package/dist/common/util/promise.js +0 -51
  445. package/dist/common/util/promise.js.map +0 -1
  446. package/dist/common/util/random.d.ts +0 -2
  447. package/dist/common/util/random.d.ts.map +0 -1
  448. package/dist/common/util/random.js +0 -17
  449. package/dist/common/util/random.js.map +0 -1
  450. package/dist/common/util/referral.d.ts +0 -2
  451. package/dist/common/util/referral.d.ts.map +0 -1
  452. package/dist/common/util/referral.js +0 -6
  453. package/dist/common/util/referral.js.map +0 -1
  454. package/dist/common/util/saxy.d.ts +0 -179
  455. package/dist/common/util/saxy.d.ts.map +0 -1
  456. package/dist/common/util/saxy.js +0 -548
  457. package/dist/common/util/saxy.js.map +0 -1
  458. package/dist/common/util/string.d.ts +0 -80
  459. package/dist/common/util/string.d.ts.map +0 -1
  460. package/dist/common/util/string.js +0 -264
  461. package/dist/common/util/string.js.map +0 -1
  462. package/dist/common/util/stripe.d.ts +0 -4
  463. package/dist/common/util/stripe.d.ts.map +0 -1
  464. package/dist/common/util/stripe.js +0 -22
  465. package/dist/common/util/stripe.js.map +0 -1
  466. package/dist/common/util/sync-failure.d.ts +0 -2
  467. package/dist/common/util/sync-failure.d.ts.map +0 -1
  468. package/dist/common/util/sync-failure.js +0 -57
  469. package/dist/common/util/sync-failure.js.map +0 -1
  470. package/dist/common/websockets/websocket-client.d.ts +0 -43
  471. package/dist/common/websockets/websocket-client.d.ts.map +0 -1
  472. package/dist/common/websockets/websocket-client.js +0 -216
  473. package/dist/common/websockets/websocket-client.js.map +0 -1
  474. package/dist/common/websockets/websocket-schema.d.ts +0 -5159
  475. package/dist/common/websockets/websocket-schema.d.ts.map +0 -1
  476. package/dist/common/websockets/websocket-schema.js +0 -55
  477. package/dist/common/websockets/websocket-schema.js.map +0 -1
  478. package/dist/config.d.ts +0 -4
  479. package/dist/config.js +0 -12
  480. package/dist/config.js.map +0 -1
  481. package/dist/create-template-project.d.ts +0 -1
  482. package/dist/create-template-project.js +0 -131
  483. package/dist/create-template-project.js.map +0 -1
  484. package/dist/credentials.d.ts +0 -4
  485. package/dist/credentials.js +0 -44
  486. package/dist/credentials.js.map +0 -1
  487. package/dist/dev-process-manager.d.ts +0 -10
  488. package/dist/dev-process-manager.js +0 -56
  489. package/dist/dev-process-manager.js.map +0 -1
  490. package/dist/display.d.ts +0 -9
  491. package/dist/display.js +0 -137
  492. package/dist/display.js.map +0 -1
  493. package/dist/fingerprint.d.ts +0 -1
  494. package/dist/fingerprint.js +0 -48
  495. package/dist/fingerprint.js.map +0 -1
  496. package/dist/index.d.ts +0 -2
  497. package/dist/index.js +0 -130
  498. package/dist/index.js.map +0 -1
  499. package/dist/json-config/hooks.d.ts +0 -9
  500. package/dist/json-config/hooks.js +0 -60
  501. package/dist/json-config/hooks.js.map +0 -1
  502. package/dist/json-config/parser.d.ts +0 -7
  503. package/dist/json-config/parser.js +0 -53
  504. package/dist/json-config/parser.js.map +0 -1
  505. package/dist/menu.d.ts +0 -14
  506. package/dist/menu.js +0 -344
  507. package/dist/menu.js.map +0 -1
  508. package/dist/project-files.d.ts +0 -103
  509. package/dist/project-files.js +0 -620
  510. package/dist/project-files.js.map +0 -1
  511. package/dist/startup-process-handler.d.ts +0 -1
  512. package/dist/startup-process-handler.js +0 -25
  513. package/dist/startup-process-handler.js.map +0 -1
  514. package/dist/terminal/background.d.ts +0 -12
  515. package/dist/terminal/background.js +0 -148
  516. package/dist/terminal/background.js.map +0 -1
  517. package/dist/terminal/base.d.ts +0 -48
  518. package/dist/terminal/base.js +0 -667
  519. package/dist/terminal/base.js.map +0 -1
  520. package/dist/tool-handlers.d.ts +0 -35
  521. package/dist/tool-handlers.js +0 -303
  522. package/dist/tool-handlers.js.map +0 -1
  523. package/dist/types.d.ts +0 -16
  524. package/dist/types.js +0 -3
  525. package/dist/types.js.map +0 -1
  526. package/dist/update-codebuff.d.ts +0 -1
  527. package/dist/update-codebuff.js +0 -169
  528. package/dist/update-codebuff.js.map +0 -1
  529. package/dist/utils/__tests__/background-process-manager.test.d.ts +0 -1
  530. package/dist/utils/__tests__/background-process-manager.test.js +0 -327
  531. package/dist/utils/__tests__/background-process-manager.test.js.map +0 -1
  532. package/dist/utils/__tests__/response-example-4-files.txt +0 -621
  533. package/dist/utils/__tests__/tool-renderers.test.d.ts +0 -1
  534. package/dist/utils/__tests__/tool-renderers.test.js +0 -83
  535. package/dist/utils/__tests__/tool-renderers.test.js.map +0 -1
  536. package/dist/utils/__tests__/xml-stream-parser.test.d.ts +0 -1
  537. package/dist/utils/__tests__/xml-stream-parser.test.js +0 -255
  538. package/dist/utils/__tests__/xml-stream-parser.test.js.map +0 -1
  539. package/dist/utils/analytics.d.ts +0 -7
  540. package/dist/utils/analytics.js +0 -100
  541. package/dist/utils/analytics.js.map +0 -1
  542. package/dist/utils/detect-shell.d.ts +0 -1
  543. package/dist/utils/detect-shell.js +0 -65
  544. package/dist/utils/detect-shell.js.map +0 -1
  545. package/dist/utils/git.d.ts +0 -13
  546. package/dist/utils/git.js +0 -143
  547. package/dist/utils/git.js.map +0 -1
  548. package/dist/utils/logger.d.ts +0 -21
  549. package/dist/utils/logger.js +0 -109
  550. package/dist/utils/logger.js.map +0 -1
  551. package/dist/utils/spinner.d.ts +0 -12
  552. package/dist/utils/spinner.js +0 -85
  553. package/dist/utils/spinner.js.map +0 -1
  554. package/dist/utils/system-info.d.ts +0 -8
  555. package/dist/utils/system-info.js +0 -22
  556. package/dist/utils/system-info.js.map +0 -1
  557. package/dist/utils/tool-renderers.d.ts +0 -16
  558. package/dist/utils/tool-renderers.js +0 -222
  559. package/dist/utils/tool-renderers.js.map +0 -1
  560. package/dist/utils/xml-stream-parser.d.ts +0 -9
  561. package/dist/utils/xml-stream-parser.js +0 -143
  562. package/dist/utils/xml-stream-parser.js.map +0 -1
  563. package/dist/web-scraper.d.ts +0 -3
  564. package/dist/web-scraper.js +0 -59
  565. package/dist/web-scraper.js.map +0 -1
  566. package/dist/workers/checkpoint-worker.d.ts +0 -1
  567. package/dist/workers/checkpoint-worker.js +0 -51
  568. package/dist/workers/checkpoint-worker.js.map +0 -1
  569. package/dist/workers/project-context.d.ts +0 -1
  570. package/dist/workers/project-context.js +0 -27
  571. package/dist/workers/project-context.js.map +0 -1
@@ -1,906 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- const bun_test_1 = require("bun:test");
4
- const saxy_1 = require("../saxy");
5
- (0, bun_test_1.describe)('Saxy XML Parser', () => {
6
- // Helper function to process XML and get events
7
- const processXML = (xml, schema, shouldParseEntities = true) => {
8
- const events = [];
9
- const parser = new saxy_1.Saxy(schema, shouldParseEntities);
10
- parser.on('text', (data) => events.push({ type: 'text', data }));
11
- parser.on('tagopen', (data) => events.push({ type: 'tagopen', data }));
12
- parser.on('tagclose', (data) => events.push({ type: 'tagclose', data }));
13
- parser.write(xml);
14
- parser.end();
15
- return events;
16
- };
17
- (0, bun_test_1.describe)('Schema Validation with Text Conversion', () => {
18
- (0, bun_test_1.it)('should convert invalid top-level tags to text nodes', () => {
19
- const schema = { root: ['child'] };
20
- const xml = '<invalid>content</invalid>';
21
- const events = processXML(xml, schema);
22
- (0, bun_test_1.expect)(events).toEqual([
23
- {
24
- type: 'text',
25
- data: { contents: '<invalid>' },
26
- },
27
- {
28
- type: 'text',
29
- data: { contents: 'content' },
30
- },
31
- {
32
- type: 'text',
33
- data: { contents: '</invalid>' },
34
- },
35
- ]);
36
- });
37
- (0, bun_test_1.it)('should convert invalid nested tags to text nodes', () => {
38
- const schema = { root: ['child'] };
39
- const xml = '<other><invalid>content</invalid></other>';
40
- const events = processXML(xml, schema);
41
- (0, bun_test_1.expect)(events).toEqual([
42
- {
43
- type: 'text',
44
- data: { contents: '<other>' },
45
- },
46
- {
47
- type: 'text',
48
- data: { contents: '<invalid>' },
49
- },
50
- {
51
- type: 'text',
52
- data: { contents: 'content' },
53
- },
54
- {
55
- type: 'text',
56
- data: { contents: '</invalid>' },
57
- },
58
- {
59
- type: 'text',
60
- data: { contents: '</other>' },
61
- },
62
- ]);
63
- });
64
- (0, bun_test_1.it)('should handle valid nested tags according to schema', () => {
65
- const schema = { root: ['child'] };
66
- const xml = '<root><child>content</child></root>';
67
- const events = processXML(xml, schema);
68
- (0, bun_test_1.expect)(events).toEqual([
69
- {
70
- data: {
71
- attrs: '',
72
- isSelfClosing: false,
73
- name: 'root',
74
- rawTag: '<root>',
75
- },
76
- type: 'tagopen',
77
- },
78
- {
79
- data: {
80
- attrs: '',
81
- isSelfClosing: false,
82
- name: 'child',
83
- rawTag: '<child>',
84
- },
85
- type: 'tagopen',
86
- },
87
- {
88
- data: {
89
- contents: 'content',
90
- },
91
- type: 'text',
92
- },
93
- {
94
- data: {
95
- name: 'child',
96
- rawTag: '</child>',
97
- },
98
- type: 'tagclose',
99
- },
100
- {
101
- data: {
102
- name: 'root',
103
- rawTag: '</root>',
104
- },
105
- type: 'tagclose',
106
- },
107
- ]);
108
- });
109
- (0, bun_test_1.it)('should convert closing tags to text when parent is invalid', () => {
110
- const schema = { root: ['child'] };
111
- const xml = '<root><invalid>content</invalid><child/></root>';
112
- const events = processXML(xml, schema);
113
- (0, bun_test_1.expect)(events[1]).toEqual({
114
- type: 'text',
115
- data: { contents: '<invalid>' },
116
- });
117
- (0, bun_test_1.expect)(events[2]).toEqual({
118
- type: 'text',
119
- data: { contents: 'content' },
120
- });
121
- (0, bun_test_1.expect)(events[3]).toEqual({
122
- type: 'text',
123
- data: { contents: '</invalid>' },
124
- });
125
- });
126
- (0, bun_test_1.it)('should handle tags starting with whitespace as text', () => {
127
- const schema = { root: ['child'] };
128
- const xml = '<root>< invalid>content</invalid></root>';
129
- const events = processXML(xml, schema);
130
- (0, bun_test_1.expect)(events[1]).toEqual({
131
- type: 'text',
132
- data: { contents: '< invalid>content' },
133
- });
134
- (0, bun_test_1.expect)(events[2]).toEqual({
135
- type: 'text',
136
- data: { contents: '</invalid>' },
137
- });
138
- });
139
- });
140
- (0, bun_test_1.describe)('Edge Cases', () => {
141
- (0, bun_test_1.it)('should handle self-closing invalid tags', () => {
142
- const schema = { root: ['child'] };
143
- const xml = '<root><invalid/></root>';
144
- const events = processXML(xml, schema);
145
- (0, bun_test_1.expect)(events[1]).toEqual({
146
- type: 'text',
147
- data: { contents: '<invalid/>' },
148
- });
149
- });
150
- (0, bun_test_1.it)('should handle nested invalid tags', () => {
151
- const schema = { root: ['child'] };
152
- const xml = '<root><invalid><alsoinvalid/></invalid></root>';
153
- const events = processXML(xml, schema);
154
- (0, bun_test_1.expect)(events[1]).toEqual({
155
- type: 'text',
156
- data: { contents: '<invalid>' },
157
- });
158
- (0, bun_test_1.expect)(events[2]).toEqual({
159
- type: 'text',
160
- data: { contents: '<alsoinvalid/>' },
161
- });
162
- (0, bun_test_1.expect)(events[3]).toEqual({
163
- type: 'text',
164
- data: { contents: '</invalid>' },
165
- });
166
- });
167
- (0, bun_test_1.it)('should preserve attributes in converted text nodes', () => {
168
- const schema = { root: ['child'] };
169
- const xml = '<root><invalid attr="value">content</invalid></root>';
170
- const events = processXML(xml, schema);
171
- (0, bun_test_1.expect)(events[1]).toEqual({
172
- type: 'text',
173
- data: { contents: '<invalid attr="value">' },
174
- });
175
- (0, bun_test_1.expect)(events[2]).toEqual({
176
- type: 'text',
177
- data: { contents: 'content' },
178
- });
179
- (0, bun_test_1.expect)(events[3]).toEqual({
180
- type: 'text',
181
- data: { contents: '</invalid>' },
182
- });
183
- });
184
- });
185
- (0, bun_test_1.it)('should handle text that looks like invalid XML tags', () => {
186
- const parser = new saxy_1.Saxy();
187
- const events = [];
188
- parser.on('text', (data) => events.push({ type: 'text', data }));
189
- parser.on('tagopen', (data) => events.push({ type: 'tagopen', data }));
190
- parser.on('tagclose', (data) => events.push({ type: 'tagclose', data }));
191
- parser.write('This is < not a tag> and < another not a tag> but <valid>this is</valid>');
192
- parser.end();
193
- (0, bun_test_1.expect)(events).toEqual([
194
- {
195
- data: {
196
- contents: 'This is < not a tag> and < another not a tag> but ',
197
- },
198
- type: 'text',
199
- },
200
- {
201
- data: {
202
- attrs: '',
203
- isSelfClosing: false,
204
- name: 'valid',
205
- rawTag: '<valid>',
206
- },
207
- type: 'tagopen',
208
- },
209
- {
210
- data: {
211
- contents: 'this is',
212
- },
213
- type: 'text',
214
- },
215
- { data: { name: 'valid', rawTag: '</valid>' }, type: 'tagclose' },
216
- ]);
217
- });
218
- (0, bun_test_1.it)('should handle text with angle brackets but no valid tag names', () => {
219
- const parser = new saxy_1.Saxy();
220
- const events = [];
221
- parser.on('text', (data) => events.push({ type: 'text', data }));
222
- parser.write('Math expressions: 2 < 3 and 5 > 4');
223
- parser.end();
224
- (0, bun_test_1.expect)(events).toEqual([
225
- {
226
- type: 'text',
227
- data: { contents: 'Math expressions: 2 < 3 and 5 > 4' },
228
- },
229
- ]);
230
- });
231
- (0, bun_test_1.it)('should correctly parse mixed valid and invalid XML-like content', () => {
232
- const parser = new saxy_1.Saxy();
233
- const events = [];
234
- parser.on('text', (data) => events.push({ type: 'text', data }));
235
- parser.on('tagopen', (data) => events.push({ type: 'tagopen', data }));
236
- parser.on('tagclose', (data) => events.push({ type: 'tagclose', data }));
237
- parser.write('Text with < brackets> and <valid-tag>real XML</valid-tag> mixed together');
238
- parser.end();
239
- (0, bun_test_1.expect)(events).toEqual([
240
- {
241
- data: {
242
- contents: 'Text with < brackets> and ',
243
- },
244
- type: 'text',
245
- },
246
- {
247
- data: {
248
- attrs: '',
249
- isSelfClosing: false,
250
- name: 'valid-tag',
251
- rawTag: '<valid-tag>',
252
- },
253
- type: 'tagopen',
254
- },
255
- {
256
- data: {
257
- contents: 'real XML',
258
- },
259
- type: 'text',
260
- },
261
- {
262
- data: {
263
- name: 'valid-tag',
264
- rawTag: '</valid-tag>',
265
- },
266
- type: 'tagclose',
267
- },
268
- {
269
- data: {
270
- contents: ' mixed together',
271
- },
272
- type: 'text',
273
- },
274
- ]);
275
- });
276
- (0, bun_test_1.it)('should handle edge cases with special characters after <', () => {
277
- const parser = new saxy_1.Saxy();
278
- const events = [];
279
- parser.on('text', (data) => events.push({ type: 'text', data }));
280
- parser.write('Text with <1>, <@invalid>, and <!not-a-tag>');
281
- parser.end();
282
- (0, bun_test_1.expect)(events).toEqual([
283
- {
284
- type: 'text',
285
- data: { contents: 'Text with <1>, <@invalid>, and <!not-a-tag>' },
286
- },
287
- ]);
288
- });
289
- (0, bun_test_1.describe)('Text Node Handling', () => {
290
- (0, bun_test_1.it)('should preserve whitespace in text nodes', () => {
291
- const parser = new saxy_1.Saxy();
292
- const events = [];
293
- parser.on('text', (data) => events.push({ type: 'text', data }));
294
- parser.write(' Text with leading and trailing spaces ');
295
- parser.end();
296
- (0, bun_test_1.expect)(events).toEqual([
297
- {
298
- type: 'text',
299
- data: { contents: ' Text with leading and trailing spaces ' },
300
- },
301
- ]);
302
- });
303
- (0, bun_test_1.it)('should handle HTML entities in text content', () => {
304
- const parser = new saxy_1.Saxy();
305
- const events = [];
306
- parser.on('text', (data) => events.push({ type: 'text', data }));
307
- parser.write('Text with &amp; and &lt; entities');
308
- parser.end();
309
- (0, bun_test_1.expect)(events).toEqual([
310
- {
311
- type: 'text',
312
- data: { contents: 'Text with & and < entities' },
313
- },
314
- ]);
315
- });
316
- (0, bun_test_1.it)('should handle split XML entities in text content', () => {
317
- // Re-initialize parser and events array inside the test
318
- const parser = new saxy_1.Saxy();
319
- const events = [];
320
- parser.on('text', (data) => events.push({ type: 'text', data }));
321
- parser.write('Text with &am');
322
- parser.write('p; and');
323
- parser.write(' &l');
324
- parser.write('t; entities &g');
325
- parser.end();
326
- (0, bun_test_1.expect)(events).toEqual([
327
- {
328
- data: {
329
- contents: 'Text with ',
330
- },
331
- type: 'text',
332
- },
333
- {
334
- data: {
335
- contents: '& and',
336
- },
337
- type: 'text',
338
- },
339
- {
340
- data: {
341
- contents: ' ',
342
- },
343
- type: 'text',
344
- },
345
- {
346
- data: {
347
- contents: '< entities ',
348
- },
349
- type: 'text',
350
- },
351
- {
352
- data: {
353
- contents: '&g',
354
- },
355
- type: 'text',
356
- },
357
- ]);
358
- (0, bun_test_1.expect)(events.map((chunk) => chunk.data.contents).join('')).toEqual('Text with & and < entities &g');
359
- });
360
- (0, bun_test_1.it)('should preserve whitespace between tags', () => {
361
- const parser = new saxy_1.Saxy();
362
- const events = [];
363
- parser.on('text', (data) => events.push({ type: 'text', data }));
364
- parser.on('tagopen', (data) => events.push({ type: 'tagopen', data }));
365
- parser.on('tagclose', (data) => events.push({ type: 'tagclose', data }));
366
- parser.write('<root> text <child> text </child> text </root>');
367
- parser.end();
368
- (0, bun_test_1.expect)(events).toEqual([
369
- {
370
- data: {
371
- attrs: '',
372
- isSelfClosing: false,
373
- name: 'root',
374
- rawTag: '<root>',
375
- },
376
- type: 'tagopen',
377
- },
378
- {
379
- data: {
380
- contents: ' text ',
381
- },
382
- type: 'text',
383
- },
384
- {
385
- data: {
386
- attrs: '',
387
- isSelfClosing: false,
388
- name: 'child',
389
- rawTag: '<child>',
390
- },
391
- type: 'tagopen',
392
- },
393
- {
394
- data: {
395
- contents: ' text ',
396
- },
397
- type: 'text',
398
- },
399
- {
400
- data: {
401
- name: 'child',
402
- rawTag: '</child>',
403
- },
404
- type: 'tagclose',
405
- },
406
- {
407
- data: {
408
- contents: ' text ',
409
- },
410
- type: 'text',
411
- },
412
- {
413
- data: {
414
- name: 'root',
415
- rawTag: '</root>',
416
- },
417
- type: 'tagclose',
418
- },
419
- ]);
420
- });
421
- (0, bun_test_1.it)('should handle multiple HTML entities in the same text node', () => {
422
- const parser = new saxy_1.Saxy();
423
- const events = [];
424
- parser.on('text', (data) => events.push({ type: 'text', data }));
425
- parser.write('Text with &amp; &lt; &gt; &quot; entities');
426
- parser.end();
427
- (0, bun_test_1.expect)(events).toEqual([
428
- {
429
- type: 'text',
430
- data: { contents: 'Text with & < > " entities' },
431
- },
432
- ]);
433
- });
434
- (0, bun_test_1.it)('should preserve newlines in text content', () => {
435
- const parser = new saxy_1.Saxy();
436
- const events = [];
437
- parser.on('text', (data) => events.push({ type: 'text', data }));
438
- parser.write('Line 1\nLine 2\r\nLine 3');
439
- parser.end();
440
- (0, bun_test_1.expect)(events).toEqual([
441
- {
442
- type: 'text',
443
- data: { contents: 'Line 1\nLine 2\r\nLine 3' },
444
- },
445
- ]);
446
- });
447
- (0, bun_test_1.it)('should handle split XML entities across chunks', async () => {
448
- const parser = new saxy_1.Saxy();
449
- const events = [];
450
- parser.on('text', (data) => events.push({ type: 'text', data }));
451
- parser.on('tagopen', (data) => events.push({ type: 'tagopen', data }));
452
- parser.on('tagclose', (data) => events.push({ type: 'tagclose', data }));
453
- // Write the XML in chunks that split the &amp; entity
454
- parser.write('<tag>before &a');
455
- parser.write('mp; after</tag>');
456
- parser.end();
457
- // The entity should be properly decoded and the text events should
458
- // reconstruct the original text correctly
459
- (0, bun_test_1.expect)(events).toEqual([
460
- {
461
- data: {
462
- attrs: '',
463
- isSelfClosing: false,
464
- name: 'tag',
465
- rawTag: '<tag>',
466
- },
467
- type: 'tagopen',
468
- },
469
- {
470
- data: {
471
- contents: 'before ',
472
- },
473
- type: 'text',
474
- },
475
- {
476
- data: {
477
- contents: '& after',
478
- },
479
- type: 'text',
480
- },
481
- {
482
- data: {
483
- name: 'tag',
484
- rawTag: '</tag>',
485
- },
486
- type: 'tagclose',
487
- },
488
- ]);
489
- // The text content should be properly reconstructed
490
- const textContent = events
491
- .filter((e) => e.type === 'text')
492
- .map((e) => e.data.contents)
493
- .join('');
494
- (0, bun_test_1.expect)(textContent).toBe('before & after');
495
- });
496
- (0, bun_test_1.it)('should handle multiple split entities in sequence', async () => {
497
- const parser = new saxy_1.Saxy();
498
- const events = [];
499
- parser.on('text', (data) => events.push({ type: 'text', data }));
500
- // Write chunks that split multiple entities
501
- parser.write('Text with &am');
502
- parser.write('p; and &l');
503
- parser.write('t; symbols');
504
- parser.end();
505
- // The entities should be properly decoded and combined
506
- (0, bun_test_1.expect)(events.map((e) => e.data.contents).join('')).toBe('Text with & and < symbols');
507
- });
508
- (0, bun_test_1.it)('should handle literal ampersand split across chunks', async () => {
509
- const parser = new saxy_1.Saxy();
510
- const events = [];
511
- parser.on('text', (data) => {
512
- events.push({ type: 'text', data });
513
- });
514
- parser.on('tagopen', (data) => events.push({ type: 'tagopen', data }));
515
- parser.on('tagclose', (data) => events.push({ type: 'tagclose', data }));
516
- // Write chunks that split a literal & character
517
- parser.write('<tag>before &');
518
- parser.write(' after</tag>');
519
- parser.end();
520
- // The & should be treated as literal text and stay with its surrounding content
521
- (0, bun_test_1.expect)(events).toEqual([
522
- {
523
- data: {
524
- attrs: '',
525
- isSelfClosing: false,
526
- name: 'tag',
527
- rawTag: '<tag>',
528
- },
529
- type: 'tagopen',
530
- },
531
- {
532
- data: {
533
- contents: 'before ',
534
- },
535
- type: 'text',
536
- },
537
- {
538
- data: {
539
- contents: '& after',
540
- },
541
- type: 'text',
542
- },
543
- {
544
- data: {
545
- name: 'tag',
546
- rawTag: '</tag>',
547
- },
548
- type: 'tagclose',
549
- },
550
- ]);
551
- // The text content should be properly reconstructed
552
- const textContent = events
553
- .filter((e) => e.type === 'text')
554
- .map((e) => e.data.contents)
555
- .join('');
556
- (0, bun_test_1.expect)(textContent).toBe('before & after');
557
- });
558
- (0, bun_test_1.it)('should not treat standalone ampersand as pending entity', async () => {
559
- const parser = new saxy_1.Saxy();
560
- const events = [];
561
- parser.on('text', (data) => {
562
- events.push({ type: 'text', data });
563
- });
564
- // Write chunks that split a standalone & character
565
- parser.write('Text with &');
566
- parser.write(' more text');
567
- parser.end();
568
- (0, bun_test_1.expect)(events).toEqual([
569
- { type: 'text', data: { contents: 'Text with ' } },
570
- { type: 'text', data: { contents: '& more text' } },
571
- ]);
572
- // The text content should be properly reconstructed
573
- const textContent = events
574
- .filter((e) => e.type === 'text')
575
- .map((e) => e.data.contents)
576
- .join('');
577
- (0, bun_test_1.expect)(textContent).toBe('Text with & more text');
578
- });
579
- (0, bun_test_1.it)('should handle text split across chunks without entities or tags', async () => {
580
- const parser = new saxy_1.Saxy();
581
- const events = [];
582
- parser.on('text', (data) => events.push({ type: 'text', data }));
583
- parser.on('tagopen', (data) => events.push({ type: 'tagopen', data }));
584
- parser.on('tagclose', (data) => events.push({ type: 'tagclose', data }));
585
- // Write text split across chunks with no entities or tags
586
- parser.write('<tag>Some text');
587
- parser.write(' continued</tag>');
588
- parser.end();
589
- // The text content should be emitted in two chunks due to the new immediate emission behavior
590
- (0, bun_test_1.expect)(events).toEqual([
591
- {
592
- data: {
593
- attrs: '',
594
- isSelfClosing: false,
595
- name: 'tag',
596
- rawTag: '<tag>',
597
- },
598
- type: 'tagopen',
599
- },
600
- {
601
- data: {
602
- contents: 'Some text',
603
- },
604
- type: 'text',
605
- },
606
- {
607
- data: {
608
- contents: ' continued',
609
- },
610
- type: 'text',
611
- },
612
- {
613
- data: {
614
- name: 'tag',
615
- rawTag: '</tag>',
616
- },
617
- type: 'tagclose',
618
- },
619
- ]);
620
- // The text content should still be properly reconstructible
621
- const textContent = events
622
- .filter((e) => e.type === 'text')
623
- .map((e) => e.data.contents)
624
- .join('');
625
- (0, bun_test_1.expect)(textContent).toBe('Some text continued');
626
- });
627
- (0, bun_test_1.it)('should output closing tag as text if not matching', async () => {
628
- const parser = new saxy_1.Saxy();
629
- const events = [];
630
- parser.on('text', (data) => events.push({ type: 'text', data }));
631
- parser.on('tagopen', (data) => events.push({ type: 'tagopen', data }));
632
- parser.on('tagclose', (data) => events.push({ type: 'tagclose', data }));
633
- // Write text split across chunks with no entities or tags
634
- parser.write('<tag></invalid></tag>');
635
- parser.end();
636
- // The text content should be emitted in two chunks due to the new immediate emission behavior
637
- (0, bun_test_1.expect)(events).toEqual([
638
- {
639
- data: {
640
- attrs: '',
641
- isSelfClosing: false,
642
- name: 'tag',
643
- rawTag: '<tag>',
644
- },
645
- type: 'tagopen',
646
- },
647
- {
648
- data: {
649
- name: 'invalid',
650
- rawTag: '</invalid>',
651
- },
652
- type: 'tagclose',
653
- },
654
- {
655
- data: {
656
- name: 'tag',
657
- rawTag: '</tag>',
658
- },
659
- type: 'tagclose',
660
- },
661
- ]);
662
- // The text content should still be properly reconstructible
663
- const textContent = events
664
- .filter((e) => e.type === 'text')
665
- .map((e) => e.data.contents)
666
- .join('');
667
- (0, bun_test_1.expect)(textContent).toBe('');
668
- });
669
- });
670
- (0, bun_test_1.describe)('shouldParseEntities = false', () => {
671
- (0, bun_test_1.it)('should not parse HTML entities in text content when shouldParseEntities is false', () => {
672
- const xml = '<tag>Text with &amp; &lt; entities</tag>';
673
- const events = processXML(xml, undefined, false);
674
- (0, bun_test_1.expect)(events).toEqual([
675
- {
676
- type: 'tagopen',
677
- data: {
678
- name: 'tag',
679
- attrs: '',
680
- isSelfClosing: false,
681
- rawTag: '<tag>',
682
- },
683
- },
684
- {
685
- type: 'text',
686
- data: { contents: 'Text with &amp; &lt; entities' },
687
- },
688
- {
689
- type: 'tagclose',
690
- data: {
691
- name: 'tag',
692
- rawTag: '</tag>',
693
- },
694
- },
695
- ]);
696
- });
697
- (0, bun_test_1.it)('should not parse HTML entities split across chunks when shouldParseEntities is false', () => {
698
- const parser = new saxy_1.Saxy(undefined, false);
699
- const events = [];
700
- parser.on('text', (data) => events.push({ type: 'text', data }));
701
- parser.on('tagopen', (data) => events.push({ type: 'tagopen', data }));
702
- parser.on('tagclose', (data) => events.push({ type: 'tagclose', data }));
703
- parser.write('<tag>Text with &am');
704
- parser.write('p; and &l');
705
- parser.write('t; entities</tag>');
706
- parser.end();
707
- (0, bun_test_1.expect)(events).toEqual([
708
- {
709
- type: 'tagopen',
710
- data: {
711
- name: 'tag',
712
- attrs: '',
713
- isSelfClosing: false,
714
- rawTag: '<tag>',
715
- },
716
- },
717
- {
718
- type: 'text',
719
- data: { contents: 'Text with &am' },
720
- },
721
- {
722
- type: 'text',
723
- data: { contents: 'p; and &l' },
724
- },
725
- {
726
- type: 'text',
727
- data: { contents: 't; entities' },
728
- },
729
- {
730
- type: 'tagclose',
731
- data: {
732
- name: 'tag',
733
- rawTag: '</tag>',
734
- },
735
- },
736
- ]);
737
- (0, bun_test_1.expect)(events
738
- .filter((e) => e.type === 'text')
739
- .map((e) => e.data.contents)
740
- .join('')).toEqual('Text with &amp; and &lt; entities');
741
- });
742
- (0, bun_test_1.it)('should handle text nodes correctly in _final when shouldParseEntities is false', () => {
743
- const parser = new saxy_1.Saxy(undefined, false);
744
- const events = [];
745
- parser.on('text', (data) => events.push({ type: 'text', data }));
746
- // Write text that would normally be parsed if shouldParseEntities was true
747
- parser.write('Final text with &amp; &lt; entities');
748
- parser.end(); // _final will be called here
749
- (0, bun_test_1.expect)(events).toEqual([
750
- {
751
- type: 'text',
752
- data: { contents: 'Final text with &amp; &lt; entities' },
753
- },
754
- ]);
755
- });
756
- });
757
- (0, bun_test_1.describe)('Real World Examples', () => {
758
- (0, bun_test_1.it)('should handle && ( &lt', () => {
759
- const parser = new saxy_1.Saxy();
760
- const events = [];
761
- parser.on('text', (data) => events.push({ type: 'text', data }));
762
- parser.on('tagopen', (data) => events.push({ type: 'tagopen', data }));
763
- parser.on('tagclose', (data) => events.push({ type: 'tagclose', data }));
764
- // Write text split across chunks with no entities or tags
765
- parser.write('<write_file>\n<path>path/to/file</path>\n<content>testing && ( &lt;div className="flex flex-col"&gt;</content>\n</write_file>');
766
- parser.end();
767
- // The text content should be emitted in two chunks due to the new immediate emission behavior
768
- (0, bun_test_1.expect)(events).toEqual([
769
- {
770
- data: {
771
- attrs: '',
772
- isSelfClosing: false,
773
- name: 'write_file',
774
- rawTag: '<write_file>',
775
- },
776
- type: 'tagopen',
777
- },
778
- {
779
- data: {
780
- attrs: '',
781
- isSelfClosing: false,
782
- name: 'path',
783
- rawTag: '<path>',
784
- },
785
- type: 'tagopen',
786
- },
787
- {
788
- data: {
789
- contents: 'path/to/file',
790
- },
791
- type: 'text',
792
- },
793
- {
794
- data: {
795
- name: 'path',
796
- rawTag: '</path>',
797
- },
798
- type: 'tagclose',
799
- },
800
- {
801
- data: {
802
- attrs: '',
803
- isSelfClosing: false,
804
- name: 'content',
805
- rawTag: '<content>',
806
- },
807
- type: 'tagopen',
808
- },
809
- {
810
- data: {
811
- contents: 'testing && ( <div className="flex flex-col">',
812
- },
813
- type: 'text',
814
- },
815
- {
816
- data: {
817
- name: 'content',
818
- rawTag: '</content>',
819
- },
820
- type: 'tagclose',
821
- },
822
- {
823
- data: {
824
- name: 'write_file',
825
- rawTag: '</write_file>',
826
- },
827
- type: 'tagclose',
828
- },
829
- ]);
830
- });
831
- (0, bun_test_1.it)('should handle entity at end of content', () => {
832
- const parser = new saxy_1.Saxy();
833
- const events = [];
834
- parser.on('text', (data) => events.push({ type: 'text', data }));
835
- parser.on('tagopen', (data) => events.push({ type: 'tagopen', data }));
836
- parser.on('tagclose', (data) => events.push({ type: 'tagclose', data }));
837
- // Write text split across chunks with no entities or tags
838
- parser.write(`<write_file>\n<path>path/to/file</path>\n<content>some value &amp</content>\n</write_file>`);
839
- parser.end();
840
- // The text content should be emitted in two chunks due to the new immediate emission behavior
841
- (0, bun_test_1.expect)(events).toEqual([
842
- {
843
- data: {
844
- attrs: '',
845
- isSelfClosing: false,
846
- name: 'write_file',
847
- rawTag: '<write_file>',
848
- },
849
- type: 'tagopen',
850
- },
851
- {
852
- data: {
853
- attrs: '',
854
- isSelfClosing: false,
855
- name: 'path',
856
- rawTag: '<path>',
857
- },
858
- type: 'tagopen',
859
- },
860
- {
861
- data: {
862
- contents: 'path/to/file',
863
- },
864
- type: 'text',
865
- },
866
- {
867
- data: {
868
- name: 'path',
869
- rawTag: '</path>',
870
- },
871
- type: 'tagclose',
872
- },
873
- {
874
- data: {
875
- attrs: '',
876
- isSelfClosing: false,
877
- name: 'content',
878
- rawTag: '<content>',
879
- },
880
- type: 'tagopen',
881
- },
882
- {
883
- data: {
884
- contents: 'some value &amp',
885
- },
886
- type: 'text',
887
- },
888
- {
889
- data: {
890
- name: 'content',
891
- rawTag: '</content>',
892
- },
893
- type: 'tagclose',
894
- },
895
- {
896
- data: {
897
- name: 'write_file',
898
- rawTag: '</write_file>',
899
- },
900
- type: 'tagclose',
901
- },
902
- ]);
903
- });
904
- });
905
- });
906
- //# sourceMappingURL=saxy.test.js.map