@colbymchenry/codegraph-darwin-arm64 0.9.0

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 (569) hide show
  1. package/bin/codegraph +3 -0
  2. package/lib/dist/bin/codegraph.d.ts +21 -0
  3. package/lib/dist/bin/codegraph.d.ts.map +1 -0
  4. package/lib/dist/bin/codegraph.js +1273 -0
  5. package/lib/dist/bin/codegraph.js.map +1 -0
  6. package/lib/dist/bin/node-version-check.d.ts +37 -0
  7. package/lib/dist/bin/node-version-check.d.ts.map +1 -0
  8. package/lib/dist/bin/node-version-check.js +79 -0
  9. package/lib/dist/bin/node-version-check.js.map +1 -0
  10. package/lib/dist/bin/uninstall.d.ts +14 -0
  11. package/lib/dist/bin/uninstall.d.ts.map +1 -0
  12. package/lib/dist/bin/uninstall.js +36 -0
  13. package/lib/dist/bin/uninstall.js.map +1 -0
  14. package/lib/dist/config.d.ts +51 -0
  15. package/lib/dist/config.d.ts.map +1 -0
  16. package/lib/dist/config.js +321 -0
  17. package/lib/dist/config.js.map +1 -0
  18. package/lib/dist/context/formatter.d.ts +30 -0
  19. package/lib/dist/context/formatter.d.ts.map +1 -0
  20. package/lib/dist/context/formatter.js +244 -0
  21. package/lib/dist/context/formatter.js.map +1 -0
  22. package/lib/dist/context/index.d.ts +97 -0
  23. package/lib/dist/context/index.d.ts.map +1 -0
  24. package/lib/dist/context/index.js +1050 -0
  25. package/lib/dist/context/index.js.map +1 -0
  26. package/lib/dist/db/index.d.ts +83 -0
  27. package/lib/dist/db/index.d.ts.map +1 -0
  28. package/lib/dist/db/index.js +219 -0
  29. package/lib/dist/db/index.js.map +1 -0
  30. package/lib/dist/db/migrations.d.ts +44 -0
  31. package/lib/dist/db/migrations.d.ts.map +1 -0
  32. package/lib/dist/db/migrations.js +131 -0
  33. package/lib/dist/db/migrations.js.map +1 -0
  34. package/lib/dist/db/queries.d.ts +253 -0
  35. package/lib/dist/db/queries.d.ts.map +1 -0
  36. package/lib/dist/db/queries.js +1207 -0
  37. package/lib/dist/db/queries.js.map +1 -0
  38. package/lib/dist/db/schema.sql +151 -0
  39. package/lib/dist/db/sqlite-adapter.d.ts +46 -0
  40. package/lib/dist/db/sqlite-adapter.d.ts.map +1 -0
  41. package/lib/dist/db/sqlite-adapter.js +114 -0
  42. package/lib/dist/db/sqlite-adapter.js.map +1 -0
  43. package/lib/dist/directory.d.ts +57 -0
  44. package/lib/dist/directory.d.ts.map +1 -0
  45. package/lib/dist/directory.js +264 -0
  46. package/lib/dist/directory.js.map +1 -0
  47. package/lib/dist/errors.d.ts +136 -0
  48. package/lib/dist/errors.d.ts.map +1 -0
  49. package/lib/dist/errors.js +219 -0
  50. package/lib/dist/errors.js.map +1 -0
  51. package/lib/dist/extraction/dfm-extractor.d.ts +31 -0
  52. package/lib/dist/extraction/dfm-extractor.d.ts.map +1 -0
  53. package/lib/dist/extraction/dfm-extractor.js +151 -0
  54. package/lib/dist/extraction/dfm-extractor.js.map +1 -0
  55. package/lib/dist/extraction/grammars.d.ts +78 -0
  56. package/lib/dist/extraction/grammars.d.ts.map +1 -0
  57. package/lib/dist/extraction/grammars.js +332 -0
  58. package/lib/dist/extraction/grammars.js.map +1 -0
  59. package/lib/dist/extraction/index.d.ts +130 -0
  60. package/lib/dist/extraction/index.d.ts.map +1 -0
  61. package/lib/dist/extraction/index.js +1305 -0
  62. package/lib/dist/extraction/index.js.map +1 -0
  63. package/lib/dist/extraction/languages/c-cpp.d.ts +4 -0
  64. package/lib/dist/extraction/languages/c-cpp.d.ts.map +1 -0
  65. package/lib/dist/extraction/languages/c-cpp.js +126 -0
  66. package/lib/dist/extraction/languages/c-cpp.js.map +1 -0
  67. package/lib/dist/extraction/languages/csharp.d.ts +3 -0
  68. package/lib/dist/extraction/languages/csharp.d.ts.map +1 -0
  69. package/lib/dist/extraction/languages/csharp.js +72 -0
  70. package/lib/dist/extraction/languages/csharp.js.map +1 -0
  71. package/lib/dist/extraction/languages/dart.d.ts +3 -0
  72. package/lib/dist/extraction/languages/dart.d.ts.map +1 -0
  73. package/lib/dist/extraction/languages/dart.js +192 -0
  74. package/lib/dist/extraction/languages/dart.js.map +1 -0
  75. package/lib/dist/extraction/languages/go.d.ts +3 -0
  76. package/lib/dist/extraction/languages/go.d.ts.map +1 -0
  77. package/lib/dist/extraction/languages/go.js +58 -0
  78. package/lib/dist/extraction/languages/go.js.map +1 -0
  79. package/lib/dist/extraction/languages/index.d.ts +10 -0
  80. package/lib/dist/extraction/languages/index.d.ts.map +1 -0
  81. package/lib/dist/extraction/languages/index.js +49 -0
  82. package/lib/dist/extraction/languages/index.js.map +1 -0
  83. package/lib/dist/extraction/languages/java.d.ts +3 -0
  84. package/lib/dist/extraction/languages/java.d.ts.map +1 -0
  85. package/lib/dist/extraction/languages/java.js +64 -0
  86. package/lib/dist/extraction/languages/java.js.map +1 -0
  87. package/lib/dist/extraction/languages/javascript.d.ts +3 -0
  88. package/lib/dist/extraction/languages/javascript.d.ts.map +1 -0
  89. package/lib/dist/extraction/languages/javascript.js +90 -0
  90. package/lib/dist/extraction/languages/javascript.js.map +1 -0
  91. package/lib/dist/extraction/languages/kotlin.d.ts +3 -0
  92. package/lib/dist/extraction/languages/kotlin.d.ts.map +1 -0
  93. package/lib/dist/extraction/languages/kotlin.js +253 -0
  94. package/lib/dist/extraction/languages/kotlin.js.map +1 -0
  95. package/lib/dist/extraction/languages/lua.d.ts +3 -0
  96. package/lib/dist/extraction/languages/lua.d.ts.map +1 -0
  97. package/lib/dist/extraction/languages/lua.js +150 -0
  98. package/lib/dist/extraction/languages/lua.js.map +1 -0
  99. package/lib/dist/extraction/languages/luau.d.ts +3 -0
  100. package/lib/dist/extraction/languages/luau.d.ts.map +1 -0
  101. package/lib/dist/extraction/languages/luau.js +37 -0
  102. package/lib/dist/extraction/languages/luau.js.map +1 -0
  103. package/lib/dist/extraction/languages/pascal.d.ts +3 -0
  104. package/lib/dist/extraction/languages/pascal.d.ts.map +1 -0
  105. package/lib/dist/extraction/languages/pascal.js +66 -0
  106. package/lib/dist/extraction/languages/pascal.js.map +1 -0
  107. package/lib/dist/extraction/languages/php.d.ts +3 -0
  108. package/lib/dist/extraction/languages/php.d.ts.map +1 -0
  109. package/lib/dist/extraction/languages/php.js +107 -0
  110. package/lib/dist/extraction/languages/php.js.map +1 -0
  111. package/lib/dist/extraction/languages/python.d.ts +3 -0
  112. package/lib/dist/extraction/languages/python.d.ts.map +1 -0
  113. package/lib/dist/extraction/languages/python.js +56 -0
  114. package/lib/dist/extraction/languages/python.js.map +1 -0
  115. package/lib/dist/extraction/languages/ruby.d.ts +3 -0
  116. package/lib/dist/extraction/languages/ruby.d.ts.map +1 -0
  117. package/lib/dist/extraction/languages/ruby.js +114 -0
  118. package/lib/dist/extraction/languages/ruby.js.map +1 -0
  119. package/lib/dist/extraction/languages/rust.d.ts +3 -0
  120. package/lib/dist/extraction/languages/rust.d.ts.map +1 -0
  121. package/lib/dist/extraction/languages/rust.js +109 -0
  122. package/lib/dist/extraction/languages/rust.js.map +1 -0
  123. package/lib/dist/extraction/languages/scala.d.ts +3 -0
  124. package/lib/dist/extraction/languages/scala.d.ts.map +1 -0
  125. package/lib/dist/extraction/languages/scala.js +139 -0
  126. package/lib/dist/extraction/languages/scala.js.map +1 -0
  127. package/lib/dist/extraction/languages/swift.d.ts +3 -0
  128. package/lib/dist/extraction/languages/swift.d.ts.map +1 -0
  129. package/lib/dist/extraction/languages/swift.js +91 -0
  130. package/lib/dist/extraction/languages/swift.js.map +1 -0
  131. package/lib/dist/extraction/languages/typescript.d.ts +3 -0
  132. package/lib/dist/extraction/languages/typescript.d.ts.map +1 -0
  133. package/lib/dist/extraction/languages/typescript.js +129 -0
  134. package/lib/dist/extraction/languages/typescript.js.map +1 -0
  135. package/lib/dist/extraction/liquid-extractor.d.ts +52 -0
  136. package/lib/dist/extraction/liquid-extractor.d.ts.map +1 -0
  137. package/lib/dist/extraction/liquid-extractor.js +313 -0
  138. package/lib/dist/extraction/liquid-extractor.js.map +1 -0
  139. package/lib/dist/extraction/parse-worker.d.ts +8 -0
  140. package/lib/dist/extraction/parse-worker.d.ts.map +1 -0
  141. package/lib/dist/extraction/parse-worker.js +94 -0
  142. package/lib/dist/extraction/parse-worker.js.map +1 -0
  143. package/lib/dist/extraction/svelte-extractor.d.ts +56 -0
  144. package/lib/dist/extraction/svelte-extractor.d.ts.map +1 -0
  145. package/lib/dist/extraction/svelte-extractor.js +272 -0
  146. package/lib/dist/extraction/svelte-extractor.js.map +1 -0
  147. package/lib/dist/extraction/tree-sitter-helpers.d.ts +28 -0
  148. package/lib/dist/extraction/tree-sitter-helpers.d.ts.map +1 -0
  149. package/lib/dist/extraction/tree-sitter-helpers.js +103 -0
  150. package/lib/dist/extraction/tree-sitter-helpers.js.map +1 -0
  151. package/lib/dist/extraction/tree-sitter-types.d.ts +179 -0
  152. package/lib/dist/extraction/tree-sitter-types.d.ts.map +1 -0
  153. package/lib/dist/extraction/tree-sitter-types.js +10 -0
  154. package/lib/dist/extraction/tree-sitter-types.js.map +1 -0
  155. package/lib/dist/extraction/tree-sitter.d.ts +233 -0
  156. package/lib/dist/extraction/tree-sitter.d.ts.map +1 -0
  157. package/lib/dist/extraction/tree-sitter.js +2425 -0
  158. package/lib/dist/extraction/tree-sitter.js.map +1 -0
  159. package/lib/dist/extraction/vue-extractor.d.ts +36 -0
  160. package/lib/dist/extraction/vue-extractor.d.ts.map +1 -0
  161. package/lib/dist/extraction/vue-extractor.js +163 -0
  162. package/lib/dist/extraction/vue-extractor.js.map +1 -0
  163. package/lib/dist/extraction/wasm/tree-sitter-lua.wasm +0 -0
  164. package/lib/dist/extraction/wasm/tree-sitter-luau.wasm +0 -0
  165. package/lib/dist/extraction/wasm/tree-sitter-pascal.wasm +0 -0
  166. package/lib/dist/extraction/wasm/tree-sitter-scala.wasm +0 -0
  167. package/lib/dist/graph/index.d.ts +8 -0
  168. package/lib/dist/graph/index.d.ts.map +1 -0
  169. package/lib/dist/graph/index.js +13 -0
  170. package/lib/dist/graph/index.js.map +1 -0
  171. package/lib/dist/graph/queries.d.ts +106 -0
  172. package/lib/dist/graph/queries.d.ts.map +1 -0
  173. package/lib/dist/graph/queries.js +366 -0
  174. package/lib/dist/graph/queries.js.map +1 -0
  175. package/lib/dist/graph/traversal.d.ts +127 -0
  176. package/lib/dist/graph/traversal.d.ts.map +1 -0
  177. package/lib/dist/graph/traversal.js +493 -0
  178. package/lib/dist/graph/traversal.js.map +1 -0
  179. package/lib/dist/index.d.ts +453 -0
  180. package/lib/dist/index.d.ts.map +1 -0
  181. package/lib/dist/index.js +833 -0
  182. package/lib/dist/index.js.map +1 -0
  183. package/lib/dist/installer/claude-md-template.d.ts +14 -0
  184. package/lib/dist/installer/claude-md-template.d.ts.map +1 -0
  185. package/lib/dist/installer/claude-md-template.js +21 -0
  186. package/lib/dist/installer/claude-md-template.js.map +1 -0
  187. package/lib/dist/installer/config-writer.d.ts +29 -0
  188. package/lib/dist/installer/config-writer.d.ts.map +1 -0
  189. package/lib/dist/installer/config-writer.js +111 -0
  190. package/lib/dist/installer/config-writer.js.map +1 -0
  191. package/lib/dist/installer/index.d.ts +65 -0
  192. package/lib/dist/installer/index.d.ts.map +1 -0
  193. package/lib/dist/installer/index.js +406 -0
  194. package/lib/dist/installer/index.js.map +1 -0
  195. package/lib/dist/installer/instructions-template.d.ts +28 -0
  196. package/lib/dist/installer/instructions-template.d.ts.map +1 -0
  197. package/lib/dist/installer/instructions-template.js +64 -0
  198. package/lib/dist/installer/instructions-template.js.map +1 -0
  199. package/lib/dist/installer/targets/claude.d.ts +47 -0
  200. package/lib/dist/installer/targets/claude.d.ts.map +1 -0
  201. package/lib/dist/installer/targets/claude.js +401 -0
  202. package/lib/dist/installer/targets/claude.js.map +1 -0
  203. package/lib/dist/installer/targets/codex.d.ts +18 -0
  204. package/lib/dist/installer/targets/codex.d.ts.map +1 -0
  205. package/lib/dist/installer/targets/codex.js +185 -0
  206. package/lib/dist/installer/targets/codex.js.map +1 -0
  207. package/lib/dist/installer/targets/cursor.d.ts +35 -0
  208. package/lib/dist/installer/targets/cursor.d.ts.map +1 -0
  209. package/lib/dist/installer/targets/cursor.js +229 -0
  210. package/lib/dist/installer/targets/cursor.js.map +1 -0
  211. package/lib/dist/installer/targets/opencode.d.ts +30 -0
  212. package/lib/dist/installer/targets/opencode.d.ts.map +1 -0
  213. package/lib/dist/installer/targets/opencode.js +235 -0
  214. package/lib/dist/installer/targets/opencode.js.map +1 -0
  215. package/lib/dist/installer/targets/registry.d.ts +35 -0
  216. package/lib/dist/installer/targets/registry.d.ts.map +1 -0
  217. package/lib/dist/installer/targets/registry.js +83 -0
  218. package/lib/dist/installer/targets/registry.js.map +1 -0
  219. package/lib/dist/installer/targets/shared.d.ts +77 -0
  220. package/lib/dist/installer/targets/shared.d.ts.map +1 -0
  221. package/lib/dist/installer/targets/shared.js +246 -0
  222. package/lib/dist/installer/targets/shared.js.map +1 -0
  223. package/lib/dist/installer/targets/toml.d.ts +52 -0
  224. package/lib/dist/installer/targets/toml.d.ts.map +1 -0
  225. package/lib/dist/installer/targets/toml.js +147 -0
  226. package/lib/dist/installer/targets/toml.js.map +1 -0
  227. package/lib/dist/installer/targets/types.d.ts +116 -0
  228. package/lib/dist/installer/targets/types.d.ts.map +1 -0
  229. package/lib/dist/installer/targets/types.js +16 -0
  230. package/lib/dist/installer/targets/types.js.map +1 -0
  231. package/lib/dist/mcp/index.d.ts +94 -0
  232. package/lib/dist/mcp/index.d.ts.map +1 -0
  233. package/lib/dist/mcp/index.js +453 -0
  234. package/lib/dist/mcp/index.js.map +1 -0
  235. package/lib/dist/mcp/server-instructions.d.ts +19 -0
  236. package/lib/dist/mcp/server-instructions.d.ts.map +1 -0
  237. package/lib/dist/mcp/server-instructions.js +71 -0
  238. package/lib/dist/mcp/server-instructions.js.map +1 -0
  239. package/lib/dist/mcp/tools.d.ts +257 -0
  240. package/lib/dist/mcp/tools.d.ts.map +1 -0
  241. package/lib/dist/mcp/tools.js +1646 -0
  242. package/lib/dist/mcp/tools.js.map +1 -0
  243. package/lib/dist/mcp/transport.d.ts +106 -0
  244. package/lib/dist/mcp/transport.d.ts.map +1 -0
  245. package/lib/dist/mcp/transport.js +233 -0
  246. package/lib/dist/mcp/transport.js.map +1 -0
  247. package/lib/dist/resolution/frameworks/cargo-workspace.d.ts +18 -0
  248. package/lib/dist/resolution/frameworks/cargo-workspace.d.ts.map +1 -0
  249. package/lib/dist/resolution/frameworks/cargo-workspace.js +225 -0
  250. package/lib/dist/resolution/frameworks/cargo-workspace.js.map +1 -0
  251. package/lib/dist/resolution/frameworks/csharp.d.ts +8 -0
  252. package/lib/dist/resolution/frameworks/csharp.d.ts.map +1 -0
  253. package/lib/dist/resolution/frameworks/csharp.js +213 -0
  254. package/lib/dist/resolution/frameworks/csharp.js.map +1 -0
  255. package/lib/dist/resolution/frameworks/express.d.ts +8 -0
  256. package/lib/dist/resolution/frameworks/express.d.ts.map +1 -0
  257. package/lib/dist/resolution/frameworks/express.js +225 -0
  258. package/lib/dist/resolution/frameworks/express.js.map +1 -0
  259. package/lib/dist/resolution/frameworks/go.d.ts +8 -0
  260. package/lib/dist/resolution/frameworks/go.d.ts.map +1 -0
  261. package/lib/dist/resolution/frameworks/go.js +158 -0
  262. package/lib/dist/resolution/frameworks/go.js.map +1 -0
  263. package/lib/dist/resolution/frameworks/index.d.ts +42 -0
  264. package/lib/dist/resolution/frameworks/index.d.ts.map +1 -0
  265. package/lib/dist/resolution/frameworks/index.js +133 -0
  266. package/lib/dist/resolution/frameworks/index.js.map +1 -0
  267. package/lib/dist/resolution/frameworks/java.d.ts +8 -0
  268. package/lib/dist/resolution/frameworks/java.d.ts.map +1 -0
  269. package/lib/dist/resolution/frameworks/java.js +177 -0
  270. package/lib/dist/resolution/frameworks/java.js.map +1 -0
  271. package/lib/dist/resolution/frameworks/laravel.d.ts +13 -0
  272. package/lib/dist/resolution/frameworks/laravel.d.ts.map +1 -0
  273. package/lib/dist/resolution/frameworks/laravel.js +248 -0
  274. package/lib/dist/resolution/frameworks/laravel.js.map +1 -0
  275. package/lib/dist/resolution/frameworks/nestjs.d.ts +26 -0
  276. package/lib/dist/resolution/frameworks/nestjs.d.ts.map +1 -0
  277. package/lib/dist/resolution/frameworks/nestjs.js +374 -0
  278. package/lib/dist/resolution/frameworks/nestjs.js.map +1 -0
  279. package/lib/dist/resolution/frameworks/python.d.ts +10 -0
  280. package/lib/dist/resolution/frameworks/python.d.ts.map +1 -0
  281. package/lib/dist/resolution/frameworks/python.js +278 -0
  282. package/lib/dist/resolution/frameworks/python.js.map +1 -0
  283. package/lib/dist/resolution/frameworks/react.d.ts +8 -0
  284. package/lib/dist/resolution/frameworks/react.d.ts.map +1 -0
  285. package/lib/dist/resolution/frameworks/react.js +272 -0
  286. package/lib/dist/resolution/frameworks/react.js.map +1 -0
  287. package/lib/dist/resolution/frameworks/ruby.d.ts +8 -0
  288. package/lib/dist/resolution/frameworks/ruby.d.ts.map +1 -0
  289. package/lib/dist/resolution/frameworks/ruby.js +198 -0
  290. package/lib/dist/resolution/frameworks/ruby.js.map +1 -0
  291. package/lib/dist/resolution/frameworks/rust.d.ts +8 -0
  292. package/lib/dist/resolution/frameworks/rust.d.ts.map +1 -0
  293. package/lib/dist/resolution/frameworks/rust.js +207 -0
  294. package/lib/dist/resolution/frameworks/rust.js.map +1 -0
  295. package/lib/dist/resolution/frameworks/svelte.d.ts +9 -0
  296. package/lib/dist/resolution/frameworks/svelte.d.ts.map +1 -0
  297. package/lib/dist/resolution/frameworks/svelte.js +249 -0
  298. package/lib/dist/resolution/frameworks/svelte.js.map +1 -0
  299. package/lib/dist/resolution/frameworks/swift.d.ts +10 -0
  300. package/lib/dist/resolution/frameworks/swift.d.ts.map +1 -0
  301. package/lib/dist/resolution/frameworks/swift.js +376 -0
  302. package/lib/dist/resolution/frameworks/swift.js.map +1 -0
  303. package/lib/dist/resolution/frameworks/vue.d.ts +9 -0
  304. package/lib/dist/resolution/frameworks/vue.d.ts.map +1 -0
  305. package/lib/dist/resolution/frameworks/vue.js +306 -0
  306. package/lib/dist/resolution/frameworks/vue.js.map +1 -0
  307. package/lib/dist/resolution/import-resolver.d.ts +40 -0
  308. package/lib/dist/resolution/import-resolver.d.ts.map +1 -0
  309. package/lib/dist/resolution/import-resolver.js +663 -0
  310. package/lib/dist/resolution/import-resolver.js.map +1 -0
  311. package/lib/dist/resolution/index.d.ts +106 -0
  312. package/lib/dist/resolution/index.d.ts.map +1 -0
  313. package/lib/dist/resolution/index.js +709 -0
  314. package/lib/dist/resolution/index.js.map +1 -0
  315. package/lib/dist/resolution/name-matcher.d.ts +32 -0
  316. package/lib/dist/resolution/name-matcher.d.ts.map +1 -0
  317. package/lib/dist/resolution/name-matcher.js +384 -0
  318. package/lib/dist/resolution/name-matcher.js.map +1 -0
  319. package/lib/dist/resolution/path-aliases.d.ts +68 -0
  320. package/lib/dist/resolution/path-aliases.d.ts.map +1 -0
  321. package/lib/dist/resolution/path-aliases.js +238 -0
  322. package/lib/dist/resolution/path-aliases.js.map +1 -0
  323. package/lib/dist/resolution/strip-comments.d.ts +27 -0
  324. package/lib/dist/resolution/strip-comments.d.ts.map +1 -0
  325. package/lib/dist/resolution/strip-comments.js +441 -0
  326. package/lib/dist/resolution/strip-comments.js.map +1 -0
  327. package/lib/dist/resolution/types.d.ts +172 -0
  328. package/lib/dist/resolution/types.d.ts.map +1 -0
  329. package/lib/dist/resolution/types.js +8 -0
  330. package/lib/dist/resolution/types.js.map +1 -0
  331. package/lib/dist/search/query-parser.d.ts +57 -0
  332. package/lib/dist/search/query-parser.d.ts.map +1 -0
  333. package/lib/dist/search/query-parser.js +177 -0
  334. package/lib/dist/search/query-parser.js.map +1 -0
  335. package/lib/dist/search/query-utils.d.ts +53 -0
  336. package/lib/dist/search/query-utils.d.ts.map +1 -0
  337. package/lib/dist/search/query-utils.js +350 -0
  338. package/lib/dist/search/query-utils.js.map +1 -0
  339. package/lib/dist/sync/git-hooks.d.ts +45 -0
  340. package/lib/dist/sync/git-hooks.d.ts.map +1 -0
  341. package/lib/dist/sync/git-hooks.js +223 -0
  342. package/lib/dist/sync/git-hooks.js.map +1 -0
  343. package/lib/dist/sync/index.d.ts +17 -0
  344. package/lib/dist/sync/index.d.ts.map +1 -0
  345. package/lib/dist/sync/index.js +28 -0
  346. package/lib/dist/sync/index.js.map +1 -0
  347. package/lib/dist/sync/watch-policy.d.ts +48 -0
  348. package/lib/dist/sync/watch-policy.d.ts.map +1 -0
  349. package/lib/dist/sync/watch-policy.js +124 -0
  350. package/lib/dist/sync/watch-policy.js.map +1 -0
  351. package/lib/dist/sync/watcher.d.ts +81 -0
  352. package/lib/dist/sync/watcher.d.ts.map +1 -0
  353. package/lib/dist/sync/watcher.js +194 -0
  354. package/lib/dist/sync/watcher.js.map +1 -0
  355. package/lib/dist/types.d.ts +423 -0
  356. package/lib/dist/types.d.ts.map +1 -0
  357. package/lib/dist/types.js +262 -0
  358. package/lib/dist/types.js.map +1 -0
  359. package/lib/dist/ui/glyphs.d.ts +42 -0
  360. package/lib/dist/ui/glyphs.d.ts.map +1 -0
  361. package/lib/dist/ui/glyphs.js +78 -0
  362. package/lib/dist/ui/glyphs.js.map +1 -0
  363. package/lib/dist/ui/shimmer-progress.d.ts +11 -0
  364. package/lib/dist/ui/shimmer-progress.d.ts.map +1 -0
  365. package/lib/dist/ui/shimmer-progress.js +90 -0
  366. package/lib/dist/ui/shimmer-progress.js.map +1 -0
  367. package/lib/dist/ui/shimmer-worker.d.ts +2 -0
  368. package/lib/dist/ui/shimmer-worker.d.ts.map +1 -0
  369. package/lib/dist/ui/shimmer-worker.js +118 -0
  370. package/lib/dist/ui/shimmer-worker.js.map +1 -0
  371. package/lib/dist/ui/types.d.ts +17 -0
  372. package/lib/dist/ui/types.d.ts.map +1 -0
  373. package/lib/dist/ui/types.js +3 -0
  374. package/lib/dist/ui/types.js.map +1 -0
  375. package/lib/dist/utils.d.ts +205 -0
  376. package/lib/dist/utils.d.ts.map +1 -0
  377. package/lib/dist/utils.js +549 -0
  378. package/lib/dist/utils.js.map +1 -0
  379. package/lib/node_modules/.package-lock.json +116 -0
  380. package/lib/node_modules/@clack/core/CHANGELOG.md +348 -0
  381. package/lib/node_modules/@clack/core/LICENSE +9 -0
  382. package/lib/node_modules/@clack/core/README.md +22 -0
  383. package/lib/node_modules/@clack/core/dist/index.d.mts +363 -0
  384. package/lib/node_modules/@clack/core/dist/index.mjs +17 -0
  385. package/lib/node_modules/@clack/core/dist/index.mjs.map +1 -0
  386. package/lib/node_modules/@clack/core/package.json +63 -0
  387. package/lib/node_modules/@clack/prompts/CHANGELOG.md +591 -0
  388. package/lib/node_modules/@clack/prompts/LICENSE +9 -0
  389. package/lib/node_modules/@clack/prompts/README.md +375 -0
  390. package/lib/node_modules/@clack/prompts/dist/index.d.mts +396 -0
  391. package/lib/node_modules/@clack/prompts/dist/index.mjs +144 -0
  392. package/lib/node_modules/@clack/prompts/dist/index.mjs.map +1 -0
  393. package/lib/node_modules/@clack/prompts/package.json +68 -0
  394. package/lib/node_modules/commander/LICENSE +22 -0
  395. package/lib/node_modules/commander/Readme.md +1176 -0
  396. package/lib/node_modules/commander/esm.mjs +16 -0
  397. package/lib/node_modules/commander/index.js +24 -0
  398. package/lib/node_modules/commander/lib/argument.js +150 -0
  399. package/lib/node_modules/commander/lib/command.js +2777 -0
  400. package/lib/node_modules/commander/lib/error.js +39 -0
  401. package/lib/node_modules/commander/lib/help.js +747 -0
  402. package/lib/node_modules/commander/lib/option.js +380 -0
  403. package/lib/node_modules/commander/lib/suggestSimilar.js +101 -0
  404. package/lib/node_modules/commander/package-support.json +19 -0
  405. package/lib/node_modules/commander/package.json +82 -0
  406. package/lib/node_modules/commander/typings/esm.d.mts +3 -0
  407. package/lib/node_modules/commander/typings/index.d.ts +1113 -0
  408. package/lib/node_modules/fast-string-truncated-width/dist/index.d.ts +4 -0
  409. package/lib/node_modules/fast-string-truncated-width/dist/index.js +111 -0
  410. package/lib/node_modules/fast-string-truncated-width/dist/types.d.ts +19 -0
  411. package/lib/node_modules/fast-string-truncated-width/dist/types.js +2 -0
  412. package/lib/node_modules/fast-string-truncated-width/dist/utils.d.ts +4 -0
  413. package/lib/node_modules/fast-string-truncated-width/dist/utils.js +20 -0
  414. package/lib/node_modules/fast-string-truncated-width/license +21 -0
  415. package/lib/node_modules/fast-string-truncated-width/package.json +35 -0
  416. package/lib/node_modules/fast-string-truncated-width/readme.md +59 -0
  417. package/lib/node_modules/fast-string-width/dist/index.d.ts +4 -0
  418. package/lib/node_modules/fast-string-width/dist/index.js +14 -0
  419. package/lib/node_modules/fast-string-width/license +21 -0
  420. package/lib/node_modules/fast-string-width/package.json +34 -0
  421. package/lib/node_modules/fast-string-width/readme.md +42 -0
  422. package/lib/node_modules/fast-wrap-ansi/LICENSE +23 -0
  423. package/lib/node_modules/fast-wrap-ansi/README.md +26 -0
  424. package/lib/node_modules/fast-wrap-ansi/lib/main.d.ts +6 -0
  425. package/lib/node_modules/fast-wrap-ansi/lib/main.js +219 -0
  426. package/lib/node_modules/fast-wrap-ansi/lib/main.js.map +1 -0
  427. package/lib/node_modules/fast-wrap-ansi/package.json +51 -0
  428. package/lib/node_modules/jsonc-parser/CHANGELOG.md +76 -0
  429. package/lib/node_modules/jsonc-parser/LICENSE.md +21 -0
  430. package/lib/node_modules/jsonc-parser/README.md +364 -0
  431. package/lib/node_modules/jsonc-parser/SECURITY.md +41 -0
  432. package/lib/node_modules/jsonc-parser/lib/esm/impl/edit.js +185 -0
  433. package/lib/node_modules/jsonc-parser/lib/esm/impl/format.js +261 -0
  434. package/lib/node_modules/jsonc-parser/lib/esm/impl/parser.js +659 -0
  435. package/lib/node_modules/jsonc-parser/lib/esm/impl/scanner.js +443 -0
  436. package/lib/node_modules/jsonc-parser/lib/esm/impl/string-intern.js +29 -0
  437. package/lib/node_modules/jsonc-parser/lib/esm/main.d.ts +351 -0
  438. package/lib/node_modules/jsonc-parser/lib/esm/main.js +178 -0
  439. package/lib/node_modules/jsonc-parser/lib/umd/impl/edit.js +201 -0
  440. package/lib/node_modules/jsonc-parser/lib/umd/impl/format.js +275 -0
  441. package/lib/node_modules/jsonc-parser/lib/umd/impl/parser.js +682 -0
  442. package/lib/node_modules/jsonc-parser/lib/umd/impl/scanner.js +456 -0
  443. package/lib/node_modules/jsonc-parser/lib/umd/impl/string-intern.js +42 -0
  444. package/lib/node_modules/jsonc-parser/lib/umd/main.d.ts +351 -0
  445. package/lib/node_modules/jsonc-parser/lib/umd/main.js +194 -0
  446. package/lib/node_modules/jsonc-parser/package.json +37 -0
  447. package/lib/node_modules/picomatch/LICENSE +21 -0
  448. package/lib/node_modules/picomatch/README.md +738 -0
  449. package/lib/node_modules/picomatch/index.js +17 -0
  450. package/lib/node_modules/picomatch/lib/constants.js +180 -0
  451. package/lib/node_modules/picomatch/lib/parse.js +1085 -0
  452. package/lib/node_modules/picomatch/lib/picomatch.js +341 -0
  453. package/lib/node_modules/picomatch/lib/scan.js +391 -0
  454. package/lib/node_modules/picomatch/lib/utils.js +72 -0
  455. package/lib/node_modules/picomatch/package.json +83 -0
  456. package/lib/node_modules/picomatch/posix.js +3 -0
  457. package/lib/node_modules/sisteransi/license +21 -0
  458. package/lib/node_modules/sisteransi/package.json +34 -0
  459. package/lib/node_modules/sisteransi/readme.md +113 -0
  460. package/lib/node_modules/sisteransi/src/index.js +58 -0
  461. package/lib/node_modules/sisteransi/src/sisteransi.d.ts +35 -0
  462. package/lib/node_modules/tree-sitter-wasms/LICENSE +24 -0
  463. package/lib/node_modules/tree-sitter-wasms/README.md +23 -0
  464. package/lib/node_modules/tree-sitter-wasms/out/tree-sitter-bash.wasm +0 -0
  465. package/lib/node_modules/tree-sitter-wasms/out/tree-sitter-c.wasm +0 -0
  466. package/lib/node_modules/tree-sitter-wasms/out/tree-sitter-c_sharp.wasm +0 -0
  467. package/lib/node_modules/tree-sitter-wasms/out/tree-sitter-cpp.wasm +0 -0
  468. package/lib/node_modules/tree-sitter-wasms/out/tree-sitter-css.wasm +0 -0
  469. package/lib/node_modules/tree-sitter-wasms/out/tree-sitter-dart.wasm +0 -0
  470. package/lib/node_modules/tree-sitter-wasms/out/tree-sitter-elisp.wasm +0 -0
  471. package/lib/node_modules/tree-sitter-wasms/out/tree-sitter-elixir.wasm +0 -0
  472. package/lib/node_modules/tree-sitter-wasms/out/tree-sitter-elm.wasm +0 -0
  473. package/lib/node_modules/tree-sitter-wasms/out/tree-sitter-embedded_template.wasm +0 -0
  474. package/lib/node_modules/tree-sitter-wasms/out/tree-sitter-go.wasm +0 -0
  475. package/lib/node_modules/tree-sitter-wasms/out/tree-sitter-html.wasm +0 -0
  476. package/lib/node_modules/tree-sitter-wasms/out/tree-sitter-java.wasm +0 -0
  477. package/lib/node_modules/tree-sitter-wasms/out/tree-sitter-javascript.wasm +0 -0
  478. package/lib/node_modules/tree-sitter-wasms/out/tree-sitter-json.wasm +0 -0
  479. package/lib/node_modules/tree-sitter-wasms/out/tree-sitter-kotlin.wasm +0 -0
  480. package/lib/node_modules/tree-sitter-wasms/out/tree-sitter-lua.wasm +0 -0
  481. package/lib/node_modules/tree-sitter-wasms/out/tree-sitter-objc.wasm +0 -0
  482. package/lib/node_modules/tree-sitter-wasms/out/tree-sitter-ocaml.wasm +0 -0
  483. package/lib/node_modules/tree-sitter-wasms/out/tree-sitter-php.wasm +0 -0
  484. package/lib/node_modules/tree-sitter-wasms/out/tree-sitter-python.wasm +0 -0
  485. package/lib/node_modules/tree-sitter-wasms/out/tree-sitter-ql.wasm +0 -0
  486. package/lib/node_modules/tree-sitter-wasms/out/tree-sitter-rescript.wasm +0 -0
  487. package/lib/node_modules/tree-sitter-wasms/out/tree-sitter-ruby.wasm +0 -0
  488. package/lib/node_modules/tree-sitter-wasms/out/tree-sitter-rust.wasm +0 -0
  489. package/lib/node_modules/tree-sitter-wasms/out/tree-sitter-scala.wasm +0 -0
  490. package/lib/node_modules/tree-sitter-wasms/out/tree-sitter-solidity.wasm +0 -0
  491. package/lib/node_modules/tree-sitter-wasms/out/tree-sitter-swift.wasm +0 -0
  492. package/lib/node_modules/tree-sitter-wasms/out/tree-sitter-systemrdl.wasm +0 -0
  493. package/lib/node_modules/tree-sitter-wasms/out/tree-sitter-tlaplus.wasm +0 -0
  494. package/lib/node_modules/tree-sitter-wasms/out/tree-sitter-toml.wasm +0 -0
  495. package/lib/node_modules/tree-sitter-wasms/out/tree-sitter-tsx.wasm +0 -0
  496. package/lib/node_modules/tree-sitter-wasms/out/tree-sitter-typescript.wasm +0 -0
  497. package/lib/node_modules/tree-sitter-wasms/out/tree-sitter-vue.wasm +0 -0
  498. package/lib/node_modules/tree-sitter-wasms/out/tree-sitter-yaml.wasm +0 -0
  499. package/lib/node_modules/tree-sitter-wasms/out/tree-sitter-zig.wasm +0 -0
  500. package/lib/node_modules/tree-sitter-wasms/package.json +64 -0
  501. package/lib/node_modules/web-tree-sitter/LICENSE +21 -0
  502. package/lib/node_modules/web-tree-sitter/README.md +269 -0
  503. package/lib/node_modules/web-tree-sitter/debug/tree-sitter.cjs +4558 -0
  504. package/lib/node_modules/web-tree-sitter/debug/tree-sitter.cjs.map +7 -0
  505. package/lib/node_modules/web-tree-sitter/debug/tree-sitter.js +4516 -0
  506. package/lib/node_modules/web-tree-sitter/debug/tree-sitter.js.map +7 -0
  507. package/lib/node_modules/web-tree-sitter/debug/tree-sitter.wasm +0 -0
  508. package/lib/node_modules/web-tree-sitter/debug/tree-sitter.wasm.map +31 -0
  509. package/lib/node_modules/web-tree-sitter/lib/alloc.c +48 -0
  510. package/lib/node_modules/web-tree-sitter/lib/alloc.h +41 -0
  511. package/lib/node_modules/web-tree-sitter/lib/array.h +291 -0
  512. package/lib/node_modules/web-tree-sitter/lib/atomic.h +68 -0
  513. package/lib/node_modules/web-tree-sitter/lib/clock.h +146 -0
  514. package/lib/node_modules/web-tree-sitter/lib/error_costs.h +11 -0
  515. package/lib/node_modules/web-tree-sitter/lib/get_changed_ranges.c +523 -0
  516. package/lib/node_modules/web-tree-sitter/lib/get_changed_ranges.h +36 -0
  517. package/lib/node_modules/web-tree-sitter/lib/host.h +21 -0
  518. package/lib/node_modules/web-tree-sitter/lib/language.c +293 -0
  519. package/lib/node_modules/web-tree-sitter/lib/language.h +293 -0
  520. package/lib/node_modules/web-tree-sitter/lib/length.h +52 -0
  521. package/lib/node_modules/web-tree-sitter/lib/lexer.c +483 -0
  522. package/lib/node_modules/web-tree-sitter/lib/lexer.h +54 -0
  523. package/lib/node_modules/web-tree-sitter/lib/lib.c +12 -0
  524. package/lib/node_modules/web-tree-sitter/lib/node.c +875 -0
  525. package/lib/node_modules/web-tree-sitter/lib/parser.c +2297 -0
  526. package/lib/node_modules/web-tree-sitter/lib/parser.h +286 -0
  527. package/lib/node_modules/web-tree-sitter/lib/point.h +48 -0
  528. package/lib/node_modules/web-tree-sitter/lib/query.c +4347 -0
  529. package/lib/node_modules/web-tree-sitter/lib/reduce_action.h +34 -0
  530. package/lib/node_modules/web-tree-sitter/lib/reusable_node.h +95 -0
  531. package/lib/node_modules/web-tree-sitter/lib/stack.c +912 -0
  532. package/lib/node_modules/web-tree-sitter/lib/stack.h +133 -0
  533. package/lib/node_modules/web-tree-sitter/lib/subtree.c +1034 -0
  534. package/lib/node_modules/web-tree-sitter/lib/subtree.h +399 -0
  535. package/lib/node_modules/web-tree-sitter/lib/tree-sitter.c +987 -0
  536. package/lib/node_modules/web-tree-sitter/lib/tree-sitter.cjs +2988 -0
  537. package/lib/node_modules/web-tree-sitter/lib/tree-sitter.wasm +0 -0
  538. package/lib/node_modules/web-tree-sitter/lib/tree-sitter.wasm.map +1 -0
  539. package/lib/node_modules/web-tree-sitter/lib/tree.c +170 -0
  540. package/lib/node_modules/web-tree-sitter/lib/tree.h +31 -0
  541. package/lib/node_modules/web-tree-sitter/lib/tree_cursor.c +716 -0
  542. package/lib/node_modules/web-tree-sitter/lib/tree_cursor.h +48 -0
  543. package/lib/node_modules/web-tree-sitter/lib/ts_assert.h +11 -0
  544. package/lib/node_modules/web-tree-sitter/lib/unicode.h +75 -0
  545. package/lib/node_modules/web-tree-sitter/lib/wasm_store.c +1937 -0
  546. package/lib/node_modules/web-tree-sitter/lib/wasm_store.h +31 -0
  547. package/lib/node_modules/web-tree-sitter/package.json +98 -0
  548. package/lib/node_modules/web-tree-sitter/src/bindings.ts +26 -0
  549. package/lib/node_modules/web-tree-sitter/src/constants.ts +133 -0
  550. package/lib/node_modules/web-tree-sitter/src/index.ts +31 -0
  551. package/lib/node_modules/web-tree-sitter/src/language.ts +291 -0
  552. package/lib/node_modules/web-tree-sitter/src/lookahead_iterator.ts +75 -0
  553. package/lib/node_modules/web-tree-sitter/src/marshal.ts +176 -0
  554. package/lib/node_modules/web-tree-sitter/src/node.ts +646 -0
  555. package/lib/node_modules/web-tree-sitter/src/parser.ts +325 -0
  556. package/lib/node_modules/web-tree-sitter/src/query.ts +973 -0
  557. package/lib/node_modules/web-tree-sitter/src/tree.ts +145 -0
  558. package/lib/node_modules/web-tree-sitter/src/tree_cursor.ts +318 -0
  559. package/lib/node_modules/web-tree-sitter/tree-sitter.cjs +4031 -0
  560. package/lib/node_modules/web-tree-sitter/tree-sitter.cjs.map +7 -0
  561. package/lib/node_modules/web-tree-sitter/tree-sitter.js +3980 -0
  562. package/lib/node_modules/web-tree-sitter/tree-sitter.js.map +7 -0
  563. package/lib/node_modules/web-tree-sitter/tree-sitter.wasm +0 -0
  564. package/lib/node_modules/web-tree-sitter/tree-sitter.wasm.map +30 -0
  565. package/lib/node_modules/web-tree-sitter/web-tree-sitter.d.ts +1030 -0
  566. package/lib/node_modules/web-tree-sitter/web-tree-sitter.d.ts.map +56 -0
  567. package/lib/package.json +55 -0
  568. package/node +0 -0
  569. package/package.json +17 -0
