@entelligentsia/forgecli 0.11.3 → 0.19.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 (1099) hide show
  1. package/CHANGELOG.md +380 -0
  2. package/README.md +2 -1
  3. package/dist/CHANGELOG-forge-plugin.md +183 -0
  4. package/dist/CHANGELOG-pi.md +55 -0
  5. package/dist/bin/argv.d.ts +2 -0
  6. package/dist/bin/argv.js +3 -1
  7. package/dist/bin/argv.js.map +1 -1
  8. package/dist/bin/config.d.ts +5 -0
  9. package/dist/bin/config.js +25 -4
  10. package/dist/bin/config.js.map +1 -1
  11. package/dist/bin/forge.js +12 -37
  12. package/dist/bin/forge.js.map +1 -1
  13. package/dist/bin/shared-parser.d.ts +23 -0
  14. package/dist/bin/shared-parser.js +12 -0
  15. package/dist/bin/shared-parser.js.map +1 -0
  16. package/dist/bin/update-cli.js +5 -0
  17. package/dist/bin/update-cli.js.map +1 -1
  18. package/dist/extensions/forgecli/approve.d.ts +4 -6
  19. package/dist/extensions/forgecli/approve.js +8 -73
  20. package/dist/extensions/forgecli/approve.js.map +1 -1
  21. package/dist/extensions/forgecli/audience-gate.d.ts +1 -1
  22. package/dist/extensions/forgecli/calibrate.d.ts +4 -1
  23. package/dist/extensions/forgecli/calibrate.js +4 -12
  24. package/dist/extensions/forgecli/calibrate.js.map +1 -1
  25. package/dist/extensions/forgecli/collate.d.ts +4 -6
  26. package/dist/extensions/forgecli/collate.js +8 -73
  27. package/dist/extensions/forgecli/collate.js.map +1 -1
  28. package/dist/extensions/forgecli/commit.d.ts +4 -6
  29. package/dist/extensions/forgecli/commit.js +8 -73
  30. package/dist/extensions/forgecli/commit.js.map +1 -1
  31. package/dist/extensions/forgecli/config-layer.d.ts +15 -0
  32. package/dist/extensions/forgecli/config-layer.js.map +1 -1
  33. package/dist/extensions/forgecli/config-tui/handler.js +1 -0
  34. package/dist/extensions/forgecli/config-tui/handler.js.map +1 -1
  35. package/dist/extensions/forgecli/config-tui/screens/tier-menu.js +8 -1
  36. package/dist/extensions/forgecli/config-tui/screens/tier-menu.js.map +1 -1
  37. package/dist/extensions/forgecli/config-tui/state/init.js +1 -0
  38. package/dist/extensions/forgecli/config-tui/state/init.js.map +1 -1
  39. package/dist/extensions/forgecli/config-tui/state/model.d.ts +4 -0
  40. package/dist/extensions/forgecli/enhance.d.ts +4 -6
  41. package/dist/extensions/forgecli/enhance.js +9 -74
  42. package/dist/extensions/forgecli/enhance.js.map +1 -1
  43. package/dist/extensions/forgecli/fix-bug.d.ts +3 -0
  44. package/dist/extensions/forgecli/fix-bug.js +58 -46
  45. package/dist/extensions/forgecli/fix-bug.js.map +1 -1
  46. package/dist/extensions/forgecli/forge-artifact-tool.d.ts +2 -0
  47. package/dist/extensions/forgecli/forge-artifact-tool.js +185 -0
  48. package/dist/extensions/forgecli/forge-artifact-tool.js.map +1 -0
  49. package/dist/extensions/forgecli/forge-cli-schema.json +19 -0
  50. package/dist/extensions/forgecli/forge-init/phase-descriptors.d.ts +72 -0
  51. package/dist/extensions/forgecli/forge-init/phase-descriptors.js +350 -0
  52. package/dist/extensions/forgecli/forge-init/phase-descriptors.js.map +1 -0
  53. package/dist/extensions/forgecli/forge-init/phase4-register.d.ts +20 -0
  54. package/dist/extensions/forgecli/forge-init/phase4-register.js +353 -0
  55. package/dist/extensions/forgecli/forge-init/phase4-register.js.map +1 -0
  56. package/dist/extensions/forgecli/forge-init/prompts.d.ts +10 -0
  57. package/dist/extensions/forgecli/forge-init/prompts.js +91 -0
  58. package/dist/extensions/forgecli/forge-init/prompts.js.map +1 -0
  59. package/dist/extensions/forgecli/forge-init/verifiers.d.ts +20 -0
  60. package/dist/extensions/forgecli/forge-init/verifiers.js +81 -0
  61. package/dist/extensions/forgecli/forge-init/verifiers.js.map +1 -0
  62. package/dist/extensions/forgecli/forge-init.js +106 -748
  63. package/dist/extensions/forgecli/forge-init.js.map +1 -1
  64. package/dist/extensions/forgecli/forge-root.d.ts +0 -1
  65. package/dist/extensions/forgecli/forge-root.js +1 -11
  66. package/dist/extensions/forgecli/forge-root.js.map +1 -1
  67. package/dist/extensions/forgecli/forge-subagent.d.ts +11 -1
  68. package/dist/extensions/forgecli/forge-subagent.js +6 -1
  69. package/dist/extensions/forgecli/forge-subagent.js.map +1 -1
  70. package/dist/extensions/forgecli/forge-tools.d.ts +27 -7
  71. package/dist/extensions/forgecli/forge-tools.js +183 -64
  72. package/dist/extensions/forgecli/forge-tools.js.map +1 -1
  73. package/dist/extensions/forgecli/forge-update-command.js +29 -18
  74. package/dist/extensions/forgecli/forge-update-command.js.map +1 -1
  75. package/dist/extensions/forgecli/friction-emit.d.ts +99 -0
  76. package/dist/extensions/forgecli/friction-emit.js +247 -0
  77. package/dist/extensions/forgecli/friction-emit.js.map +1 -0
  78. package/dist/extensions/forgecli/health-check.js +1 -1
  79. package/dist/extensions/forgecli/health-check.js.map +1 -1
  80. package/dist/extensions/forgecli/hook-dispatcher.d.ts +1 -0
  81. package/dist/extensions/forgecli/hook-dispatcher.js +25 -0
  82. package/dist/extensions/forgecli/hook-dispatcher.js.map +1 -1
  83. package/dist/extensions/forgecli/hooks/post-init-hook.js +1 -1
  84. package/dist/extensions/forgecli/hooks/post-sprint-hook.js +1 -1
  85. package/dist/extensions/forgecli/hooks/write-guard.js +1 -1
  86. package/dist/extensions/forgecli/hooks/write-guard.js.map +1 -1
  87. package/dist/extensions/forgecli/implement.d.ts +4 -6
  88. package/dist/extensions/forgecli/implement.js +8 -73
  89. package/dist/extensions/forgecli/implement.js.map +1 -1
  90. package/dist/extensions/forgecli/index.js +27 -26
  91. package/dist/extensions/forgecli/index.js.map +1 -1
  92. package/dist/extensions/forgecli/lib/catalog-helpers.d.ts +13 -0
  93. package/dist/extensions/forgecli/lib/catalog-helpers.js +51 -0
  94. package/dist/extensions/forgecli/lib/catalog-helpers.js.map +1 -0
  95. package/dist/extensions/forgecli/lib/catalog-loader.d.ts +46 -0
  96. package/dist/extensions/forgecli/lib/catalog-loader.js +176 -0
  97. package/dist/extensions/forgecli/lib/catalog-loader.js.map +1 -0
  98. package/dist/extensions/forgecli/lib/catalog-types.d.ts +16 -0
  99. package/dist/extensions/forgecli/lib/catalog-types.js +161 -0
  100. package/dist/extensions/forgecli/lib/catalog-types.js.map +1 -0
  101. package/dist/extensions/forgecli/lib/exec-helpers.d.ts +25 -0
  102. package/dist/extensions/forgecli/lib/exec-helpers.js +52 -0
  103. package/dist/extensions/forgecli/lib/exec-helpers.js.map +1 -0
  104. package/dist/extensions/forgecli/lib/forge-config.d.ts +20 -0
  105. package/dist/extensions/forgecli/lib/forge-config.js +43 -0
  106. package/dist/extensions/forgecli/lib/forge-config.js.map +1 -0
  107. package/dist/extensions/forgecli/lib/frontmatter-parser.d.ts +13 -0
  108. package/dist/extensions/forgecli/lib/frontmatter-parser.js +56 -0
  109. package/dist/extensions/forgecli/lib/frontmatter-parser.js.map +1 -0
  110. package/dist/extensions/forgecli/lib/manifest-checker.d.ts +22 -0
  111. package/dist/extensions/forgecli/lib/manifest-checker.js +64 -0
  112. package/dist/extensions/forgecli/lib/manifest-checker.js.map +1 -0
  113. package/dist/extensions/forgecli/lib/orchestrator-preflight.d.ts +46 -0
  114. package/dist/extensions/forgecli/lib/orchestrator-preflight.js +64 -0
  115. package/dist/extensions/forgecli/lib/orchestrator-preflight.js.map +1 -0
  116. package/dist/extensions/forgecli/lib/orchestrator-types.d.ts +20 -0
  117. package/dist/extensions/forgecli/lib/orchestrator-types.js +14 -0
  118. package/dist/extensions/forgecli/lib/orchestrator-types.js.map +1 -0
  119. package/dist/extensions/forgecli/lib/parsers.d.ts +25 -0
  120. package/dist/extensions/forgecli/lib/parsers.js +164 -0
  121. package/dist/extensions/forgecli/lib/parsers.js.map +1 -0
  122. package/dist/extensions/forgecli/lib/shared-fs-utils.d.ts +12 -0
  123. package/dist/extensions/forgecli/lib/shared-fs-utils.js +37 -0
  124. package/dist/extensions/forgecli/lib/shared-fs-utils.js.map +1 -0
  125. package/dist/extensions/forgecli/lib/spawn-store-cli.d.ts +44 -0
  126. package/dist/extensions/forgecli/lib/spawn-store-cli.js +93 -0
  127. package/dist/extensions/forgecli/lib/spawn-store-cli.js.map +1 -0
  128. package/dist/extensions/forgecli/lib/state-helpers.d.ts +33 -0
  129. package/dist/extensions/forgecli/lib/state-helpers.js +69 -0
  130. package/dist/extensions/forgecli/lib/state-helpers.js.map +1 -0
  131. package/dist/extensions/forgecli/lib/store-cli-timeouts.d.ts +4 -0
  132. package/dist/extensions/forgecli/lib/store-cli-timeouts.js +10 -0
  133. package/dist/extensions/forgecli/lib/store-cli-timeouts.js.map +1 -0
  134. package/dist/extensions/forgecli/lib/versions.d.ts +56 -0
  135. package/dist/extensions/forgecli/lib/versions.js +116 -0
  136. package/dist/extensions/forgecli/lib/versions.js.map +1 -0
  137. package/dist/extensions/forgecli/loaders/persona-skill-loader.js +2 -2
  138. package/dist/extensions/forgecli/loaders/persona-skill-loader.js.map +1 -1
  139. package/dist/extensions/forgecli/migration-engine.d.ts +6 -0
  140. package/dist/extensions/forgecli/migration-engine.js +59 -39
  141. package/dist/extensions/forgecli/migration-engine.js.map +1 -1
  142. package/dist/extensions/forgecli/parsers/persona-skill-loader.d.ts +45 -0
  143. package/dist/extensions/forgecli/parsers/persona-skill-loader.js +201 -0
  144. package/dist/extensions/forgecli/parsers/persona-skill-loader.js.map +1 -0
  145. package/dist/extensions/forgecli/parsers/workflow-loader.d.ts +41 -0
  146. package/dist/extensions/forgecli/parsers/workflow-loader.js +87 -0
  147. package/dist/extensions/forgecli/parsers/workflow-loader.js.map +1 -0
  148. package/dist/extensions/forgecli/plan.d.ts +4 -6
  149. package/dist/extensions/forgecli/plan.js +9 -73
  150. package/dist/extensions/forgecli/plan.js.map +1 -1
  151. package/dist/extensions/forgecli/regenerate.d.ts +22 -0
  152. package/dist/extensions/forgecli/regenerate.js +133 -3
  153. package/dist/extensions/forgecli/regenerate.js.map +1 -1
  154. package/dist/extensions/forgecli/retrospective.d.ts +2 -1
  155. package/dist/extensions/forgecli/retrospective.js +6 -36
  156. package/dist/extensions/forgecli/retrospective.js.map +1 -1
  157. package/dist/extensions/forgecli/review-code.d.ts +4 -6
  158. package/dist/extensions/forgecli/review-code.js +8 -73
  159. package/dist/extensions/forgecli/review-code.js.map +1 -1
  160. package/dist/extensions/forgecli/review-plan.d.ts +4 -6
  161. package/dist/extensions/forgecli/review-plan.js +8 -73
  162. package/dist/extensions/forgecli/review-plan.js.map +1 -1
  163. package/dist/extensions/forgecli/run-sprint.d.ts +2 -0
  164. package/dist/extensions/forgecli/run-sprint.js +53 -52
  165. package/dist/extensions/forgecli/run-sprint.js.map +1 -1
  166. package/dist/extensions/forgecli/run-task.d.ts +3 -0
  167. package/dist/extensions/forgecli/run-task.js +39 -68
  168. package/dist/extensions/forgecli/run-task.js.map +1 -1
  169. package/dist/extensions/forgecli/skill-curation-flag.d.ts +21 -0
  170. package/dist/extensions/forgecli/skill-curation-flag.js +71 -0
  171. package/dist/extensions/forgecli/skill-curation-flag.js.map +1 -0
  172. package/dist/extensions/forgecli/skill-curator-subagent.d.ts +101 -0
  173. package/dist/extensions/forgecli/skill-curator-subagent.js +342 -0
  174. package/dist/extensions/forgecli/skill-curator-subagent.js.map +1 -0
  175. package/dist/extensions/forgecli/skill-retriever.d.ts +84 -0
  176. package/dist/extensions/forgecli/skill-retriever.js +246 -0
  177. package/dist/extensions/forgecli/skill-retriever.js.map +1 -0
  178. package/dist/extensions/forgecli/skill-usage-tracker.d.ts +91 -0
  179. package/dist/extensions/forgecli/skill-usage-tracker.js +224 -0
  180. package/dist/extensions/forgecli/skill-usage-tracker.js.map +1 -0
  181. package/dist/extensions/forgecli/store-error-remediation.d.ts +65 -0
  182. package/dist/extensions/forgecli/store-error-remediation.js +299 -0
  183. package/dist/extensions/forgecli/store-error-remediation.js.map +1 -0
  184. package/dist/extensions/forgecli/store-resolver.js +3 -12
  185. package/dist/extensions/forgecli/store-resolver.js.map +1 -1
  186. package/dist/extensions/forgecli/store-validator.js +6 -11
  187. package/dist/extensions/forgecli/store-validator.js.map +1 -1
  188. package/dist/extensions/forgecli/subagent/agents.d.ts +4 -0
  189. package/dist/extensions/forgecli/subagent/agents.js +5 -8
  190. package/dist/extensions/forgecli/subagent/agents.js.map +1 -1
  191. package/dist/extensions/forgecli/transition-guard.js +20 -61
  192. package/dist/extensions/forgecli/transition-guard.js.map +1 -1
  193. package/dist/extensions/forgecli/validate.d.ts +4 -6
  194. package/dist/extensions/forgecli/validate.js +8 -73
  195. package/dist/extensions/forgecli/validate.js.map +1 -1
  196. package/dist/extensions/forgecli/wf-engine/engine.js +2 -2
  197. package/dist/extensions/forgecli/wf-engine/engine.js.map +1 -1
  198. package/dist/extensions/forgecli/wf-engine/loader.d.ts +1 -1
  199. package/dist/extensions/forgecli/wf-engine/loader.js +1 -1
  200. package/dist/extensions/forgecli/wf-engine/loader.js.map +1 -1
  201. package/dist/forge-payload/.base-pack/skills/architect-skills.md +1 -0
  202. package/dist/forge-payload/.base-pack/skills/bug-fixer-skills.md +1 -0
  203. package/dist/forge-payload/.base-pack/skills/collator-skills.md +1 -0
  204. package/dist/forge-payload/.base-pack/skills/engineer-skills.md +1 -0
  205. package/dist/forge-payload/.base-pack/skills/generic-skills.md +1 -0
  206. package/dist/forge-payload/.base-pack/skills/qa-engineer-skills.md +1 -0
  207. package/dist/forge-payload/.base-pack/skills/supervisor-skills.md +1 -0
  208. package/dist/forge-payload/.base-pack/workflows/_fragments/generation-instructions.md +81 -0
  209. package/dist/forge-payload/.base-pack/workflows/_fragments/iron-laws.md +72 -0
  210. package/dist/forge-payload/.base-pack/workflows/_fragments/store-cli-verbs.md +11 -1
  211. package/dist/forge-payload/.base-pack/workflows/_fragments/store-write-verification.md +11 -0
  212. package/dist/forge-payload/.base-pack/workflows/architect_approve.md +11 -12
  213. package/dist/forge-payload/.base-pack/workflows/architect_review_sprint_completion.md +4 -1
  214. package/dist/forge-payload/.base-pack/workflows/architect_sprint_intake.md +10 -1
  215. package/dist/forge-payload/.base-pack/workflows/architect_sprint_plan.md +8 -1
  216. package/dist/forge-payload/.base-pack/workflows/collator_agent.md +18 -1
  217. package/dist/forge-payload/.base-pack/workflows/commit_task.md +5 -10
  218. package/dist/forge-payload/.base-pack/workflows/enhance.md +338 -11
  219. package/dist/forge-payload/.base-pack/workflows/fix_bug.md +9 -2
  220. package/dist/forge-payload/.base-pack/workflows/implement_plan.md +22 -35
  221. package/dist/forge-payload/.base-pack/workflows/migrate_structural.md +9 -0
  222. package/dist/forge-payload/.base-pack/workflows/orchestrate_task.md +4 -0
  223. package/dist/forge-payload/.base-pack/workflows/plan_task.md +17 -21
  224. package/dist/forge-payload/.base-pack/workflows/review_code.md +13 -20
  225. package/dist/forge-payload/.base-pack/workflows/review_plan.md +10 -21
  226. package/dist/forge-payload/.base-pack/workflows/sprint_retrospective.md +10 -1
  227. package/dist/forge-payload/.base-pack/workflows/update_implementation.md +5 -10
  228. package/dist/forge-payload/.base-pack/workflows/update_plan.md +5 -10
  229. package/dist/forge-payload/.base-pack/workflows/validate_task.md +11 -12
  230. package/dist/forge-payload/.claude-plugin/plugin.json +5 -5
  231. package/dist/forge-payload/.schemas/_defs/phaseSummary.schema.json +18 -0
  232. package/dist/forge-payload/.schemas/bug.schema.json +8 -24
  233. package/dist/forge-payload/.schemas/config.schema.json +165 -33
  234. package/dist/forge-payload/.schemas/enum-catalog.json +71 -0
  235. package/dist/forge-payload/.schemas/event.schema.json +20 -2
  236. package/dist/forge-payload/.schemas/migrations.json +452 -134
  237. package/dist/forge-payload/.schemas/proposal.schema.json +40 -0
  238. package/dist/forge-payload/.schemas/task.schema.json +6 -21
  239. package/dist/forge-payload/.schemas/transitions/bug.json +31 -0
  240. package/dist/forge-payload/.schemas/transitions/sprint.json +46 -0
  241. package/dist/forge-payload/.schemas/transitions/task.json +109 -0
  242. package/dist/forge-payload/agents/store-query-validator.md +103 -0
  243. package/dist/forge-payload/agents/tomoshibi.md +185 -0
  244. package/dist/forge-payload/commands/health.md +3 -3
  245. package/dist/forge-payload/commands/regenerate.md +109 -20
  246. package/dist/forge-payload/hooks/check-update.cjs +255 -0
  247. package/dist/forge-payload/hooks/check-update.js +378 -0
  248. package/dist/forge-payload/hooks/forge-permissions.cjs +171 -0
  249. package/dist/forge-payload/hooks/forge-permissions.js +164 -0
  250. package/dist/forge-payload/hooks/post-init.cjs +120 -0
  251. package/dist/forge-payload/hooks/post-sprint.cjs +108 -0
  252. package/dist/forge-payload/hooks/triage-error.cjs +104 -0
  253. package/dist/forge-payload/hooks/triage-error.js +77 -0
  254. package/dist/forge-payload/hooks/validate-write.cjs +250 -0
  255. package/dist/forge-payload/hooks/validate-write.js +250 -0
  256. package/dist/forge-payload/integrity.json +38 -0
  257. package/dist/forge-payload/meta/workflows/_fragments/generation-instructions.md +81 -0
  258. package/dist/forge-payload/meta/workflows/_fragments/iron-laws.md +72 -0
  259. package/dist/forge-payload/meta/workflows/_fragments/store-cli-verbs.md +11 -1
  260. package/dist/forge-payload/meta/workflows/_fragments/store-write-verification.md +11 -0
  261. package/dist/forge-payload/meta/workflows/meta-approve.md +9 -11
  262. package/dist/forge-payload/meta/workflows/meta-collate.md +16 -0
  263. package/dist/forge-payload/meta/workflows/meta-commit.md +3 -9
  264. package/dist/forge-payload/meta/workflows/meta-enhance.md +347 -12
  265. package/dist/forge-payload/meta/workflows/meta-fix-bug.md +8 -2
  266. package/dist/forge-payload/meta/workflows/meta-implement.md +20 -35
  267. package/dist/forge-payload/meta/workflows/meta-migrate.md +18 -0
  268. package/dist/forge-payload/meta/workflows/meta-orchestrate.md +2 -0
  269. package/dist/forge-payload/meta/workflows/meta-plan-task.md +15 -21
  270. package/dist/forge-payload/meta/workflows/meta-quiz-agent.md +4 -1
  271. package/dist/forge-payload/meta/workflows/meta-retrospective.md +8 -0
  272. package/dist/forge-payload/meta/workflows/meta-review-implementation.md +11 -19
  273. package/dist/forge-payload/meta/workflows/meta-review-plan.md +10 -16
  274. package/dist/forge-payload/meta/workflows/meta-review-sprint-completion.md +3 -0
  275. package/dist/forge-payload/meta/workflows/meta-sprint-intake.md +8 -0
  276. package/dist/forge-payload/meta/workflows/meta-sprint-plan.md +5 -0
  277. package/dist/forge-payload/meta/workflows/meta-update-implementation.md +3 -9
  278. package/dist/forge-payload/meta/workflows/meta-update-plan.md +3 -9
  279. package/dist/forge-payload/meta/workflows/meta-validate.md +9 -11
  280. package/dist/forge-payload/schemas/structure-manifest.json +513 -0
  281. package/dist/forge-payload/tools/build-context-pack.cjs +3 -2
  282. package/dist/forge-payload/tools/compression-gate.cjs +192 -0
  283. package/dist/forge-payload/tools/delete-candidate-detector.cjs +114 -0
  284. package/dist/forge-payload/tools/friction-emit.cjs +2 -1
  285. package/dist/forge-payload/tools/judge-proposal.cjs +177 -0
  286. package/dist/forge-payload/tools/lib/frontmatter.cjs +62 -0
  287. package/dist/forge-payload/tools/lib/fsutil.cjs +61 -0
  288. package/dist/forge-payload/tools/lib/json-io.cjs +43 -0
  289. package/dist/forge-payload/tools/lib/schema-loader.cjs +139 -0
  290. package/dist/forge-payload/tools/lib/slug.cjs +39 -0
  291. package/dist/forge-payload/tools/lib/store-facade.cjs +6 -5
  292. package/dist/forge-payload/tools/manage-versions.cjs +132 -4
  293. package/dist/forge-payload/tools/preflight-gate.cjs +55 -7
  294. package/dist/forge-payload/tools/queue-drain.cjs +152 -0
  295. package/dist/forge-payload/tools/replay-scoring.cjs +117 -0
  296. package/dist/forge-payload/tools/seed-store.cjs +1 -13
  297. package/dist/forge-payload/tools/store-cli.cjs +55 -108
  298. package/dist/forge-payload/tools/store.cjs +26 -37
  299. package/dist/forge-payload/tools/substitute-placeholders.cjs +74 -35
  300. package/node_modules/@earendil-works/pi-agent-core/dist/agent-loop.d.ts +1 -1
  301. package/node_modules/@earendil-works/pi-agent-core/dist/agent-loop.d.ts.map +1 -1
  302. package/node_modules/@earendil-works/pi-agent-core/dist/agent-loop.js +23 -0
  303. package/node_modules/@earendil-works/pi-agent-core/dist/agent-loop.js.map +1 -1
  304. package/node_modules/@earendil-works/pi-agent-core/dist/agent.d.ts +2 -2
  305. package/node_modules/@earendil-works/pi-agent-core/dist/agent.d.ts.map +1 -1
  306. package/node_modules/@earendil-works/pi-agent-core/dist/agent.js +1 -1
  307. package/node_modules/@earendil-works/pi-agent-core/dist/agent.js.map +1 -1
  308. package/node_modules/@earendil-works/pi-agent-core/dist/harness/agent-harness.d.ts +2 -2
  309. package/node_modules/@earendil-works/pi-agent-core/dist/harness/agent-harness.d.ts.map +1 -1
  310. package/node_modules/@earendil-works/pi-agent-core/dist/harness/agent-harness.js.map +1 -1
  311. package/node_modules/@earendil-works/pi-agent-core/dist/harness/compaction/branch-summarization.d.ts +5 -5
  312. package/node_modules/@earendil-works/pi-agent-core/dist/harness/compaction/branch-summarization.d.ts.map +1 -1
  313. package/node_modules/@earendil-works/pi-agent-core/dist/harness/compaction/branch-summarization.js.map +1 -1
  314. package/node_modules/@earendil-works/pi-agent-core/dist/harness/compaction/compaction.d.ts +4 -4
  315. package/node_modules/@earendil-works/pi-agent-core/dist/harness/compaction/compaction.d.ts.map +1 -1
  316. package/node_modules/@earendil-works/pi-agent-core/dist/harness/compaction/compaction.js.map +1 -1
  317. package/node_modules/@earendil-works/pi-agent-core/dist/harness/compaction/utils.d.ts +1 -1
  318. package/node_modules/@earendil-works/pi-agent-core/dist/harness/compaction/utils.d.ts.map +1 -1
  319. package/node_modules/@earendil-works/pi-agent-core/dist/harness/compaction/utils.js.map +1 -1
  320. package/node_modules/@earendil-works/pi-agent-core/dist/harness/env/nodejs.d.ts +1 -1
  321. package/node_modules/@earendil-works/pi-agent-core/dist/harness/env/nodejs.d.ts.map +1 -1
  322. package/node_modules/@earendil-works/pi-agent-core/dist/harness/env/nodejs.js.map +1 -1
  323. package/node_modules/@earendil-works/pi-agent-core/dist/harness/execution-env.d.ts +4 -0
  324. package/node_modules/@earendil-works/pi-agent-core/dist/harness/execution-env.d.ts.map +1 -0
  325. package/node_modules/@earendil-works/pi-agent-core/dist/harness/execution-env.js +3 -0
  326. package/node_modules/@earendil-works/pi-agent-core/dist/harness/execution-env.js.map +1 -0
  327. package/node_modules/@earendil-works/pi-agent-core/dist/harness/messages.d.ts +2 -2
  328. package/node_modules/@earendil-works/pi-agent-core/dist/harness/messages.d.ts.map +1 -1
  329. package/node_modules/@earendil-works/pi-agent-core/dist/harness/messages.js.map +1 -1
  330. package/node_modules/@earendil-works/pi-agent-core/dist/harness/prompt-templates.d.ts +1 -1
  331. package/node_modules/@earendil-works/pi-agent-core/dist/harness/prompt-templates.d.ts.map +1 -1
  332. package/node_modules/@earendil-works/pi-agent-core/dist/harness/prompt-templates.js.map +1 -1
  333. package/node_modules/@earendil-works/pi-agent-core/dist/harness/session/jsonl-repo.d.ts +1 -1
  334. package/node_modules/@earendil-works/pi-agent-core/dist/harness/session/jsonl-repo.d.ts.map +1 -1
  335. package/node_modules/@earendil-works/pi-agent-core/dist/harness/session/jsonl-repo.js.map +1 -1
  336. package/node_modules/@earendil-works/pi-agent-core/dist/harness/session/jsonl-storage.d.ts +1 -1
  337. package/node_modules/@earendil-works/pi-agent-core/dist/harness/session/jsonl-storage.d.ts.map +1 -1
  338. package/node_modules/@earendil-works/pi-agent-core/dist/harness/session/jsonl-storage.js.map +1 -1
  339. package/node_modules/@earendil-works/pi-agent-core/dist/harness/session/memory-repo.d.ts +1 -1
  340. package/node_modules/@earendil-works/pi-agent-core/dist/harness/session/memory-repo.d.ts.map +1 -1
  341. package/node_modules/@earendil-works/pi-agent-core/dist/harness/session/memory-repo.js.map +1 -1
  342. package/node_modules/@earendil-works/pi-agent-core/dist/harness/session/memory-storage.d.ts +1 -1
  343. package/node_modules/@earendil-works/pi-agent-core/dist/harness/session/memory-storage.d.ts.map +1 -1
  344. package/node_modules/@earendil-works/pi-agent-core/dist/harness/session/memory-storage.js.map +1 -1
  345. package/node_modules/@earendil-works/pi-agent-core/dist/harness/session/repo/jsonl.d.ts +20 -0
  346. package/node_modules/@earendil-works/pi-agent-core/dist/harness/session/repo/jsonl.d.ts.map +1 -0
  347. package/node_modules/@earendil-works/pi-agent-core/dist/harness/session/repo/jsonl.js +92 -0
  348. package/node_modules/@earendil-works/pi-agent-core/dist/harness/session/repo/jsonl.js.map +1 -0
  349. package/node_modules/@earendil-works/pi-agent-core/dist/harness/session/repo/memory.d.ts +18 -0
  350. package/node_modules/@earendil-works/pi-agent-core/dist/harness/session/repo/memory.d.ts.map +1 -0
  351. package/node_modules/@earendil-works/pi-agent-core/dist/harness/session/repo/memory.js +42 -0
  352. package/node_modules/@earendil-works/pi-agent-core/dist/harness/session/repo/memory.js.map +1 -0
  353. package/node_modules/@earendil-works/pi-agent-core/dist/harness/session/repo/shared.d.ts +10 -0
  354. package/node_modules/@earendil-works/pi-agent-core/dist/harness/session/repo/shared.d.ts.map +1 -0
  355. package/node_modules/@earendil-works/pi-agent-core/dist/harness/session/repo/shared.js +31 -0
  356. package/node_modules/@earendil-works/pi-agent-core/dist/harness/session/repo/shared.js.map +1 -0
  357. package/node_modules/@earendil-works/pi-agent-core/dist/harness/session/repo-utils.d.ts +2 -2
  358. package/node_modules/@earendil-works/pi-agent-core/dist/harness/session/repo-utils.d.ts.map +1 -1
  359. package/node_modules/@earendil-works/pi-agent-core/dist/harness/session/repo-utils.js.map +1 -1
  360. package/node_modules/@earendil-works/pi-agent-core/dist/harness/session/session.d.ts +2 -2
  361. package/node_modules/@earendil-works/pi-agent-core/dist/harness/session/session.d.ts.map +1 -1
  362. package/node_modules/@earendil-works/pi-agent-core/dist/harness/session/session.js.map +1 -1
  363. package/node_modules/@earendil-works/pi-agent-core/dist/harness/session/storage/jsonl.d.ts +30 -0
  364. package/node_modules/@earendil-works/pi-agent-core/dist/harness/session/storage/jsonl.d.ts.map +1 -0
  365. package/node_modules/@earendil-works/pi-agent-core/dist/harness/session/storage/jsonl.js +170 -0
  366. package/node_modules/@earendil-works/pi-agent-core/dist/harness/session/storage/jsonl.js.map +1 -0
  367. package/node_modules/@earendil-works/pi-agent-core/dist/harness/session/storage/memory.d.ts +26 -0
  368. package/node_modules/@earendil-works/pi-agent-core/dist/harness/session/storage/memory.d.ts.map +1 -0
  369. package/node_modules/@earendil-works/pi-agent-core/dist/harness/session/storage/memory.js +90 -0
  370. package/node_modules/@earendil-works/pi-agent-core/dist/harness/session/storage/memory.js.map +1 -0
  371. package/node_modules/@earendil-works/pi-agent-core/dist/harness/skills.d.ts +1 -1
  372. package/node_modules/@earendil-works/pi-agent-core/dist/harness/skills.d.ts.map +1 -1
  373. package/node_modules/@earendil-works/pi-agent-core/dist/harness/skills.js.map +1 -1
  374. package/node_modules/@earendil-works/pi-agent-core/dist/harness/system-prompt.d.ts +1 -1
  375. package/node_modules/@earendil-works/pi-agent-core/dist/harness/system-prompt.d.ts.map +1 -1
  376. package/node_modules/@earendil-works/pi-agent-core/dist/harness/system-prompt.js.map +1 -1
  377. package/node_modules/@earendil-works/pi-agent-core/dist/harness/types.d.ts +10 -22
  378. package/node_modules/@earendil-works/pi-agent-core/dist/harness/types.d.ts.map +1 -1
  379. package/node_modules/@earendil-works/pi-agent-core/dist/harness/types.js +17 -23
  380. package/node_modules/@earendil-works/pi-agent-core/dist/harness/types.js.map +1 -1
  381. package/node_modules/@earendil-works/pi-agent-core/dist/harness/utils/shell-output.d.ts +1 -1
  382. package/node_modules/@earendil-works/pi-agent-core/dist/harness/utils/shell-output.d.ts.map +1 -1
  383. package/node_modules/@earendil-works/pi-agent-core/dist/harness/utils/shell-output.js.map +1 -1
  384. package/node_modules/@earendil-works/pi-agent-core/dist/index.d.ts +19 -19
  385. package/node_modules/@earendil-works/pi-agent-core/dist/index.d.ts.map +1 -1
  386. package/node_modules/@earendil-works/pi-agent-core/dist/index.js.map +1 -1
  387. package/node_modules/@earendil-works/pi-agent-core/dist/node.d.ts +2 -2
  388. package/node_modules/@earendil-works/pi-agent-core/dist/node.d.ts.map +1 -1
  389. package/node_modules/@earendil-works/pi-agent-core/dist/node.js.map +1 -1
  390. package/node_modules/@earendil-works/pi-agent-core/package.json +9 -10
  391. package/node_modules/@earendil-works/pi-ai/dist/api-registry.d.ts +1 -1
  392. package/node_modules/@earendil-works/pi-ai/dist/api-registry.d.ts.map +1 -1
  393. package/node_modules/@earendil-works/pi-ai/dist/api-registry.js.map +1 -1
  394. package/node_modules/@earendil-works/pi-ai/dist/bedrock-provider.d.ts +2 -2
  395. package/node_modules/@earendil-works/pi-ai/dist/bedrock-provider.d.ts.map +1 -1
  396. package/node_modules/@earendil-works/pi-ai/dist/bedrock-provider.js.map +1 -1
  397. package/node_modules/@earendil-works/pi-ai/dist/cli.d.ts.map +1 -1
  398. package/node_modules/@earendil-works/pi-ai/dist/cli.js +14 -0
  399. package/node_modules/@earendil-works/pi-ai/dist/cli.js.map +1 -1
  400. package/node_modules/@earendil-works/pi-ai/dist/env-api-keys.d.ts +1 -1
  401. package/node_modules/@earendil-works/pi-ai/dist/env-api-keys.d.ts.map +1 -1
  402. package/node_modules/@earendil-works/pi-ai/dist/env-api-keys.js +10 -2
  403. package/node_modules/@earendil-works/pi-ai/dist/env-api-keys.js.map +1 -1
  404. package/node_modules/@earendil-works/pi-ai/dist/image-models.d.ts +2 -2
  405. package/node_modules/@earendil-works/pi-ai/dist/image-models.d.ts.map +1 -1
  406. package/node_modules/@earendil-works/pi-ai/dist/image-models.generated.d.ts.map +1 -1
  407. package/node_modules/@earendil-works/pi-ai/dist/image-models.generated.js.map +1 -1
  408. package/node_modules/@earendil-works/pi-ai/dist/image-models.js.map +1 -1
  409. package/node_modules/@earendil-works/pi-ai/dist/images-api-registry.d.ts +1 -1
  410. package/node_modules/@earendil-works/pi-ai/dist/images-api-registry.d.ts.map +1 -1
  411. package/node_modules/@earendil-works/pi-ai/dist/images-api-registry.js.map +1 -1
  412. package/node_modules/@earendil-works/pi-ai/dist/images.d.ts +2 -2
  413. package/node_modules/@earendil-works/pi-ai/dist/images.d.ts.map +1 -1
  414. package/node_modules/@earendil-works/pi-ai/dist/images.js.map +1 -1
  415. package/node_modules/@earendil-works/pi-ai/dist/index.d.ts +29 -29
  416. package/node_modules/@earendil-works/pi-ai/dist/index.d.ts.map +1 -1
  417. package/node_modules/@earendil-works/pi-ai/dist/index.js.map +1 -1
  418. package/node_modules/@earendil-works/pi-ai/dist/models.d.ts +2 -2
  419. package/node_modules/@earendil-works/pi-ai/dist/models.d.ts.map +1 -1
  420. package/node_modules/@earendil-works/pi-ai/dist/models.generated.d.ts +317 -509
  421. package/node_modules/@earendil-works/pi-ai/dist/models.generated.d.ts.map +1 -1
  422. package/node_modules/@earendil-works/pi-ai/dist/models.generated.js +400 -620
  423. package/node_modules/@earendil-works/pi-ai/dist/models.generated.js.map +1 -1
  424. package/node_modules/@earendil-works/pi-ai/dist/models.js.map +1 -1
  425. package/node_modules/@earendil-works/pi-ai/dist/oauth.d.ts +1 -1
  426. package/node_modules/@earendil-works/pi-ai/dist/oauth.d.ts.map +1 -1
  427. package/node_modules/@earendil-works/pi-ai/dist/oauth.js.map +1 -1
  428. package/node_modules/@earendil-works/pi-ai/dist/providers/amazon-bedrock.d.ts +1 -1
  429. package/node_modules/@earendil-works/pi-ai/dist/providers/amazon-bedrock.d.ts.map +1 -1
  430. package/node_modules/@earendil-works/pi-ai/dist/providers/amazon-bedrock.js +5 -2
  431. package/node_modules/@earendil-works/pi-ai/dist/providers/amazon-bedrock.js.map +1 -1
  432. package/node_modules/@earendil-works/pi-ai/dist/providers/anthropic.d.ts +23 -6
  433. package/node_modules/@earendil-works/pi-ai/dist/providers/anthropic.d.ts.map +1 -1
  434. package/node_modules/@earendil-works/pi-ai/dist/providers/anthropic.js +11 -23
  435. package/node_modules/@earendil-works/pi-ai/dist/providers/anthropic.js.map +1 -1
  436. package/node_modules/@earendil-works/pi-ai/dist/providers/azure-openai-responses.d.ts +1 -1
  437. package/node_modules/@earendil-works/pi-ai/dist/providers/azure-openai-responses.d.ts.map +1 -1
  438. package/node_modules/@earendil-works/pi-ai/dist/providers/azure-openai-responses.js +2 -1
  439. package/node_modules/@earendil-works/pi-ai/dist/providers/azure-openai-responses.js.map +1 -1
  440. package/node_modules/@earendil-works/pi-ai/dist/providers/cloudflare.d.ts +1 -1
  441. package/node_modules/@earendil-works/pi-ai/dist/providers/cloudflare.d.ts.map +1 -1
  442. package/node_modules/@earendil-works/pi-ai/dist/providers/cloudflare.js.map +1 -1
  443. package/node_modules/@earendil-works/pi-ai/dist/providers/faux.d.ts +1 -1
  444. package/node_modules/@earendil-works/pi-ai/dist/providers/faux.d.ts.map +1 -1
  445. package/node_modules/@earendil-works/pi-ai/dist/providers/faux.js.map +1 -1
  446. package/node_modules/@earendil-works/pi-ai/dist/providers/github-copilot-headers.d.ts +1 -1
  447. package/node_modules/@earendil-works/pi-ai/dist/providers/github-copilot-headers.d.ts.map +1 -1
  448. package/node_modules/@earendil-works/pi-ai/dist/providers/github-copilot-headers.js.map +1 -1
  449. package/node_modules/@earendil-works/pi-ai/dist/providers/google-shared.d.ts +1 -1
  450. package/node_modules/@earendil-works/pi-ai/dist/providers/google-shared.d.ts.map +1 -1
  451. package/node_modules/@earendil-works/pi-ai/dist/providers/google-shared.js.map +1 -1
  452. package/node_modules/@earendil-works/pi-ai/dist/providers/google-vertex.d.ts +2 -2
  453. package/node_modules/@earendil-works/pi-ai/dist/providers/google-vertex.d.ts.map +1 -1
  454. package/node_modules/@earendil-works/pi-ai/dist/providers/google-vertex.js.map +1 -1
  455. package/node_modules/@earendil-works/pi-ai/dist/providers/google.d.ts +2 -2
  456. package/node_modules/@earendil-works/pi-ai/dist/providers/google.d.ts.map +1 -1
  457. package/node_modules/@earendil-works/pi-ai/dist/providers/google.js.map +1 -1
  458. package/node_modules/@earendil-works/pi-ai/dist/providers/images/openrouter.d.ts +1 -1
  459. package/node_modules/@earendil-works/pi-ai/dist/providers/images/openrouter.d.ts.map +1 -1
  460. package/node_modules/@earendil-works/pi-ai/dist/providers/images/openrouter.js.map +1 -1
  461. package/node_modules/@earendil-works/pi-ai/dist/providers/images/register-builtins.d.ts +1 -1
  462. package/node_modules/@earendil-works/pi-ai/dist/providers/images/register-builtins.d.ts.map +1 -1
  463. package/node_modules/@earendil-works/pi-ai/dist/providers/images/register-builtins.js.map +1 -1
  464. package/node_modules/@earendil-works/pi-ai/dist/providers/mistral.d.ts +1 -1
  465. package/node_modules/@earendil-works/pi-ai/dist/providers/mistral.d.ts.map +1 -1
  466. package/node_modules/@earendil-works/pi-ai/dist/providers/mistral.js.map +1 -1
  467. package/node_modules/@earendil-works/pi-ai/dist/providers/openai-codex-responses.d.ts +1 -1
  468. package/node_modules/@earendil-works/pi-ai/dist/providers/openai-codex-responses.d.ts.map +1 -1
  469. package/node_modules/@earendil-works/pi-ai/dist/providers/openai-codex-responses.js +12 -3
  470. package/node_modules/@earendil-works/pi-ai/dist/providers/openai-codex-responses.js.map +1 -1
  471. package/node_modules/@earendil-works/pi-ai/dist/providers/openai-completions.d.ts +1 -1
  472. package/node_modules/@earendil-works/pi-ai/dist/providers/openai-completions.d.ts.map +1 -1
  473. package/node_modules/@earendil-works/pi-ai/dist/providers/openai-completions.js +2 -1
  474. package/node_modules/@earendil-works/pi-ai/dist/providers/openai-completions.js.map +1 -1
  475. package/node_modules/@earendil-works/pi-ai/dist/providers/openai-prompt-cache.d.ts +3 -0
  476. package/node_modules/@earendil-works/pi-ai/dist/providers/openai-prompt-cache.d.ts.map +1 -0
  477. package/node_modules/@earendil-works/pi-ai/dist/providers/openai-prompt-cache.js +10 -0
  478. package/node_modules/@earendil-works/pi-ai/dist/providers/openai-prompt-cache.js.map +1 -0
  479. package/node_modules/@earendil-works/pi-ai/dist/providers/openai-responses-shared.d.ts +2 -2
  480. package/node_modules/@earendil-works/pi-ai/dist/providers/openai-responses-shared.d.ts.map +1 -1
  481. package/node_modules/@earendil-works/pi-ai/dist/providers/openai-responses-shared.js.map +1 -1
  482. package/node_modules/@earendil-works/pi-ai/dist/providers/openai-responses.d.ts +1 -1
  483. package/node_modules/@earendil-works/pi-ai/dist/providers/openai-responses.d.ts.map +1 -1
  484. package/node_modules/@earendil-works/pi-ai/dist/providers/openai-responses.js +2 -1
  485. package/node_modules/@earendil-works/pi-ai/dist/providers/openai-responses.js.map +1 -1
  486. package/node_modules/@earendil-works/pi-ai/dist/providers/register-builtins.d.ts +10 -10
  487. package/node_modules/@earendil-works/pi-ai/dist/providers/register-builtins.d.ts.map +1 -1
  488. package/node_modules/@earendil-works/pi-ai/dist/providers/register-builtins.js +13 -2
  489. package/node_modules/@earendil-works/pi-ai/dist/providers/register-builtins.js.map +1 -1
  490. package/node_modules/@earendil-works/pi-ai/dist/providers/simple-options.d.ts +3 -3
  491. package/node_modules/@earendil-works/pi-ai/dist/providers/simple-options.d.ts.map +1 -1
  492. package/node_modules/@earendil-works/pi-ai/dist/providers/simple-options.js +6 -11
  493. package/node_modules/@earendil-works/pi-ai/dist/providers/simple-options.js.map +1 -1
  494. package/node_modules/@earendil-works/pi-ai/dist/providers/transform-messages.d.ts +1 -1
  495. package/node_modules/@earendil-works/pi-ai/dist/providers/transform-messages.d.ts.map +1 -1
  496. package/node_modules/@earendil-works/pi-ai/dist/providers/transform-messages.js.map +1 -1
  497. package/node_modules/@earendil-works/pi-ai/dist/stream.d.ts +3 -3
  498. package/node_modules/@earendil-works/pi-ai/dist/stream.d.ts.map +1 -1
  499. package/node_modules/@earendil-works/pi-ai/dist/stream.js.map +1 -1
  500. package/node_modules/@earendil-works/pi-ai/dist/types.d.ts +13 -3
  501. package/node_modules/@earendil-works/pi-ai/dist/types.d.ts.map +1 -1
  502. package/node_modules/@earendil-works/pi-ai/dist/types.js.map +1 -1
  503. package/node_modules/@earendil-works/pi-ai/dist/utils/event-stream.d.ts +3 -3
  504. package/node_modules/@earendil-works/pi-ai/dist/utils/event-stream.d.ts.map +1 -1
  505. package/node_modules/@earendil-works/pi-ai/dist/utils/event-stream.js +2 -2
  506. package/node_modules/@earendil-works/pi-ai/dist/utils/event-stream.js.map +1 -1
  507. package/node_modules/@earendil-works/pi-ai/dist/utils/oauth/anthropic.d.ts +1 -1
  508. package/node_modules/@earendil-works/pi-ai/dist/utils/oauth/anthropic.d.ts.map +1 -1
  509. package/node_modules/@earendil-works/pi-ai/dist/utils/oauth/anthropic.js.map +1 -1
  510. package/node_modules/@earendil-works/pi-ai/dist/utils/oauth/device-code.d.ts +19 -0
  511. package/node_modules/@earendil-works/pi-ai/dist/utils/oauth/device-code.d.ts.map +1 -0
  512. package/node_modules/@earendil-works/pi-ai/dist/utils/oauth/device-code.js +55 -0
  513. package/node_modules/@earendil-works/pi-ai/dist/utils/oauth/device-code.js.map +1 -0
  514. package/node_modules/@earendil-works/pi-ai/dist/utils/oauth/github-copilot.d.ts +3 -3
  515. package/node_modules/@earendil-works/pi-ai/dist/utils/oauth/github-copilot.d.ts.map +1 -1
  516. package/node_modules/@earendil-works/pi-ai/dist/utils/oauth/github-copilot.js +45 -69
  517. package/node_modules/@earendil-works/pi-ai/dist/utils/oauth/github-copilot.js.map +1 -1
  518. package/node_modules/@earendil-works/pi-ai/dist/utils/oauth/index.d.ts +6 -5
  519. package/node_modules/@earendil-works/pi-ai/dist/utils/oauth/index.d.ts.map +1 -1
  520. package/node_modules/@earendil-works/pi-ai/dist/utils/oauth/index.js +1 -0
  521. package/node_modules/@earendil-works/pi-ai/dist/utils/oauth/index.js.map +1 -1
  522. package/node_modules/@earendil-works/pi-ai/dist/utils/oauth/openai-codex.d.ts +1 -1
  523. package/node_modules/@earendil-works/pi-ai/dist/utils/oauth/openai-codex.d.ts.map +1 -1
  524. package/node_modules/@earendil-works/pi-ai/dist/utils/oauth/openai-codex.js +1 -1
  525. package/node_modules/@earendil-works/pi-ai/dist/utils/oauth/openai-codex.js.map +1 -1
  526. package/node_modules/@earendil-works/pi-ai/dist/utils/oauth/types.d.ts +9 -2
  527. package/node_modules/@earendil-works/pi-ai/dist/utils/oauth/types.d.ts.map +1 -1
  528. package/node_modules/@earendil-works/pi-ai/dist/utils/oauth/types.js.map +1 -1
  529. package/node_modules/@earendil-works/pi-ai/dist/utils/overflow.d.ts +1 -1
  530. package/node_modules/@earendil-works/pi-ai/dist/utils/overflow.d.ts.map +1 -1
  531. package/node_modules/@earendil-works/pi-ai/dist/utils/overflow.js.map +1 -1
  532. package/node_modules/@earendil-works/pi-ai/dist/utils/validation.d.ts +1 -1
  533. package/node_modules/@earendil-works/pi-ai/dist/utils/validation.d.ts.map +1 -1
  534. package/node_modules/@earendil-works/pi-ai/dist/utils/validation.js.map +1 -1
  535. package/node_modules/@earendil-works/pi-ai/package.json +15 -16
  536. package/node_modules/@earendil-works/pi-coding-agent/CHANGELOG.md +55 -0
  537. package/node_modules/@earendil-works/pi-coding-agent/README.md +6 -4
  538. package/node_modules/@earendil-works/pi-coding-agent/dist/bun/cli.d.ts.map +1 -1
  539. package/node_modules/@earendil-works/pi-coding-agent/dist/bun/cli.js.map +1 -1
  540. package/node_modules/@earendil-works/pi-coding-agent/dist/cli/args.d.ts +1 -1
  541. package/node_modules/@earendil-works/pi-coding-agent/dist/cli/args.d.ts.map +1 -1
  542. package/node_modules/@earendil-works/pi-coding-agent/dist/cli/args.js.map +1 -1
  543. package/node_modules/@earendil-works/pi-coding-agent/dist/cli/config-selector.d.ts +2 -2
  544. package/node_modules/@earendil-works/pi-coding-agent/dist/cli/config-selector.d.ts.map +1 -1
  545. package/node_modules/@earendil-works/pi-coding-agent/dist/cli/config-selector.js.map +1 -1
  546. package/node_modules/@earendil-works/pi-coding-agent/dist/cli/file-processor.d.ts.map +1 -1
  547. package/node_modules/@earendil-works/pi-coding-agent/dist/cli/file-processor.js.map +1 -1
  548. package/node_modules/@earendil-works/pi-coding-agent/dist/cli/initial-message.d.ts +1 -1
  549. package/node_modules/@earendil-works/pi-coding-agent/dist/cli/initial-message.d.ts.map +1 -1
  550. package/node_modules/@earendil-works/pi-coding-agent/dist/cli/initial-message.js.map +1 -1
  551. package/node_modules/@earendil-works/pi-coding-agent/dist/cli/list-models.d.ts +1 -1
  552. package/node_modules/@earendil-works/pi-coding-agent/dist/cli/list-models.d.ts.map +1 -1
  553. package/node_modules/@earendil-works/pi-coding-agent/dist/cli/list-models.js.map +1 -1
  554. package/node_modules/@earendil-works/pi-coding-agent/dist/cli/session-picker.d.ts +1 -1
  555. package/node_modules/@earendil-works/pi-coding-agent/dist/cli/session-picker.d.ts.map +1 -1
  556. package/node_modules/@earendil-works/pi-coding-agent/dist/cli/session-picker.js.map +1 -1
  557. package/node_modules/@earendil-works/pi-coding-agent/dist/cli.d.ts.map +1 -1
  558. package/node_modules/@earendil-works/pi-coding-agent/dist/cli.js +4 -10
  559. package/node_modules/@earendil-works/pi-coding-agent/dist/cli.js.map +1 -1
  560. package/node_modules/@earendil-works/pi-coding-agent/dist/config.d.ts.map +1 -1
  561. package/node_modules/@earendil-works/pi-coding-agent/dist/config.js +13 -14
  562. package/node_modules/@earendil-works/pi-coding-agent/dist/config.js.map +1 -1
  563. package/node_modules/@earendil-works/pi-coding-agent/dist/core/agent-session-runtime.d.ts +9 -9
  564. package/node_modules/@earendil-works/pi-coding-agent/dist/core/agent-session-runtime.d.ts.map +1 -1
  565. package/node_modules/@earendil-works/pi-coding-agent/dist/core/agent-session-runtime.js +6 -6
  566. package/node_modules/@earendil-works/pi-coding-agent/dist/core/agent-session-runtime.js.map +1 -1
  567. package/node_modules/@earendil-works/pi-coding-agent/dist/core/agent-session-services.d.ts +7 -7
  568. package/node_modules/@earendil-works/pi-coding-agent/dist/core/agent-session-services.d.ts.map +1 -1
  569. package/node_modules/@earendil-works/pi-coding-agent/dist/core/agent-session-services.js +3 -2
  570. package/node_modules/@earendil-works/pi-coding-agent/dist/core/agent-session-services.js.map +1 -1
  571. package/node_modules/@earendil-works/pi-coding-agent/dist/core/agent-session.d.ts +23 -21
  572. package/node_modules/@earendil-works/pi-coding-agent/dist/core/agent-session.d.ts.map +1 -1
  573. package/node_modules/@earendil-works/pi-coding-agent/dist/core/agent-session.js +99 -137
  574. package/node_modules/@earendil-works/pi-coding-agent/dist/core/agent-session.js.map +1 -1
  575. package/node_modules/@earendil-works/pi-coding-agent/dist/core/auth-guidance.d.ts.map +1 -1
  576. package/node_modules/@earendil-works/pi-coding-agent/dist/core/auth-guidance.js.map +1 -1
  577. package/node_modules/@earendil-works/pi-coding-agent/dist/core/auth-storage.d.ts +1 -1
  578. package/node_modules/@earendil-works/pi-coding-agent/dist/core/auth-storage.d.ts.map +1 -1
  579. package/node_modules/@earendil-works/pi-coding-agent/dist/core/auth-storage.js +3 -2
  580. package/node_modules/@earendil-works/pi-coding-agent/dist/core/auth-storage.js.map +1 -1
  581. package/node_modules/@earendil-works/pi-coding-agent/dist/core/bash-executor.d.ts +1 -1
  582. package/node_modules/@earendil-works/pi-coding-agent/dist/core/bash-executor.d.ts.map +1 -1
  583. package/node_modules/@earendil-works/pi-coding-agent/dist/core/bash-executor.js.map +1 -1
  584. package/node_modules/@earendil-works/pi-coding-agent/dist/core/compaction/branch-summarization.d.ts +3 -3
  585. package/node_modules/@earendil-works/pi-coding-agent/dist/core/compaction/branch-summarization.d.ts.map +1 -1
  586. package/node_modules/@earendil-works/pi-coding-agent/dist/core/compaction/branch-summarization.js.map +1 -1
  587. package/node_modules/@earendil-works/pi-coding-agent/dist/core/compaction/compaction.d.ts +2 -2
  588. package/node_modules/@earendil-works/pi-coding-agent/dist/core/compaction/compaction.d.ts.map +1 -1
  589. package/node_modules/@earendil-works/pi-coding-agent/dist/core/compaction/compaction.js.map +1 -1
  590. package/node_modules/@earendil-works/pi-coding-agent/dist/core/compaction/index.d.ts +3 -3
  591. package/node_modules/@earendil-works/pi-coding-agent/dist/core/compaction/index.d.ts.map +1 -1
  592. package/node_modules/@earendil-works/pi-coding-agent/dist/core/compaction/index.js.map +1 -1
  593. package/node_modules/@earendil-works/pi-coding-agent/dist/core/exec.d.ts.map +1 -1
  594. package/node_modules/@earendil-works/pi-coding-agent/dist/core/exec.js.map +1 -1
  595. package/node_modules/@earendil-works/pi-coding-agent/dist/core/export-html/index.d.ts +1 -1
  596. package/node_modules/@earendil-works/pi-coding-agent/dist/core/export-html/index.d.ts.map +1 -1
  597. package/node_modules/@earendil-works/pi-coding-agent/dist/core/export-html/index.js +8 -6
  598. package/node_modules/@earendil-works/pi-coding-agent/dist/core/export-html/index.js.map +1 -1
  599. package/node_modules/@earendil-works/pi-coding-agent/dist/core/export-html/template.js +6 -3
  600. package/node_modules/@earendil-works/pi-coding-agent/dist/core/export-html/tool-renderer.d.ts +2 -2
  601. package/node_modules/@earendil-works/pi-coding-agent/dist/core/export-html/tool-renderer.d.ts.map +1 -1
  602. package/node_modules/@earendil-works/pi-coding-agent/dist/core/export-html/tool-renderer.js.map +1 -1
  603. package/node_modules/@earendil-works/pi-coding-agent/dist/core/extensions/index.d.ts +8 -8
  604. package/node_modules/@earendil-works/pi-coding-agent/dist/core/extensions/index.d.ts.map +1 -1
  605. package/node_modules/@earendil-works/pi-coding-agent/dist/core/extensions/index.js.map +1 -1
  606. package/node_modules/@earendil-works/pi-coding-agent/dist/core/extensions/loader.d.ts +2 -2
  607. package/node_modules/@earendil-works/pi-coding-agent/dist/core/extensions/loader.d.ts.map +1 -1
  608. package/node_modules/@earendil-works/pi-coding-agent/dist/core/extensions/loader.js +12 -29
  609. package/node_modules/@earendil-works/pi-coding-agent/dist/core/extensions/loader.js.map +1 -1
  610. package/node_modules/@earendil-works/pi-coding-agent/dist/core/extensions/runner.d.ts +6 -6
  611. package/node_modules/@earendil-works/pi-coding-agent/dist/core/extensions/runner.d.ts.map +1 -1
  612. package/node_modules/@earendil-works/pi-coding-agent/dist/core/extensions/runner.js.map +1 -1
  613. package/node_modules/@earendil-works/pi-coding-agent/dist/core/extensions/types.d.ts +19 -19
  614. package/node_modules/@earendil-works/pi-coding-agent/dist/core/extensions/types.d.ts.map +1 -1
  615. package/node_modules/@earendil-works/pi-coding-agent/dist/core/extensions/types.js.map +1 -1
  616. package/node_modules/@earendil-works/pi-coding-agent/dist/core/extensions/wrapper.d.ts +2 -2
  617. package/node_modules/@earendil-works/pi-coding-agent/dist/core/extensions/wrapper.d.ts.map +1 -1
  618. package/node_modules/@earendil-works/pi-coding-agent/dist/core/extensions/wrapper.js.map +1 -1
  619. package/node_modules/@earendil-works/pi-coding-agent/dist/core/footer-data-provider.d.ts.map +1 -1
  620. package/node_modules/@earendil-works/pi-coding-agent/dist/core/footer-data-provider.js.map +1 -1
  621. package/node_modules/@earendil-works/pi-coding-agent/dist/core/http-dispatcher.d.ts +21 -0
  622. package/node_modules/@earendil-works/pi-coding-agent/dist/core/http-dispatcher.d.ts.map +1 -0
  623. package/node_modules/@earendil-works/pi-coding-agent/dist/core/http-dispatcher.js +48 -0
  624. package/node_modules/@earendil-works/pi-coding-agent/dist/core/http-dispatcher.js.map +1 -0
  625. package/node_modules/@earendil-works/pi-coding-agent/dist/core/index.d.ts +8 -8
  626. package/node_modules/@earendil-works/pi-coding-agent/dist/core/index.d.ts.map +1 -1
  627. package/node_modules/@earendil-works/pi-coding-agent/dist/core/index.js.map +1 -1
  628. package/node_modules/@earendil-works/pi-coding-agent/dist/core/keybindings.d.ts.map +1 -1
  629. package/node_modules/@earendil-works/pi-coding-agent/dist/core/keybindings.js.map +1 -1
  630. package/node_modules/@earendil-works/pi-coding-agent/dist/core/model-registry.d.ts +4 -4
  631. package/node_modules/@earendil-works/pi-coding-agent/dist/core/model-registry.d.ts.map +1 -1
  632. package/node_modules/@earendil-works/pi-coding-agent/dist/core/model-registry.js +7 -3
  633. package/node_modules/@earendil-works/pi-coding-agent/dist/core/model-registry.js.map +1 -1
  634. package/node_modules/@earendil-works/pi-coding-agent/dist/core/model-resolver.d.ts +1 -1
  635. package/node_modules/@earendil-works/pi-coding-agent/dist/core/model-resolver.d.ts.map +1 -1
  636. package/node_modules/@earendil-works/pi-coding-agent/dist/core/model-resolver.js.map +1 -1
  637. package/node_modules/@earendil-works/pi-coding-agent/dist/core/package-manager.d.ts +2 -1
  638. package/node_modules/@earendil-works/pi-coding-agent/dist/core/package-manager.d.ts.map +1 -1
  639. package/node_modules/@earendil-works/pi-coding-agent/dist/core/package-manager.js +48 -32
  640. package/node_modules/@earendil-works/pi-coding-agent/dist/core/package-manager.js.map +1 -1
  641. package/node_modules/@earendil-works/pi-coding-agent/dist/core/prompt-templates.d.ts +1 -1
  642. package/node_modules/@earendil-works/pi-coding-agent/dist/core/prompt-templates.d.ts.map +1 -1
  643. package/node_modules/@earendil-works/pi-coding-agent/dist/core/prompt-templates.js +6 -20
  644. package/node_modules/@earendil-works/pi-coding-agent/dist/core/prompt-templates.js.map +1 -1
  645. package/node_modules/@earendil-works/pi-coding-agent/dist/core/resolve-config-value.d.ts.map +1 -1
  646. package/node_modules/@earendil-works/pi-coding-agent/dist/core/resolve-config-value.js.map +1 -1
  647. package/node_modules/@earendil-works/pi-coding-agent/dist/core/resource-loader.d.ts +9 -9
  648. package/node_modules/@earendil-works/pi-coding-agent/dist/core/resource-loader.d.ts.map +1 -1
  649. package/node_modules/@earendil-works/pi-coding-agent/dist/core/resource-loader.js +38 -31
  650. package/node_modules/@earendil-works/pi-coding-agent/dist/core/resource-loader.js.map +1 -1
  651. package/node_modules/@earendil-works/pi-coding-agent/dist/core/sdk.d.ts +13 -13
  652. package/node_modules/@earendil-works/pi-coding-agent/dist/core/sdk.d.ts.map +1 -1
  653. package/node_modules/@earendil-works/pi-coding-agent/dist/core/sdk.js +9 -4
  654. package/node_modules/@earendil-works/pi-coding-agent/dist/core/sdk.js.map +1 -1
  655. package/node_modules/@earendil-works/pi-coding-agent/dist/core/session-manager.d.ts +1 -1
  656. package/node_modules/@earendil-works/pi-coding-agent/dist/core/session-manager.d.ts.map +1 -1
  657. package/node_modules/@earendil-works/pi-coding-agent/dist/core/session-manager.js +32 -24
  658. package/node_modules/@earendil-works/pi-coding-agent/dist/core/session-manager.js.map +1 -1
  659. package/node_modules/@earendil-works/pi-coding-agent/dist/core/settings-manager.d.ts +3 -0
  660. package/node_modules/@earendil-works/pi-coding-agent/dist/core/settings-manager.d.ts.map +1 -1
  661. package/node_modules/@earendil-works/pi-coding-agent/dist/core/settings-manager.js +26 -13
  662. package/node_modules/@earendil-works/pi-coding-agent/dist/core/settings-manager.js.map +1 -1
  663. package/node_modules/@earendil-works/pi-coding-agent/dist/core/skills.d.ts +2 -2
  664. package/node_modules/@earendil-works/pi-coding-agent/dist/core/skills.d.ts.map +1 -1
  665. package/node_modules/@earendil-works/pi-coding-agent/dist/core/skills.js +8 -22
  666. package/node_modules/@earendil-works/pi-coding-agent/dist/core/skills.js.map +1 -1
  667. package/node_modules/@earendil-works/pi-coding-agent/dist/core/slash-commands.d.ts +1 -1
  668. package/node_modules/@earendil-works/pi-coding-agent/dist/core/slash-commands.d.ts.map +1 -1
  669. package/node_modules/@earendil-works/pi-coding-agent/dist/core/slash-commands.js.map +1 -1
  670. package/node_modules/@earendil-works/pi-coding-agent/dist/core/source-info.d.ts +1 -1
  671. package/node_modules/@earendil-works/pi-coding-agent/dist/core/source-info.d.ts.map +1 -1
  672. package/node_modules/@earendil-works/pi-coding-agent/dist/core/source-info.js.map +1 -1
  673. package/node_modules/@earendil-works/pi-coding-agent/dist/core/system-prompt.d.ts +1 -1
  674. package/node_modules/@earendil-works/pi-coding-agent/dist/core/system-prompt.d.ts.map +1 -1
  675. package/node_modules/@earendil-works/pi-coding-agent/dist/core/system-prompt.js +1 -0
  676. package/node_modules/@earendil-works/pi-coding-agent/dist/core/system-prompt.js.map +1 -1
  677. package/node_modules/@earendil-works/pi-coding-agent/dist/core/telemetry.d.ts +1 -1
  678. package/node_modules/@earendil-works/pi-coding-agent/dist/core/telemetry.d.ts.map +1 -1
  679. package/node_modules/@earendil-works/pi-coding-agent/dist/core/telemetry.js.map +1 -1
  680. package/node_modules/@earendil-works/pi-coding-agent/dist/core/tools/bash.d.ts +2 -2
  681. package/node_modules/@earendil-works/pi-coding-agent/dist/core/tools/bash.d.ts.map +1 -1
  682. package/node_modules/@earendil-works/pi-coding-agent/dist/core/tools/bash.js +9 -3
  683. package/node_modules/@earendil-works/pi-coding-agent/dist/core/tools/bash.js.map +1 -1
  684. package/node_modules/@earendil-works/pi-coding-agent/dist/core/tools/edit-diff.d.ts +3 -1
  685. package/node_modules/@earendil-works/pi-coding-agent/dist/core/tools/edit-diff.d.ts.map +1 -1
  686. package/node_modules/@earendil-works/pi-coding-agent/dist/core/tools/edit-diff.js +8 -1
  687. package/node_modules/@earendil-works/pi-coding-agent/dist/core/tools/edit-diff.js.map +1 -1
  688. package/node_modules/@earendil-works/pi-coding-agent/dist/core/tools/edit.d.ts +5 -3
  689. package/node_modules/@earendil-works/pi-coding-agent/dist/core/tools/edit.d.ts.map +1 -1
  690. package/node_modules/@earendil-works/pi-coding-agent/dist/core/tools/edit.js +3 -2
  691. package/node_modules/@earendil-works/pi-coding-agent/dist/core/tools/edit.js.map +1 -1
  692. package/node_modules/@earendil-works/pi-coding-agent/dist/core/tools/find.d.ts +2 -2
  693. package/node_modules/@earendil-works/pi-coding-agent/dist/core/tools/find.d.ts.map +1 -1
  694. package/node_modules/@earendil-works/pi-coding-agent/dist/core/tools/find.js.map +1 -1
  695. package/node_modules/@earendil-works/pi-coding-agent/dist/core/tools/grep.d.ts +2 -2
  696. package/node_modules/@earendil-works/pi-coding-agent/dist/core/tools/grep.d.ts.map +1 -1
  697. package/node_modules/@earendil-works/pi-coding-agent/dist/core/tools/grep.js.map +1 -1
  698. package/node_modules/@earendil-works/pi-coding-agent/dist/core/tools/index.d.ts +17 -17
  699. package/node_modules/@earendil-works/pi-coding-agent/dist/core/tools/index.d.ts.map +1 -1
  700. package/node_modules/@earendil-works/pi-coding-agent/dist/core/tools/index.js.map +1 -1
  701. package/node_modules/@earendil-works/pi-coding-agent/dist/core/tools/ls.d.ts +2 -2
  702. package/node_modules/@earendil-works/pi-coding-agent/dist/core/tools/ls.d.ts.map +1 -1
  703. package/node_modules/@earendil-works/pi-coding-agent/dist/core/tools/ls.js.map +1 -1
  704. package/node_modules/@earendil-works/pi-coding-agent/dist/core/tools/output-accumulator.d.ts +3 -1
  705. package/node_modules/@earendil-works/pi-coding-agent/dist/core/tools/output-accumulator.d.ts.map +1 -1
  706. package/node_modules/@earendil-works/pi-coding-agent/dist/core/tools/output-accumulator.js +9 -3
  707. package/node_modules/@earendil-works/pi-coding-agent/dist/core/tools/output-accumulator.js.map +1 -1
  708. package/node_modules/@earendil-works/pi-coding-agent/dist/core/tools/path-utils.d.ts.map +1 -1
  709. package/node_modules/@earendil-works/pi-coding-agent/dist/core/tools/path-utils.js +3 -22
  710. package/node_modules/@earendil-works/pi-coding-agent/dist/core/tools/path-utils.js.map +1 -1
  711. package/node_modules/@earendil-works/pi-coding-agent/dist/core/tools/read.d.ts +2 -2
  712. package/node_modules/@earendil-works/pi-coding-agent/dist/core/tools/read.d.ts.map +1 -1
  713. package/node_modules/@earendil-works/pi-coding-agent/dist/core/tools/read.js.map +1 -1
  714. package/node_modules/@earendil-works/pi-coding-agent/dist/core/tools/render-utils.d.ts.map +1 -1
  715. package/node_modules/@earendil-works/pi-coding-agent/dist/core/tools/render-utils.js.map +1 -1
  716. package/node_modules/@earendil-works/pi-coding-agent/dist/core/tools/tool-definition-wrapper.d.ts +1 -1
  717. package/node_modules/@earendil-works/pi-coding-agent/dist/core/tools/tool-definition-wrapper.d.ts.map +1 -1
  718. package/node_modules/@earendil-works/pi-coding-agent/dist/core/tools/tool-definition-wrapper.js.map +1 -1
  719. package/node_modules/@earendil-works/pi-coding-agent/dist/core/tools/truncate.d.ts.map +1 -1
  720. package/node_modules/@earendil-works/pi-coding-agent/dist/core/tools/truncate.js +12 -2
  721. package/node_modules/@earendil-works/pi-coding-agent/dist/core/tools/truncate.js.map +1 -1
  722. package/node_modules/@earendil-works/pi-coding-agent/dist/core/tools/write.d.ts +1 -1
  723. package/node_modules/@earendil-works/pi-coding-agent/dist/core/tools/write.d.ts.map +1 -1
  724. package/node_modules/@earendil-works/pi-coding-agent/dist/core/tools/write.js.map +1 -1
  725. package/node_modules/@earendil-works/pi-coding-agent/dist/index.d.ts +30 -29
  726. package/node_modules/@earendil-works/pi-coding-agent/dist/index.d.ts.map +1 -1
  727. package/node_modules/@earendil-works/pi-coding-agent/dist/index.js +2 -1
  728. package/node_modules/@earendil-works/pi-coding-agent/dist/index.js.map +1 -1
  729. package/node_modules/@earendil-works/pi-coding-agent/dist/main.d.ts +1 -1
  730. package/node_modules/@earendil-works/pi-coding-agent/dist/main.d.ts.map +1 -1
  731. package/node_modules/@earendil-works/pi-coding-agent/dist/main.js +7 -6
  732. package/node_modules/@earendil-works/pi-coding-agent/dist/main.js.map +1 -1
  733. package/node_modules/@earendil-works/pi-coding-agent/dist/migrations.d.ts.map +1 -1
  734. package/node_modules/@earendil-works/pi-coding-agent/dist/migrations.js.map +1 -1
  735. package/node_modules/@earendil-works/pi-coding-agent/dist/modes/index.d.ts +5 -5
  736. package/node_modules/@earendil-works/pi-coding-agent/dist/modes/index.d.ts.map +1 -1
  737. package/node_modules/@earendil-works/pi-coding-agent/dist/modes/index.js.map +1 -1
  738. package/node_modules/@earendil-works/pi-coding-agent/dist/modes/interactive/components/armin.d.ts.map +1 -1
  739. package/node_modules/@earendil-works/pi-coding-agent/dist/modes/interactive/components/armin.js.map +1 -1
  740. package/node_modules/@earendil-works/pi-coding-agent/dist/modes/interactive/components/assistant-message.d.ts.map +1 -1
  741. package/node_modules/@earendil-works/pi-coding-agent/dist/modes/interactive/components/assistant-message.js.map +1 -1
  742. package/node_modules/@earendil-works/pi-coding-agent/dist/modes/interactive/components/bash-execution.d.ts +1 -1
  743. package/node_modules/@earendil-works/pi-coding-agent/dist/modes/interactive/components/bash-execution.d.ts.map +1 -1
  744. package/node_modules/@earendil-works/pi-coding-agent/dist/modes/interactive/components/bash-execution.js.map +1 -1
  745. package/node_modules/@earendil-works/pi-coding-agent/dist/modes/interactive/components/bordered-loader.d.ts +1 -1
  746. package/node_modules/@earendil-works/pi-coding-agent/dist/modes/interactive/components/bordered-loader.d.ts.map +1 -1
  747. package/node_modules/@earendil-works/pi-coding-agent/dist/modes/interactive/components/bordered-loader.js.map +1 -1
  748. package/node_modules/@earendil-works/pi-coding-agent/dist/modes/interactive/components/branch-summary-message.d.ts +1 -1
  749. package/node_modules/@earendil-works/pi-coding-agent/dist/modes/interactive/components/branch-summary-message.d.ts.map +1 -1
  750. package/node_modules/@earendil-works/pi-coding-agent/dist/modes/interactive/components/branch-summary-message.js.map +1 -1
  751. package/node_modules/@earendil-works/pi-coding-agent/dist/modes/interactive/components/compaction-summary-message.d.ts +1 -1
  752. package/node_modules/@earendil-works/pi-coding-agent/dist/modes/interactive/components/compaction-summary-message.d.ts.map +1 -1
  753. package/node_modules/@earendil-works/pi-coding-agent/dist/modes/interactive/components/compaction-summary-message.js.map +1 -1
  754. package/node_modules/@earendil-works/pi-coding-agent/dist/modes/interactive/components/config-selector.d.ts +2 -2
  755. package/node_modules/@earendil-works/pi-coding-agent/dist/modes/interactive/components/config-selector.d.ts.map +1 -1
  756. package/node_modules/@earendil-works/pi-coding-agent/dist/modes/interactive/components/config-selector.js +1 -1
  757. package/node_modules/@earendil-works/pi-coding-agent/dist/modes/interactive/components/config-selector.js.map +1 -1
  758. package/node_modules/@earendil-works/pi-coding-agent/dist/modes/interactive/components/countdown-timer.d.ts +2 -2
  759. package/node_modules/@earendil-works/pi-coding-agent/dist/modes/interactive/components/countdown-timer.d.ts.map +1 -1
  760. package/node_modules/@earendil-works/pi-coding-agent/dist/modes/interactive/components/countdown-timer.js +2 -2
  761. package/node_modules/@earendil-works/pi-coding-agent/dist/modes/interactive/components/countdown-timer.js.map +1 -1
  762. package/node_modules/@earendil-works/pi-coding-agent/dist/modes/interactive/components/custom-editor.d.ts +1 -1
  763. package/node_modules/@earendil-works/pi-coding-agent/dist/modes/interactive/components/custom-editor.d.ts.map +1 -1
  764. package/node_modules/@earendil-works/pi-coding-agent/dist/modes/interactive/components/custom-editor.js.map +1 -1
  765. package/node_modules/@earendil-works/pi-coding-agent/dist/modes/interactive/components/custom-message.d.ts +2 -2
  766. package/node_modules/@earendil-works/pi-coding-agent/dist/modes/interactive/components/custom-message.d.ts.map +1 -1
  767. package/node_modules/@earendil-works/pi-coding-agent/dist/modes/interactive/components/custom-message.js.map +1 -1
  768. package/node_modules/@earendil-works/pi-coding-agent/dist/modes/interactive/components/daxnuts.d.ts.map +1 -1
  769. package/node_modules/@earendil-works/pi-coding-agent/dist/modes/interactive/components/daxnuts.js.map +1 -1
  770. package/node_modules/@earendil-works/pi-coding-agent/dist/modes/interactive/components/diff.d.ts.map +1 -1
  771. package/node_modules/@earendil-works/pi-coding-agent/dist/modes/interactive/components/diff.js.map +1 -1
  772. package/node_modules/@earendil-works/pi-coding-agent/dist/modes/interactive/components/dynamic-border.d.ts.map +1 -1
  773. package/node_modules/@earendil-works/pi-coding-agent/dist/modes/interactive/components/dynamic-border.js.map +1 -1
  774. package/node_modules/@earendil-works/pi-coding-agent/dist/modes/interactive/components/earendil-announcement.d.ts.map +1 -1
  775. package/node_modules/@earendil-works/pi-coding-agent/dist/modes/interactive/components/earendil-announcement.js.map +1 -1
  776. package/node_modules/@earendil-works/pi-coding-agent/dist/modes/interactive/components/extension-editor.d.ts +1 -1
  777. package/node_modules/@earendil-works/pi-coding-agent/dist/modes/interactive/components/extension-editor.d.ts.map +1 -1
  778. package/node_modules/@earendil-works/pi-coding-agent/dist/modes/interactive/components/extension-editor.js.map +1 -1
  779. package/node_modules/@earendil-works/pi-coding-agent/dist/modes/interactive/components/extension-input.d.ts.map +1 -1
  780. package/node_modules/@earendil-works/pi-coding-agent/dist/modes/interactive/components/extension-input.js.map +1 -1
  781. package/node_modules/@earendil-works/pi-coding-agent/dist/modes/interactive/components/extension-selector.d.ts.map +1 -1
  782. package/node_modules/@earendil-works/pi-coding-agent/dist/modes/interactive/components/extension-selector.js.map +1 -1
  783. package/node_modules/@earendil-works/pi-coding-agent/dist/modes/interactive/components/footer.d.ts +4 -3
  784. package/node_modules/@earendil-works/pi-coding-agent/dist/modes/interactive/components/footer.d.ts.map +1 -1
  785. package/node_modules/@earendil-works/pi-coding-agent/dist/modes/interactive/components/footer.js +16 -7
  786. package/node_modules/@earendil-works/pi-coding-agent/dist/modes/interactive/components/footer.js.map +1 -1
  787. package/node_modules/@earendil-works/pi-coding-agent/dist/modes/interactive/components/index.d.ts +31 -31
  788. package/node_modules/@earendil-works/pi-coding-agent/dist/modes/interactive/components/index.d.ts.map +1 -1
  789. package/node_modules/@earendil-works/pi-coding-agent/dist/modes/interactive/components/index.js.map +1 -1
  790. package/node_modules/@earendil-works/pi-coding-agent/dist/modes/interactive/components/keybinding-hints.d.ts.map +1 -1
  791. package/node_modules/@earendil-works/pi-coding-agent/dist/modes/interactive/components/keybinding-hints.js.map +1 -1
  792. package/node_modules/@earendil-works/pi-coding-agent/dist/modes/interactive/components/login-dialog.d.ts +10 -2
  793. package/node_modules/@earendil-works/pi-coding-agent/dist/modes/interactive/components/login-dialog.d.ts.map +1 -1
  794. package/node_modules/@earendil-works/pi-coding-agent/dist/modes/interactive/components/login-dialog.js +31 -6
  795. package/node_modules/@earendil-works/pi-coding-agent/dist/modes/interactive/components/login-dialog.js.map +1 -1
  796. package/node_modules/@earendil-works/pi-coding-agent/dist/modes/interactive/components/model-selector.d.ts +2 -2
  797. package/node_modules/@earendil-works/pi-coding-agent/dist/modes/interactive/components/model-selector.d.ts.map +1 -1
  798. package/node_modules/@earendil-works/pi-coding-agent/dist/modes/interactive/components/model-selector.js.map +1 -1
  799. package/node_modules/@earendil-works/pi-coding-agent/dist/modes/interactive/components/oauth-selector.d.ts +1 -1
  800. package/node_modules/@earendil-works/pi-coding-agent/dist/modes/interactive/components/oauth-selector.d.ts.map +1 -1
  801. package/node_modules/@earendil-works/pi-coding-agent/dist/modes/interactive/components/oauth-selector.js.map +1 -1
  802. package/node_modules/@earendil-works/pi-coding-agent/dist/modes/interactive/components/scoped-models-selector.d.ts.map +1 -1
  803. package/node_modules/@earendil-works/pi-coding-agent/dist/modes/interactive/components/scoped-models-selector.js.map +1 -1
  804. package/node_modules/@earendil-works/pi-coding-agent/dist/modes/interactive/components/session-selector-search.d.ts +1 -1
  805. package/node_modules/@earendil-works/pi-coding-agent/dist/modes/interactive/components/session-selector-search.d.ts.map +1 -1
  806. package/node_modules/@earendil-works/pi-coding-agent/dist/modes/interactive/components/session-selector-search.js.map +1 -1
  807. package/node_modules/@earendil-works/pi-coding-agent/dist/modes/interactive/components/session-selector.d.ts +3 -3
  808. package/node_modules/@earendil-works/pi-coding-agent/dist/modes/interactive/components/session-selector.d.ts.map +1 -1
  809. package/node_modules/@earendil-works/pi-coding-agent/dist/modes/interactive/components/session-selector.js.map +1 -1
  810. package/node_modules/@earendil-works/pi-coding-agent/dist/modes/interactive/components/settings-selector.d.ts +3 -1
  811. package/node_modules/@earendil-works/pi-coding-agent/dist/modes/interactive/components/settings-selector.d.ts.map +1 -1
  812. package/node_modules/@earendil-works/pi-coding-agent/dist/modes/interactive/components/settings-selector.js +15 -0
  813. package/node_modules/@earendil-works/pi-coding-agent/dist/modes/interactive/components/settings-selector.js.map +1 -1
  814. package/node_modules/@earendil-works/pi-coding-agent/dist/modes/interactive/components/show-images-selector.d.ts.map +1 -1
  815. package/node_modules/@earendil-works/pi-coding-agent/dist/modes/interactive/components/show-images-selector.js.map +1 -1
  816. package/node_modules/@earendil-works/pi-coding-agent/dist/modes/interactive/components/skill-invocation-message.d.ts +1 -1
  817. package/node_modules/@earendil-works/pi-coding-agent/dist/modes/interactive/components/skill-invocation-message.d.ts.map +1 -1
  818. package/node_modules/@earendil-works/pi-coding-agent/dist/modes/interactive/components/skill-invocation-message.js.map +1 -1
  819. package/node_modules/@earendil-works/pi-coding-agent/dist/modes/interactive/components/theme-selector.d.ts.map +1 -1
  820. package/node_modules/@earendil-works/pi-coding-agent/dist/modes/interactive/components/theme-selector.js.map +1 -1
  821. package/node_modules/@earendil-works/pi-coding-agent/dist/modes/interactive/components/thinking-selector.d.ts.map +1 -1
  822. package/node_modules/@earendil-works/pi-coding-agent/dist/modes/interactive/components/thinking-selector.js.map +1 -1
  823. package/node_modules/@earendil-works/pi-coding-agent/dist/modes/interactive/components/tool-execution.d.ts +1 -1
  824. package/node_modules/@earendil-works/pi-coding-agent/dist/modes/interactive/components/tool-execution.d.ts.map +1 -1
  825. package/node_modules/@earendil-works/pi-coding-agent/dist/modes/interactive/components/tool-execution.js.map +1 -1
  826. package/node_modules/@earendil-works/pi-coding-agent/dist/modes/interactive/components/tree-selector.d.ts +1 -1
  827. package/node_modules/@earendil-works/pi-coding-agent/dist/modes/interactive/components/tree-selector.d.ts.map +1 -1
  828. package/node_modules/@earendil-works/pi-coding-agent/dist/modes/interactive/components/tree-selector.js.map +1 -1
  829. package/node_modules/@earendil-works/pi-coding-agent/dist/modes/interactive/components/user-message-selector.d.ts.map +1 -1
  830. package/node_modules/@earendil-works/pi-coding-agent/dist/modes/interactive/components/user-message-selector.js.map +1 -1
  831. package/node_modules/@earendil-works/pi-coding-agent/dist/modes/interactive/components/user-message.d.ts.map +1 -1
  832. package/node_modules/@earendil-works/pi-coding-agent/dist/modes/interactive/components/user-message.js.map +1 -1
  833. package/node_modules/@earendil-works/pi-coding-agent/dist/modes/interactive/interactive-mode.d.ts +4 -3
  834. package/node_modules/@earendil-works/pi-coding-agent/dist/modes/interactive/interactive-mode.d.ts.map +1 -1
  835. package/node_modules/@earendil-works/pi-coding-agent/dist/modes/interactive/interactive-mode.js +37 -14
  836. package/node_modules/@earendil-works/pi-coding-agent/dist/modes/interactive/interactive-mode.js.map +1 -1
  837. package/node_modules/@earendil-works/pi-coding-agent/dist/modes/interactive/theme/theme.d.ts +1 -1
  838. package/node_modules/@earendil-works/pi-coding-agent/dist/modes/interactive/theme/theme.d.ts.map +1 -1
  839. package/node_modules/@earendil-works/pi-coding-agent/dist/modes/interactive/theme/theme.js +37 -28
  840. package/node_modules/@earendil-works/pi-coding-agent/dist/modes/interactive/theme/theme.js.map +1 -1
  841. package/node_modules/@earendil-works/pi-coding-agent/dist/modes/print-mode.d.ts +1 -1
  842. package/node_modules/@earendil-works/pi-coding-agent/dist/modes/print-mode.d.ts.map +1 -1
  843. package/node_modules/@earendil-works/pi-coding-agent/dist/modes/print-mode.js.map +1 -1
  844. package/node_modules/@earendil-works/pi-coding-agent/dist/modes/rpc/rpc-client.d.ts +5 -5
  845. package/node_modules/@earendil-works/pi-coding-agent/dist/modes/rpc/rpc-client.d.ts.map +1 -1
  846. package/node_modules/@earendil-works/pi-coding-agent/dist/modes/rpc/rpc-client.js +1 -1
  847. package/node_modules/@earendil-works/pi-coding-agent/dist/modes/rpc/rpc-client.js.map +1 -1
  848. package/node_modules/@earendil-works/pi-coding-agent/dist/modes/rpc/rpc-mode.d.ts +2 -2
  849. package/node_modules/@earendil-works/pi-coding-agent/dist/modes/rpc/rpc-mode.d.ts.map +1 -1
  850. package/node_modules/@earendil-works/pi-coding-agent/dist/modes/rpc/rpc-mode.js.map +1 -1
  851. package/node_modules/@earendil-works/pi-coding-agent/dist/modes/rpc/rpc-types.d.ts +4 -4
  852. package/node_modules/@earendil-works/pi-coding-agent/dist/modes/rpc/rpc-types.d.ts.map +1 -1
  853. package/node_modules/@earendil-works/pi-coding-agent/dist/modes/rpc/rpc-types.js.map +1 -1
  854. package/node_modules/@earendil-works/pi-coding-agent/dist/package-manager-cli.d.ts.map +1 -1
  855. package/node_modules/@earendil-works/pi-coding-agent/dist/package-manager-cli.js +40 -1
  856. package/node_modules/@earendil-works/pi-coding-agent/dist/package-manager-cli.js.map +1 -1
  857. package/node_modules/@earendil-works/pi-coding-agent/dist/utils/changelog.d.ts +1 -1
  858. package/node_modules/@earendil-works/pi-coding-agent/dist/utils/changelog.d.ts.map +1 -1
  859. package/node_modules/@earendil-works/pi-coding-agent/dist/utils/changelog.js.map +1 -1
  860. package/node_modules/@earendil-works/pi-coding-agent/dist/utils/clipboard-image.d.ts.map +1 -1
  861. package/node_modules/@earendil-works/pi-coding-agent/dist/utils/clipboard-image.js.map +1 -1
  862. package/node_modules/@earendil-works/pi-coding-agent/dist/utils/clipboard.d.ts.map +1 -1
  863. package/node_modules/@earendil-works/pi-coding-agent/dist/utils/clipboard.js.map +1 -1
  864. package/node_modules/@earendil-works/pi-coding-agent/dist/utils/exif-orientation.d.ts +1 -1
  865. package/node_modules/@earendil-works/pi-coding-agent/dist/utils/exif-orientation.d.ts.map +1 -1
  866. package/node_modules/@earendil-works/pi-coding-agent/dist/utils/exif-orientation.js.map +1 -1
  867. package/node_modules/@earendil-works/pi-coding-agent/dist/utils/image-convert.d.ts.map +1 -1
  868. package/node_modules/@earendil-works/pi-coding-agent/dist/utils/image-convert.js.map +1 -1
  869. package/node_modules/@earendil-works/pi-coding-agent/dist/utils/image-resize.d.ts.map +1 -1
  870. package/node_modules/@earendil-works/pi-coding-agent/dist/utils/image-resize.js.map +1 -1
  871. package/node_modules/@earendil-works/pi-coding-agent/dist/utils/paths.d.ts +16 -1
  872. package/node_modules/@earendil-works/pi-coding-agent/dist/utils/paths.d.ts.map +1 -1
  873. package/node_modules/@earendil-works/pi-coding-agent/dist/utils/paths.js +49 -7
  874. package/node_modules/@earendil-works/pi-coding-agent/dist/utils/paths.js.map +1 -1
  875. package/node_modules/@earendil-works/pi-coding-agent/dist/utils/shell.d.ts.map +1 -1
  876. package/node_modules/@earendil-works/pi-coding-agent/dist/utils/shell.js.map +1 -1
  877. package/node_modules/@earendil-works/pi-coding-agent/dist/utils/syntax-highlight.d.ts.map +1 -1
  878. package/node_modules/@earendil-works/pi-coding-agent/dist/utils/syntax-highlight.js.map +1 -1
  879. package/node_modules/@earendil-works/pi-coding-agent/dist/utils/tools-manager.d.ts.map +1 -1
  880. package/node_modules/@earendil-works/pi-coding-agent/dist/utils/tools-manager.js.map +1 -1
  881. package/node_modules/@earendil-works/pi-coding-agent/dist/utils/version-check.d.ts +2 -1
  882. package/node_modules/@earendil-works/pi-coding-agent/dist/utils/version-check.d.ts.map +1 -1
  883. package/node_modules/@earendil-works/pi-coding-agent/dist/utils/version-check.js +9 -4
  884. package/node_modules/@earendil-works/pi-coding-agent/dist/utils/version-check.js.map +1 -1
  885. package/node_modules/@earendil-works/pi-coding-agent/dist/utils/windows-self-update.d.ts.map +1 -1
  886. package/node_modules/@earendil-works/pi-coding-agent/dist/utils/windows-self-update.js.map +1 -1
  887. package/node_modules/@earendil-works/pi-coding-agent/docs/custom-provider.md +44 -12
  888. package/node_modules/@earendil-works/pi-coding-agent/docs/index.md +6 -4
  889. package/node_modules/@earendil-works/pi-coding-agent/docs/models.md +8 -2
  890. package/node_modules/@earendil-works/pi-coding-agent/docs/packages.md +5 -4
  891. package/node_modules/@earendil-works/pi-coding-agent/docs/quickstart.md +3 -1
  892. package/node_modules/@earendil-works/pi-coding-agent/docs/sdk.md +2 -0
  893. package/node_modules/@earendil-works/pi-coding-agent/docs/termux.md +1 -1
  894. package/node_modules/@earendil-works/pi-coding-agent/docs/usage.md +2 -2
  895. package/node_modules/@earendil-works/pi-coding-agent/examples/extensions/custom-provider-anthropic/package.json +2 -2
  896. package/node_modules/@earendil-works/pi-coding-agent/examples/extensions/custom-provider-gitlab-duo/package.json +1 -1
  897. package/node_modules/@earendil-works/pi-coding-agent/examples/extensions/custom-provider-gitlab-duo/test.ts +1 -1
  898. package/node_modules/@earendil-works/pi-coding-agent/examples/extensions/doom-overlay/doom-component.ts +2 -2
  899. package/node_modules/@earendil-works/pi-coding-agent/examples/extensions/doom-overlay/index.ts +3 -3
  900. package/node_modules/@earendil-works/pi-coding-agent/examples/extensions/overlay-qa-tests.ts +97 -66
  901. package/node_modules/@earendil-works/pi-coding-agent/examples/extensions/overlay-test.ts +7 -4
  902. package/node_modules/@earendil-works/pi-coding-agent/examples/extensions/plan-mode/index.ts +1 -1
  903. package/node_modules/@earendil-works/pi-coding-agent/examples/extensions/sandbox/package.json +2 -2
  904. package/node_modules/@earendil-works/pi-coding-agent/examples/extensions/subagent/index.ts +1 -1
  905. package/node_modules/@earendil-works/pi-coding-agent/examples/extensions/with-deps/package.json +3 -3
  906. package/node_modules/@earendil-works/pi-coding-agent/npm-shrinkwrap.json +1425 -0
  907. package/node_modules/@earendil-works/pi-coding-agent/package.json +32 -31
  908. package/node_modules/@earendil-works/pi-tui/dist/autocomplete.d.ts.map +1 -1
  909. package/node_modules/@earendil-works/pi-tui/dist/autocomplete.js.map +1 -1
  910. package/node_modules/@earendil-works/pi-tui/dist/components/box.d.ts +1 -1
  911. package/node_modules/@earendil-works/pi-tui/dist/components/box.d.ts.map +1 -1
  912. package/node_modules/@earendil-works/pi-tui/dist/components/box.js.map +1 -1
  913. package/node_modules/@earendil-works/pi-tui/dist/components/cancellable-loader.d.ts +1 -1
  914. package/node_modules/@earendil-works/pi-tui/dist/components/cancellable-loader.d.ts.map +1 -1
  915. package/node_modules/@earendil-works/pi-tui/dist/components/cancellable-loader.js.map +1 -1
  916. package/node_modules/@earendil-works/pi-tui/dist/components/editor.d.ts +3 -3
  917. package/node_modules/@earendil-works/pi-tui/dist/components/editor.d.ts.map +1 -1
  918. package/node_modules/@earendil-works/pi-tui/dist/components/editor.js.map +1 -1
  919. package/node_modules/@earendil-works/pi-tui/dist/components/image.d.ts +2 -2
  920. package/node_modules/@earendil-works/pi-tui/dist/components/image.d.ts.map +1 -1
  921. package/node_modules/@earendil-works/pi-tui/dist/components/image.js.map +1 -1
  922. package/node_modules/@earendil-works/pi-tui/dist/components/input.d.ts +1 -1
  923. package/node_modules/@earendil-works/pi-tui/dist/components/input.d.ts.map +1 -1
  924. package/node_modules/@earendil-works/pi-tui/dist/components/input.js.map +1 -1
  925. package/node_modules/@earendil-works/pi-tui/dist/components/loader.d.ts +5 -5
  926. package/node_modules/@earendil-works/pi-tui/dist/components/loader.d.ts.map +1 -1
  927. package/node_modules/@earendil-works/pi-tui/dist/components/loader.js +4 -4
  928. package/node_modules/@earendil-works/pi-tui/dist/components/loader.js.map +1 -1
  929. package/node_modules/@earendil-works/pi-tui/dist/components/markdown.d.ts +1 -1
  930. package/node_modules/@earendil-works/pi-tui/dist/components/markdown.d.ts.map +1 -1
  931. package/node_modules/@earendil-works/pi-tui/dist/components/markdown.js.map +1 -1
  932. package/node_modules/@earendil-works/pi-tui/dist/components/select-list.d.ts +1 -1
  933. package/node_modules/@earendil-works/pi-tui/dist/components/select-list.d.ts.map +1 -1
  934. package/node_modules/@earendil-works/pi-tui/dist/components/select-list.js.map +1 -1
  935. package/node_modules/@earendil-works/pi-tui/dist/components/settings-list.d.ts +1 -1
  936. package/node_modules/@earendil-works/pi-tui/dist/components/settings-list.d.ts.map +1 -1
  937. package/node_modules/@earendil-works/pi-tui/dist/components/settings-list.js.map +1 -1
  938. package/node_modules/@earendil-works/pi-tui/dist/components/spacer.d.ts +1 -1
  939. package/node_modules/@earendil-works/pi-tui/dist/components/spacer.d.ts.map +1 -1
  940. package/node_modules/@earendil-works/pi-tui/dist/components/spacer.js.map +1 -1
  941. package/node_modules/@earendil-works/pi-tui/dist/components/text.d.ts +1 -1
  942. package/node_modules/@earendil-works/pi-tui/dist/components/text.d.ts.map +1 -1
  943. package/node_modules/@earendil-works/pi-tui/dist/components/text.js.map +1 -1
  944. package/node_modules/@earendil-works/pi-tui/dist/components/truncated-text.d.ts +1 -1
  945. package/node_modules/@earendil-works/pi-tui/dist/components/truncated-text.d.ts.map +1 -1
  946. package/node_modules/@earendil-works/pi-tui/dist/components/truncated-text.js.map +1 -1
  947. package/node_modules/@earendil-works/pi-tui/dist/editor-component.d.ts +2 -2
  948. package/node_modules/@earendil-works/pi-tui/dist/editor-component.d.ts.map +1 -1
  949. package/node_modules/@earendil-works/pi-tui/dist/editor-component.js.map +1 -1
  950. package/node_modules/@earendil-works/pi-tui/dist/index.d.ts +22 -22
  951. package/node_modules/@earendil-works/pi-tui/dist/index.d.ts.map +1 -1
  952. package/node_modules/@earendil-works/pi-tui/dist/index.js.map +1 -1
  953. package/node_modules/@earendil-works/pi-tui/dist/keybindings.d.ts +1 -1
  954. package/node_modules/@earendil-works/pi-tui/dist/keybindings.d.ts.map +1 -1
  955. package/node_modules/@earendil-works/pi-tui/dist/keybindings.js.map +1 -1
  956. package/node_modules/@earendil-works/pi-tui/dist/terminal.d.ts.map +1 -1
  957. package/node_modules/@earendil-works/pi-tui/dist/terminal.js +25 -15
  958. package/node_modules/@earendil-works/pi-tui/dist/terminal.js.map +1 -1
  959. package/node_modules/@earendil-works/pi-tui/dist/tui.d.ts +2 -2
  960. package/node_modules/@earendil-works/pi-tui/dist/tui.d.ts.map +1 -1
  961. package/node_modules/@earendil-works/pi-tui/dist/tui.js.map +1 -1
  962. package/node_modules/@earendil-works/pi-tui/native/win32/prebuilds/win32-arm64/win32-console-mode.node +0 -0
  963. package/node_modules/@earendil-works/pi-tui/native/win32/prebuilds/win32-x64/win32-console-mode.node +0 -0
  964. package/node_modules/@earendil-works/pi-tui/package.json +8 -11
  965. package/node_modules/@mariozechner/clipboard/package.json +2 -1
  966. package/node_modules/@mariozechner/clipboard-linux-x64-musl/README.md +3 -0
  967. package/node_modules/@mariozechner/clipboard-linux-x64-musl/clipboard.linux-x64-musl.node +0 -0
  968. package/node_modules/@mariozechner/clipboard-linux-x64-musl/package.json +25 -0
  969. package/package.json +15 -8
  970. package/dist/bin/forgecli.d.ts +0 -2
  971. package/dist/bin/forgecli.js +0 -6
  972. package/dist/bin/forgecli.js.map +0 -1
  973. package/node_modules/koffi/CHANGELOG.md +0 -1093
  974. package/node_modules/koffi/LICENSE.txt +0 -22
  975. package/node_modules/koffi/README.md +0 -43
  976. package/node_modules/koffi/build/koffi/darwin_arm64/koffi.node +0 -0
  977. package/node_modules/koffi/build/koffi/darwin_x64/koffi.node +0 -0
  978. package/node_modules/koffi/build/koffi/freebsd_arm64/koffi.node +0 -0
  979. package/node_modules/koffi/build/koffi/freebsd_ia32/koffi.node +0 -0
  980. package/node_modules/koffi/build/koffi/freebsd_x64/koffi.node +0 -0
  981. package/node_modules/koffi/build/koffi/linux_arm64/koffi.node +0 -0
  982. package/node_modules/koffi/build/koffi/linux_armhf/koffi.node +0 -0
  983. package/node_modules/koffi/build/koffi/linux_ia32/koffi.node +0 -0
  984. package/node_modules/koffi/build/koffi/linux_loong64/koffi.node +0 -0
  985. package/node_modules/koffi/build/koffi/linux_riscv64d/koffi.node +0 -0
  986. package/node_modules/koffi/build/koffi/linux_x64/koffi.node +0 -0
  987. package/node_modules/koffi/build/koffi/musl_arm64/koffi.node +0 -0
  988. package/node_modules/koffi/build/koffi/musl_x64/koffi.node +0 -0
  989. package/node_modules/koffi/build/koffi/openbsd_ia32/koffi.node +0 -0
  990. package/node_modules/koffi/build/koffi/openbsd_x64/koffi.node +0 -0
  991. package/node_modules/koffi/build/koffi/win32_arm64/koffi.exp +0 -0
  992. package/node_modules/koffi/build/koffi/win32_arm64/koffi.lib +0 -0
  993. package/node_modules/koffi/build/koffi/win32_arm64/koffi.node +0 -0
  994. package/node_modules/koffi/build/koffi/win32_ia32/koffi.exp +0 -0
  995. package/node_modules/koffi/build/koffi/win32_ia32/koffi.lib +0 -0
  996. package/node_modules/koffi/build/koffi/win32_ia32/koffi.node +0 -0
  997. package/node_modules/koffi/build/koffi/win32_x64/koffi.exp +0 -0
  998. package/node_modules/koffi/build/koffi/win32_x64/koffi.lib +0 -0
  999. package/node_modules/koffi/build/koffi/win32_x64/koffi.node +0 -0
  1000. package/node_modules/koffi/doc/benchmarks.md +0 -126
  1001. package/node_modules/koffi/doc/callbacks.md +0 -210
  1002. package/node_modules/koffi/doc/contribute.md +0 -148
  1003. package/node_modules/koffi/doc/functions.md +0 -250
  1004. package/node_modules/koffi/doc/index.md +0 -61
  1005. package/node_modules/koffi/doc/input.md +0 -471
  1006. package/node_modules/koffi/doc/migration.md +0 -159
  1007. package/node_modules/koffi/doc/misc.md +0 -180
  1008. package/node_modules/koffi/doc/output.md +0 -305
  1009. package/node_modules/koffi/doc/packaging.md +0 -88
  1010. package/node_modules/koffi/doc/platforms.md +0 -36
  1011. package/node_modules/koffi/doc/pointers.md +0 -328
  1012. package/node_modules/koffi/doc/start.md +0 -118
  1013. package/node_modules/koffi/doc/unions.md +0 -186
  1014. package/node_modules/koffi/doc/variables.md +0 -102
  1015. package/node_modules/koffi/index.d.ts +0 -288
  1016. package/node_modules/koffi/index.js +0 -634
  1017. package/node_modules/koffi/indirect.js +0 -533
  1018. package/node_modules/koffi/lib/native/base/base.cc +0 -11015
  1019. package/node_modules/koffi/lib/native/base/base.hh +0 -6003
  1020. package/node_modules/koffi/lib/native/base/crc.inc +0 -2214
  1021. package/node_modules/koffi/lib/native/base/crc_gen.py +0 -72
  1022. package/node_modules/koffi/lib/native/base/mimetypes.inc +0 -1248
  1023. package/node_modules/koffi/lib/native/base/mimetypes_gen.py +0 -58
  1024. package/node_modules/koffi/lib/native/base/tower.cc +0 -821
  1025. package/node_modules/koffi/lib/native/base/tower.hh +0 -81
  1026. package/node_modules/koffi/lib/native/base/unicode.inc +0 -408
  1027. package/node_modules/koffi/lib/native/base/unicode_gen.py +0 -152
  1028. package/node_modules/koffi/package.json +0 -38
  1029. package/node_modules/koffi/src/cnoke/LICENSE.txt +0 -22
  1030. package/node_modules/koffi/src/cnoke/README.md +0 -99
  1031. package/node_modules/koffi/src/cnoke/assets/FindCNoke.cmake +0 -127
  1032. package/node_modules/koffi/src/cnoke/assets/toolchains.json +0 -126
  1033. package/node_modules/koffi/src/cnoke/assets/win_delay_hook.c +0 -36
  1034. package/node_modules/koffi/src/cnoke/cnoke.js +0 -170
  1035. package/node_modules/koffi/src/cnoke/package.json +0 -24
  1036. package/node_modules/koffi/src/cnoke/src/builder.js +0 -511
  1037. package/node_modules/koffi/src/cnoke/src/index.js +0 -10
  1038. package/node_modules/koffi/src/cnoke/src/tools.js +0 -407
  1039. package/node_modules/koffi/src/koffi/CMakeLists.txt +0 -182
  1040. package/node_modules/koffi/src/koffi/src/abi_arm32.cc +0 -1018
  1041. package/node_modules/koffi/src/koffi/src/abi_arm32_asm.S +0 -169
  1042. package/node_modules/koffi/src/koffi/src/abi_arm64.cc +0 -1295
  1043. package/node_modules/koffi/src/koffi/src/abi_arm64_asm.S +0 -195
  1044. package/node_modules/koffi/src/koffi/src/abi_arm64_asm.asm +0 -174
  1045. package/node_modules/koffi/src/koffi/src/abi_loong64.cc +0 -5
  1046. package/node_modules/koffi/src/koffi/src/abi_loong64_asm.S +0 -204
  1047. package/node_modules/koffi/src/koffi/src/abi_riscv64.cc +0 -915
  1048. package/node_modules/koffi/src/koffi/src/abi_riscv64_asm.S +0 -203
  1049. package/node_modules/koffi/src/koffi/src/abi_x64_sysv.cc +0 -939
  1050. package/node_modules/koffi/src/koffi/src/abi_x64_sysv_asm.S +0 -231
  1051. package/node_modules/koffi/src/koffi/src/abi_x64_win.cc +0 -715
  1052. package/node_modules/koffi/src/koffi/src/abi_x64_win_asm.S +0 -166
  1053. package/node_modules/koffi/src/koffi/src/abi_x64_win_asm.asm +0 -192
  1054. package/node_modules/koffi/src/koffi/src/abi_x86.cc +0 -860
  1055. package/node_modules/koffi/src/koffi/src/abi_x86_asm.S +0 -193
  1056. package/node_modules/koffi/src/koffi/src/abi_x86_asm.asm +0 -177
  1057. package/node_modules/koffi/src/koffi/src/call.cc +0 -1326
  1058. package/node_modules/koffi/src/koffi/src/call.hh +0 -179
  1059. package/node_modules/koffi/src/koffi/src/errno.inc +0 -462
  1060. package/node_modules/koffi/src/koffi/src/ffi.cc +0 -2702
  1061. package/node_modules/koffi/src/koffi/src/ffi.hh +0 -354
  1062. package/node_modules/koffi/src/koffi/src/init.js +0 -105
  1063. package/node_modules/koffi/src/koffi/src/parser.cc +0 -220
  1064. package/node_modules/koffi/src/koffi/src/parser.hh +0 -54
  1065. package/node_modules/koffi/src/koffi/src/util.cc +0 -1807
  1066. package/node_modules/koffi/src/koffi/src/util.hh +0 -221
  1067. package/node_modules/koffi/src/koffi/src/uv.cc +0 -193
  1068. package/node_modules/koffi/src/koffi/src/uv.def +0 -10
  1069. package/node_modules/koffi/src/koffi/src/uv.hh +0 -40
  1070. package/node_modules/koffi/src/koffi/src/win32.cc +0 -198
  1071. package/node_modules/koffi/src/koffi/src/win32.hh +0 -119
  1072. package/node_modules/koffi/src/koffi/tools/write_trampolines.js +0 -77
  1073. package/node_modules/koffi/vendor/node-addon-api/LICENSE.md +0 -9
  1074. package/node_modules/koffi/vendor/node-addon-api/README.md +0 -95
  1075. package/node_modules/koffi/vendor/node-addon-api/napi-inl.deprecated.h +0 -186
  1076. package/node_modules/koffi/vendor/node-addon-api/napi-inl.h +0 -7033
  1077. package/node_modules/koffi/vendor/node-addon-api/napi.h +0 -3309
  1078. package/node_modules/koffi/vendor/node-api-headers/LICENSE +0 -21
  1079. package/node_modules/koffi/vendor/node-api-headers/README.md +0 -95
  1080. package/node_modules/koffi/vendor/node-api-headers/def/js_native_api.def +0 -125
  1081. package/node_modules/koffi/vendor/node-api-headers/def/node_api.def +0 -157
  1082. package/node_modules/koffi/vendor/node-api-headers/include/js_native_api.h +0 -591
  1083. package/node_modules/koffi/vendor/node-api-headers/include/js_native_api_types.h +0 -210
  1084. package/node_modules/koffi/vendor/node-api-headers/include/node_api.h +0 -265
  1085. package/node_modules/koffi/vendor/node-api-headers/include/node_api_types.h +0 -58
  1086. package/node_modules/koffi/vendor/node-api-headers/include/uv/aix.h +0 -32
  1087. package/node_modules/koffi/vendor/node-api-headers/include/uv/bsd.h +0 -34
  1088. package/node_modules/koffi/vendor/node-api-headers/include/uv/darwin.h +0 -61
  1089. package/node_modules/koffi/vendor/node-api-headers/include/uv/errno.h +0 -483
  1090. package/node_modules/koffi/vendor/node-api-headers/include/uv/linux.h +0 -34
  1091. package/node_modules/koffi/vendor/node-api-headers/include/uv/os390.h +0 -33
  1092. package/node_modules/koffi/vendor/node-api-headers/include/uv/posix.h +0 -31
  1093. package/node_modules/koffi/vendor/node-api-headers/include/uv/sunos.h +0 -44
  1094. package/node_modules/koffi/vendor/node-api-headers/include/uv/threadpool.h +0 -37
  1095. package/node_modules/koffi/vendor/node-api-headers/include/uv/tree.h +0 -521
  1096. package/node_modules/koffi/vendor/node-api-headers/include/uv/unix.h +0 -512
  1097. package/node_modules/koffi/vendor/node-api-headers/include/uv/version.h +0 -43
  1098. package/node_modules/koffi/vendor/node-api-headers/include/uv/win.h +0 -698
  1099. package/node_modules/koffi/vendor/node-api-headers/include/uv.h +0 -1990
