axon-code 2.4.0 → 2.5.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (569) hide show
  1. package/dist/auth/snapshot.d.ts +24 -0
  2. package/dist/auth/snapshot.d.ts.map +1 -0
  3. package/dist/auth/snapshot.js +144 -0
  4. package/dist/auth/snapshot.js.map +1 -0
  5. package/dist/cli.js +3 -1
  6. package/dist/cli.js.map +1 -1
  7. package/dist/config/index.d.ts +30 -15
  8. package/dist/config/index.d.ts.map +1 -1
  9. package/dist/config/index.js +13 -2
  10. package/dist/config/index.js.map +1 -1
  11. package/dist/core/client.d.ts +7 -2
  12. package/dist/core/client.d.ts.map +1 -1
  13. package/dist/core/client.js +50 -18
  14. package/dist/core/client.js.map +1 -1
  15. package/dist/core/loop.d.ts +2 -7
  16. package/dist/core/loop.d.ts.map +1 -1
  17. package/dist/core/loop.js +16 -38
  18. package/dist/core/loop.js.map +1 -1
  19. package/dist/core/max-tokens.d.ts +24 -0
  20. package/dist/core/max-tokens.d.ts.map +1 -0
  21. package/dist/core/max-tokens.js +64 -0
  22. package/dist/core/max-tokens.js.map +1 -0
  23. package/dist/goals/goal-store.d.ts +1 -1
  24. package/dist/goals/goal-store.d.ts.map +1 -1
  25. package/dist/goals/goal-store.js.map +1 -1
  26. package/dist/hooks/auto-verify.d.ts +86 -0
  27. package/dist/hooks/auto-verify.d.ts.map +1 -0
  28. package/dist/hooks/auto-verify.js +297 -0
  29. package/dist/hooks/auto-verify.js.map +1 -0
  30. package/dist/mcp/config.d.ts +8 -8
  31. package/dist/media/index.d.ts +1 -0
  32. package/dist/media/index.d.ts.map +1 -1
  33. package/dist/media/index.js +2 -0
  34. package/dist/media/index.js.map +1 -1
  35. package/dist/media/office-visual.d.ts +66 -0
  36. package/dist/media/office-visual.d.ts.map +1 -0
  37. package/dist/media/office-visual.js +409 -0
  38. package/dist/media/office-visual.js.map +1 -0
  39. package/dist/memory/long-term-store.d.ts +6 -0
  40. package/dist/memory/long-term-store.d.ts.map +1 -1
  41. package/dist/memory/long-term-store.js +66 -48
  42. package/dist/memory/long-term-store.js.map +1 -1
  43. package/dist/memory/memory-search.d.ts +5 -2
  44. package/dist/memory/memory-search.d.ts.map +1 -1
  45. package/dist/memory/memory-search.js +27 -10
  46. package/dist/memory/memory-search.js.map +1 -1
  47. package/dist/memory/memory-sync.d.ts.map +1 -1
  48. package/dist/memory/memory-sync.js +4 -0
  49. package/dist/memory/memory-sync.js.map +1 -1
  50. package/dist/memory/notebook.d.ts +7 -0
  51. package/dist/memory/notebook.d.ts.map +1 -1
  52. package/dist/memory/notebook.js +62 -9
  53. package/dist/memory/notebook.js.map +1 -1
  54. package/dist/network/discovery.d.ts +2 -0
  55. package/dist/network/discovery.d.ts.map +1 -1
  56. package/dist/network/discovery.js +10 -5
  57. package/dist/network/discovery.js.map +1 -1
  58. package/dist/network/global-proxy.d.ts +7 -0
  59. package/dist/network/global-proxy.d.ts.map +1 -1
  60. package/dist/network/global-proxy.js +67 -0
  61. package/dist/network/global-proxy.js.map +1 -1
  62. package/dist/network/index.d.ts +6 -1
  63. package/dist/network/index.d.ts.map +1 -1
  64. package/dist/network/index.js +16 -11
  65. package/dist/network/index.js.map +1 -1
  66. package/dist/network/transport.d.ts +41 -4
  67. package/dist/network/transport.d.ts.map +1 -1
  68. package/dist/network/transport.js +234 -61
  69. package/dist/network/transport.js.map +1 -1
  70. package/dist/network/types.d.ts +19 -1
  71. package/dist/network/types.d.ts.map +1 -1
  72. package/dist/network/types.js.map +1 -1
  73. package/dist/notifications/cmux.d.ts +115 -0
  74. package/dist/notifications/cmux.d.ts.map +1 -0
  75. package/dist/notifications/cmux.js +436 -0
  76. package/dist/notifications/cmux.js.map +1 -0
  77. package/dist/prompt/attachments.d.ts +7 -0
  78. package/dist/prompt/attachments.d.ts.map +1 -1
  79. package/dist/prompt/attachments.js +57 -0
  80. package/dist/prompt/attachments.js.map +1 -1
  81. package/dist/prompt/builder.js +1 -1
  82. package/dist/prompt/builder.js.map +1 -1
  83. package/dist/prompt/cache.d.ts +2 -0
  84. package/dist/prompt/cache.d.ts.map +1 -1
  85. package/dist/prompt/cache.js +2 -0
  86. package/dist/prompt/cache.js.map +1 -1
  87. package/dist/prompt/templates.d.ts +1 -1
  88. package/dist/prompt/templates.d.ts.map +1 -1
  89. package/dist/prompt/templates.js +4 -3
  90. package/dist/prompt/templates.js.map +1 -1
  91. package/dist/prompt/types.d.ts +3 -1
  92. package/dist/prompt/types.d.ts.map +1 -1
  93. package/dist/prompt/types.js.map +1 -1
  94. package/dist/proxy/server.d.ts.map +1 -1
  95. package/dist/proxy/server.js +32 -11
  96. package/dist/proxy/server.js.map +1 -1
  97. package/dist/search/ripgrep.d.ts.map +1 -1
  98. package/dist/search/ripgrep.js +11 -0
  99. package/dist/search/ripgrep.js.map +1 -1
  100. package/dist/session/index.d.ts +2 -0
  101. package/dist/session/index.d.ts.map +1 -1
  102. package/dist/session/index.js +1 -0
  103. package/dist/session/index.js.map +1 -1
  104. package/dist/skills/builtin/algorithmic-art/LICENSE.txt +202 -0
  105. package/dist/skills/builtin/algorithmic-art/SKILL.md +405 -0
  106. package/dist/skills/builtin/algorithmic-art/templates/generator_template.js +223 -0
  107. package/dist/skills/builtin/algorithmic-art/templates/viewer.html +599 -0
  108. package/dist/skills/builtin/analyze-logs/SKILL.md +75 -0
  109. package/dist/skills/builtin/audit-official/SKILL.md +81 -0
  110. package/dist/skills/builtin/brand-guidelines/LICENSE.txt +202 -0
  111. package/dist/skills/builtin/brand-guidelines/SKILL.md +73 -0
  112. package/dist/skills/builtin/build-portable/SKILL.md +53 -0
  113. package/dist/skills/builtin/canvas-design/SKILL.md +130 -0
  114. package/dist/skills/builtin/changelog/SKILL.md +65 -0
  115. package/dist/skills/builtin/code-review/SKILL.md +75 -0
  116. package/dist/skills/builtin/doc-coauthoring/SKILL.md +375 -0
  117. package/dist/skills/builtin/doctor/SKILL.md +166 -0
  118. package/dist/skills/builtin/docx/LICENSE.txt +30 -0
  119. package/dist/skills/builtin/docx/SKILL.md +590 -0
  120. package/dist/skills/builtin/docx/scripts/__init__.py +1 -0
  121. package/dist/skills/builtin/docx/scripts/accept_changes.py +135 -0
  122. package/dist/skills/builtin/docx/scripts/comment.py +318 -0
  123. package/dist/skills/builtin/docx/scripts/office/helpers/__init__.py +0 -0
  124. package/dist/skills/builtin/docx/scripts/office/helpers/merge_runs.py +199 -0
  125. package/dist/skills/builtin/docx/scripts/office/helpers/simplify_redlines.py +197 -0
  126. package/dist/skills/builtin/docx/scripts/office/pack.py +159 -0
  127. package/dist/skills/builtin/docx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-chart.xsd +1499 -0
  128. package/dist/skills/builtin/docx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-chartDrawing.xsd +146 -0
  129. package/dist/skills/builtin/docx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-diagram.xsd +1085 -0
  130. package/dist/skills/builtin/docx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-lockedCanvas.xsd +11 -0
  131. package/dist/skills/builtin/docx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-main.xsd +3081 -0
  132. package/dist/skills/builtin/docx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-picture.xsd +23 -0
  133. package/dist/skills/builtin/docx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-spreadsheetDrawing.xsd +185 -0
  134. package/dist/skills/builtin/docx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-wordprocessingDrawing.xsd +287 -0
  135. package/dist/skills/builtin/docx/scripts/office/schemas/ISO-IEC29500-4_2016/pml.xsd +1676 -0
  136. package/dist/skills/builtin/docx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-additionalCharacteristics.xsd +28 -0
  137. package/dist/skills/builtin/docx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-bibliography.xsd +144 -0
  138. package/dist/skills/builtin/docx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-commonSimpleTypes.xsd +174 -0
  139. package/dist/skills/builtin/docx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-customXmlDataProperties.xsd +25 -0
  140. package/dist/skills/builtin/docx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-customXmlSchemaProperties.xsd +18 -0
  141. package/dist/skills/builtin/docx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-documentPropertiesCustom.xsd +59 -0
  142. package/dist/skills/builtin/docx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-documentPropertiesExtended.xsd +56 -0
  143. package/dist/skills/builtin/docx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-documentPropertiesVariantTypes.xsd +195 -0
  144. package/dist/skills/builtin/docx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-math.xsd +582 -0
  145. package/dist/skills/builtin/docx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-relationshipReference.xsd +25 -0
  146. package/dist/skills/builtin/docx/scripts/office/schemas/ISO-IEC29500-4_2016/sml.xsd +4439 -0
  147. package/dist/skills/builtin/docx/scripts/office/schemas/ISO-IEC29500-4_2016/vml-main.xsd +570 -0
  148. package/dist/skills/builtin/docx/scripts/office/schemas/ISO-IEC29500-4_2016/vml-officeDrawing.xsd +509 -0
  149. package/dist/skills/builtin/docx/scripts/office/schemas/ISO-IEC29500-4_2016/vml-presentationDrawing.xsd +12 -0
  150. package/dist/skills/builtin/docx/scripts/office/schemas/ISO-IEC29500-4_2016/vml-spreadsheetDrawing.xsd +108 -0
  151. package/dist/skills/builtin/docx/scripts/office/schemas/ISO-IEC29500-4_2016/vml-wordprocessingDrawing.xsd +96 -0
  152. package/dist/skills/builtin/docx/scripts/office/schemas/ISO-IEC29500-4_2016/wml.xsd +3646 -0
  153. package/dist/skills/builtin/docx/scripts/office/schemas/ISO-IEC29500-4_2016/xml.xsd +116 -0
  154. package/dist/skills/builtin/docx/scripts/office/schemas/ecma/fouth-edition/opc-contentTypes.xsd +42 -0
  155. package/dist/skills/builtin/docx/scripts/office/schemas/ecma/fouth-edition/opc-coreProperties.xsd +50 -0
  156. package/dist/skills/builtin/docx/scripts/office/schemas/ecma/fouth-edition/opc-digSig.xsd +49 -0
  157. package/dist/skills/builtin/docx/scripts/office/schemas/ecma/fouth-edition/opc-relationships.xsd +33 -0
  158. package/dist/skills/builtin/docx/scripts/office/schemas/mce/mc.xsd +75 -0
  159. package/dist/skills/builtin/docx/scripts/office/schemas/microsoft/wml-2010.xsd +560 -0
  160. package/dist/skills/builtin/docx/scripts/office/schemas/microsoft/wml-2012.xsd +67 -0
  161. package/dist/skills/builtin/docx/scripts/office/schemas/microsoft/wml-2018.xsd +14 -0
  162. package/dist/skills/builtin/docx/scripts/office/schemas/microsoft/wml-cex-2018.xsd +20 -0
  163. package/dist/skills/builtin/docx/scripts/office/schemas/microsoft/wml-cid-2016.xsd +13 -0
  164. package/dist/skills/builtin/docx/scripts/office/schemas/microsoft/wml-sdtdatahash-2020.xsd +4 -0
  165. package/dist/skills/builtin/docx/scripts/office/schemas/microsoft/wml-symex-2015.xsd +8 -0
  166. package/dist/skills/builtin/docx/scripts/office/soffice.py +183 -0
  167. package/dist/skills/builtin/docx/scripts/office/unpack.py +132 -0
  168. package/dist/skills/builtin/docx/scripts/office/validate.py +111 -0
  169. package/dist/skills/builtin/docx/scripts/office/validators/__init__.py +15 -0
  170. package/dist/skills/builtin/docx/scripts/office/validators/base.py +847 -0
  171. package/dist/skills/builtin/docx/scripts/office/validators/docx.py +446 -0
  172. package/dist/skills/builtin/docx/scripts/office/validators/pptx.py +275 -0
  173. package/dist/skills/builtin/docx/scripts/office/validators/redlining.py +247 -0
  174. package/dist/skills/builtin/docx/scripts/templates/comments.xml +3 -0
  175. package/dist/skills/builtin/docx/scripts/templates/commentsExtended.xml +3 -0
  176. package/dist/skills/builtin/docx/scripts/templates/commentsExtensible.xml +3 -0
  177. package/dist/skills/builtin/docx/scripts/templates/commentsIds.xml +3 -0
  178. package/dist/skills/builtin/docx/scripts/templates/people.xml +3 -0
  179. package/dist/skills/builtin/frontend-design/LICENSE.txt +177 -0
  180. package/dist/skills/builtin/frontend-design/SKILL.md +42 -0
  181. package/dist/skills/builtin/i18n-check/SKILL.md +56 -0
  182. package/dist/skills/builtin/internal-comms/LICENSE.txt +202 -0
  183. package/dist/skills/builtin/internal-comms/SKILL.md +32 -0
  184. package/dist/skills/builtin/internal-comms/examples/3p-updates.md +47 -0
  185. package/dist/skills/builtin/internal-comms/examples/company-newsletter.md +65 -0
  186. package/dist/skills/builtin/internal-comms/examples/faq-answers.md +30 -0
  187. package/dist/skills/builtin/internal-comms/examples/general-comms.md +16 -0
  188. package/dist/skills/builtin/mcp-builder/LICENSE.txt +202 -0
  189. package/dist/skills/builtin/mcp-builder/SKILL.md +236 -0
  190. package/dist/skills/builtin/mcp-builder/reference/evaluation.md +602 -0
  191. package/dist/skills/builtin/mcp-builder/reference/mcp_best_practices.md +249 -0
  192. package/dist/skills/builtin/mcp-builder/reference/node_mcp_server.md +970 -0
  193. package/dist/skills/builtin/mcp-builder/reference/python_mcp_server.md +719 -0
  194. package/dist/skills/builtin/mcp-builder/scripts/connections.py +151 -0
  195. package/dist/skills/builtin/mcp-builder/scripts/evaluation.py +373 -0
  196. package/dist/skills/builtin/mcp-builder/scripts/example_evaluation.xml +22 -0
  197. package/dist/skills/builtin/mcp-builder/scripts/requirements.txt +2 -0
  198. package/dist/skills/builtin/pdf/LICENSE.txt +30 -0
  199. package/dist/skills/builtin/pdf/SKILL.md +314 -0
  200. package/dist/skills/builtin/pdf/forms.md +294 -0
  201. package/dist/skills/builtin/pdf/reference.md +612 -0
  202. package/dist/skills/builtin/pdf/scripts/check_bounding_boxes.py +65 -0
  203. package/dist/skills/builtin/pdf/scripts/check_fillable_fields.py +11 -0
  204. package/dist/skills/builtin/pdf/scripts/convert_pdf_to_images.py +33 -0
  205. package/dist/skills/builtin/pdf/scripts/create_validation_image.py +37 -0
  206. package/dist/skills/builtin/pdf/scripts/extract_form_field_info.py +122 -0
  207. package/dist/skills/builtin/pdf/scripts/extract_form_structure.py +115 -0
  208. package/dist/skills/builtin/pdf/scripts/fill_fillable_fields.py +98 -0
  209. package/dist/skills/builtin/pdf/scripts/fill_pdf_form_with_annotations.py +107 -0
  210. package/dist/skills/builtin/pptx/LICENSE.txt +30 -0
  211. package/dist/skills/builtin/pptx/SKILL.md +232 -0
  212. package/dist/skills/builtin/pptx/editing.md +205 -0
  213. package/dist/skills/builtin/pptx/pptxgenjs.md +420 -0
  214. package/dist/skills/builtin/pptx/scripts/__init__.py +0 -0
  215. package/dist/skills/builtin/pptx/scripts/add_slide.py +195 -0
  216. package/dist/skills/builtin/pptx/scripts/clean.py +286 -0
  217. package/dist/skills/builtin/pptx/scripts/office/helpers/__init__.py +0 -0
  218. package/dist/skills/builtin/pptx/scripts/office/helpers/merge_runs.py +199 -0
  219. package/dist/skills/builtin/pptx/scripts/office/helpers/simplify_redlines.py +197 -0
  220. package/dist/skills/builtin/pptx/scripts/office/pack.py +159 -0
  221. package/dist/skills/builtin/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-chart.xsd +1499 -0
  222. package/dist/skills/builtin/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-chartDrawing.xsd +146 -0
  223. package/dist/skills/builtin/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-diagram.xsd +1085 -0
  224. package/dist/skills/builtin/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-lockedCanvas.xsd +11 -0
  225. package/dist/skills/builtin/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-main.xsd +3081 -0
  226. package/dist/skills/builtin/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-picture.xsd +23 -0
  227. package/dist/skills/builtin/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-spreadsheetDrawing.xsd +185 -0
  228. package/dist/skills/builtin/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-wordprocessingDrawing.xsd +287 -0
  229. package/dist/skills/builtin/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/pml.xsd +1676 -0
  230. package/dist/skills/builtin/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-additionalCharacteristics.xsd +28 -0
  231. package/dist/skills/builtin/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-bibliography.xsd +144 -0
  232. package/dist/skills/builtin/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-commonSimpleTypes.xsd +174 -0
  233. package/dist/skills/builtin/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-customXmlDataProperties.xsd +25 -0
  234. package/dist/skills/builtin/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-customXmlSchemaProperties.xsd +18 -0
  235. package/dist/skills/builtin/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-documentPropertiesCustom.xsd +59 -0
  236. package/dist/skills/builtin/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-documentPropertiesExtended.xsd +56 -0
  237. package/dist/skills/builtin/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-documentPropertiesVariantTypes.xsd +195 -0
  238. package/dist/skills/builtin/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-math.xsd +582 -0
  239. package/dist/skills/builtin/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-relationshipReference.xsd +25 -0
  240. package/dist/skills/builtin/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/sml.xsd +4439 -0
  241. package/dist/skills/builtin/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/vml-main.xsd +570 -0
  242. package/dist/skills/builtin/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/vml-officeDrawing.xsd +509 -0
  243. package/dist/skills/builtin/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/vml-presentationDrawing.xsd +12 -0
  244. package/dist/skills/builtin/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/vml-spreadsheetDrawing.xsd +108 -0
  245. package/dist/skills/builtin/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/vml-wordprocessingDrawing.xsd +96 -0
  246. package/dist/skills/builtin/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/wml.xsd +3646 -0
  247. package/dist/skills/builtin/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/xml.xsd +116 -0
  248. package/dist/skills/builtin/pptx/scripts/office/schemas/ecma/fouth-edition/opc-contentTypes.xsd +42 -0
  249. package/dist/skills/builtin/pptx/scripts/office/schemas/ecma/fouth-edition/opc-coreProperties.xsd +50 -0
  250. package/dist/skills/builtin/pptx/scripts/office/schemas/ecma/fouth-edition/opc-digSig.xsd +49 -0
  251. package/dist/skills/builtin/pptx/scripts/office/schemas/ecma/fouth-edition/opc-relationships.xsd +33 -0
  252. package/dist/skills/builtin/pptx/scripts/office/schemas/mce/mc.xsd +75 -0
  253. package/dist/skills/builtin/pptx/scripts/office/schemas/microsoft/wml-2010.xsd +560 -0
  254. package/dist/skills/builtin/pptx/scripts/office/schemas/microsoft/wml-2012.xsd +67 -0
  255. package/dist/skills/builtin/pptx/scripts/office/schemas/microsoft/wml-2018.xsd +14 -0
  256. package/dist/skills/builtin/pptx/scripts/office/schemas/microsoft/wml-cex-2018.xsd +20 -0
  257. package/dist/skills/builtin/pptx/scripts/office/schemas/microsoft/wml-cid-2016.xsd +13 -0
  258. package/dist/skills/builtin/pptx/scripts/office/schemas/microsoft/wml-sdtdatahash-2020.xsd +4 -0
  259. package/dist/skills/builtin/pptx/scripts/office/schemas/microsoft/wml-symex-2015.xsd +8 -0
  260. package/dist/skills/builtin/pptx/scripts/office/soffice.py +183 -0
  261. package/dist/skills/builtin/pptx/scripts/office/unpack.py +132 -0
  262. package/dist/skills/builtin/pptx/scripts/office/validate.py +111 -0
  263. package/dist/skills/builtin/pptx/scripts/office/validators/__init__.py +15 -0
  264. package/dist/skills/builtin/pptx/scripts/office/validators/base.py +847 -0
  265. package/dist/skills/builtin/pptx/scripts/office/validators/docx.py +446 -0
  266. package/dist/skills/builtin/pptx/scripts/office/validators/pptx.py +275 -0
  267. package/dist/skills/builtin/pptx/scripts/office/validators/redlining.py +247 -0
  268. package/dist/skills/builtin/pptx/scripts/thumbnail.py +289 -0
  269. package/dist/skills/builtin/promo-video/SKILL.md +124 -0
  270. package/dist/skills/builtin/promote/SKILL.md +77 -0
  271. package/dist/skills/builtin/skill-creator/LICENSE.txt +202 -0
  272. package/dist/skills/builtin/skill-creator/SKILL.md +598 -0
  273. package/dist/skills/builtin/skill-creator/agents/analyzer.md +274 -0
  274. package/dist/skills/builtin/skill-creator/agents/comparator.md +202 -0
  275. package/dist/skills/builtin/skill-creator/agents/grader.md +223 -0
  276. package/dist/skills/builtin/skill-creator/assets/eval_review.html +146 -0
  277. package/dist/skills/builtin/skill-creator/eval-viewer/generate_review.py +471 -0
  278. package/dist/skills/builtin/skill-creator/eval-viewer/viewer.html +1325 -0
  279. package/dist/skills/builtin/skill-creator/references/schemas.md +430 -0
  280. package/dist/skills/builtin/skill-creator/scripts/__init__.py +0 -0
  281. package/dist/skills/builtin/skill-creator/scripts/aggregate_benchmark.py +401 -0
  282. package/dist/skills/builtin/skill-creator/scripts/generate_report.py +326 -0
  283. package/dist/skills/builtin/skill-creator/scripts/improve_description.py +248 -0
  284. package/dist/skills/builtin/skill-creator/scripts/package_skill.py +136 -0
  285. package/dist/skills/builtin/skill-creator/scripts/quick_validate.py +103 -0
  286. package/dist/skills/builtin/skill-creator/scripts/run_eval.py +310 -0
  287. package/dist/skills/builtin/skill-creator/scripts/run_loop.py +332 -0
  288. package/dist/skills/builtin/skill-creator/scripts/utils.py +47 -0
  289. package/dist/skills/builtin/slack-gif-creator/LICENSE.txt +202 -0
  290. package/dist/skills/builtin/slack-gif-creator/SKILL.md +254 -0
  291. package/dist/skills/builtin/slack-gif-creator/core/easing.py +234 -0
  292. package/dist/skills/builtin/slack-gif-creator/core/frame_composer.py +176 -0
  293. package/dist/skills/builtin/slack-gif-creator/core/gif_builder.py +269 -0
  294. package/dist/skills/builtin/slack-gif-creator/core/validators.py +136 -0
  295. package/dist/skills/builtin/slack-gif-creator/requirements.txt +4 -0
  296. package/dist/skills/builtin/sync-version/SKILL.md +39 -0
  297. package/dist/skills/builtin/theme-factory/LICENSE.txt +202 -0
  298. package/dist/skills/builtin/theme-factory/SKILL.md +59 -0
  299. package/dist/skills/builtin/theme-factory/theme-showcase.pdf +0 -0
  300. package/dist/skills/builtin/theme-factory/themes/arctic-frost.md +19 -0
  301. package/dist/skills/builtin/theme-factory/themes/botanical-garden.md +19 -0
  302. package/dist/skills/builtin/theme-factory/themes/desert-rose.md +19 -0
  303. package/dist/skills/builtin/theme-factory/themes/forest-canopy.md +19 -0
  304. package/dist/skills/builtin/theme-factory/themes/golden-hour.md +19 -0
  305. package/dist/skills/builtin/theme-factory/themes/midnight-galaxy.md +19 -0
  306. package/dist/skills/builtin/theme-factory/themes/modern-minimalist.md +19 -0
  307. package/dist/skills/builtin/theme-factory/themes/ocean-depths.md +19 -0
  308. package/dist/skills/builtin/theme-factory/themes/sunset-boulevard.md +19 -0
  309. package/dist/skills/builtin/theme-factory/themes/tech-innovation.md +19 -0
  310. package/dist/skills/builtin/web-artifacts-builder/LICENSE.txt +202 -0
  311. package/dist/skills/builtin/web-artifacts-builder/SKILL.md +74 -0
  312. package/dist/skills/builtin/web-artifacts-builder/scripts/bundle-artifact.sh +54 -0
  313. package/dist/skills/builtin/web-artifacts-builder/scripts/init-artifact.sh +322 -0
  314. package/dist/skills/builtin/web-artifacts-builder/scripts/shadcn-components.tar.gz +0 -0
  315. package/dist/skills/builtin/webapp-testing/LICENSE.txt +202 -0
  316. package/dist/skills/builtin/webapp-testing/SKILL.md +96 -0
  317. package/dist/skills/builtin/webapp-testing/examples/console_logging.py +35 -0
  318. package/dist/skills/builtin/webapp-testing/examples/element_discovery.py +40 -0
  319. package/dist/skills/builtin/webapp-testing/examples/static_html_automation.py +33 -0
  320. package/dist/skills/builtin/webapp-testing/scripts/with_server.py +106 -0
  321. package/dist/skills/builtin/xlsx/LICENSE.txt +30 -0
  322. package/dist/skills/builtin/xlsx/SKILL.md +292 -0
  323. package/dist/skills/builtin/xlsx/scripts/office/helpers/__init__.py +0 -0
  324. package/dist/skills/builtin/xlsx/scripts/office/helpers/merge_runs.py +199 -0
  325. package/dist/skills/builtin/xlsx/scripts/office/helpers/simplify_redlines.py +197 -0
  326. package/dist/skills/builtin/xlsx/scripts/office/pack.py +159 -0
  327. package/dist/skills/builtin/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-chart.xsd +1499 -0
  328. package/dist/skills/builtin/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-chartDrawing.xsd +146 -0
  329. package/dist/skills/builtin/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-diagram.xsd +1085 -0
  330. package/dist/skills/builtin/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-lockedCanvas.xsd +11 -0
  331. package/dist/skills/builtin/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-main.xsd +3081 -0
  332. package/dist/skills/builtin/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-picture.xsd +23 -0
  333. package/dist/skills/builtin/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-spreadsheetDrawing.xsd +185 -0
  334. package/dist/skills/builtin/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-wordprocessingDrawing.xsd +287 -0
  335. package/dist/skills/builtin/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/pml.xsd +1676 -0
  336. package/dist/skills/builtin/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-additionalCharacteristics.xsd +28 -0
  337. package/dist/skills/builtin/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-bibliography.xsd +144 -0
  338. package/dist/skills/builtin/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-commonSimpleTypes.xsd +174 -0
  339. package/dist/skills/builtin/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-customXmlDataProperties.xsd +25 -0
  340. package/dist/skills/builtin/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-customXmlSchemaProperties.xsd +18 -0
  341. package/dist/skills/builtin/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-documentPropertiesCustom.xsd +59 -0
  342. package/dist/skills/builtin/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-documentPropertiesExtended.xsd +56 -0
  343. package/dist/skills/builtin/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-documentPropertiesVariantTypes.xsd +195 -0
  344. package/dist/skills/builtin/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-math.xsd +582 -0
  345. package/dist/skills/builtin/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-relationshipReference.xsd +25 -0
  346. package/dist/skills/builtin/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/sml.xsd +4439 -0
  347. package/dist/skills/builtin/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/vml-main.xsd +570 -0
  348. package/dist/skills/builtin/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/vml-officeDrawing.xsd +509 -0
  349. package/dist/skills/builtin/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/vml-presentationDrawing.xsd +12 -0
  350. package/dist/skills/builtin/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/vml-spreadsheetDrawing.xsd +108 -0
  351. package/dist/skills/builtin/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/vml-wordprocessingDrawing.xsd +96 -0
  352. package/dist/skills/builtin/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/wml.xsd +3646 -0
  353. package/dist/skills/builtin/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/xml.xsd +116 -0
  354. package/dist/skills/builtin/xlsx/scripts/office/schemas/ecma/fouth-edition/opc-contentTypes.xsd +42 -0
  355. package/dist/skills/builtin/xlsx/scripts/office/schemas/ecma/fouth-edition/opc-coreProperties.xsd +50 -0
  356. package/dist/skills/builtin/xlsx/scripts/office/schemas/ecma/fouth-edition/opc-digSig.xsd +49 -0
  357. package/dist/skills/builtin/xlsx/scripts/office/schemas/ecma/fouth-edition/opc-relationships.xsd +33 -0
  358. package/dist/skills/builtin/xlsx/scripts/office/schemas/mce/mc.xsd +75 -0
  359. package/dist/skills/builtin/xlsx/scripts/office/schemas/microsoft/wml-2010.xsd +560 -0
  360. package/dist/skills/builtin/xlsx/scripts/office/schemas/microsoft/wml-2012.xsd +67 -0
  361. package/dist/skills/builtin/xlsx/scripts/office/schemas/microsoft/wml-2018.xsd +14 -0
  362. package/dist/skills/builtin/xlsx/scripts/office/schemas/microsoft/wml-cex-2018.xsd +20 -0
  363. package/dist/skills/builtin/xlsx/scripts/office/schemas/microsoft/wml-cid-2016.xsd +13 -0
  364. package/dist/skills/builtin/xlsx/scripts/office/schemas/microsoft/wml-sdtdatahash-2020.xsd +4 -0
  365. package/dist/skills/builtin/xlsx/scripts/office/schemas/microsoft/wml-symex-2015.xsd +8 -0
  366. package/dist/skills/builtin/xlsx/scripts/office/soffice.py +183 -0
  367. package/dist/skills/builtin/xlsx/scripts/office/unpack.py +132 -0
  368. package/dist/skills/builtin/xlsx/scripts/office/validate.py +111 -0
  369. package/dist/skills/builtin/xlsx/scripts/office/validators/__init__.py +15 -0
  370. package/dist/skills/builtin/xlsx/scripts/office/validators/base.py +847 -0
  371. package/dist/skills/builtin/xlsx/scripts/office/validators/docx.py +446 -0
  372. package/dist/skills/builtin/xlsx/scripts/office/validators/pptx.py +275 -0
  373. package/dist/skills/builtin/xlsx/scripts/office/validators/redlining.py +247 -0
  374. package/dist/skills/builtin/xlsx/scripts/recalc.py +184 -0
  375. package/dist/tools/base.d.ts +16 -0
  376. package/dist/tools/base.d.ts.map +1 -1
  377. package/dist/tools/base.js +32 -0
  378. package/dist/tools/base.js.map +1 -1
  379. package/dist/tools/bash.d.ts.map +1 -1
  380. package/dist/tools/bash.js +8 -0
  381. package/dist/tools/bash.js.map +1 -1
  382. package/dist/tools/file.d.ts +3 -1
  383. package/dist/tools/file.d.ts.map +1 -1
  384. package/dist/tools/file.js +116 -126
  385. package/dist/tools/file.js.map +1 -1
  386. package/dist/tools/generate-design.d.ts +5 -1
  387. package/dist/tools/generate-design.d.ts.map +1 -1
  388. package/dist/tools/generate-design.js +25 -3
  389. package/dist/tools/generate-design.js.map +1 -1
  390. package/dist/tools/goal.d.ts +1 -1
  391. package/dist/tools/goal.d.ts.map +1 -1
  392. package/dist/tools/goal.js +18 -9
  393. package/dist/tools/goal.js.map +1 -1
  394. package/dist/tools/index.d.ts +7 -0
  395. package/dist/tools/index.d.ts.map +1 -1
  396. package/dist/tools/index.js +67 -1
  397. package/dist/tools/index.js.map +1 -1
  398. package/dist/tools/network-agent.js +2 -1
  399. package/dist/tools/network-agent.js.map +1 -1
  400. package/dist/tools/schedule.d.ts.map +1 -1
  401. package/dist/tools/schedule.js +2 -26
  402. package/dist/tools/schedule.js.map +1 -1
  403. package/dist/tools/skill.d.ts +1 -1
  404. package/dist/tools/skill.d.ts.map +1 -1
  405. package/dist/tools/skill.js +18 -31
  406. package/dist/tools/skill.js.map +1 -1
  407. package/dist/web/server/api-manager.d.ts +3 -0
  408. package/dist/web/server/api-manager.d.ts.map +1 -1
  409. package/dist/web/server/api-manager.js +128 -12
  410. package/dist/web/server/api-manager.js.map +1 -1
  411. package/dist/web/server/app-manager.d.ts +71 -0
  412. package/dist/web/server/app-manager.d.ts.map +1 -0
  413. package/dist/web/server/app-manager.js +364 -0
  414. package/dist/web/server/app-manager.js.map +1 -0
  415. package/dist/web/server/channels/bridge.d.ts.map +1 -1
  416. package/dist/web/server/channels/bridge.js +2 -1
  417. package/dist/web/server/channels/bridge.js.map +1 -1
  418. package/dist/web/server/codex-auth-manager.d.ts +43 -0
  419. package/dist/web/server/codex-auth-manager.d.ts.map +1 -0
  420. package/dist/web/server/codex-auth-manager.js +429 -0
  421. package/dist/web/server/codex-auth-manager.js.map +1 -0
  422. package/dist/web/server/conversation.d.ts +34 -5
  423. package/dist/web/server/conversation.d.ts.map +1 -1
  424. package/dist/web/server/conversation.js +408 -132
  425. package/dist/web/server/conversation.js.map +1 -1
  426. package/dist/web/server/image-attachments.d.ts +23 -0
  427. package/dist/web/server/image-attachments.d.ts.map +1 -0
  428. package/dist/web/server/image-attachments.js +93 -0
  429. package/dist/web/server/image-attachments.js.map +1 -0
  430. package/dist/web/server/index.d.ts.map +1 -1
  431. package/dist/web/server/index.js +28 -0
  432. package/dist/web/server/index.js.map +1 -1
  433. package/dist/web/server/routes/__tests__/app-api.test.d.ts +5 -0
  434. package/dist/web/server/routes/__tests__/app-api.test.d.ts.map +1 -0
  435. package/dist/web/server/routes/__tests__/app-api.test.js +48 -0
  436. package/dist/web/server/routes/__tests__/app-api.test.js.map +1 -0
  437. package/dist/web/server/routes/__tests__/tunnel-api.test.d.ts +2 -0
  438. package/dist/web/server/routes/__tests__/tunnel-api.test.d.ts.map +1 -0
  439. package/dist/web/server/routes/__tests__/tunnel-api.test.js +96 -0
  440. package/dist/web/server/routes/__tests__/tunnel-api.test.js.map +1 -0
  441. package/dist/web/server/routes/ai-editor.d.ts.map +1 -1
  442. package/dist/web/server/routes/ai-editor.js +9 -45
  443. package/dist/web/server/routes/ai-editor.js.map +1 -1
  444. package/dist/web/server/routes/ai-hover.d.ts.map +1 -1
  445. package/dist/web/server/routes/ai-hover.js +6 -23
  446. package/dist/web/server/routes/ai-hover.js.map +1 -1
  447. package/dist/web/server/routes/api.d.ts.map +1 -1
  448. package/dist/web/server/routes/api.js +27 -20
  449. package/dist/web/server/routes/api.js.map +1 -1
  450. package/dist/web/server/routes/app-api.d.ts +8 -0
  451. package/dist/web/server/routes/app-api.d.ts.map +1 -0
  452. package/dist/web/server/routes/app-api.js +191 -0
  453. package/dist/web/server/routes/app-api.js.map +1 -0
  454. package/dist/web/server/routes/auth.d.ts.map +1 -1
  455. package/dist/web/server/routes/auth.js +306 -5
  456. package/dist/web/server/routes/auth.js.map +1 -1
  457. package/dist/web/server/routes/autocomplete-api.d.ts.map +1 -1
  458. package/dist/web/server/routes/autocomplete-api.js +5 -43
  459. package/dist/web/server/routes/autocomplete-api.js.map +1 -1
  460. package/dist/web/server/routes/axon-cloud.d.ts.map +1 -1
  461. package/dist/web/server/routes/axon-cloud.js +2 -0
  462. package/dist/web/server/routes/axon-cloud.js.map +1 -1
  463. package/dist/web/server/routes/network-api.d.ts +1 -0
  464. package/dist/web/server/routes/network-api.d.ts.map +1 -1
  465. package/dist/web/server/routes/network-api.js +36 -11
  466. package/dist/web/server/routes/network-api.js.map +1 -1
  467. package/dist/web/server/routes/port-forward.d.ts.map +1 -1
  468. package/dist/web/server/routes/port-forward.js +3 -2
  469. package/dist/web/server/routes/port-forward.js.map +1 -1
  470. package/dist/web/server/routes/schedule-api.d.ts.map +1 -1
  471. package/dist/web/server/routes/schedule-api.js +5 -1
  472. package/dist/web/server/routes/schedule-api.js.map +1 -1
  473. package/dist/web/server/routes/tunnel-api.d.ts +14 -0
  474. package/dist/web/server/routes/tunnel-api.d.ts.map +1 -0
  475. package/dist/web/server/routes/tunnel-api.js +52 -0
  476. package/dist/web/server/routes/tunnel-api.js.map +1 -0
  477. package/dist/web/server/runtime/codex-client.d.ts +30 -0
  478. package/dist/web/server/runtime/codex-client.d.ts.map +1 -0
  479. package/dist/web/server/runtime/codex-client.js +1002 -0
  480. package/dist/web/server/runtime/codex-client.js.map +1 -0
  481. package/dist/web/server/runtime/factory.d.ts +3 -0
  482. package/dist/web/server/runtime/factory.d.ts.map +1 -0
  483. package/dist/web/server/runtime/factory.js +16 -0
  484. package/dist/web/server/runtime/factory.js.map +1 -0
  485. package/dist/web/server/runtime/runtime-selection.d.ts +16 -0
  486. package/dist/web/server/runtime/runtime-selection.d.ts.map +1 -0
  487. package/dist/web/server/runtime/runtime-selection.js +33 -0
  488. package/dist/web/server/runtime/runtime-selection.js.map +1 -0
  489. package/dist/web/server/runtime/tool-input-normalizer.d.ts +3 -0
  490. package/dist/web/server/runtime/tool-input-normalizer.d.ts.map +1 -0
  491. package/dist/web/server/runtime/tool-input-normalizer.js +52 -0
  492. package/dist/web/server/runtime/tool-input-normalizer.js.map +1 -0
  493. package/dist/web/server/runtime/types.d.ts +97 -0
  494. package/dist/web/server/runtime/types.d.ts.map +1 -0
  495. package/dist/web/server/runtime/types.js +2 -0
  496. package/dist/web/server/runtime/types.js.map +1 -0
  497. package/dist/web/server/runtime/utility-client.d.ts +5 -0
  498. package/dist/web/server/runtime/utility-client.d.ts.map +1 -0
  499. package/dist/web/server/runtime/utility-client.js +65 -0
  500. package/dist/web/server/runtime/utility-client.js.map +1 -0
  501. package/dist/web/server/services/config-service.d.ts +7 -2
  502. package/dist/web/server/services/config-service.d.ts.map +1 -1
  503. package/dist/web/server/services/config-service.js +41 -0
  504. package/dist/web/server/services/config-service.js.map +1 -1
  505. package/dist/web/server/services/gemini-image-service.d.ts +20 -1
  506. package/dist/web/server/services/gemini-image-service.d.ts.map +1 -1
  507. package/dist/web/server/services/gemini-image-service.js +121 -13
  508. package/dist/web/server/services/gemini-image-service.js.map +1 -1
  509. package/dist/web/server/session-manager.d.ts +1 -0
  510. package/dist/web/server/session-manager.d.ts.map +1 -1
  511. package/dist/web/server/session-manager.js +1 -0
  512. package/dist/web/server/session-manager.js.map +1 -1
  513. package/dist/web/server/slash-commands.d.ts.map +1 -1
  514. package/dist/web/server/slash-commands.js +59 -17
  515. package/dist/web/server/slash-commands.js.map +1 -1
  516. package/dist/web/server/tunnel.d.ts +47 -0
  517. package/dist/web/server/tunnel.d.ts.map +1 -0
  518. package/dist/web/server/tunnel.js +165 -0
  519. package/dist/web/server/tunnel.js.map +1 -0
  520. package/dist/web/server/user-interaction.d.ts +10 -0
  521. package/dist/web/server/user-interaction.d.ts.map +1 -1
  522. package/dist/web/server/user-interaction.js +28 -0
  523. package/dist/web/server/user-interaction.js.map +1 -1
  524. package/dist/web/server/web-auth.d.ts +35 -3
  525. package/dist/web/server/web-auth.d.ts.map +1 -1
  526. package/dist/web/server/web-auth.js +298 -29
  527. package/dist/web/server/web-auth.js.map +1 -1
  528. package/dist/web/server/web-scheduler.d.ts.map +1 -1
  529. package/dist/web/server/web-scheduler.js +9 -0
  530. package/dist/web/server/web-scheduler.js.map +1 -1
  531. package/dist/web/server/websocket-git-handlers.d.ts.map +1 -1
  532. package/dist/web/server/websocket-git-handlers.js +5 -29
  533. package/dist/web/server/websocket-git-handlers.js.map +1 -1
  534. package/dist/web/server/websocket.d.ts.map +1 -1
  535. package/dist/web/server/websocket.js +193 -44
  536. package/dist/web/server/websocket.js.map +1 -1
  537. package/dist/web/shared/auth-summary.d.ts +28 -0
  538. package/dist/web/shared/auth-summary.d.ts.map +1 -0
  539. package/dist/web/shared/auth-summary.js +53 -0
  540. package/dist/web/shared/auth-summary.js.map +1 -0
  541. package/dist/web/shared/model-catalog.d.ts +30 -0
  542. package/dist/web/shared/model-catalog.d.ts.map +1 -0
  543. package/dist/web/shared/model-catalog.js +373 -0
  544. package/dist/web/shared/model-catalog.js.map +1 -0
  545. package/dist/web/shared/model-preferences.d.ts +5 -0
  546. package/dist/web/shared/model-preferences.d.ts.map +1 -0
  547. package/dist/web/shared/model-preferences.js +13 -0
  548. package/dist/web/shared/model-preferences.js.map +1 -0
  549. package/dist/web/shared/setup-runtime.d.ts +27 -0
  550. package/dist/web/shared/setup-runtime.d.ts.map +1 -0
  551. package/dist/web/shared/setup-runtime.js +114 -0
  552. package/dist/web/shared/setup-runtime.js.map +1 -0
  553. package/dist/web/shared/thinking-config.d.ts +20 -0
  554. package/dist/web/shared/thinking-config.d.ts.map +1 -0
  555. package/dist/web/shared/thinking-config.js +99 -0
  556. package/dist/web/shared/thinking-config.js.map +1 -0
  557. package/dist/web/shared/types.d.ts +22 -2
  558. package/dist/web/shared/types.d.ts.map +1 -1
  559. package/dist/web/shared/types.js.map +1 -1
  560. package/electron/main.cjs +7 -2
  561. package/package.json +4 -2
  562. package/src/web/client/dist/assets/index-B0gwq5PJ.js +727 -0
  563. package/src/web/client/dist/assets/index-CwhuMLtk.css +32 -0
  564. package/src/web/client/dist/icons/icon-192.png +0 -0
  565. package/src/web/client/dist/icons/icon-512.png +0 -0
  566. package/src/web/client/dist/index.html +31 -0
  567. package/src/web/client/dist/logo.png +0 -0
  568. package/src/web/client/dist/manifest.webmanifest +25 -0
  569. package/src/web/client/dist/sw.js +78 -0