@@ -0,0 +1,523 @@
1
+ #include "./get_changed_ranges.h"
2
+ #include "./subtree.h"
3
+ #include "./language.h"
4
+ #include "./error_costs.h"
5
+ #include "./tree_cursor.h"
6
+ #include "./ts_assert.h"
7
+
8
+ // #define DEBUG_GET_CHANGED_RANGES
9
+
10
+ static void ts_range_array_add(
11
+ TSRangeArray *self,
12
+ Length start,
13
+ Length end
14
+ ) {
15
+ if (self->size > 0) {
16
+ TSRange *last_range = array_back(self);
17
+ if (start.bytes <= last_range->end_byte) {
18
+ last_range->end_byte = end.bytes;
19
+ last_range->end_point = end.extent;
20
+ return;
21
+ }
22
+ }
23
+
24
+ if (start.bytes < end.bytes) {
25
+ TSRange range = { start.extent, end.extent, start.bytes, end.bytes };
26
+ array_push(self, range);
27
+ }
28
+ }
29
+
30
+ bool ts_range_array_intersects(
31
+ const TSRangeArray *self,
32
+ unsigned start_index,
33
+ uint32_t start_byte,
34
+ uint32_t end_byte
35
+ ) {
36
+ for (unsigned i = start_index; i < self->size; i++) {
37
+ TSRange *range = array_get(self, i);
38
+ if (range->end_byte > start_byte) {
39
+ if (range->start_byte >= end_byte) break;
40
+ return true;
41
+ }
42
+ }
43
+ return false;
44
+ }
45
+
46
+ void ts_range_array_get_changed_ranges(
47
+ const TSRange *old_ranges, unsigned old_range_count,
48
+ const TSRange *new_ranges, unsigned new_range_count,
49
+ TSRangeArray *differences
50
+ ) {
51
+ unsigned new_index = 0;
52
+ unsigned old_index = 0;
53
+ Length current_position = length_zero();
54
+ bool in_old_range = false;
55
+ bool in_new_range = false;
56
+
57
+ while (old_index < old_range_count || new_index < new_range_count) {
58
+ const TSRange *old_range = &old_ranges[old_index];
59
+ const TSRange *new_range = &new_ranges[new_index];
60
+
61
+ Length next_old_position;
62
+ if (in_old_range) {
63
+ next_old_position = (Length) {old_range->end_byte, old_range->end_point};
64
+ } else if (old_index < old_range_count) {
65
+ next_old_position = (Length) {old_range->start_byte, old_range->start_point};
66
+ } else {
67
+ next_old_position = LENGTH_MAX;
68
+ }
69
+
70
+ Length next_new_position;
71
+ if (in_new_range) {
72
+ next_new_position = (Length) {new_range->end_byte, new_range->end_point};
73
+ } else if (new_index < new_range_count) {
74
+ next_new_position = (Length) {new_range->start_byte, new_range->start_point};
75
+ } else {
76
+ next_new_position = LENGTH_MAX;
77
+ }
78
+
79
+ if (next_old_position.bytes < next_new_position.bytes) {
80
+ if (in_old_range != in_new_range) {
81
+ ts_range_array_add(differences, current_position, next_old_position);
82
+ }
83
+ if (in_old_range) old_index++;
84
+ current_position = next_old_position;
85
+ in_old_range = !in_old_range;
86
+ } else if (next_new_position.bytes < next_old_position.bytes) {
87
+ if (in_old_range != in_new_range) {
88
+ ts_range_array_add(differences, current_position, next_new_position);
89
+ }
90
+ if (in_new_range) new_index++;
91
+ current_position = next_new_position;
92
+ in_new_range = !in_new_range;
93
+ } else {
94
+ if (in_old_range != in_new_range) {
95
+ ts_range_array_add(differences, current_position, next_new_position);
96
+ }
97
+ if (in_old_range) old_index++;
98
+ if (in_new_range) new_index++;
99
+ in_old_range = !in_old_range;
100
+ in_new_range = !in_new_range;
101
+ current_position = next_new_position;
102
+ }
103
+ }
104
+ }
105
+
106
+ typedef struct {
107
+ TreeCursor cursor;
108
+ const TSLanguage *language;
109
+ unsigned visible_depth;
110
+ bool in_padding;
111
+ Subtree prev_external_token;
112
+ } Iterator;
113
+
114
+ static Iterator iterator_new(
115
+ TreeCursor *cursor,
116
+ const Subtree *tree,
117
+ const TSLanguage *language
118
+ ) {
119
+ array_clear(&cursor->stack);
120
+ array_push(&cursor->stack, ((TreeCursorEntry) {
121
+ .subtree = tree,
122
+ .position = length_zero(),
123
+ .child_index = 0,
124
+ .structural_child_index = 0,
125
+ }));
126
+ return (Iterator) {
127
+ .cursor = *cursor,
128
+ .language = language,
129
+ .visible_depth = 1,
130
+ .in_padding = false,
131
+ .prev_external_token = NULL_SUBTREE,
132
+ };
133
+ }
134
+
135
+ static bool iterator_done(Iterator *self) {
136
+ return self->cursor.stack.size == 0;
137
+ }
138
+
139
+ static Length iterator_start_position(Iterator *self) {
140
+ TreeCursorEntry entry = *array_back(&self->cursor.stack);
141
+ if (self->in_padding) {
142
+ return entry.position;
143
+ } else {
144
+ return length_add(entry.position, ts_subtree_padding(*entry.subtree));
145
+ }
146
+ }
147
+
148
+ static Length iterator_end_position(Iterator *self) {
149
+ TreeCursorEntry entry = *array_back(&self->cursor.stack);
150
+ Length result = length_add(entry.position, ts_subtree_padding(*entry.subtree));
151
+ if (self->in_padding) {
152
+ return result;
153
+ } else {
154
+ return length_add(result, ts_subtree_size(*entry.subtree));
155
+ }
156
+ }
157
+
158
+ static bool iterator_tree_is_visible(const Iterator *self) {
159
+ TreeCursorEntry entry = *array_back(&self->cursor.stack);
160
+ if (ts_subtree_visible(*entry.subtree)) return true;
161
+ if (self->cursor.stack.size > 1) {
162
+ Subtree parent = *array_get(&self->cursor.stack, self->cursor.stack.size - 2)->subtree;
163
+ return ts_language_alias_at(
164
+ self->language,
165
+ parent.ptr->production_id,
166
+ entry.structural_child_index
167
+ ) != 0;
168
+ }
169
+ return false;
170
+ }
171
+
172
+ static void iterator_get_visible_state(
173
+ const Iterator *self,
174
+ Subtree *tree,
175
+ TSSymbol *alias_symbol,
176
+ uint32_t *start_byte
177
+ ) {
178
+ uint32_t i = self->cursor.stack.size - 1;
179
+
180
+ if (self->in_padding) {
181
+ if (i == 0) return;
182
+ i--;
183
+ }
184
+
185
+ for (; i + 1 > 0; i--) {
186
+ TreeCursorEntry entry = *array_get(&self->cursor.stack, i);
187
+
188
+ if (i > 0) {
189
+ const Subtree *parent = array_get(&self->cursor.stack, i - 1)->subtree;
190
+ *alias_symbol = ts_language_alias_at(
191
+ self->language,
192
+ parent->ptr->production_id,
193
+ entry.structural_child_index
194
+ );
195
+ }
196
+
197
+ if (ts_subtree_visible(*entry.subtree) || *alias_symbol) {
198
+ *tree = *entry.subtree;
199
+ *start_byte = entry.position.bytes;
200
+ break;
201
+ }
202
+ }
203
+ }
204
+
205
+ static void iterator_ascend(Iterator *self) {
206
+ if (iterator_done(self)) return;
207
+ if (iterator_tree_is_visible(self) && !self->in_padding) self->visible_depth--;
208
+ if (array_back(&self->cursor.stack)->child_index > 0) self->in_padding = false;
209
+ self->cursor.stack.size--;
210
+ }
211
+
212
+ static bool iterator_descend(Iterator *self, uint32_t goal_position) {
213
+ if (self->in_padding) return false;
214
+
215
+ bool did_descend = false;
216
+ do {
217
+ did_descend = false;
218
+ TreeCursorEntry entry = *array_back(&self->cursor.stack);
219
+ Length position = entry.position;
220
+ uint32_t structural_child_index = 0;
221
+ for (uint32_t i = 0, n = ts_subtree_child_count(*entry.subtree); i < n; i++) {
222
+ const Subtree *child = &ts_subtree_children(*entry.subtree)[i];
223
+ Length child_left = length_add(position, ts_subtree_padding(*child));
224
+ Length child_right = length_add(child_left, ts_subtree_size(*child));
225
+
226
+ if (child_right.bytes > goal_position) {
227
+ array_push(&self->cursor.stack, ((TreeCursorEntry) {
228
+ .subtree = child,
229
+ .position = position,
230
+ .child_index = i,
231
+ .structural_child_index = structural_child_index,
232
+ }));
233
+
234
+ if (iterator_tree_is_visible(self)) {
235
+ if (child_left.bytes > goal_position) {
236
+ self->in_padding = true;
237
+ } else {
238
+ self->visible_depth++;
239
+ }
240
+ return true;
241
+ }
242
+
243
+ did_descend = true;
244
+ break;
245
+ }
246
+
247
+ position = child_right;
248
+ if (!ts_subtree_extra(*child)) structural_child_index++;
249
+ Subtree last_external_token = ts_subtree_last_external_token(*child);
250
+ if (last_external_token.ptr) {
251
+ self->prev_external_token = last_external_token;
252
+ }
253
+ }
254
+ } while (did_descend);
255
+
256
+ return false;
257
+ }
258
+
259
+ static void iterator_advance(Iterator *self) {
260
+ if (self->in_padding) {
261
+ self->in_padding = false;
262
+ if (iterator_tree_is_visible(self)) {
263
+ self->visible_depth++;
264
+ } else {
265
+ iterator_descend(self, 0);
266
+ }
267
+ return;
268
+ }
269
+
270
+ for (;;) {
271
+ if (iterator_tree_is_visible(self)) self->visible_depth--;
272
+ TreeCursorEntry entry = array_pop(&self->cursor.stack);
273
+ if (iterator_done(self)) return;
274
+
275
+ const Subtree *parent = array_back(&self->cursor.stack)->subtree;
276
+ uint32_t child_index = entry.child_index + 1;
277
+ Subtree last_external_token = ts_subtree_last_external_token(*entry.subtree);
278
+ if (last_external_token.ptr) {
279
+ self->prev_external_token = last_external_token;
280
+ }
281
+ if (ts_subtree_child_count(*parent) > child_index) {
282
+ Length position = length_add(entry.position, ts_subtree_total_size(*entry.subtree));
283
+ uint32_t structural_child_index = entry.structural_child_index;
284
+ if (!ts_subtree_extra(*entry.subtree)) structural_child_index++;
285
+ const Subtree *next_child = &ts_subtree_children(*parent)[child_index];
286
+
287
+ array_push(&self->cursor.stack, ((TreeCursorEntry) {
288
+ .subtree = next_child,
289
+ .position = position,
290
+ .child_index = child_index,
291
+ .structural_child_index = structural_child_index,
292
+ }));
293
+
294
+ if (iterator_tree_is_visible(self)) {
295
+ if (ts_subtree_padding(*next_child).bytes > 0) {
296
+ self->in_padding = true;
297
+ } else {
298
+ self->visible_depth++;
299
+ }
300
+ } else {
301
+ iterator_descend(self, 0);
302
+ }
303
+ break;
304
+ }
305
+ }
306
+ }
307
+
308
+ typedef enum {
309
+ IteratorDiffers,
310
+ IteratorMayDiffer,
311
+ IteratorMatches,
312
+ } IteratorComparison;
313
+
314
+ static IteratorComparison iterator_compare(
315
+ const Iterator *old_iter,
316
+ const Iterator *new_iter
317
+ ) {
318
+ Subtree old_tree = NULL_SUBTREE;
319
+ Subtree new_tree = NULL_SUBTREE;
320
+ uint32_t old_start = 0;
321
+ uint32_t new_start = 0;
322
+ TSSymbol old_alias_symbol = 0;
323
+ TSSymbol new_alias_symbol = 0;
324
+ iterator_get_visible_state(old_iter, &old_tree, &old_alias_symbol, &old_start);
325
+ iterator_get_visible_state(new_iter, &new_tree, &new_alias_symbol, &new_start);
326
+ TSSymbol old_symbol = ts_subtree_symbol(old_tree);
327
+ TSSymbol new_symbol = ts_subtree_symbol(new_tree);
328
+
329
+ if (!old_tree.ptr && !new_tree.ptr) return IteratorMatches;
330
+ if (!old_tree.ptr || !new_tree.ptr) return IteratorDiffers;
331
+ if (old_alias_symbol != new_alias_symbol || old_symbol != new_symbol) return IteratorDiffers;
332
+
333
+ uint32_t old_size = ts_subtree_size(old_tree).bytes;
334
+ uint32_t new_size = ts_subtree_size(new_tree).bytes;
335
+ TSStateId old_state = ts_subtree_parse_state(old_tree);
336
+ TSStateId new_state = ts_subtree_parse_state(new_tree);
337
+ bool old_has_external_tokens = ts_subtree_has_external_tokens(old_tree);
338
+ bool new_has_external_tokens = ts_subtree_has_external_tokens(new_tree);
339
+ uint32_t old_error_cost = ts_subtree_error_cost(old_tree);
340
+ uint32_t new_error_cost = ts_subtree_error_cost(new_tree);
341
+
342
+ if (
343
+ old_start != new_start ||
344
+ old_symbol == ts_builtin_sym_error ||
345
+ old_size != new_size ||
346
+ old_state == TS_TREE_STATE_NONE ||
347
+ new_state == TS_TREE_STATE_NONE ||
348
+ ((old_state == ERROR_STATE) != (new_state == ERROR_STATE)) ||
349
+ old_error_cost != new_error_cost ||
350
+ old_has_external_tokens != new_has_external_tokens ||
351
+ ts_subtree_has_changes(old_tree) ||
352
+ (
353
+ old_has_external_tokens &&
354
+ !ts_subtree_external_scanner_state_eq(old_iter->prev_external_token, new_iter->prev_external_token)
355
+ )
356
+ ) {
357
+ return IteratorMayDiffer;
358
+ }
359
+
360
+ return IteratorMatches;
361
+ }
362
+
363
+ #ifdef DEBUG_GET_CHANGED_RANGES
364
+ static inline void iterator_print_state(Iterator *self) {
365
+ TreeCursorEntry entry = *array_back(&self->cursor.stack);
366
+ TSPoint start = iterator_start_position(self).extent;
367
+ TSPoint end = iterator_end_position(self).extent;
368
+ const char *name = ts_language_symbol_name(self->language, ts_subtree_symbol(*entry.subtree));
369
+ printf(
370
+ "(%-25s %s\t depth:%u [%u, %u] - [%u, %u])",
371
+ name, self->in_padding ? "(p)" : " ",
372
+ self->visible_depth,
373
+ start.row, start.column,
374
+ end.row, end.column
375
+ );
376
+ }
377
+ #endif
378
+
379
+ unsigned ts_subtree_get_changed_ranges(
380
+ const Subtree *old_tree, const Subtree *new_tree,
381
+ TreeCursor *cursor1, TreeCursor *cursor2,
382
+ const TSLanguage *language,
383
+ const TSRangeArray *included_range_differences,
384
+ TSRange **ranges
385
+ ) {
386
+ TSRangeArray results = array_new();
387
+
388
+ Iterator old_iter = iterator_new(cursor1, old_tree, language);
389
+ Iterator new_iter = iterator_new(cursor2, new_tree, language);
390
+
391
+ unsigned included_range_difference_index = 0;
392
+
393
+ Length position = iterator_start_position(&old_iter);
394
+ Length next_position = iterator_start_position(&new_iter);
395
+ if (position.bytes < next_position.bytes) {
396
+ ts_range_array_add(&results, position, next_position);
397
+ position = next_position;
398
+ } else if (position.bytes > next_position.bytes) {
399
+ ts_range_array_add(&results, next_position, position);
400
+ next_position = position;
401
+ }
402
+
403
+ do {
404
+ #ifdef DEBUG_GET_CHANGED_RANGES
405
+ printf("At [%-2u, %-2u] Compare ", position.extent.row, position.extent.column);
406
+ iterator_print_state(&old_iter);
407
+ printf("\tvs\t");
408
+ iterator_print_state(&new_iter);
409
+ puts("");
410
+ #endif
411
+
412
+ // Compare the old and new subtrees.
413
+ IteratorComparison comparison = iterator_compare(&old_iter, &new_iter);
414
+
415
+ // Even if the two subtrees appear to be identical, they could differ
416
+ // internally if they contain a range of text that was previously
417
+ // excluded from the parse, and is now included, or vice-versa.
418
+ if (comparison == IteratorMatches && ts_range_array_intersects(
419
+ included_range_differences,
420
+ included_range_difference_index,
421
+ position.bytes,
422
+ iterator_end_position(&old_iter).bytes
423
+ )) {
424
+ comparison = IteratorMayDiffer;
425
+ }
426
+
427
+ bool is_changed = false;
428
+ switch (comparison) {
429
+ // If the subtrees are definitely identical, move to the end
430
+ // of both subtrees.
431
+ case IteratorMatches:
432
+ next_position = iterator_end_position(&old_iter);
433
+ break;
434
+
435
+ // If the subtrees might differ internally, descend into both
436
+ // subtrees, finding the first child that spans the current position.
437
+ case IteratorMayDiffer:
438
+ if (iterator_descend(&old_iter, position.bytes)) {
439
+ if (!iterator_descend(&new_iter, position.bytes)) {
440
+ is_changed = true;
441
+ next_position = iterator_end_position(&old_iter);
442
+ }
443
+ } else if (iterator_descend(&new_iter, position.bytes)) {
444
+ is_changed = true;
445
+ next_position = iterator_end_position(&new_iter);
446
+ } else {
447
+ next_position = length_min(
448
+ iterator_end_position(&old_iter),
449
+ iterator_end_position(&new_iter)
450
+ );
451
+ }
452
+ break;
453
+
454
+ // If the subtrees are different, record a change and then move
455
+ // to the end of both subtrees.
456
+ case IteratorDiffers:
457
+ is_changed = true;
458
+ next_position = length_min(
459
+ iterator_end_position(&old_iter),
460
+ iterator_end_position(&new_iter)
461
+ );
462
+ break;
463
+ }
464
+
465
+ // Ensure that both iterators are caught up to the current position.
466
+ while (
467
+ !iterator_done(&old_iter) &&
468
+ iterator_end_position(&old_iter).bytes <= next_position.bytes
469
+ ) iterator_advance(&old_iter);
470
+ while (
471
+ !iterator_done(&new_iter) &&
472
+ iterator_end_position(&new_iter).bytes <= next_position.bytes
473
+ ) iterator_advance(&new_iter);
474
+
475
+ // Ensure that both iterators are at the same depth in the tree.
476
+ while (old_iter.visible_depth > new_iter.visible_depth) {
477
+ iterator_ascend(&old_iter);
478
+ }
479
+ while (new_iter.visible_depth > old_iter.visible_depth) {
480
+ iterator_ascend(&new_iter);
481
+ }
482
+
483
+ if (is_changed) {
484
+ #ifdef DEBUG_GET_CHANGED_RANGES
485
+ printf(
486
+ " change: [[%u, %u] - [%u, %u]]\n",
487
+ position.extent.row + 1, position.extent.column,
488
+ next_position.extent.row + 1, next_position.extent.column
489
+ );
490
+ #endif
491
+
492
+ ts_range_array_add(&results, position, next_position);
493
+ }
494
+
495
+ position = next_position;
496
+
497
+ // Keep track of the current position in the included range differences
498
+ // array in order to avoid scanning the entire array on each iteration.
499
+ while (included_range_difference_index < included_range_differences->size) {
500
+ const TSRange *range = array_get(included_range_differences,
501
+ included_range_difference_index
502
+ );
503
+ if (range->end_byte <= position.bytes) {
504
+ included_range_difference_index++;
505
+ } else {
506
+ break;
507
+ }
508
+ }
509
+ } while (!iterator_done(&old_iter) && !iterator_done(&new_iter));
510
+
511
+ Length old_size = ts_subtree_total_size(*old_tree);
512
+ Length new_size = ts_subtree_total_size(*new_tree);
513
+ if (old_size.bytes < new_size.bytes) {
514
+ ts_range_array_add(&results, old_size, new_size);
515
+ } else if (new_size.bytes < old_size.bytes) {
516
+ ts_range_array_add(&results, new_size, old_size);
517
+ }
518
+
519
+ *cursor1 = old_iter.cursor;
520
+ *cursor2 = new_iter.cursor;
521
+ *ranges = results.contents;
522
+ return results.size;
523
+ }
@@ -0,0 +1,36 @@
1
+ #ifndef TREE_SITTER_GET_CHANGED_RANGES_H_
2
+ #define TREE_SITTER_GET_CHANGED_RANGES_H_
3
+
4
+ #ifdef __cplusplus
5
+ extern "C" {
6
+ #endif
7
+
8
+ #include "./tree_cursor.h"
9
+ #include "./subtree.h"
10
+
11
+ typedef Array(TSRange) TSRangeArray;
12
+
13
+ void ts_range_array_get_changed_ranges(
14
+ const TSRange *old_ranges, unsigned old_range_count,
15
+ const TSRange *new_ranges, unsigned new_range_count,
16
+ TSRangeArray *differences
17
+ );
18
+
19
+ bool ts_range_array_intersects(
20
+ const TSRangeArray *self, unsigned start_index,
21
+ uint32_t start_byte, uint32_t end_byte
22
+ );
23
+
24
+ unsigned ts_subtree_get_changed_ranges(
25
+ const Subtree *old_tree, const Subtree *new_tree,
26
+ TreeCursor *cursor1, TreeCursor *cursor2,
27
+ const TSLanguage *language,
28
+ const TSRangeArray *included_range_differences,
29
+ TSRange **ranges
30
+ );
31
+
32
+ #ifdef __cplusplus
33
+ }
34
+ #endif
35
+
36
+ #endif // TREE_SITTER_GET_CHANGED_RANGES_H_
@@ -0,0 +1,21 @@
1
+
2
+ // Determine endian and pointer size based on known defines.
3
+ // TS_BIG_ENDIAN and TS_PTR_SIZE can be set as -D compiler arguments
4
+ // to override this.
5
+
6
+ #if !defined(TS_BIG_ENDIAN)
7
+ #if (defined(__BYTE_ORDER__) && __BYTE_ORDER__ == __ORDER_BIG_ENDIAN__) \
8
+ || (defined( __APPLE_CC__) && (defined(__ppc__) || defined(__ppc64__)))
9
+ #define TS_BIG_ENDIAN 1
10
+ #else
11
+ #define TS_BIG_ENDIAN 0
12
+ #endif
13
+ #endif
14
+
15
+ #if !defined(TS_PTR_SIZE)
16
+ #if UINTPTR_MAX == 0xFFFFFFFF
17
+ #define TS_PTR_SIZE 32
18
+ #else
19
+ #define TS_PTR_SIZE 64
20
+ #endif
21
+ #endif