@@ -1,1295 +0,0 @@
1
- // SPDX-License-Identifier: MIT
2
- // SPDX-FileCopyrightText: 2025 Niels Martignène <niels.martignene@protonmail.com>
3
-
4
- #if defined(__aarch64__) || defined(_M_ARM64)
5
-
6
- #include "lib/native/base/base.hh"
7
- #include "ffi.hh"
8
- #include "call.hh"
9
- #include "util.hh"
10
- #if defined(_WIN32)
11
- #include "win32.hh"
12
- #endif
13
-
14
- #include <napi.h>
15
-
16
- namespace K {
17
-
18
- struct HfaInfo {
19
- int count;
20
- bool float32;
21
- };
22
-
23
- struct X0X1Ret {
24
- uint64_t x0;
25
- uint64_t x1;
26
- };
27
- struct HfaRet {
28
- double d0;
29
- double d1;
30
- double d2;
31
- double d3;
32
- };
33
-
34
- struct BackRegisters {
35
- uint64_t x0;
36
- uint64_t x1;
37
- double d0;
38
- double d1;
39
- double d2;
40
- double d3;
41
- };
42
-
43
- extern "C" X0X1Ret ForwardCallGG(const void *func, uint8_t *sp, uint8_t **out_old_sp);
44
- extern "C" float ForwardCallF(const void *func, uint8_t *sp, uint8_t **out_old_sp);
45
- extern "C" HfaRet ForwardCallDDDD(const void *func, uint8_t *sp, uint8_t **out_old_sp);
46
-
47
- extern "C" X0X1Ret ForwardCallXGG(const void *func, uint8_t *sp, uint8_t **out_old_sp);
48
- extern "C" float ForwardCallXF(const void *func, uint8_t *sp, uint8_t **out_old_sp);
49
- extern "C" HfaRet ForwardCallXDDDD(const void *func, uint8_t *sp, uint8_t **out_old_sp);
50
-
51
- extern "C" uint8_t Trampoline0;
52
- extern "C" uint8_t TrampolineEnd;
53
- extern "C" void *FindTrampolineStart();
54
- extern "C" void *FindTrampolineEnd();
55
-
56
- static HfaInfo IsHFA(const TypeInfo *type)
57
- {
58
- bool float32 = false;
59
- bool float64 = false;
60
- int count = 0;
61
-
62
- count = AnalyseFlat(type, [&](const TypeInfo *type, int, int) {
63
- if (type->primitive == PrimitiveKind::Float32) {
64
- float32 = true;
65
- } else if (type->primitive == PrimitiveKind::Float64) {
66
- float64 = true;
67
- } else {
68
- float32 = true;
69
- float64 = true;
70
- }
71
- });
72
-
73
- HfaInfo info = {};
74
-
75
- if (count < 1 || count > 4)
76
- return info;
77
- if (float32 && float64)
78
- return info;
79
-
80
- info.count = count;
81
- info.float32 = float32;
82
-
83
- return info;
84
- }
85
-
86
- static inline void ExpandFloats(uint8_t *ptr, Size len, Size bytes)
87
- {
88
- for (Size i = len - 1; i >= 0; i--) {
89
- const uint8_t *src = ptr + i * bytes;
90
- uint8_t *dest = ptr + i * 8;
91
-
92
- memmove(dest, src, bytes);
93
- }
94
- }
95
-
96
- static inline void CompactFloats(uint8_t *ptr, Size len, Size bytes)
97
- {
98
- for (Size i = 0; i < len; i++) {
99
- const uint8_t *src = ptr + i * 8;
100
- uint8_t *dest = ptr + i * bytes;
101
-
102
- memmove(dest, src, bytes);
103
- }
104
- }
105
-
106
- bool AnalyseFunction(Napi::Env, InstanceData *, FunctionInfo *func)
107
- {
108
- if (HfaInfo hfa = IsHFA(func->ret.type); hfa.count) {
109
- func->ret.vec_count = (int8_t)hfa.count;
110
- func->ret.vec_bytes = hfa.float32 ? 4 : 8;
111
- } else if (func->ret.type->size <= 16) {
112
- func->ret.gpr_count = (int8_t)((func->ret.type->size + 7) / 8);
113
- } else {
114
- func->ret.use_memory = true;
115
- }
116
-
117
- int gpr_avail = 8;
118
- int vec_avail = 8;
119
- #if defined(_M_ARM64EC)
120
- if (func->variadic) {
121
- gpr_avail = 4;
122
- }
123
- #endif
124
-
125
- for (ParameterInfo &param: func->parameters) {
126
- switch (param.type->primitive) {
127
- case PrimitiveKind::Void: { K_UNREACHABLE(); } break;
128
-
129
- case PrimitiveKind::Bool:
130
- case PrimitiveKind::Int8:
131
- case PrimitiveKind::UInt8:
132
- case PrimitiveKind::Int16:
133
- case PrimitiveKind::Int16S:
134
- case PrimitiveKind::UInt16:
135
- case PrimitiveKind::UInt16S:
136
- case PrimitiveKind::Int32:
137
- case PrimitiveKind::Int32S:
138
- case PrimitiveKind::UInt32:
139
- case PrimitiveKind::UInt32S:
140
- case PrimitiveKind::Int64:
141
- case PrimitiveKind::Int64S:
142
- case PrimitiveKind::UInt64:
143
- case PrimitiveKind::UInt64S:
144
- case PrimitiveKind::String:
145
- case PrimitiveKind::String16:
146
- case PrimitiveKind::String32:
147
- case PrimitiveKind::Pointer:
148
- case PrimitiveKind::Callback: {
149
- #if defined(__APPLE__)
150
- if (param.variadic)
151
- break;
152
- #endif
153
-
154
- if (gpr_avail) {
155
- param.gpr_count = 1;
156
- gpr_avail--;
157
- }
158
- } break;
159
- case PrimitiveKind::Record:
160
- case PrimitiveKind::Union: {
161
- HfaInfo hfa = IsHFA(param.type);
162
-
163
- #if defined(_M_ARM64EC)
164
- if (func->variadic) {
165
- if (IsRegularSize(param.type->size, 8) && gpr_avail) {
166
- param.gpr_count = 1;
167
- gpr_avail--;
168
- } else {
169
- if (gpr_avail) {
170
- param.gpr_count = 1;
171
- gpr_avail--;
172
- }
173
- param.use_memory = true;
174
- }
175
-
176
- break;
177
- }
178
- #endif
179
-
180
- #if defined(_WIN32)
181
- if (param.variadic) {
182
- hfa.count = 0;
183
- }
184
- #elif defined(__APPLE__)
185
- if (param.variadic) {
186
- param.use_memory = (param.type->size > 16);
187
- break;
188
- }
189
- #endif
190
-
191
- if (hfa.count) {
192
- if (hfa.count <= vec_avail) {
193
- param.vec_count = (int8_t)hfa.count;
194
- param.vec_bytes = hfa.float32 ? 4 : 8;
195
- vec_avail -= hfa.count;
196
- } else {
197
- vec_avail = 0;
198
- }
199
- } else if (param.type->size <= 16) {
200
- int gpr_count = (param.type->size + 7) / 8;
201
-
202
- if (gpr_count <= gpr_avail) {
203
- param.gpr_count = (int8_t)gpr_count;
204
- gpr_avail -= gpr_count;
205
- } else {
206
- gpr_avail = 0;
207
- }
208
- } else {
209
- // Big types (more than 16 bytes) are replaced by a pointer
210
- if (gpr_avail) {
211
- param.gpr_count = 1;
212
- gpr_avail--;
213
- }
214
- param.use_memory = true;
215
- }
216
- } break;
217
- case PrimitiveKind::Array: { K_UNREACHABLE(); } break;
218
- case PrimitiveKind::Float32:
219
- case PrimitiveKind::Float64: {
220
- #if defined(_WIN32)
221
- if (param.variadic) {
222
- if (gpr_avail) {
223
- param.gpr_count = 1;
224
- gpr_avail--;
225
- }
226
- break;
227
- }
228
- #elif defined(__APPLE__)
229
- if (param.variadic)
230
- break;
231
- #endif
232
-
233
- if (vec_avail) {
234
- param.vec_count = 1;
235
- vec_avail--;
236
- }
237
- } break;
238
-
239
- case PrimitiveKind::Prototype: { K_UNREACHABLE(); } break;
240
- }
241
- }
242
-
243
- func->args_size = 16 * func->parameters.len;
244
- func->forward_fp = (vec_avail < 8);
245
-
246
- return true;
247
- }
248
-
249
- bool CallData::Prepare(const FunctionInfo *func, const Napi::CallbackInfo &info)
250
- {
251
- uint64_t *args_ptr = nullptr;
252
- uint64_t *gpr_ptr = nullptr;
253
- uint64_t *vec_ptr = nullptr;
254
-
255
- // Return through registers unless it's too big
256
- if (!AllocStack(func->args_size, 16, &args_ptr)) [[unlikely]]
257
- return false;
258
- if (!AllocStack(8 * 8, 8, &vec_ptr)) [[unlikely]]
259
- return false;
260
- if (!AllocStack(9 * 8, 8, &gpr_ptr)) [[unlikely]]
261
- return false;
262
- if (func->ret.use_memory) {
263
- return_ptr = AllocHeap(func->ret.type->size, 16);
264
- gpr_ptr[8] = (uint64_t)return_ptr;
265
- }
266
-
267
- #if defined(_M_ARM64EC)
268
- if (func->variadic) {
269
- gpr_ptr[4] = (uint64_t)args_ptr;
270
- gpr_ptr[5] = 0;
271
-
272
- for (Size i = 4; i < func->parameters.len; i++) {
273
- const ParameterInfo &param = func->parameters[i];
274
- gpr_ptr[5] += std::max((Size)8, param.type->size);
275
- }
276
- }
277
- #endif
278
-
279
- #if defined(__APPLE__)
280
- #define PUSH_INTEGER(CType) \
281
- do { \
282
- if (!value.IsNumber() && !value.IsBigInt()) [[unlikely]] { \
283
- ThrowError<Napi::TypeError>(env, "Unexpected %1 value, expected number", GetValueType(instance, value)); \
284
- return false; \
285
- } \
286
- \
287
- CType v = GetNumber<CType>(value); \
288
- \
289
- if (param.gpr_count) [[likely]] { \
290
- *(gpr_ptr++) = (uint64_t)v; \
291
- } else { \
292
- args_ptr = AlignUp(args_ptr, param.variadic ? 8 : param.type->align); \
293
- *args_ptr = (uint64_t)v; \
294
- args_ptr = (uint64_t *)((uint8_t *)args_ptr + param.type->size); \
295
- } \
296
- } while (false)
297
- #define PUSH_INTEGER_SWAP(CType) \
298
- do { \
299
- if (!value.IsNumber() && !value.IsBigInt()) [[unlikely]] { \
300
- ThrowError<Napi::TypeError>(env, "Unexpected %1 value, expected number", GetValueType(instance, value)); \
301
- return false; \
302
- } \
303
- \
304
- CType v = GetNumber<CType>(value); \
305
- \
306
- if (param.gpr_count) [[likely]] { \
307
- *(gpr_ptr++) = (uint64_t)ReverseBytes(v); \
308
- } else { \
309
- args_ptr = AlignUp(args_ptr, param.variadic ? 8 : param.type->align); \
310
- *args_ptr = (uint64_t)ReverseBytes(v); \
311
- args_ptr = (uint64_t *)((uint8_t *)args_ptr + param.type->size); \
312
- } \
313
- } while (false)
314
- #else
315
- #define PUSH_INTEGER(CType) \
316
- do { \
317
- if (!value.IsNumber() && !value.IsBigInt()) [[unlikely]] { \
318
- ThrowError<Napi::TypeError>(env, "Unexpected %1 value, expected number", GetValueType(instance, value)); \
319
- return false; \
320
- } \
321
- \
322
- CType v = GetNumber<CType>(value); \
323
- *((param.gpr_count ? gpr_ptr : args_ptr)++) = (uint64_t)v; \
324
- } while (false)
325
- #define PUSH_INTEGER_SWAP(CType) \
326
- do { \
327
- if (!value.IsNumber() && !value.IsBigInt()) [[unlikely]] { \
328
- ThrowError<Napi::TypeError>(env, "Unexpected %1 value, expected number", GetValueType(instance, value)); \
329
- return false; \
330
- } \
331
- \
332
- CType v = GetNumber<CType>(value); \
333
- *((param.gpr_count ? gpr_ptr : args_ptr)++) = (uint64_t)ReverseBytes(v); \
334
- } while (false)
335
- #endif
336
-
337
- // Push arguments
338
- for (Size i = 0; i < func->parameters.len; i++) {
339
- const ParameterInfo &param = func->parameters[i];
340
- K_ASSERT(param.directions >= 1 && param.directions <= 3);
341
-
342
- Napi::Value value = info[param.offset];
343
-
344
- switch (param.type->primitive) {
345
- case PrimitiveKind::Void: { K_UNREACHABLE(); } break;
346
-
347
- case PrimitiveKind::Bool: {
348
- if (!value.IsBoolean()) [[unlikely]] {
349
- ThrowError<Napi::TypeError>(env, "Unexpected %1 value, expected boolean", GetValueType(instance, value));
350
- return false;
351
- }
352
-
353
- bool b = value.As<Napi::Boolean>();
354
-
355
- #if defined(__APPLE__)
356
- if (param.gpr_count) [[likely]] {
357
- *(gpr_ptr++) = (uint64_t)b;
358
- } else {
359
- args_ptr = AlignUp(args_ptr, param.variadic ? 8 : 1);
360
- *(uint8_t *)args_ptr = b;
361
- args_ptr = (uint64_t *)((uint8_t *)args_ptr + 1);
362
- }
363
- #else
364
- *((param.gpr_count ? gpr_ptr : args_ptr)++) = (uint64_t)b;
365
- #endif
366
- } break;
367
- case PrimitiveKind::Int8: { PUSH_INTEGER(int8_t); } break;
368
- case PrimitiveKind::UInt8: { PUSH_INTEGER(uint8_t); } break;
369
- case PrimitiveKind::Int16: { PUSH_INTEGER(int16_t); } break;
370
- case PrimitiveKind::Int16S: { PUSH_INTEGER_SWAP(int16_t); } break;
371
- case PrimitiveKind::UInt16: { PUSH_INTEGER(uint16_t); } break;
372
- case PrimitiveKind::UInt16S: { PUSH_INTEGER_SWAP(uint16_t); } break;
373
- case PrimitiveKind::Int32: { PUSH_INTEGER(int32_t); } break;
374
- case PrimitiveKind::Int32S: { PUSH_INTEGER_SWAP(int32_t); } break;
375
- case PrimitiveKind::UInt32: { PUSH_INTEGER(uint32_t); } break;
376
- case PrimitiveKind::UInt32S: { PUSH_INTEGER_SWAP(uint32_t); } break;
377
- case PrimitiveKind::Int64: { PUSH_INTEGER(int64_t); } break;
378
- case PrimitiveKind::Int64S: { PUSH_INTEGER_SWAP(int64_t); } break;
379
- case PrimitiveKind::UInt64: { PUSH_INTEGER(uint64_t); } break;
380
- case PrimitiveKind::UInt64S: { PUSH_INTEGER_SWAP(uint64_t); } break;
381
- case PrimitiveKind::String: {
382
- const char *str;
383
- if (!PushString(value, param.directions, &str)) [[unlikely]]
384
- return false;
385
-
386
- #if defined(__APPLE__)
387
- args_ptr = param.gpr_count ? args_ptr : AlignUp(args_ptr, 8);
388
- #endif
389
- *(const char **)((param.gpr_count ? gpr_ptr : args_ptr)++) = str;
390
- } break;
391
- case PrimitiveKind::String16: {
392
- const char16_t *str16;
393
- if (!PushString16(value, param.directions, &str16)) [[unlikely]]
394
- return false;
395
-
396
- #if defined(__APPLE__)
397
- args_ptr = param.gpr_count ? args_ptr : AlignUp(args_ptr, 8);
398
- #endif
399
- *(const char16_t **)((param.gpr_count ? gpr_ptr : args_ptr)++) = str16;
400
- } break;
401
- case PrimitiveKind::String32: {
402
- const char32_t *str32;
403
- if (!PushString32(value, param.directions, &str32)) [[unlikely]]
404
- return false;
405
-
406
- #if defined(__APPLE__)
407
- args_ptr = param.gpr_count ? args_ptr : AlignUp(args_ptr, 8);
408
- #endif
409
- *(const char32_t **)((param.gpr_count ? gpr_ptr : args_ptr)++) = str32;
410
- } break;
411
- case PrimitiveKind::Pointer: {
412
- void *ptr;
413
- if (!PushPointer(value, param.type, param.directions, &ptr)) [[unlikely]]
414
- return false;
415
-
416
- #if defined(__APPLE__)
417
- args_ptr = param.gpr_count ? args_ptr : AlignUp(args_ptr, 8);
418
- #endif
419
- *(void **)((param.gpr_count ? gpr_ptr : args_ptr)++) = ptr;
420
- } break;
421
- case PrimitiveKind::Record:
422
- case PrimitiveKind::Union: {
423
- if (!IsObject(value)) [[unlikely]] {
424
- ThrowError<Napi::TypeError>(env, "Unexpected %1 value, expected object", GetValueType(instance, value));
425
- return false;
426
- }
427
-
428
- Napi::Object obj = value.As<Napi::Object>();
429
-
430
- if (param.vec_count) { // HFA
431
- uint8_t *ptr = (uint8_t *)vec_ptr;
432
-
433
- if (!PushObject(obj, param.type, ptr))
434
- return false;
435
- ExpandFloats(ptr, param.vec_count, param.vec_bytes);
436
-
437
- vec_ptr += param.vec_count;
438
- } else if (!param.use_memory) {
439
- if (param.gpr_count) {
440
- K_ASSERT(param.type->align <= 8);
441
-
442
- if (!PushObject(obj, param.type, (uint8_t *)gpr_ptr))
443
- return false;
444
- gpr_ptr += param.gpr_count;
445
- } else if (param.type->size) {
446
- #if defined(__APPLE__)
447
- args_ptr = AlignUp(args_ptr, 8);
448
- #endif
449
- if (!PushObject(obj, param.type, (uint8_t *)args_ptr))
450
- return false;
451
- args_ptr += (param.type->size + 7) / 8;
452
- }
453
- } else {
454
- uint8_t *ptr = AllocHeap(param.type->size, 16);
455
-
456
- if (param.gpr_count) {
457
- K_ASSERT(param.gpr_count == 1);
458
- K_ASSERT(param.vec_count == 0);
459
-
460
- *(uint8_t **)(gpr_ptr++) = ptr;
461
- } else {
462
- #if defined(__APPLE__)
463
- args_ptr = AlignUp(args_ptr, 8);
464
- #endif
465
- *(uint8_t **)(args_ptr++) = ptr;
466
- }
467
-
468
- if (!PushObject(obj, param.type, ptr))
469
- return false;
470
- }
471
- } break;
472
- case PrimitiveKind::Array: { K_UNREACHABLE(); } break;
473
- case PrimitiveKind::Float32: {
474
- if (!value.IsNumber() && !value.IsBigInt()) [[unlikely]] {
475
- ThrowError<Napi::TypeError>(env, "Unexpected %1 value, expected number", GetValueType(instance, value));
476
- return false;
477
- }
478
-
479
- float f = GetNumber<float>(value);
480
-
481
- if (param.vec_count) [[likely]] {
482
- memset((uint8_t *)vec_ptr + 4, 0, 4);
483
- *(float *)(vec_ptr++) = f;
484
- #if defined(_WIN32)
485
- } else if (param.gpr_count) {
486
- memset((uint8_t *)gpr_ptr + 4, 0, 4);
487
- *(float *)(gpr_ptr++) = f;
488
- #endif
489
- } else {
490
- #if defined(__APPLE__)
491
- args_ptr = AlignUp(args_ptr, param.variadic ? 8 : 4);
492
- *(float *)args_ptr = f;
493
- args_ptr = (uint64_t *)((uint8_t *)args_ptr + 4);
494
- #else
495
- memset((uint8_t *)args_ptr + 4, 0, 4);
496
- *(float *)(args_ptr++) = f;
497
- #endif
498
- }
499
- } break;
500
- case PrimitiveKind::Float64: {
501
- if (!value.IsNumber() && !value.IsBigInt()) [[unlikely]] {
502
- ThrowError<Napi::TypeError>(env, "Unexpected %1 value, expected number", GetValueType(instance, value));
503
- return false;
504
- }
505
-
506
- double d = GetNumber<double>(value);
507
-
508
- if (param.vec_count) [[likely]] {
509
- *(double *)(vec_ptr++) = d;
510
- #if defined(_WIN32)
511
- } else if (param.gpr_count) {
512
- *(double *)(gpr_ptr++) = d;
513
- #endif
514
- } else {
515
- #if defined(__APPLE__)
516
- args_ptr = AlignUp(args_ptr, 8);
517
- #endif
518
- *(double *)(args_ptr++) = d;
519
- }
520
- } break;
521
- case PrimitiveKind::Callback: {
522
- void *ptr;
523
- if (!PushCallback(value, param.type, &ptr)) [[unlikely]]
524
- return false;
525
-
526
- #if defined(__APPLE__)
527
- args_ptr = param.gpr_count ? args_ptr : AlignUp(args_ptr, 8);
528
- #endif
529
- *(void **)((param.gpr_count ? gpr_ptr : args_ptr)++) = ptr;
530
- } break;
531
-
532
- case PrimitiveKind::Prototype: { K_UNREACHABLE(); } break;
533
- }
534
- }
535
-
536
- #undef PUSH_INTEGER_SWAP
537
- #undef PUSH_INTEGER
538
-
539
- new_sp = mem->stack.end();
540
-
541
- return true;
542
- }
543
-
544
- void CallData::Execute(const FunctionInfo *func, void *native)
545
- {
546
- #if defined(_WIN32)
547
- TEB *teb = GetTEB();
548
-
549
- // Restore previous stack limits at the end
550
- K_DEFER_C(exception_list = teb->ExceptionList,
551
- base = teb->StackBase,
552
- limit = teb->StackLimit,
553
- dealloc = teb->DeallocationStack,
554
- guaranteed = teb->GuaranteedStackBytes) {
555
- teb->ExceptionList = exception_list;
556
- teb->StackBase = base;
557
- teb->StackLimit = limit;
558
- teb->DeallocationStack = dealloc;
559
- teb->GuaranteedStackBytes = guaranteed;
560
-
561
- instance->last_error = teb->LastErrorValue;
562
- };
563
-
564
- // Adjust stack limits so SEH works correctly
565
- teb->ExceptionList = (void *)-1; // EXCEPTION_CHAIN_END
566
- teb->StackBase = mem->stack0.end();
567
- teb->StackLimit = mem->stack0.ptr;
568
- teb->DeallocationStack = mem->stack0.ptr;
569
- teb->GuaranteedStackBytes = 0;
570
-
571
- teb->LastErrorValue = instance->last_error;
572
- #endif
573
-
574
- #define PERFORM_CALL(Suffix) \
575
- ([&]() { \
576
- auto ret = (func->forward_fp ? ForwardCallX ## Suffix(native, new_sp, &old_sp) \
577
- : ForwardCall ## Suffix(native, new_sp, &old_sp)); \
578
- return ret; \
579
- })()
580
-
581
- // Execute and convert return value
582
- switch (func->ret.type->primitive) {
583
- case PrimitiveKind::Void:
584
- case PrimitiveKind::Bool:
585
- case PrimitiveKind::Int8:
586
- case PrimitiveKind::UInt8:
587
- case PrimitiveKind::Int16:
588
- case PrimitiveKind::Int16S:
589
- case PrimitiveKind::UInt16:
590
- case PrimitiveKind::UInt16S:
591
- case PrimitiveKind::Int32:
592
- case PrimitiveKind::Int32S:
593
- case PrimitiveKind::UInt32:
594
- case PrimitiveKind::UInt32S:
595
- case PrimitiveKind::Int64:
596
- case PrimitiveKind::Int64S:
597
- case PrimitiveKind::UInt64:
598
- case PrimitiveKind::UInt64S:
599
- case PrimitiveKind::String:
600
- case PrimitiveKind::String16:
601
- case PrimitiveKind::String32:
602
- case PrimitiveKind::Pointer:
603
- case PrimitiveKind::Callback: { result.u64 = PERFORM_CALL(GG).x0; } break;
604
- case PrimitiveKind::Record:
605
- case PrimitiveKind::Union: {
606
- if (func->ret.gpr_count) {
607
- X0X1Ret ret = PERFORM_CALL(GG);
608
- memcpy(&result.buf, &ret, K_SIZE(ret));
609
- } else if (func->ret.vec_count) {
610
- HfaRet ret = PERFORM_CALL(DDDD);
611
- memcpy(&result.buf, &ret, K_SIZE(ret));
612
- } else {
613
- PERFORM_CALL(GG);
614
- }
615
- } break;
616
- case PrimitiveKind::Array: { K_UNREACHABLE(); } break;
617
- case PrimitiveKind::Float32: { result.f = PERFORM_CALL(F); } break;
618
- case PrimitiveKind::Float64: { result.d = PERFORM_CALL(DDDD).d0; } break;
619
-
620
- case PrimitiveKind::Prototype: { K_UNREACHABLE(); } break;
621
- }
622
-
623
- #undef PERFORM_CALL
624
- }
625
-
626
- Napi::Value CallData::Complete(const FunctionInfo *func)
627
- {
628
- K_DEFER {
629
- PopOutArguments();
630
-
631
- if (func->ret.type->dispose) {
632
- func->ret.type->dispose(env, func->ret.type, result.ptr);
633
- }
634
- };
635
-
636
- switch (func->ret.type->primitive) {
637
- case PrimitiveKind::Void: return env.Undefined();
638
- case PrimitiveKind::Bool: return Napi::Boolean::New(env, result.u8 & 0x1);
639
- case PrimitiveKind::Int8: return Napi::Number::New(env, (double)result.i8);
640
- case PrimitiveKind::UInt8: return Napi::Number::New(env, (double)result.u8);
641
- case PrimitiveKind::Int16: return Napi::Number::New(env, (double)result.i16);
642
- case PrimitiveKind::Int16S: return Napi::Number::New(env, (double)ReverseBytes(result.i16));
643
- case PrimitiveKind::UInt16: return Napi::Number::New(env, (double)result.u16);
644
- case PrimitiveKind::UInt16S: return Napi::Number::New(env, (double)ReverseBytes(result.u16));
645
- case PrimitiveKind::Int32: return Napi::Number::New(env, (double)result.i32);
646
- case PrimitiveKind::Int32S: return Napi::Number::New(env, (double)ReverseBytes(result.i32));
647
- case PrimitiveKind::UInt32: return Napi::Number::New(env, (double)result.u32);
648
- case PrimitiveKind::UInt32S: return Napi::Number::New(env, (double)ReverseBytes(result.u32));
649
- case PrimitiveKind::Int64: return NewBigInt(env, result.i64);
650
- case PrimitiveKind::Int64S: return NewBigInt(env, ReverseBytes(result.i64));
651
- case PrimitiveKind::UInt64: return NewBigInt(env, result.u64);
652
- case PrimitiveKind::UInt64S: return NewBigInt(env, ReverseBytes(result.u64));
653
- case PrimitiveKind::String: return result.ptr ? Napi::String::New(env, (const char *)result.ptr) : env.Null();
654
- case PrimitiveKind::String16: return result.ptr ? Napi::String::New(env, (const char16_t *)result.ptr) : env.Null();
655
- case PrimitiveKind::String32: return result.ptr ? MakeStringFromUTF32(env, (const char32_t *)result.ptr) : env.Null();
656
- case PrimitiveKind::Pointer:
657
- case PrimitiveKind::Callback: {
658
- if (result.ptr) {
659
- Napi::External<void> external = Napi::External<void>::New(env, result.ptr);
660
- SetValueTag(external, func->ret.type->ref.marker);
661
-
662
- return external;
663
- } else {
664
- return env.Null();
665
- }
666
- } break;
667
- case PrimitiveKind::Record:
668
- case PrimitiveKind::Union: {
669
- if (func->ret.vec_count) { // HFA
670
- uint8_t *ptr = (uint8_t *)&result.buf;
671
-
672
- CompactFloats(ptr, func->ret.vec_count, func->ret.vec_bytes);
673
-
674
- Napi::Object obj = DecodeObject(env, ptr, func->ret.type);
675
- return obj;
676
- } else {
677
- const uint8_t *ptr = return_ptr ? (const uint8_t *)return_ptr
678
- : (const uint8_t *)&result.buf;
679
-
680
- Napi::Object obj = DecodeObject(env, ptr, func->ret.type);
681
- return obj;
682
- }
683
- } break;
684
- case PrimitiveKind::Array: { K_UNREACHABLE(); } break;
685
- case PrimitiveKind::Float32: return Napi::Number::New(env, (double)result.f);
686
- case PrimitiveKind::Float64: return Napi::Number::New(env, result.d);
687
-
688
- case PrimitiveKind::Prototype: { K_UNREACHABLE(); } break;
689
- }
690
-
691
- K_UNREACHABLE();
692
- }
693
-
694
- void CallData::Relay(Size idx, uint8_t *sp)
695
- {
696
- const TrampolineInfo &trampoline = shared.trampolines[idx];
697
-
698
- uint8_t *own_sp = sp;
699
- uint8_t *caller_sp = sp + 208;
700
- BackRegisters *out_reg = (BackRegisters *)(sp + 136);
701
-
702
- const FunctionInfo *proto = trampoline.proto;
703
- Napi::Function func = trampoline.func.Value();
704
-
705
- uint64_t *gpr_ptr = (uint64_t *)own_sp;
706
- uint64_t *vec_ptr = gpr_ptr + 9;
707
- uint64_t *args_ptr = (uint64_t *)caller_sp;
708
-
709
- uint8_t *return_ptr = proto->ret.use_memory ? (uint8_t *)gpr_ptr[8] : nullptr;
710
-
711
- K_DEFER_N(err_guard) { memset(out_reg, 0, K_SIZE(*out_reg)); };
712
-
713
- LocalArray<napi_value, MaxParameters + 1> arguments;
714
-
715
- arguments.Append(!trampoline.recv.IsEmpty() ? trampoline.recv.Value() : env.Undefined());
716
-
717
- // Convert to JS arguments
718
- for (Size i = 0; i < proto->parameters.len; i++) {
719
- const ParameterInfo &param = proto->parameters[i];
720
- K_ASSERT(param.directions >= 1 && param.directions <= 3);
721
-
722
- switch (param.type->primitive) {
723
- case PrimitiveKind::Void: { K_UNREACHABLE(); } break;
724
-
725
- case PrimitiveKind::Bool: {
726
- #if defined(__APPLE__)
727
- bool b;
728
- if (param.gpr_count) {
729
- b = *(bool *)(gpr_ptr++);
730
- } else {
731
- b = *(bool *)args_ptr;
732
- args_ptr = (uint64_t *)((uint8_t *)args_ptr + 1);
733
- }
734
- #else
735
- bool b = *(bool *)((param.gpr_count ? gpr_ptr : args_ptr)++);
736
- #endif
737
-
738
- Napi::Value arg = Napi::Boolean::New(env, b);
739
- arguments.Append(arg);
740
- } break;
741
- case PrimitiveKind::Int8: {
742
- #if defined(__APPLE__)
743
- double d;
744
- if (param.gpr_count) {
745
- d = (double)*(int8_t *)(gpr_ptr++);
746
- } else {
747
- d = (double)*(int8_t *)args_ptr;
748
- args_ptr = (uint64_t *)((uint8_t *)args_ptr + 1);
749
- }
750
- #else
751
- double d = (double)*(int8_t *)((param.gpr_count ? gpr_ptr : args_ptr)++);
752
- #endif
753
-
754
- Napi::Value arg = Napi::Number::New(env, d);
755
- arguments.Append(arg);
756
- } break;
757
- case PrimitiveKind::UInt8: {
758
- #if defined(__APPLE__)
759
- double d;
760
- if (param.gpr_count) {
761
- d = (double)*(uint8_t *)(gpr_ptr++);
762
- } else {
763
- d = (double)*(uint8_t *)args_ptr;
764
- args_ptr = (uint64_t *)((uint8_t *)args_ptr + 1);
765
- }
766
- #else
767
- double d = (double)*(uint8_t *)((param.gpr_count ? gpr_ptr : args_ptr)++);
768
- #endif
769
-
770
- Napi::Value arg = Napi::Number::New(env, d);
771
- arguments.Append(arg);
772
- } break;
773
- case PrimitiveKind::Int16: {
774
- #if defined(__APPLE__)
775
- double d;
776
- if (param.gpr_count) {
777
- d = (double)*(int16_t *)(gpr_ptr++);
778
- } else {
779
- args_ptr = AlignUp(args_ptr, 2);
780
- d = (double)*(int16_t *)args_ptr;
781
- args_ptr = (uint64_t *)((uint8_t *)args_ptr + 2);
782
- }
783
- #else
784
- double d = (double)*(int16_t *)((param.gpr_count ? gpr_ptr : args_ptr)++);
785
- #endif
786
-
787
- Napi::Value arg = Napi::Number::New(env, d);
788
- arguments.Append(arg);
789
- } break;
790
- case PrimitiveKind::Int16S: {
791
- #if defined(__APPLE__)
792
- double d;
793
- if (param.gpr_count) {
794
- int16_t v = *(int16_t *)(gpr_ptr++);
795
- d = (double)ReverseBytes(v);
796
- } else {
797
- args_ptr = AlignUp(args_ptr, 2);
798
-
799
- int16_t v = *(int16_t *)args_ptr;
800
- d = (double)ReverseBytes(v);
801
-
802
- args_ptr = (uint64_t *)((uint8_t *)args_ptr + 2);
803
- }
804
- #else
805
- int16_t v = *(int16_t *)((param.gpr_count ? gpr_ptr : args_ptr)++);
806
- double d = (double)ReverseBytes(v);
807
- #endif
808
-
809
- Napi::Value arg = Napi::Number::New(env, d);
810
- arguments.Append(arg);
811
- } break;
812
- case PrimitiveKind::UInt16: {
813
- #if defined(__APPLE__)
814
- double d;
815
- if (param.gpr_count) {
816
- d = (double)*(uint16_t *)(gpr_ptr++);
817
- } else {
818
- args_ptr = AlignUp(args_ptr, 2);
819
- d = (double)*(uint16_t *)args_ptr;
820
- args_ptr = (uint64_t *)((uint8_t *)args_ptr + 2);
821
- }
822
- #else
823
- double d = (double)*(uint16_t *)((param.gpr_count ? gpr_ptr : args_ptr)++);
824
- #endif
825
-
826
- Napi::Value arg = Napi::Number::New(env, d);
827
- arguments.Append(arg);
828
- } break;
829
- case PrimitiveKind::UInt16S: {
830
- #if defined(__APPLE__)
831
- double d;
832
- if (param.gpr_count) {
833
- uint16_t v = *(uint16_t *)(gpr_ptr++);
834
- d = (double)ReverseBytes(v);
835
- } else {
836
- args_ptr = AlignUp(args_ptr, 2);
837
-
838
- uint16_t v = *(uint16_t *)args_ptr;
839
- d = (double)ReverseBytes(v);
840
-
841
- args_ptr = (uint64_t *)((uint8_t *)args_ptr + 2);
842
- }
843
- #else
844
- uint16_t v = *(uint16_t *)((param.gpr_count ? gpr_ptr : args_ptr)++);
845
- double d = (double)ReverseBytes(v);
846
- #endif
847
-
848
- Napi::Value arg = Napi::Number::New(env, d);
849
- arguments.Append(arg);
850
- } break;
851
- case PrimitiveKind::Int32: {
852
- #if defined(__APPLE__)
853
- double d;
854
- if (param.gpr_count) {
855
- d = (double)*(int32_t *)(gpr_ptr++);
856
- } else {
857
- args_ptr = AlignUp(args_ptr, 4);
858
- d = (double)*(int32_t *)args_ptr;
859
- args_ptr = (uint64_t *)((uint8_t *)args_ptr + 4);
860
- }
861
- #else
862
- double d = (double)*(int32_t *)((param.gpr_count ? gpr_ptr : args_ptr)++);
863
- #endif
864
-
865
- Napi::Value arg = Napi::Number::New(env, d);
866
- arguments.Append(arg);
867
- } break;
868
- case PrimitiveKind::Int32S: {
869
- #if defined(__APPLE__)
870
- double d;
871
- if (param.gpr_count) {
872
- int32_t v = *(int32_t *)(gpr_ptr++);
873
- d = (double)ReverseBytes(v);
874
- } else {
875
- args_ptr = AlignUp(args_ptr, 4);
876
-
877
- int32_t v = *(int32_t *)args_ptr;
878
- d = (double)ReverseBytes(v);
879
-
880
- args_ptr = (uint64_t *)((uint8_t *)args_ptr + 4);
881
- }
882
- #else
883
- int32_t v = *(int32_t *)((param.gpr_count ? gpr_ptr : args_ptr)++);
884
- double d = (double)ReverseBytes(v);
885
- #endif
886
-
887
- Napi::Value arg = Napi::Number::New(env, d);
888
- arguments.Append(arg);
889
- } break;
890
- case PrimitiveKind::UInt32: {
891
- #if defined(__APPLE__)
892
- double d;
893
- if (param.gpr_count) {
894
- d = (double)*(uint32_t *)(gpr_ptr++);
895
- } else {
896
- args_ptr = AlignUp(args_ptr, 4);
897
- d = (double)*(uint32_t *)args_ptr;
898
- args_ptr = (uint64_t *)((uint8_t *)args_ptr + 4);
899
- }
900
- #else
901
- double d = (double)*(uint32_t *)((param.gpr_count ? gpr_ptr : args_ptr)++);
902
- #endif
903
-
904
- Napi::Value arg = Napi::Number::New(env, d);
905
- arguments.Append(arg);
906
- } break;
907
- case PrimitiveKind::UInt32S: {
908
- #if defined(__APPLE__)
909
- double d;
910
- if (param.gpr_count) {
911
- uint32_t v = *(uint32_t *)(gpr_ptr++);
912
- d = (double)ReverseBytes(v);
913
- } else {
914
- args_ptr = AlignUp(args_ptr, 4);
915
-
916
- uint32_t v = *(uint32_t *)args_ptr;
917
- d = (double)ReverseBytes(v);
918
-
919
- args_ptr = (uint64_t *)((uint8_t *)args_ptr + 4);
920
- }
921
- #else
922
- uint32_t v = *(uint32_t *)((param.gpr_count ? gpr_ptr : args_ptr)++);
923
- double d = (double)ReverseBytes(v);
924
- #endif
925
-
926
- Napi::Value arg = Napi::Number::New(env, d);
927
- arguments.Append(arg);
928
- } break;
929
- case PrimitiveKind::Int64: {
930
- #if defined(__APPLE__)
931
- args_ptr = AlignUp(args_ptr, 8);
932
- #endif
933
-
934
- int64_t v = *(int64_t *)((param.gpr_count ? gpr_ptr : args_ptr)++);
935
-
936
- Napi::Value arg = NewBigInt(env, v);
937
- arguments.Append(arg);
938
- } break;
939
- case PrimitiveKind::Int64S: {
940
- #if defined(__APPLE__)
941
- args_ptr = AlignUp(args_ptr, 8);
942
- #endif
943
-
944
- int64_t v = *(int64_t *)((param.gpr_count ? gpr_ptr : args_ptr)++);
945
-
946
- Napi::Value arg = NewBigInt(env, ReverseBytes(v));
947
- arguments.Append(arg);
948
- } break;
949
- case PrimitiveKind::UInt64: {
950
- #if defined(__APPLE__)
951
- args_ptr = AlignUp(args_ptr, 8);
952
- #endif
953
-
954
- uint64_t v = *(uint64_t *)((param.gpr_count ? gpr_ptr : args_ptr)++);
955
-
956
- Napi::Value arg = NewBigInt(env, v);
957
- arguments.Append(arg);
958
- } break;
959
- case PrimitiveKind::UInt64S: {
960
- #if defined(__APPLE__)
961
- args_ptr = AlignUp(args_ptr, 8);
962
- #endif
963
-
964
- uint64_t v = *(uint64_t *)((param.gpr_count ? gpr_ptr : args_ptr)++);
965
-
966
- Napi::Value arg = NewBigInt(env, ReverseBytes(v));
967
- arguments.Append(arg);
968
- } break;
969
- case PrimitiveKind::String: {
970
- #if defined(__APPLE__)
971
- args_ptr = AlignUp(args_ptr, 8);
972
- #endif
973
-
974
- const char *str = *(const char **)((param.gpr_count ? gpr_ptr : args_ptr)++);
975
-
976
- Napi::Value arg = str ? Napi::String::New(env, str) : env.Null();
977
- arguments.Append(arg);
978
-
979
- if (param.type->dispose) {
980
- param.type->dispose(env, param.type, str);
981
- }
982
- } break;
983
- case PrimitiveKind::String16: {
984
- #if defined(__APPLE__)
985
- args_ptr = AlignUp(args_ptr, 8);
986
- #endif
987
-
988
- const char16_t *str16 = *(const char16_t **)((param.gpr_count ? gpr_ptr : args_ptr)++);
989
-
990
- Napi::Value arg = str16 ? Napi::String::New(env, str16) : env.Null();
991
- arguments.Append(arg);
992
-
993
- if (param.type->dispose) {
994
- param.type->dispose(env, param.type, str16);
995
- }
996
- } break;
997
- case PrimitiveKind::String32: {
998
- #if defined(__APPLE__)
999
- args_ptr = AlignUp(args_ptr, 8);
1000
- #endif
1001
-
1002
- const char32_t *str32 = *(const char32_t **)((param.gpr_count ? gpr_ptr : args_ptr)++);
1003
-
1004
- Napi::Value arg = str32 ? MakeStringFromUTF32(env, str32) : env.Null();
1005
- arguments.Append(arg);
1006
- } break;
1007
- case PrimitiveKind::Pointer:
1008
- case PrimitiveKind::Callback: {
1009
- #if defined(__APPLE__)
1010
- args_ptr = AlignUp(args_ptr, 8);
1011
- #endif
1012
-
1013
- void *ptr2 = *(void **)((param.gpr_count ? gpr_ptr : args_ptr)++);
1014
-
1015
- if (ptr2) {
1016
- Napi::External<void> external = Napi::External<void>::New(env, ptr2);
1017
- SetValueTag(external, param.type->ref.marker);
1018
-
1019
- arguments.Append(external);
1020
- } else {
1021
- arguments.Append(env.Null());
1022
- }
1023
-
1024
- if (param.type->dispose) {
1025
- param.type->dispose(env, param.type, ptr2);
1026
- }
1027
- } break;
1028
- case PrimitiveKind::Record:
1029
- case PrimitiveKind::Union: {
1030
- if (param.vec_count) { // HFA
1031
- uint8_t *ptr = (uint8_t *)vec_ptr;
1032
-
1033
- CompactFloats(ptr, param.vec_count, param.vec_bytes);
1034
-
1035
- Napi::Object obj = DecodeObject(env, ptr, param.type);
1036
- arguments.Append(obj);
1037
-
1038
- vec_ptr += param.vec_count;
1039
- } else if (!param.use_memory) {
1040
- if (param.gpr_count) {
1041
- K_ASSERT(param.type->align <= 8);
1042
-
1043
- Napi::Object obj = DecodeObject(env, (uint8_t *)gpr_ptr, param.type);
1044
- arguments.Append(obj);
1045
-
1046
- gpr_ptr += param.gpr_count;
1047
- } else if (param.type->size) {
1048
- args_ptr = AlignUp(args_ptr, param.type->align);
1049
-
1050
- Napi::Object obj = DecodeObject(env, (uint8_t *)args_ptr, param.type);
1051
- arguments.Append(obj);
1052
-
1053
- args_ptr += (param.type->size + 7) / 8;
1054
- }
1055
- } else {
1056
- #if defined(__APPLE__)
1057
- args_ptr = AlignUp(args_ptr, 8);
1058
- #endif
1059
-
1060
- void *ptr2 = *(void **)((param.gpr_count ? gpr_ptr : args_ptr)++);
1061
-
1062
- Napi::Object obj = DecodeObject(env, (uint8_t *)ptr2, param.type);
1063
- arguments.Append(obj);
1064
- }
1065
- } break;
1066
- case PrimitiveKind::Array: { K_UNREACHABLE(); } break;
1067
- case PrimitiveKind::Float32: {
1068
- float f;
1069
- if (param.vec_count) [[likely]] {
1070
- f = *(float *)(vec_ptr++);
1071
- #if defined(_WIN32)
1072
- } else if (param.gpr_count) {
1073
- f = *(float *)(gpr_ptr++);
1074
- #endif
1075
- } else {
1076
- #if defined(__APPLE__)
1077
- args_ptr = AlignUp(args_ptr, 4);
1078
- f = *(float *)args_ptr;
1079
- args_ptr = (uint64_t *)((uint8_t *)args_ptr + 4);
1080
- #else
1081
- f = *(float *)(args_ptr++);
1082
- #endif
1083
- }
1084
-
1085
- Napi::Value arg = Napi::Number::New(env, (double)f);
1086
- arguments.Append(arg);
1087
- } break;
1088
- case PrimitiveKind::Float64: {
1089
- double d;
1090
- if (param.vec_count) [[likely]] {
1091
- d = *(double *)(vec_ptr++);
1092
- #if defined(_WIN32)
1093
- } else if (param.gpr_count) {
1094
- d = *(double *)(gpr_ptr++);
1095
- #endif
1096
- } else {
1097
- #if defined(__APPLE__)
1098
- args_ptr = AlignUp(args_ptr, 8);
1099
- #endif
1100
-
1101
- d = *(double *)(args_ptr++);
1102
- }
1103
-
1104
- Napi::Value arg = Napi::Number::New(env, d);
1105
- arguments.Append(arg);
1106
- } break;
1107
-
1108
- case PrimitiveKind::Prototype: { K_UNREACHABLE(); } break;
1109
- }
1110
- }
1111
-
1112
- const TypeInfo *type = proto->ret.type;
1113
-
1114
- // Make the call!
1115
- Napi::Value value = func.Call(arguments[0], arguments.len - 1, arguments.data + 1);
1116
-
1117
- if (env.IsExceptionPending()) [[unlikely]]
1118
- return;
1119
-
1120
- #define RETURN_INTEGER(CType) \
1121
- do { \
1122
- if (!value.IsNumber() && !value.IsBigInt()) [[unlikely]] { \
1123
- ThrowError<Napi::TypeError>(env, "Unexpected %1 value, expected number", GetValueType(instance, value)); \
1124
- return; \
1125
- } \
1126
- \
1127
- CType v = GetNumber<CType>(value); \
1128
- out_reg->x0 = (uint64_t)v; \
1129
- } while (false)
1130
- #define RETURN_INTEGER_SWAP(CType) \
1131
- do { \
1132
- if (!value.IsNumber() && !value.IsBigInt()) [[unlikely]] { \
1133
- ThrowError<Napi::TypeError>(env, "Unexpected %1 value, expected number", GetValueType(instance, value)); \
1134
- return; \
1135
- } \
1136
- \
1137
- CType v = GetNumber<CType>(value); \
1138
- out_reg->x0 = (uint64_t)ReverseBytes(v); \
1139
- } while (false)
1140
-
1141
- // Convert the result
1142
- switch (type->primitive) {
1143
- case PrimitiveKind::Void: {} break;
1144
- case PrimitiveKind::Bool: {
1145
- if (!value.IsBoolean()) [[unlikely]] {
1146
- ThrowError<Napi::TypeError>(env, "Unexpected %1 value, expected boolean", GetValueType(instance, value));
1147
- return;
1148
- }
1149
-
1150
- bool b = value.As<Napi::Boolean>();
1151
- out_reg->x0 = (uint64_t)b;
1152
- } break;
1153
- case PrimitiveKind::Int8: { RETURN_INTEGER(int8_t); } break;
1154
- case PrimitiveKind::UInt8: { RETURN_INTEGER(uint8_t); } break;
1155
- case PrimitiveKind::Int16: { RETURN_INTEGER(int16_t); } break;
1156
- case PrimitiveKind::Int16S: { RETURN_INTEGER_SWAP(int16_t); } break;
1157
- case PrimitiveKind::UInt16: { RETURN_INTEGER(uint16_t); } break;
1158
- case PrimitiveKind::UInt16S: { RETURN_INTEGER_SWAP(uint16_t); } break;
1159
- case PrimitiveKind::Int32: { RETURN_INTEGER(int32_t); } break;
1160
- case PrimitiveKind::Int32S: { RETURN_INTEGER_SWAP(int32_t); } break;
1161
- case PrimitiveKind::UInt32: { RETURN_INTEGER(uint32_t); } break;
1162
- case PrimitiveKind::UInt32S: { RETURN_INTEGER_SWAP(uint32_t); } break;
1163
- case PrimitiveKind::Int64: { RETURN_INTEGER(int64_t); } break;
1164
- case PrimitiveKind::Int64S: { RETURN_INTEGER_SWAP(int64_t); } break;
1165
- case PrimitiveKind::UInt64: { RETURN_INTEGER(uint64_t); } break;
1166
- case PrimitiveKind::UInt64S: { RETURN_INTEGER_SWAP(uint64_t); } break;
1167
- case PrimitiveKind::String: {
1168
- const char *str;
1169
- if (!PushString(value, 1, &str)) [[unlikely]]
1170
- return;
1171
-
1172
- out_reg->x0 = (uint64_t)str;
1173
- } break;
1174
- case PrimitiveKind::String16: {
1175
- const char16_t *str16;
1176
- if (!PushString16(value, 1, &str16)) [[unlikely]]
1177
- return;
1178
-
1179
- out_reg->x0 = (uint64_t)str16;
1180
- } break;
1181
- case PrimitiveKind::String32: {
1182
- const char32_t *str32;
1183
- if (!PushString32(value, 1, &str32)) [[unlikely]]
1184
- return;
1185
-
1186
- out_reg->x0 = (uint64_t)str32;
1187
- } break;
1188
- case PrimitiveKind::Pointer: {
1189
- uint8_t *ptr;
1190
-
1191
- if (CheckValueTag(value, type->ref.marker)) {
1192
- ptr = value.As<Napi::External<uint8_t>>().Data();
1193
- } else if (IsObject(value) && (type->ref.type->primitive == PrimitiveKind::Record ||
1194
- type->ref.type->primitive == PrimitiveKind::Union)) {
1195
- Napi::Object obj = value.As<Napi::Object>();
1196
-
1197
- ptr = AllocHeap(type->ref.type->size, 16);
1198
-
1199
- if (!PushObject(obj, type->ref.type, ptr))
1200
- return;
1201
- } else if (IsNullOrUndefined(value)) {
1202
- ptr = nullptr;
1203
- } else {
1204
- ThrowError<Napi::TypeError>(env, "Unexpected %1 value, expected %2", GetValueType(instance, value), type->name);
1205
- return;
1206
- }
1207
-
1208
- out_reg->x0 = (uint64_t)ptr;
1209
- } break;
1210
- case PrimitiveKind::Record:
1211
- case PrimitiveKind::Union: {
1212
- if (!IsObject(value)) [[unlikely]] {
1213
- ThrowError<Napi::TypeError>(env, "Unexpected %1 value, expected object", GetValueType(instance, value));
1214
- return;
1215
- }
1216
-
1217
- Napi::Object obj = value.As<Napi::Object>();
1218
-
1219
- if (return_ptr) {
1220
- if (!PushObject(obj, type, return_ptr))
1221
- return;
1222
- out_reg->x0 = (uint64_t)return_ptr;
1223
- } else if (proto->ret.vec_count) { // HFA
1224
- uint8_t *ptr = (uint8_t *)&out_reg->d0;
1225
-
1226
- ExpandFloats(ptr, proto->ret.vec_count, proto->ret.vec_bytes);
1227
- PushObject(obj, type, ptr);
1228
- } else {
1229
- PushObject(obj, type, (uint8_t *)&out_reg->x0);
1230
- }
1231
- } break;
1232
- case PrimitiveKind::Array: { K_UNREACHABLE(); } break;
1233
- case PrimitiveKind::Float32: {
1234
- if (!value.IsNumber() && !value.IsBigInt()) [[unlikely]] {
1235
- ThrowError<Napi::TypeError>(env, "Unexpected %1 value, expected number", GetValueType(instance, value));
1236
- return;
1237
- }
1238
-
1239
- float f = GetNumber<float>(value);
1240
-
1241
- memset((uint8_t *)&out_reg->d0 + 4, 0, 4);
1242
- memcpy(&out_reg->d0, &f, 4);
1243
- } break;
1244
- case PrimitiveKind::Float64: {
1245
- if (!value.IsNumber() && !value.IsBigInt()) [[unlikely]] {
1246
- ThrowError<Napi::TypeError>(env, "Unexpected %1 value, expected number", GetValueType(instance, value));
1247
- return;
1248
- }
1249
-
1250
- double d = GetNumber<double>(value);
1251
- out_reg->d0 = d;
1252
- } break;
1253
- case PrimitiveKind::Callback: {
1254
- void *ptr;
1255
-
1256
- if (value.IsFunction()) {
1257
- Napi::Function func2 = value.As<Napi::Function>();
1258
-
1259
- ptr = ReserveTrampoline(type->ref.proto, func2);
1260
- if (!ptr) [[unlikely]]
1261
- return;
1262
- } else if (CheckValueTag(value, type->ref.marker)) {
1263
- ptr = value.As<Napi::External<void>>().Data();
1264
- } else if (IsNullOrUndefined(value)) {
1265
- ptr = nullptr;
1266
- } else {
1267
- ThrowError<Napi::TypeError>(env, "Unexpected %1 value, expected %2", GetValueType(instance, value), type->name);
1268
- return;
1269
- }
1270
-
1271
- out_reg->x0 = (uint64_t)ptr;
1272
- } break;
1273
-
1274
- case PrimitiveKind::Prototype: { K_UNREACHABLE(); } break;
1275
- }
1276
-
1277
- #undef RETURN_INTEGER_SWAP
1278
- #undef RETURN_INTEGER
1279
-
1280
- err_guard.Disable();
1281
- }
1282
-
1283
- void *FindTrampolineStart()
1284
- {
1285
- return &Trampoline0;
1286
- }
1287
-
1288
- void *FindTrampolineEnd()
1289
- {
1290
- return &TrampolineEnd;
1291
- }
1292
-
1293
- }
1294
-
1295
- #endif