@@ -0,0 +1,401 @@
1
+ #!/usr/bin/env python3
2
+ """
3
+ Aggregate individual run results into benchmark summary statistics.
4
+
5
+ Reads grading.json files from run directories and produces:
6
+ - run_summary with mean, stddev, min, max for each metric
7
+ - delta between with_skill and without_skill configurations
8
+
9
+ Usage:
10
+ python aggregate_benchmark.py <benchmark_dir>
11
+
12
+ Example:
13
+ python aggregate_benchmark.py benchmarks/2026-01-15T10-30-00/
14
+
15
+ The script supports two directory layouts:
16
+
17
+ Workspace layout (from skill-creator iterations):
18
+ <benchmark_dir>/
19
+ └── eval-N/
20
+ ├── with_skill/
21
+ │ ├── run-1/grading.json
22
+ │ └── run-2/grading.json
23
+ └── without_skill/
24
+ ├── run-1/grading.json
25
+ └── run-2/grading.json
26
+
27
+ Legacy layout (with runs/ subdirectory):
28
+ <benchmark_dir>/
29
+ └── runs/
30
+ └── eval-N/
31
+ ├── with_skill/
32
+ │ └── run-1/grading.json
33
+ └── without_skill/
34
+ └── run-1/grading.json
35
+ """
36
+
37
+ import argparse
38
+ import json
39
+ import math
40
+ import sys
41
+ from datetime import datetime, timezone
42
+ from pathlib import Path
43
+
44
+
45
+ def calculate_stats(values: list[float]) -> dict:
46
+ """Calculate mean, stddev, min, max for a list of values."""
47
+ if not values:
48
+ return {"mean": 0.0, "stddev": 0.0, "min": 0.0, "max": 0.0}
49
+
50
+ n = len(values)
51
+ mean = sum(values) / n
52
+
53
+ if n > 1:
54
+ variance = sum((x - mean) ** 2 for x in values) / (n - 1)
55
+ stddev = math.sqrt(variance)
56
+ else:
57
+ stddev = 0.0
58
+
59
+ return {
60
+ "mean": round(mean, 4),
61
+ "stddev": round(stddev, 4),
62
+ "min": round(min(values), 4),
63
+ "max": round(max(values), 4)
64
+ }
65
+
66
+
67
+ def load_run_results(benchmark_dir: Path) -> dict:
68
+ """
69
+ Load all run results from a benchmark directory.
70
+
71
+ Returns dict keyed by config name (e.g. "with_skill"/"without_skill",
72
+ or "new_skill"/"old_skill"), each containing a list of run results.
73
+ """
74
+ # Support both layouts: eval dirs directly under benchmark_dir, or under runs/
75
+ runs_dir = benchmark_dir / "runs"
76
+ if runs_dir.exists():
77
+ search_dir = runs_dir
78
+ elif list(benchmark_dir.glob("eval-*")):
79
+ search_dir = benchmark_dir
80
+ else:
81
+ print(f"No eval directories found in {benchmark_dir} or {benchmark_dir / 'runs'}")
82
+ return {}
83
+
84
+ results: dict[str, list] = {}
85
+
86
+ for eval_idx, eval_dir in enumerate(sorted(search_dir.glob("eval-*"))):
87
+ metadata_path = eval_dir / "eval_metadata.json"
88
+ if metadata_path.exists():
89
+ try:
90
+ with open(metadata_path) as mf:
91
+ eval_id = json.load(mf).get("eval_id", eval_idx)
92
+ except (json.JSONDecodeError, OSError):
93
+ eval_id = eval_idx
94
+ else:
95
+ try:
96
+ eval_id = int(eval_dir.name.split("-")[1])
97
+ except ValueError:
98
+ eval_id = eval_idx
99
+
100
+ # Discover config directories dynamically rather than hardcoding names
101
+ for config_dir in sorted(eval_dir.iterdir()):
102
+ if not config_dir.is_dir():
103
+ continue
104
+ # Skip non-config directories (inputs, outputs, etc.)
105
+ if not list(config_dir.glob("run-*")):
106
+ continue
107
+ config = config_dir.name
108
+ if config not in results:
109
+ results[config] = []
110
+
111
+ for run_dir in sorted(config_dir.glob("run-*")):
112
+ run_number = int(run_dir.name.split("-")[1])
113
+ grading_file = run_dir / "grading.json"
114
+
115
+ if not grading_file.exists():
116
+ print(f"Warning: grading.json not found in {run_dir}")
117
+ continue
118
+
119
+ try:
120
+ with open(grading_file) as f:
121
+ grading = json.load(f)
122
+ except json.JSONDecodeError as e:
123
+ print(f"Warning: Invalid JSON in {grading_file}: {e}")
124
+ continue
125
+
126
+ # Extract metrics
127
+ result = {
128
+ "eval_id": eval_id,
129
+ "run_number": run_number,
130
+ "pass_rate": grading.get("summary", {}).get("pass_rate", 0.0),
131
+ "passed": grading.get("summary", {}).get("passed", 0),
132
+ "failed": grading.get("summary", {}).get("failed", 0),
133
+ "total": grading.get("summary", {}).get("total", 0),
134
+ }
135
+
136
+ # Extract timing — check grading.json first, then sibling timing.json
137
+ timing = grading.get("timing", {})
138
+ result["time_seconds"] = timing.get("total_duration_seconds", 0.0)
139
+ timing_file = run_dir / "timing.json"
140
+ if result["time_seconds"] == 0.0 and timing_file.exists():
141
+ try:
142
+ with open(timing_file) as tf:
143
+ timing_data = json.load(tf)
144
+ result["time_seconds"] = timing_data.get("total_duration_seconds", 0.0)
145
+ result["tokens"] = timing_data.get("total_tokens", 0)
146
+ except json.JSONDecodeError:
147
+ pass
148
+
149
+ # Extract metrics if available
150
+ metrics = grading.get("execution_metrics", {})
151
+ result["tool_calls"] = metrics.get("total_tool_calls", 0)
152
+ if not result.get("tokens"):
153
+ result["tokens"] = metrics.get("output_chars", 0)
154
+ result["errors"] = metrics.get("errors_encountered", 0)
155
+
156
+ # Extract expectations — viewer requires fields: text, passed, evidence
157
+ raw_expectations = grading.get("expectations", [])
158
+ for exp in raw_expectations:
159
+ if "text" not in exp or "passed" not in exp:
160
+ print(f"Warning: expectation in {grading_file} missing required fields (text, passed, evidence): {exp}")
161
+ result["expectations"] = raw_expectations
162
+
163
+ # Extract notes from user_notes_summary
164
+ notes_summary = grading.get("user_notes_summary", {})
165
+ notes = []
166
+ notes.extend(notes_summary.get("uncertainties", []))
167
+ notes.extend(notes_summary.get("needs_review", []))
168
+ notes.extend(notes_summary.get("workarounds", []))
169
+ result["notes"] = notes
170
+
171
+ results[config].append(result)
172
+
173
+ return results
174
+
175
+
176
+ def aggregate_results(results: dict) -> dict:
177
+ """
178
+ Aggregate run results into summary statistics.
179
+
180
+ Returns run_summary with stats for each configuration and delta.
181
+ """
182
+ run_summary = {}
183
+ configs = list(results.keys())
184
+
185
+ for config in configs:
186
+ runs = results.get(config, [])
187
+
188
+ if not runs:
189
+ run_summary[config] = {
190
+ "pass_rate": {"mean": 0.0, "stddev": 0.0, "min": 0.0, "max": 0.0},
191
+ "time_seconds": {"mean": 0.0, "stddev": 0.0, "min": 0.0, "max": 0.0},
192
+ "tokens": {"mean": 0, "stddev": 0, "min": 0, "max": 0}
193
+ }
194
+ continue
195
+
196
+ pass_rates = [r["pass_rate"] for r in runs]
197
+ times = [r["time_seconds"] for r in runs]
198
+ tokens = [r.get("tokens", 0) for r in runs]
199
+
200
+ run_summary[config] = {
201
+ "pass_rate": calculate_stats(pass_rates),
202
+ "time_seconds": calculate_stats(times),
203
+ "tokens": calculate_stats(tokens)
204
+ }
205
+
206
+ # Calculate delta between the first two configs (if two exist)
207
+ if len(configs) >= 2:
208
+ primary = run_summary.get(configs[0], {})
209
+ baseline = run_summary.get(configs[1], {})
210
+ else:
211
+ primary = run_summary.get(configs[0], {}) if configs else {}
212
+ baseline = {}
213
+
214
+ delta_pass_rate = primary.get("pass_rate", {}).get("mean", 0) - baseline.get("pass_rate", {}).get("mean", 0)
215
+ delta_time = primary.get("time_seconds", {}).get("mean", 0) - baseline.get("time_seconds", {}).get("mean", 0)
216
+ delta_tokens = primary.get("tokens", {}).get("mean", 0) - baseline.get("tokens", {}).get("mean", 0)
217
+
218
+ run_summary["delta"] = {
219
+ "pass_rate": f"{delta_pass_rate:+.2f}",
220
+ "time_seconds": f"{delta_time:+.1f}",
221
+ "tokens": f"{delta_tokens:+.0f}"
222
+ }
223
+
224
+ return run_summary
225
+
226
+
227
+ def generate_benchmark(benchmark_dir: Path, skill_name: str = "", skill_path: str = "") -> dict:
228
+ """
229
+ Generate complete benchmark.json from run results.
230
+ """
231
+ results = load_run_results(benchmark_dir)
232
+ run_summary = aggregate_results(results)
233
+
234
+ # Build runs array for benchmark.json
235
+ runs = []
236
+ for config in results:
237
+ for result in results[config]:
238
+ runs.append({
239
+ "eval_id": result["eval_id"],
240
+ "configuration": config,
241
+ "run_number": result["run_number"],
242
+ "result": {
243
+ "pass_rate": result["pass_rate"],
244
+ "passed": result["passed"],
245
+ "failed": result["failed"],
246
+ "total": result["total"],
247
+ "time_seconds": result["time_seconds"],
248
+ "tokens": result.get("tokens", 0),
249
+ "tool_calls": result.get("tool_calls", 0),
250
+ "errors": result.get("errors", 0)
251
+ },
252
+ "expectations": result["expectations"],
253
+ "notes": result["notes"]
254
+ })
255
+
256
+ # Determine eval IDs from results
257
+ eval_ids = sorted(set(
258
+ r["eval_id"]
259
+ for config in results.values()
260
+ for r in config
261
+ ))
262
+
263
+ benchmark = {
264
+ "metadata": {
265
+ "skill_name": skill_name or "<skill-name>",
266
+ "skill_path": skill_path or "<path/to/skill>",
267
+ "executor_model": "<model-name>",
268
+ "analyzer_model": "<model-name>",
269
+ "timestamp": datetime.now(timezone.utc).strftime("%Y-%m-%dT%H:%M:%SZ"),
270
+ "evals_run": eval_ids,
271
+ "runs_per_configuration": 3
272
+ },
273
+ "runs": runs,
274
+ "run_summary": run_summary,
275
+ "notes": [] # To be filled by analyzer
276
+ }
277
+
278
+ return benchmark
279
+
280
+
281
+ def generate_markdown(benchmark: dict) -> str:
282
+ """Generate human-readable benchmark.md from benchmark data."""
283
+ metadata = benchmark["metadata"]
284
+ run_summary = benchmark["run_summary"]
285
+
286
+ # Determine config names (excluding "delta")
287
+ configs = [k for k in run_summary if k != "delta"]
288
+ config_a = configs[0] if len(configs) >= 1 else "config_a"
289
+ config_b = configs[1] if len(configs) >= 2 else "config_b"
290
+ label_a = config_a.replace("_", " ").title()
291
+ label_b = config_b.replace("_", " ").title()
292
+
293
+ lines = [
294
+ f"# Skill Benchmark: {metadata['skill_name']}",
295
+ "",
296
+ f"**Model**: {metadata['executor_model']}",
297
+ f"**Date**: {metadata['timestamp']}",
298
+ f"**Evals**: {', '.join(map(str, metadata['evals_run']))} ({metadata['runs_per_configuration']} runs each per configuration)",
299
+ "",
300
+ "## Summary",
301
+ "",
302
+ f"| Metric | {label_a} | {label_b} | Delta |",
303
+ "|--------|------------|---------------|-------|",
304
+ ]
305
+
306
+ a_summary = run_summary.get(config_a, {})
307
+ b_summary = run_summary.get(config_b, {})
308
+ delta = run_summary.get("delta", {})
309
+
310
+ # Format pass rate
311
+ a_pr = a_summary.get("pass_rate", {})
312
+ b_pr = b_summary.get("pass_rate", {})
313
+ lines.append(f"| Pass Rate | {a_pr.get('mean', 0)*100:.0f}% ± {a_pr.get('stddev', 0)*100:.0f}% | {b_pr.get('mean', 0)*100:.0f}% ± {b_pr.get('stddev', 0)*100:.0f}% | {delta.get('pass_rate', '—')} |")
314
+
315
+ # Format time
316
+ a_time = a_summary.get("time_seconds", {})
317
+ b_time = b_summary.get("time_seconds", {})
318
+ lines.append(f"| Time | {a_time.get('mean', 0):.1f}s ± {a_time.get('stddev', 0):.1f}s | {b_time.get('mean', 0):.1f}s ± {b_time.get('stddev', 0):.1f}s | {delta.get('time_seconds', '—')}s |")
319
+
320
+ # Format tokens
321
+ a_tokens = a_summary.get("tokens", {})
322
+ b_tokens = b_summary.get("tokens", {})
323
+ lines.append(f"| Tokens | {a_tokens.get('mean', 0):.0f} ± {a_tokens.get('stddev', 0):.0f} | {b_tokens.get('mean', 0):.0f} ± {b_tokens.get('stddev', 0):.0f} | {delta.get('tokens', '—')} |")
324
+
325
+ # Notes section
326
+ if benchmark.get("notes"):
327
+ lines.extend([
328
+ "",
329
+ "## Notes",
330
+ ""
331
+ ])
332
+ for note in benchmark["notes"]:
333
+ lines.append(f"- {note}")
334
+
335
+ return "\n".join(lines)
336
+
337
+
338
+ def main():
339
+ parser = argparse.ArgumentParser(
340
+ description="Aggregate benchmark run results into summary statistics"
341
+ )
342
+ parser.add_argument(
343
+ "benchmark_dir",
344
+ type=Path,
345
+ help="Path to the benchmark directory"
346
+ )
347
+ parser.add_argument(
348
+ "--skill-name",
349
+ default="",
350
+ help="Name of the skill being benchmarked"
351
+ )
352
+ parser.add_argument(
353
+ "--skill-path",
354
+ default="",
355
+ help="Path to the skill being benchmarked"
356
+ )
357
+ parser.add_argument(
358
+ "--output", "-o",
359
+ type=Path,
360
+ help="Output path for benchmark.json (default: <benchmark_dir>/benchmark.json)"
361
+ )
362
+
363
+ args = parser.parse_args()
364
+
365
+ if not args.benchmark_dir.exists():
366
+ print(f"Directory not found: {args.benchmark_dir}")
367
+ sys.exit(1)
368
+
369
+ # Generate benchmark
370
+ benchmark = generate_benchmark(args.benchmark_dir, args.skill_name, args.skill_path)
371
+
372
+ # Determine output paths
373
+ output_json = args.output or (args.benchmark_dir / "benchmark.json")
374
+ output_md = output_json.with_suffix(".md")
375
+
376
+ # Write benchmark.json
377
+ with open(output_json, "w") as f:
378
+ json.dump(benchmark, f, indent=2)
379
+ print(f"Generated: {output_json}")
380
+
381
+ # Write benchmark.md
382
+ markdown = generate_markdown(benchmark)
383
+ with open(output_md, "w") as f:
384
+ f.write(markdown)
385
+ print(f"Generated: {output_md}")
386
+
387
+ # Print summary
388
+ run_summary = benchmark["run_summary"]
389
+ configs = [k for k in run_summary if k != "delta"]
390
+ delta = run_summary.get("delta", {})
391
+
392
+ print(f"\nSummary:")
393
+ for config in configs:
394
+ pr = run_summary[config]["pass_rate"]["mean"]
395
+ label = config.replace("_", " ").title()
396
+ print(f" {label}: {pr*100:.1f}% pass rate")
397
+ print(f" Delta: {delta.get('pass_rate', '—')}")
398
+
399
+
400
+ if __name__ == "__main__":
401
+ main()