xtrm-tools 0.6.0 → 0.7.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 (632) hide show
  1. package/.xtrm/config/README.md +10 -0
  2. package/{config/mcp_servers.json → .xtrm/config/claude.mcp.json} +0 -28
  3. package/{config → .xtrm/config}/instructions/agents-top.md +12 -3
  4. package/{config → .xtrm/config}/instructions/claude-top.md +12 -3
  5. package/{config → .xtrm/config}/pi/extensions/beads/index.ts +44 -13
  6. package/{config → .xtrm/config}/pi/extensions/custom-footer/index.ts +59 -82
  7. package/{config → .xtrm/config}/pi/extensions/xtrm-ui/index.ts +3 -3
  8. package/{config → .xtrm/config}/pi/install-schema.json +2 -2
  9. package/.xtrm/config/pi.mcp.json +39 -0
  10. package/.xtrm/config/settings.json +41 -0
  11. package/.xtrm/extensions/auto-session-name/index.ts +29 -0
  12. package/.xtrm/extensions/auto-session-name/package.json +16 -0
  13. package/.xtrm/extensions/auto-update/index.ts +71 -0
  14. package/.xtrm/extensions/auto-update/package.json +16 -0
  15. package/.xtrm/extensions/beads/index.ts +232 -0
  16. package/.xtrm/extensions/beads/package.json +19 -0
  17. package/.xtrm/extensions/compact-header/index.ts +69 -0
  18. package/.xtrm/extensions/compact-header/package.json +16 -0
  19. package/.xtrm/extensions/core/adapter.ts +52 -0
  20. package/.xtrm/extensions/core/guard-rules.ts +100 -0
  21. package/.xtrm/extensions/core/lib.ts +3 -0
  22. package/.xtrm/extensions/core/logger.ts +45 -0
  23. package/.xtrm/extensions/core/package.json +18 -0
  24. package/.xtrm/extensions/core/runner.ts +71 -0
  25. package/.xtrm/extensions/core/session-state.ts +59 -0
  26. package/.xtrm/extensions/custom-footer/index.ts +398 -0
  27. package/.xtrm/extensions/custom-footer/package.json +19 -0
  28. package/.xtrm/extensions/custom-provider-qwen-cli/index.ts +363 -0
  29. package/.xtrm/extensions/custom-provider-qwen-cli/package.json +1 -0
  30. package/.xtrm/extensions/git-checkpoint/index.ts +53 -0
  31. package/.xtrm/extensions/git-checkpoint/package.json +16 -0
  32. package/.xtrm/extensions/lsp-bootstrap/index.ts +134 -0
  33. package/.xtrm/extensions/lsp-bootstrap/package.json +17 -0
  34. package/.xtrm/extensions/pi-serena-compact/index.ts +121 -0
  35. package/.xtrm/extensions/pi-serena-compact/package.json +16 -0
  36. package/.xtrm/extensions/quality-gates/index.ts +66 -0
  37. package/.xtrm/extensions/quality-gates/package.json +19 -0
  38. package/.xtrm/extensions/service-skills/index.ts +108 -0
  39. package/.xtrm/extensions/service-skills/package.json +19 -0
  40. package/.xtrm/extensions/session-flow/index.ts +96 -0
  41. package/.xtrm/extensions/session-flow/package.json +19 -0
  42. package/.xtrm/extensions/xtrm-loader/index.ts +152 -0
  43. package/.xtrm/extensions/xtrm-loader/package.json +19 -0
  44. package/.xtrm/extensions/xtrm-ui/format.ts +93 -0
  45. package/.xtrm/extensions/xtrm-ui/index.ts +1044 -0
  46. package/.xtrm/extensions/xtrm-ui/package.json +10 -0
  47. package/.xtrm/extensions/xtrm-ui/themes/pidex-dark.json +85 -0
  48. package/.xtrm/extensions/xtrm-ui/themes/pidex-light.json +85 -0
  49. package/{hooks → .xtrm/hooks}/README.md +2 -1
  50. package/{hooks → .xtrm/hooks}/beads-commit-gate.mjs +4 -0
  51. package/.xtrm/hooks/beads-memory-gate.mjs +119 -0
  52. package/{plugins/xtrm-tools → .xtrm}/hooks/quality-check-env.mjs +1 -4
  53. package/.xtrm/hooks/statusline.mjs +156 -0
  54. package/{plugins/xtrm-tools → .xtrm}/hooks/using-xtrm-reminder.mjs +8 -7
  55. package/.xtrm/registry.json +1323 -0
  56. package/CHANGELOG.md +27 -0
  57. package/README.md +3 -1
  58. package/cli/dist/index.cjs +27025 -30731
  59. package/cli/dist/index.cjs.map +1 -1
  60. package/cli/package.json +2 -1
  61. package/package.json +12 -12
  62. package/.claude-plugin/marketplace.json +0 -19
  63. package/.claude-plugin/plugin.json +0 -9
  64. package/config/hooks.json +0 -83
  65. package/config/settings.json +0 -70
  66. package/hooks/beads-memory-gate.mjs +0 -94
  67. package/hooks/quality-check-env.mjs +0 -79
  68. package/hooks/statusline.mjs +0 -183
  69. package/hooks/tsconfig-cache.json +0 -14
  70. package/hooks/using-xtrm-reminder.mjs +0 -47
  71. package/plugins/xtrm-tools/.claude-plugin/plugin.json +0 -9
  72. package/plugins/xtrm-tools/.mcp.json +0 -18
  73. package/plugins/xtrm-tools/hooks/README.md +0 -61
  74. package/plugins/xtrm-tools/hooks/beads-claim-sync.mjs +0 -154
  75. package/plugins/xtrm-tools/hooks/beads-commit-gate.mjs +0 -70
  76. package/plugins/xtrm-tools/hooks/beads-compact-restore.mjs +0 -77
  77. package/plugins/xtrm-tools/hooks/beads-compact-save.mjs +0 -63
  78. package/plugins/xtrm-tools/hooks/beads-edit-gate.mjs +0 -85
  79. package/plugins/xtrm-tools/hooks/beads-gate-core.mjs +0 -236
  80. package/plugins/xtrm-tools/hooks/beads-gate-messages.mjs +0 -75
  81. package/plugins/xtrm-tools/hooks/beads-gate-utils.mjs +0 -176
  82. package/plugins/xtrm-tools/hooks/beads-memory-gate.mjs +0 -94
  83. package/plugins/xtrm-tools/hooks/beads-stop-gate.mjs +0 -53
  84. package/plugins/xtrm-tools/hooks/gitnexus/gitnexus-hook.cjs +0 -222
  85. package/plugins/xtrm-tools/hooks/hooks.json +0 -129
  86. package/plugins/xtrm-tools/hooks/quality-check.cjs +0 -1286
  87. package/plugins/xtrm-tools/hooks/quality-check.py +0 -345
  88. package/plugins/xtrm-tools/hooks/statusline.mjs +0 -183
  89. package/plugins/xtrm-tools/hooks/tsconfig-cache.json +0 -14
  90. package/plugins/xtrm-tools/hooks/worktree-boundary.mjs +0 -33
  91. package/plugins/xtrm-tools/hooks/xtrm-logger.mjs +0 -123
  92. package/plugins/xtrm-tools/hooks/xtrm-session-logger.mjs +0 -27
  93. package/plugins/xtrm-tools/hooks/xtrm-tool-logger.mjs +0 -53
  94. package/plugins/xtrm-tools/skills/README.txt +0 -31
  95. package/plugins/xtrm-tools/skills/clean-code/SKILL.md +0 -201
  96. package/plugins/xtrm-tools/skills/creating-service-skills/SKILL.md +0 -433
  97. package/plugins/xtrm-tools/skills/creating-service-skills/references/script_quality_standards.md +0 -425
  98. package/plugins/xtrm-tools/skills/creating-service-skills/references/service_skill_system_guide.md +0 -278
  99. package/plugins/xtrm-tools/skills/creating-service-skills/scripts/bootstrap.py +0 -326
  100. package/plugins/xtrm-tools/skills/creating-service-skills/scripts/deep_dive.py +0 -304
  101. package/plugins/xtrm-tools/skills/creating-service-skills/scripts/scaffolder.py +0 -482
  102. package/plugins/xtrm-tools/skills/delegating/SKILL.md +0 -196
  103. package/plugins/xtrm-tools/skills/delegating/config.yaml +0 -210
  104. package/plugins/xtrm-tools/skills/delegating/references/orchestration-protocols.md +0 -41
  105. package/plugins/xtrm-tools/skills/docker-expert/SKILL.md +0 -409
  106. package/plugins/xtrm-tools/skills/documenting/CHANGELOG.md +0 -23
  107. package/plugins/xtrm-tools/skills/documenting/README.md +0 -148
  108. package/plugins/xtrm-tools/skills/documenting/SKILL.md +0 -113
  109. package/plugins/xtrm-tools/skills/documenting/examples/example_pattern.md +0 -70
  110. package/plugins/xtrm-tools/skills/documenting/examples/example_reference.md +0 -70
  111. package/plugins/xtrm-tools/skills/documenting/examples/example_ssot_analytics.md +0 -64
  112. package/plugins/xtrm-tools/skills/documenting/examples/example_workflow.md +0 -141
  113. package/plugins/xtrm-tools/skills/documenting/references/changelog-format.md +0 -97
  114. package/plugins/xtrm-tools/skills/documenting/references/metadata-schema.md +0 -136
  115. package/plugins/xtrm-tools/skills/documenting/references/taxonomy.md +0 -81
  116. package/plugins/xtrm-tools/skills/documenting/references/versioning-rules.md +0 -78
  117. package/plugins/xtrm-tools/skills/documenting/scripts/bump_version.sh +0 -60
  118. package/plugins/xtrm-tools/skills/documenting/scripts/changelog/__init__.py +0 -0
  119. package/plugins/xtrm-tools/skills/documenting/scripts/changelog/add_entry.py +0 -216
  120. package/plugins/xtrm-tools/skills/documenting/scripts/changelog/bump_release.py +0 -117
  121. package/plugins/xtrm-tools/skills/documenting/scripts/changelog/init_changelog.py +0 -54
  122. package/plugins/xtrm-tools/skills/documenting/scripts/changelog/validate_changelog.py +0 -128
  123. package/plugins/xtrm-tools/skills/documenting/scripts/drift_detector.py +0 -266
  124. package/plugins/xtrm-tools/skills/documenting/scripts/generate_template.py +0 -311
  125. package/plugins/xtrm-tools/skills/documenting/scripts/list_by_category.sh +0 -84
  126. package/plugins/xtrm-tools/skills/documenting/scripts/orchestrator.py +0 -255
  127. package/plugins/xtrm-tools/skills/documenting/scripts/validate_metadata.py +0 -242
  128. package/plugins/xtrm-tools/skills/documenting/templates/CHANGELOG.md.template +0 -13
  129. package/plugins/xtrm-tools/skills/documenting/tests/integration_test.sh +0 -70
  130. package/plugins/xtrm-tools/skills/documenting/tests/test_changelog.py +0 -201
  131. package/plugins/xtrm-tools/skills/documenting/tests/test_drift_detector.py +0 -80
  132. package/plugins/xtrm-tools/skills/documenting/tests/test_orchestrator.py +0 -52
  133. package/plugins/xtrm-tools/skills/documenting/tests/test_validate_metadata.py +0 -64
  134. package/plugins/xtrm-tools/skills/find-skills/SKILL.md +0 -133
  135. package/plugins/xtrm-tools/skills/gitnexus-exploring/SKILL.md +0 -75
  136. package/plugins/xtrm-tools/skills/gitnexus-impact-analysis/SKILL.md +0 -94
  137. package/plugins/xtrm-tools/skills/gitnexus-refactoring/SKILL.md +0 -113
  138. package/plugins/xtrm-tools/skills/hook-development/SKILL.md +0 -797
  139. package/plugins/xtrm-tools/skills/hook-development/examples/load-context.sh +0 -55
  140. package/plugins/xtrm-tools/skills/hook-development/examples/quality-check.js +0 -1168
  141. package/plugins/xtrm-tools/skills/hook-development/examples/validate-bash.sh +0 -43
  142. package/plugins/xtrm-tools/skills/hook-development/examples/validate-write.sh +0 -38
  143. package/plugins/xtrm-tools/skills/hook-development/references/advanced.md +0 -527
  144. package/plugins/xtrm-tools/skills/hook-development/references/migration.md +0 -369
  145. package/plugins/xtrm-tools/skills/hook-development/references/patterns.md +0 -412
  146. package/plugins/xtrm-tools/skills/hook-development/scripts/README.md +0 -164
  147. package/plugins/xtrm-tools/skills/hook-development/scripts/hook-linter.sh +0 -153
  148. package/plugins/xtrm-tools/skills/hook-development/scripts/test-hook.sh +0 -252
  149. package/plugins/xtrm-tools/skills/hook-development/scripts/validate-hook-schema.sh +0 -159
  150. package/plugins/xtrm-tools/skills/obsidian-cli/SKILL.md +0 -106
  151. package/plugins/xtrm-tools/skills/orchestrating-agents/SKILL.md +0 -135
  152. package/plugins/xtrm-tools/skills/orchestrating-agents/config.yaml +0 -45
  153. package/plugins/xtrm-tools/skills/orchestrating-agents/references/agent-context-integration.md +0 -37
  154. package/plugins/xtrm-tools/skills/orchestrating-agents/references/examples.md +0 -45
  155. package/plugins/xtrm-tools/skills/orchestrating-agents/references/handover-protocol.md +0 -31
  156. package/plugins/xtrm-tools/skills/orchestrating-agents/references/workflows.md +0 -42
  157. package/plugins/xtrm-tools/skills/orchestrating-agents/scripts/detect_neighbors.py +0 -23
  158. package/plugins/xtrm-tools/skills/planning/SKILL.md +0 -405
  159. package/plugins/xtrm-tools/skills/planning/evals/evals.json +0 -19
  160. package/plugins/xtrm-tools/skills/prompt-improving/README.md +0 -162
  161. package/plugins/xtrm-tools/skills/prompt-improving/SKILL.md +0 -74
  162. package/plugins/xtrm-tools/skills/prompt-improving/references/analysis_commands.md +0 -24
  163. package/plugins/xtrm-tools/skills/prompt-improving/references/chain_of_thought.md +0 -24
  164. package/plugins/xtrm-tools/skills/prompt-improving/references/mcp_definitions.md +0 -20
  165. package/plugins/xtrm-tools/skills/prompt-improving/references/multishot.md +0 -23
  166. package/plugins/xtrm-tools/skills/prompt-improving/references/xml_core.md +0 -60
  167. package/plugins/xtrm-tools/skills/python-testing/SKILL.md +0 -815
  168. package/plugins/xtrm-tools/skills/scoping-service-skills/SKILL.md +0 -231
  169. package/plugins/xtrm-tools/skills/scoping-service-skills/scripts/scope.py +0 -74
  170. package/plugins/xtrm-tools/skills/senior-backend/SKILL.md +0 -209
  171. package/plugins/xtrm-tools/skills/senior-backend/references/api_design_patterns.md +0 -103
  172. package/plugins/xtrm-tools/skills/senior-backend/references/backend_security_practices.md +0 -103
  173. package/plugins/xtrm-tools/skills/senior-backend/references/database_optimization_guide.md +0 -103
  174. package/plugins/xtrm-tools/skills/senior-backend/scripts/api_load_tester.py +0 -114
  175. package/plugins/xtrm-tools/skills/senior-backend/scripts/api_scaffolder.py +0 -114
  176. package/plugins/xtrm-tools/skills/senior-backend/scripts/database_migration_tool.py +0 -114
  177. package/plugins/xtrm-tools/skills/senior-data-scientist/SKILL.md +0 -226
  178. package/plugins/xtrm-tools/skills/senior-data-scientist/references/experiment_design_frameworks.md +0 -80
  179. package/plugins/xtrm-tools/skills/senior-data-scientist/references/feature_engineering_patterns.md +0 -80
  180. package/plugins/xtrm-tools/skills/senior-data-scientist/references/statistical_methods_advanced.md +0 -80
  181. package/plugins/xtrm-tools/skills/senior-data-scientist/scripts/experiment_designer.py +0 -100
  182. package/plugins/xtrm-tools/skills/senior-data-scientist/scripts/feature_engineering_pipeline.py +0 -100
  183. package/plugins/xtrm-tools/skills/senior-data-scientist/scripts/model_evaluation_suite.py +0 -100
  184. package/plugins/xtrm-tools/skills/senior-devops/SKILL.md +0 -209
  185. package/plugins/xtrm-tools/skills/senior-devops/references/cicd_pipeline_guide.md +0 -103
  186. package/plugins/xtrm-tools/skills/senior-devops/references/deployment_strategies.md +0 -103
  187. package/plugins/xtrm-tools/skills/senior-devops/references/infrastructure_as_code.md +0 -103
  188. package/plugins/xtrm-tools/skills/senior-devops/scripts/deployment_manager.py +0 -114
  189. package/plugins/xtrm-tools/skills/senior-devops/scripts/pipeline_generator.py +0 -114
  190. package/plugins/xtrm-tools/skills/senior-devops/scripts/terraform_scaffolder.py +0 -114
  191. package/plugins/xtrm-tools/skills/senior-security/SKILL.md +0 -209
  192. package/plugins/xtrm-tools/skills/senior-security/references/cryptography_implementation.md +0 -103
  193. package/plugins/xtrm-tools/skills/senior-security/references/penetration_testing_guide.md +0 -103
  194. package/plugins/xtrm-tools/skills/senior-security/references/security_architecture_patterns.md +0 -103
  195. package/plugins/xtrm-tools/skills/senior-security/scripts/pentest_automator.py +0 -114
  196. package/plugins/xtrm-tools/skills/senior-security/scripts/security_auditor.py +0 -114
  197. package/plugins/xtrm-tools/skills/senior-security/scripts/threat_modeler.py +0 -114
  198. package/plugins/xtrm-tools/skills/skill-creator/LICENSE.txt +0 -202
  199. package/plugins/xtrm-tools/skills/skill-creator/SKILL.md +0 -479
  200. package/plugins/xtrm-tools/skills/skill-creator/agents/analyzer.md +0 -274
  201. package/plugins/xtrm-tools/skills/skill-creator/agents/comparator.md +0 -202
  202. package/plugins/xtrm-tools/skills/skill-creator/agents/grader.md +0 -223
  203. package/plugins/xtrm-tools/skills/skill-creator/assets/eval_review.html +0 -146
  204. package/plugins/xtrm-tools/skills/skill-creator/eval-viewer/generate_review.py +0 -471
  205. package/plugins/xtrm-tools/skills/skill-creator/eval-viewer/viewer.html +0 -1325
  206. package/plugins/xtrm-tools/skills/skill-creator/references/schemas.md +0 -430
  207. package/plugins/xtrm-tools/skills/skill-creator/scripts/__init__.py +0 -0
  208. package/plugins/xtrm-tools/skills/skill-creator/scripts/aggregate_benchmark.py +0 -401
  209. package/plugins/xtrm-tools/skills/skill-creator/scripts/generate_report.py +0 -326
  210. package/plugins/xtrm-tools/skills/skill-creator/scripts/improve_description.py +0 -248
  211. package/plugins/xtrm-tools/skills/skill-creator/scripts/package_skill.py +0 -136
  212. package/plugins/xtrm-tools/skills/skill-creator/scripts/quick_validate.py +0 -103
  213. package/plugins/xtrm-tools/skills/skill-creator/scripts/run_eval.py +0 -310
  214. package/plugins/xtrm-tools/skills/skill-creator/scripts/run_loop.py +0 -332
  215. package/plugins/xtrm-tools/skills/skill-creator/scripts/utils.py +0 -47
  216. package/plugins/xtrm-tools/skills/sync-docs/SKILL.md +0 -286
  217. package/plugins/xtrm-tools/skills/sync-docs/evals/evals.json +0 -89
  218. package/plugins/xtrm-tools/skills/sync-docs/references/doc-structure.md +0 -99
  219. package/plugins/xtrm-tools/skills/sync-docs/references/schema.md +0 -103
  220. package/plugins/xtrm-tools/skills/sync-docs/scripts/changelog/add_entry.py +0 -216
  221. package/plugins/xtrm-tools/skills/sync-docs/scripts/context_gatherer.py +0 -240
  222. package/plugins/xtrm-tools/skills/sync-docs/scripts/doc_structure_analyzer.py +0 -495
  223. package/plugins/xtrm-tools/skills/sync-docs/scripts/drift_detector.py +0 -563
  224. package/plugins/xtrm-tools/skills/sync-docs/scripts/validate_doc.py +0 -365
  225. package/plugins/xtrm-tools/skills/sync-docs/scripts/validate_metadata.py +0 -185
  226. package/plugins/xtrm-tools/skills/sync-docs-workspace/iteration-1/benchmark.json +0 -293
  227. package/plugins/xtrm-tools/skills/sync-docs-workspace/iteration-1/benchmark.md +0 -13
  228. package/plugins/xtrm-tools/skills/sync-docs-workspace/iteration-1/eval-doc-audit/eval_metadata.json +0 -27
  229. package/plugins/xtrm-tools/skills/sync-docs-workspace/iteration-1/eval-doc-audit/with_skill/outputs/result.md +0 -210
  230. package/plugins/xtrm-tools/skills/sync-docs-workspace/iteration-1/eval-doc-audit/with_skill/run-1/grading.json +0 -28
  231. package/plugins/xtrm-tools/skills/sync-docs-workspace/iteration-1/eval-doc-audit/with_skill/run-1/timing.json +0 -1
  232. package/plugins/xtrm-tools/skills/sync-docs-workspace/iteration-1/eval-doc-audit/without_skill/outputs/result.md +0 -101
  233. package/plugins/xtrm-tools/skills/sync-docs-workspace/iteration-1/eval-doc-audit/without_skill/run-1/grading.json +0 -28
  234. package/plugins/xtrm-tools/skills/sync-docs-workspace/iteration-1/eval-doc-audit/without_skill/run-1/timing.json +0 -5
  235. package/plugins/xtrm-tools/skills/sync-docs-workspace/iteration-1/eval-doc-audit/without_skill/timing.json +0 -5
  236. package/plugins/xtrm-tools/skills/sync-docs-workspace/iteration-1/eval-fix-mode/eval_metadata.json +0 -27
  237. package/plugins/xtrm-tools/skills/sync-docs-workspace/iteration-1/eval-fix-mode/with_skill/outputs/result.md +0 -198
  238. package/plugins/xtrm-tools/skills/sync-docs-workspace/iteration-1/eval-fix-mode/with_skill/run-1/grading.json +0 -28
  239. package/plugins/xtrm-tools/skills/sync-docs-workspace/iteration-1/eval-fix-mode/with_skill/run-1/timing.json +0 -1
  240. package/plugins/xtrm-tools/skills/sync-docs-workspace/iteration-1/eval-fix-mode/without_skill/outputs/result.md +0 -94
  241. package/plugins/xtrm-tools/skills/sync-docs-workspace/iteration-1/eval-fix-mode/without_skill/run-1/grading.json +0 -28
  242. package/plugins/xtrm-tools/skills/sync-docs-workspace/iteration-1/eval-fix-mode/without_skill/run-1/timing.json +0 -1
  243. package/plugins/xtrm-tools/skills/sync-docs-workspace/iteration-1/eval-sprint-closeout/eval_metadata.json +0 -27
  244. package/plugins/xtrm-tools/skills/sync-docs-workspace/iteration-1/eval-sprint-closeout/with_skill/outputs/result.md +0 -237
  245. package/plugins/xtrm-tools/skills/sync-docs-workspace/iteration-1/eval-sprint-closeout/with_skill/run-1/grading.json +0 -28
  246. package/plugins/xtrm-tools/skills/sync-docs-workspace/iteration-1/eval-sprint-closeout/with_skill/run-1/timing.json +0 -1
  247. package/plugins/xtrm-tools/skills/sync-docs-workspace/iteration-1/eval-sprint-closeout/without_skill/outputs/result.md +0 -134
  248. package/plugins/xtrm-tools/skills/sync-docs-workspace/iteration-1/eval-sprint-closeout/without_skill/run-1/grading.json +0 -28
  249. package/plugins/xtrm-tools/skills/sync-docs-workspace/iteration-1/eval-sprint-closeout/without_skill/run-1/timing.json +0 -1
  250. package/plugins/xtrm-tools/skills/sync-docs-workspace/iteration-2/benchmark.json +0 -297
  251. package/plugins/xtrm-tools/skills/sync-docs-workspace/iteration-2/benchmark.md +0 -13
  252. package/plugins/xtrm-tools/skills/sync-docs-workspace/iteration-2/eval-doc-audit/eval_metadata.json +0 -27
  253. package/plugins/xtrm-tools/skills/sync-docs-workspace/iteration-2/eval-doc-audit/with_skill/outputs/result.md +0 -137
  254. package/plugins/xtrm-tools/skills/sync-docs-workspace/iteration-2/eval-doc-audit/with_skill/run-1/grading.json +0 -92
  255. package/plugins/xtrm-tools/skills/sync-docs-workspace/iteration-2/eval-doc-audit/with_skill/run-1/timing.json +0 -1
  256. package/plugins/xtrm-tools/skills/sync-docs-workspace/iteration-2/eval-doc-audit/without_skill/outputs/result.md +0 -134
  257. package/plugins/xtrm-tools/skills/sync-docs-workspace/iteration-2/eval-doc-audit/without_skill/run-1/grading.json +0 -86
  258. package/plugins/xtrm-tools/skills/sync-docs-workspace/iteration-2/eval-doc-audit/without_skill/run-1/timing.json +0 -1
  259. package/plugins/xtrm-tools/skills/sync-docs-workspace/iteration-2/eval-fix-mode/eval_metadata.json +0 -27
  260. package/plugins/xtrm-tools/skills/sync-docs-workspace/iteration-2/eval-fix-mode/with_skill/outputs/result.md +0 -193
  261. package/plugins/xtrm-tools/skills/sync-docs-workspace/iteration-2/eval-fix-mode/with_skill/run-1/grading.json +0 -72
  262. package/plugins/xtrm-tools/skills/sync-docs-workspace/iteration-2/eval-fix-mode/with_skill/run-1/timing.json +0 -1
  263. package/plugins/xtrm-tools/skills/sync-docs-workspace/iteration-2/eval-fix-mode/without_skill/outputs/result.md +0 -211
  264. package/plugins/xtrm-tools/skills/sync-docs-workspace/iteration-2/eval-fix-mode/without_skill/run-1/grading.json +0 -91
  265. package/plugins/xtrm-tools/skills/sync-docs-workspace/iteration-2/eval-fix-mode/without_skill/run-1/timing.json +0 -5
  266. package/plugins/xtrm-tools/skills/sync-docs-workspace/iteration-2/eval-sprint-closeout/eval_metadata.json +0 -27
  267. package/plugins/xtrm-tools/skills/sync-docs-workspace/iteration-2/eval-sprint-closeout/with_skill/outputs/result.md +0 -182
  268. package/plugins/xtrm-tools/skills/sync-docs-workspace/iteration-2/eval-sprint-closeout/with_skill/run-1/grading.json +0 -95
  269. package/plugins/xtrm-tools/skills/sync-docs-workspace/iteration-2/eval-sprint-closeout/with_skill/run-1/timing.json +0 -1
  270. package/plugins/xtrm-tools/skills/sync-docs-workspace/iteration-2/eval-sprint-closeout/without_skill/outputs/result.md +0 -222
  271. package/plugins/xtrm-tools/skills/sync-docs-workspace/iteration-2/eval-sprint-closeout/without_skill/run-1/grading.json +0 -88
  272. package/plugins/xtrm-tools/skills/sync-docs-workspace/iteration-2/eval-sprint-closeout/without_skill/run-1/timing.json +0 -5
  273. package/plugins/xtrm-tools/skills/sync-docs-workspace/iteration-3/benchmark.json +0 -298
  274. package/plugins/xtrm-tools/skills/sync-docs-workspace/iteration-3/benchmark.md +0 -13
  275. package/plugins/xtrm-tools/skills/sync-docs-workspace/iteration-3/eval-doc-audit/eval_metadata.json +0 -27
  276. package/plugins/xtrm-tools/skills/sync-docs-workspace/iteration-3/eval-doc-audit/with_skill/outputs/result.md +0 -125
  277. package/plugins/xtrm-tools/skills/sync-docs-workspace/iteration-3/eval-doc-audit/with_skill/run-1/grading.json +0 -97
  278. package/plugins/xtrm-tools/skills/sync-docs-workspace/iteration-3/eval-doc-audit/with_skill/run-1/timing.json +0 -5
  279. package/plugins/xtrm-tools/skills/sync-docs-workspace/iteration-3/eval-doc-audit/without_skill/outputs/result.md +0 -144
  280. package/plugins/xtrm-tools/skills/sync-docs-workspace/iteration-3/eval-doc-audit/without_skill/run-1/grading.json +0 -78
  281. package/plugins/xtrm-tools/skills/sync-docs-workspace/iteration-3/eval-doc-audit/without_skill/run-1/timing.json +0 -5
  282. package/plugins/xtrm-tools/skills/sync-docs-workspace/iteration-3/eval-fix-mode/eval_metadata.json +0 -27
  283. package/plugins/xtrm-tools/skills/sync-docs-workspace/iteration-3/eval-fix-mode/with_skill/outputs/result.md +0 -104
  284. package/plugins/xtrm-tools/skills/sync-docs-workspace/iteration-3/eval-fix-mode/with_skill/run-1/grading.json +0 -91
  285. package/plugins/xtrm-tools/skills/sync-docs-workspace/iteration-3/eval-fix-mode/with_skill/run-1/timing.json +0 -5
  286. package/plugins/xtrm-tools/skills/sync-docs-workspace/iteration-3/eval-fix-mode/without_skill/outputs/result.md +0 -79
  287. package/plugins/xtrm-tools/skills/sync-docs-workspace/iteration-3/eval-fix-mode/without_skill/run-1/grading.json +0 -82
  288. package/plugins/xtrm-tools/skills/sync-docs-workspace/iteration-3/eval-fix-mode/without_skill/run-1/timing.json +0 -5
  289. package/plugins/xtrm-tools/skills/sync-docs-workspace/iteration-3/eval-sprint-closeout/eval_metadata.json +0 -27
  290. package/plugins/xtrm-tools/skills/sync-docs-workspace/iteration-3/eval-sprint-closeout/with_skill/outputs/phase1_context.json +0 -302
  291. package/plugins/xtrm-tools/skills/sync-docs-workspace/iteration-3/eval-sprint-closeout/with_skill/outputs/phase2_drift.txt +0 -33
  292. package/plugins/xtrm-tools/skills/sync-docs-workspace/iteration-3/eval-sprint-closeout/with_skill/outputs/phase3_analysis.json +0 -114
  293. package/plugins/xtrm-tools/skills/sync-docs-workspace/iteration-3/eval-sprint-closeout/with_skill/outputs/phase4_fix.txt +0 -118
  294. package/plugins/xtrm-tools/skills/sync-docs-workspace/iteration-3/eval-sprint-closeout/with_skill/outputs/phase5_validate.txt +0 -38
  295. package/plugins/xtrm-tools/skills/sync-docs-workspace/iteration-3/eval-sprint-closeout/with_skill/outputs/result.md +0 -158
  296. package/plugins/xtrm-tools/skills/sync-docs-workspace/iteration-3/eval-sprint-closeout/with_skill/run-1/grading.json +0 -95
  297. package/plugins/xtrm-tools/skills/sync-docs-workspace/iteration-3/eval-sprint-closeout/with_skill/run-1/timing.json +0 -5
  298. package/plugins/xtrm-tools/skills/sync-docs-workspace/iteration-3/eval-sprint-closeout/without_skill/outputs/result.md +0 -71
  299. package/plugins/xtrm-tools/skills/sync-docs-workspace/iteration-3/eval-sprint-closeout/without_skill/run-1/grading.json +0 -90
  300. package/plugins/xtrm-tools/skills/sync-docs-workspace/iteration-3/eval-sprint-closeout/without_skill/run-1/timing.json +0 -5
  301. package/plugins/xtrm-tools/skills/test-planning/SKILL.md +0 -465
  302. package/plugins/xtrm-tools/skills/test-planning/evals/evals.json +0 -23
  303. package/plugins/xtrm-tools/skills/updating-service-skills/SKILL.md +0 -136
  304. package/plugins/xtrm-tools/skills/updating-service-skills/scripts/drift_detector.py +0 -222
  305. package/plugins/xtrm-tools/skills/using-quality-gates/SKILL.md +0 -254
  306. package/plugins/xtrm-tools/skills/using-serena-lsp/README.md +0 -8
  307. package/plugins/xtrm-tools/skills/using-serena-lsp/REFERENCE.md +0 -194
  308. package/plugins/xtrm-tools/skills/using-serena-lsp/SKILL.md +0 -82
  309. package/plugins/xtrm-tools/skills/using-service-skills/SKILL.md +0 -108
  310. package/plugins/xtrm-tools/skills/using-service-skills/scripts/cataloger.py +0 -74
  311. package/plugins/xtrm-tools/skills/using-service-skills/scripts/skill_activator.py +0 -152
  312. package/plugins/xtrm-tools/skills/using-service-skills/scripts/test_skill_activator.py +0 -58
  313. package/plugins/xtrm-tools/skills/using-tdd/SKILL.md +0 -410
  314. package/plugins/xtrm-tools/skills/using-xtrm/SKILL.md +0 -127
  315. package/plugins/xtrm-tools/skills/xt-debugging/SKILL.md +0 -149
  316. package/plugins/xtrm-tools/skills/xt-end/SKILL.md +0 -297
  317. package/plugins/xtrm-tools/skills/xt-merge/SKILL.md +0 -313
  318. package/project-skills/quality-gates/.claude/hooks/hook-config.json +0 -66
  319. package/project-skills/quality-gates/.claude/hooks/quality-check.cjs +0 -1286
  320. package/project-skills/quality-gates/.claude/hooks/quality-check.py +0 -334
  321. package/project-skills/quality-gates/.claude/settings.json +0 -3
  322. package/project-skills/quality-gates/.claude/skills/using-quality-gates/SKILL.md +0 -254
  323. package/project-skills/quality-gates/README.md +0 -109
  324. package/project-skills/quality-gates/evals/evals.json +0 -181
  325. package/project-skills/quality-gates/workspace/iteration-1/FINAL-EVAL-SUMMARY.md +0 -75
  326. package/project-skills/quality-gates/workspace/iteration-1/edge-case-auto-fix-verification/with_skill/outputs/response.md +0 -59
  327. package/project-skills/quality-gates/workspace/iteration-1/edge-case-mixed-language-project/with_skill/outputs/response.md +0 -60
  328. package/project-skills/quality-gates/workspace/iteration-1/eval-summary.md +0 -105
  329. package/project-skills/quality-gates/workspace/iteration-1/partial-install-python-only/with_skill/outputs/response.md +0 -93
  330. package/project-skills/quality-gates/workspace/iteration-1/python-refactor-request/with_skill/outputs/response.md +0 -104
  331. package/project-skills/quality-gates/workspace/iteration-1/quality-gate-error-fix/with_skill/outputs/response.md +0 -74
  332. package/project-skills/quality-gates/workspace/iteration-1/should-not-trigger-general-chat/with_skill/outputs/response.md +0 -18
  333. package/project-skills/quality-gates/workspace/iteration-1/should-not-trigger-math-question/with_skill/outputs/response.md +0 -18
  334. package/project-skills/quality-gates/workspace/iteration-1/should-not-trigger-unrelated-coding/with_skill/outputs/response.md +0 -56
  335. package/project-skills/quality-gates/workspace/iteration-1/tdd-guard-blocking-confusion/with_skill/outputs/response.md +0 -67
  336. package/project-skills/quality-gates/workspace/iteration-1/typescript-feature-with-tests/with_skill/outputs/response.md +0 -97
  337. package/project-skills/service-skills-set/.claude/git-hooks/doc_reminder.py +0 -67
  338. package/project-skills/service-skills-set/.claude/git-hooks/skill_staleness.py +0 -194
  339. package/project-skills/service-skills-set/.claude/service-registry.json +0 -4
  340. package/project-skills/service-skills-set/.claude/settings.json +0 -37
  341. package/project-skills/service-skills-set/.claude/skills/creating-service-skills/SKILL.md +0 -433
  342. package/project-skills/service-skills-set/.claude/skills/creating-service-skills/references/script_quality_standards.md +0 -425
  343. package/project-skills/service-skills-set/.claude/skills/creating-service-skills/references/service_skill_system_guide.md +0 -278
  344. package/project-skills/service-skills-set/.claude/skills/creating-service-skills/scripts/bootstrap.py +0 -308
  345. package/project-skills/service-skills-set/.claude/skills/creating-service-skills/scripts/deep_dive.py +0 -304
  346. package/project-skills/service-skills-set/.claude/skills/creating-service-skills/scripts/scaffolder.py +0 -482
  347. package/project-skills/service-skills-set/.claude/skills/scoping-service-skills/SKILL.md +0 -231
  348. package/project-skills/service-skills-set/.claude/skills/scoping-service-skills/scripts/scope.py +0 -74
  349. package/project-skills/service-skills-set/.claude/skills/updating-service-skills/SKILL.md +0 -136
  350. package/project-skills/service-skills-set/.claude/skills/updating-service-skills/scripts/drift_detector.py +0 -222
  351. package/project-skills/service-skills-set/.claude/skills/using-service-skills/SKILL.md +0 -108
  352. package/project-skills/service-skills-set/.claude/skills/using-service-skills/scripts/cataloger.py +0 -74
  353. package/project-skills/service-skills-set/.claude/skills/using-service-skills/scripts/skill_activator.py +0 -152
  354. package/project-skills/service-skills-set/README.md +0 -93
  355. package/project-skills/service-skills-set/install-service-skills.py +0 -193
  356. package/project-skills/service-skills-set/service-skills-readme.md +0 -236
  357. package/skills/README.txt +0 -31
  358. package/skills/clean-code/SKILL.md +0 -201
  359. package/skills/creating-service-skills/SKILL.md +0 -433
  360. package/skills/creating-service-skills/references/script_quality_standards.md +0 -425
  361. package/skills/creating-service-skills/references/service_skill_system_guide.md +0 -278
  362. package/skills/creating-service-skills/scripts/bootstrap.py +0 -326
  363. package/skills/creating-service-skills/scripts/deep_dive.py +0 -304
  364. package/skills/creating-service-skills/scripts/scaffolder.py +0 -482
  365. package/skills/delegating/SKILL.md +0 -196
  366. package/skills/delegating/config.yaml +0 -210
  367. package/skills/delegating/references/orchestration-protocols.md +0 -41
  368. package/skills/docker-expert/SKILL.md +0 -409
  369. package/skills/documenting/CHANGELOG.md +0 -23
  370. package/skills/documenting/README.md +0 -148
  371. package/skills/documenting/SKILL.md +0 -113
  372. package/skills/documenting/examples/example_pattern.md +0 -70
  373. package/skills/documenting/examples/example_reference.md +0 -70
  374. package/skills/documenting/examples/example_ssot_analytics.md +0 -64
  375. package/skills/documenting/examples/example_workflow.md +0 -141
  376. package/skills/documenting/references/changelog-format.md +0 -97
  377. package/skills/documenting/references/metadata-schema.md +0 -136
  378. package/skills/documenting/references/taxonomy.md +0 -81
  379. package/skills/documenting/references/versioning-rules.md +0 -78
  380. package/skills/documenting/scripts/bump_version.sh +0 -60
  381. package/skills/documenting/scripts/changelog/__init__.py +0 -0
  382. package/skills/documenting/scripts/changelog/add_entry.py +0 -216
  383. package/skills/documenting/scripts/changelog/bump_release.py +0 -117
  384. package/skills/documenting/scripts/changelog/init_changelog.py +0 -54
  385. package/skills/documenting/scripts/changelog/validate_changelog.py +0 -128
  386. package/skills/documenting/scripts/drift_detector.py +0 -266
  387. package/skills/documenting/scripts/generate_template.py +0 -311
  388. package/skills/documenting/scripts/list_by_category.sh +0 -84
  389. package/skills/documenting/scripts/orchestrator.py +0 -255
  390. package/skills/documenting/scripts/validate_metadata.py +0 -242
  391. package/skills/documenting/templates/CHANGELOG.md.template +0 -13
  392. package/skills/find-skills/SKILL.md +0 -133
  393. package/skills/gitnexus-exploring/SKILL.md +0 -75
  394. package/skills/gitnexus-impact-analysis/SKILL.md +0 -94
  395. package/skills/gitnexus-refactoring/SKILL.md +0 -113
  396. package/skills/hook-development/SKILL.md +0 -797
  397. package/skills/hook-development/examples/load-context.sh +0 -55
  398. package/skills/hook-development/examples/quality-check.js +0 -1168
  399. package/skills/hook-development/examples/validate-bash.sh +0 -43
  400. package/skills/hook-development/examples/validate-write.sh +0 -38
  401. package/skills/hook-development/references/advanced.md +0 -527
  402. package/skills/hook-development/references/migration.md +0 -369
  403. package/skills/hook-development/references/patterns.md +0 -412
  404. package/skills/hook-development/scripts/README.md +0 -164
  405. package/skills/hook-development/scripts/hook-linter.sh +0 -153
  406. package/skills/hook-development/scripts/test-hook.sh +0 -252
  407. package/skills/hook-development/scripts/validate-hook-schema.sh +0 -159
  408. package/skills/obsidian-cli/SKILL.md +0 -106
  409. package/skills/orchestrating-agents/SKILL.md +0 -135
  410. package/skills/orchestrating-agents/config.yaml +0 -45
  411. package/skills/orchestrating-agents/references/agent-context-integration.md +0 -37
  412. package/skills/orchestrating-agents/references/examples.md +0 -45
  413. package/skills/orchestrating-agents/references/handover-protocol.md +0 -31
  414. package/skills/orchestrating-agents/references/workflows.md +0 -42
  415. package/skills/orchestrating-agents/scripts/detect_neighbors.py +0 -23
  416. package/skills/planning/SKILL.md +0 -405
  417. package/skills/planning/evals/evals.json +0 -19
  418. package/skills/prompt-improving/README.md +0 -162
  419. package/skills/prompt-improving/SKILL.md +0 -74
  420. package/skills/prompt-improving/references/analysis_commands.md +0 -24
  421. package/skills/prompt-improving/references/chain_of_thought.md +0 -24
  422. package/skills/prompt-improving/references/mcp_definitions.md +0 -20
  423. package/skills/prompt-improving/references/multishot.md +0 -23
  424. package/skills/prompt-improving/references/xml_core.md +0 -60
  425. package/skills/python-testing/SKILL.md +0 -815
  426. package/skills/scoping-service-skills/SKILL.md +0 -231
  427. package/skills/scoping-service-skills/scripts/scope.py +0 -74
  428. package/skills/senior-backend/SKILL.md +0 -209
  429. package/skills/senior-backend/references/api_design_patterns.md +0 -103
  430. package/skills/senior-backend/references/backend_security_practices.md +0 -103
  431. package/skills/senior-backend/references/database_optimization_guide.md +0 -103
  432. package/skills/senior-backend/scripts/api_load_tester.py +0 -114
  433. package/skills/senior-backend/scripts/api_scaffolder.py +0 -114
  434. package/skills/senior-backend/scripts/database_migration_tool.py +0 -114
  435. package/skills/senior-data-scientist/SKILL.md +0 -226
  436. package/skills/senior-data-scientist/references/experiment_design_frameworks.md +0 -80
  437. package/skills/senior-data-scientist/references/feature_engineering_patterns.md +0 -80
  438. package/skills/senior-data-scientist/references/statistical_methods_advanced.md +0 -80
  439. package/skills/senior-data-scientist/scripts/experiment_designer.py +0 -100
  440. package/skills/senior-data-scientist/scripts/feature_engineering_pipeline.py +0 -100
  441. package/skills/senior-data-scientist/scripts/model_evaluation_suite.py +0 -100
  442. package/skills/senior-devops/SKILL.md +0 -209
  443. package/skills/senior-devops/references/cicd_pipeline_guide.md +0 -103
  444. package/skills/senior-devops/references/deployment_strategies.md +0 -103
  445. package/skills/senior-devops/references/infrastructure_as_code.md +0 -103
  446. package/skills/senior-devops/scripts/deployment_manager.py +0 -114
  447. package/skills/senior-devops/scripts/pipeline_generator.py +0 -114
  448. package/skills/senior-devops/scripts/terraform_scaffolder.py +0 -114
  449. package/skills/senior-security/SKILL.md +0 -209
  450. package/skills/senior-security/references/cryptography_implementation.md +0 -103
  451. package/skills/senior-security/references/penetration_testing_guide.md +0 -103
  452. package/skills/senior-security/references/security_architecture_patterns.md +0 -103
  453. package/skills/senior-security/scripts/pentest_automator.py +0 -114
  454. package/skills/senior-security/scripts/security_auditor.py +0 -114
  455. package/skills/senior-security/scripts/threat_modeler.py +0 -114
  456. package/skills/skill-creator/LICENSE.txt +0 -202
  457. package/skills/skill-creator/SKILL.md +0 -479
  458. package/skills/skill-creator/agents/analyzer.md +0 -274
  459. package/skills/skill-creator/agents/comparator.md +0 -202
  460. package/skills/skill-creator/agents/grader.md +0 -223
  461. package/skills/skill-creator/assets/eval_review.html +0 -146
  462. package/skills/skill-creator/eval-viewer/generate_review.py +0 -471
  463. package/skills/skill-creator/eval-viewer/viewer.html +0 -1325
  464. package/skills/skill-creator/references/schemas.md +0 -430
  465. package/skills/skill-creator/scripts/__init__.py +0 -0
  466. package/skills/skill-creator/scripts/aggregate_benchmark.py +0 -401
  467. package/skills/skill-creator/scripts/generate_report.py +0 -326
  468. package/skills/skill-creator/scripts/improve_description.py +0 -248
  469. package/skills/skill-creator/scripts/package_skill.py +0 -136
  470. package/skills/skill-creator/scripts/quick_validate.py +0 -103
  471. package/skills/skill-creator/scripts/run_eval.py +0 -310
  472. package/skills/skill-creator/scripts/run_loop.py +0 -332
  473. package/skills/skill-creator/scripts/utils.py +0 -47
  474. package/skills/sync-docs/SKILL.md +0 -286
  475. package/skills/sync-docs/evals/evals.json +0 -89
  476. package/skills/sync-docs/references/doc-structure.md +0 -99
  477. package/skills/sync-docs/references/schema.md +0 -103
  478. package/skills/sync-docs/scripts/changelog/add_entry.py +0 -216
  479. package/skills/sync-docs/scripts/context_gatherer.py +0 -240
  480. package/skills/sync-docs/scripts/doc_structure_analyzer.py +0 -495
  481. package/skills/sync-docs/scripts/drift_detector.py +0 -563
  482. package/skills/sync-docs/scripts/validate_doc.py +0 -365
  483. package/skills/sync-docs/scripts/validate_metadata.py +0 -185
  484. package/skills/sync-docs-workspace/iteration-1/benchmark.json +0 -293
  485. package/skills/sync-docs-workspace/iteration-1/benchmark.md +0 -13
  486. package/skills/sync-docs-workspace/iteration-1/eval-doc-audit/eval_metadata.json +0 -27
  487. package/skills/sync-docs-workspace/iteration-1/eval-doc-audit/with_skill/outputs/result.md +0 -210
  488. package/skills/sync-docs-workspace/iteration-1/eval-doc-audit/with_skill/run-1/grading.json +0 -28
  489. package/skills/sync-docs-workspace/iteration-1/eval-doc-audit/with_skill/run-1/timing.json +0 -1
  490. package/skills/sync-docs-workspace/iteration-1/eval-doc-audit/without_skill/outputs/result.md +0 -101
  491. package/skills/sync-docs-workspace/iteration-1/eval-doc-audit/without_skill/run-1/grading.json +0 -28
  492. package/skills/sync-docs-workspace/iteration-1/eval-doc-audit/without_skill/run-1/timing.json +0 -5
  493. package/skills/sync-docs-workspace/iteration-1/eval-doc-audit/without_skill/timing.json +0 -5
  494. package/skills/sync-docs-workspace/iteration-1/eval-fix-mode/eval_metadata.json +0 -27
  495. package/skills/sync-docs-workspace/iteration-1/eval-fix-mode/with_skill/outputs/result.md +0 -198
  496. package/skills/sync-docs-workspace/iteration-1/eval-fix-mode/with_skill/run-1/grading.json +0 -28
  497. package/skills/sync-docs-workspace/iteration-1/eval-fix-mode/with_skill/run-1/timing.json +0 -1
  498. package/skills/sync-docs-workspace/iteration-1/eval-fix-mode/without_skill/outputs/result.md +0 -94
  499. package/skills/sync-docs-workspace/iteration-1/eval-fix-mode/without_skill/run-1/grading.json +0 -28
  500. package/skills/sync-docs-workspace/iteration-1/eval-fix-mode/without_skill/run-1/timing.json +0 -1
  501. package/skills/sync-docs-workspace/iteration-1/eval-sprint-closeout/eval_metadata.json +0 -27
  502. package/skills/sync-docs-workspace/iteration-1/eval-sprint-closeout/with_skill/outputs/result.md +0 -237
  503. package/skills/sync-docs-workspace/iteration-1/eval-sprint-closeout/with_skill/run-1/grading.json +0 -28
  504. package/skills/sync-docs-workspace/iteration-1/eval-sprint-closeout/with_skill/run-1/timing.json +0 -1
  505. package/skills/sync-docs-workspace/iteration-1/eval-sprint-closeout/without_skill/outputs/result.md +0 -134
  506. package/skills/sync-docs-workspace/iteration-1/eval-sprint-closeout/without_skill/run-1/grading.json +0 -28
  507. package/skills/sync-docs-workspace/iteration-1/eval-sprint-closeout/without_skill/run-1/timing.json +0 -1
  508. package/skills/sync-docs-workspace/iteration-2/benchmark.json +0 -297
  509. package/skills/sync-docs-workspace/iteration-2/benchmark.md +0 -13
  510. package/skills/sync-docs-workspace/iteration-2/eval-doc-audit/eval_metadata.json +0 -27
  511. package/skills/sync-docs-workspace/iteration-2/eval-doc-audit/with_skill/outputs/result.md +0 -137
  512. package/skills/sync-docs-workspace/iteration-2/eval-doc-audit/with_skill/run-1/grading.json +0 -92
  513. package/skills/sync-docs-workspace/iteration-2/eval-doc-audit/with_skill/run-1/timing.json +0 -1
  514. package/skills/sync-docs-workspace/iteration-2/eval-doc-audit/without_skill/outputs/result.md +0 -134
  515. package/skills/sync-docs-workspace/iteration-2/eval-doc-audit/without_skill/run-1/grading.json +0 -86
  516. package/skills/sync-docs-workspace/iteration-2/eval-doc-audit/without_skill/run-1/timing.json +0 -1
  517. package/skills/sync-docs-workspace/iteration-2/eval-fix-mode/eval_metadata.json +0 -27
  518. package/skills/sync-docs-workspace/iteration-2/eval-fix-mode/with_skill/outputs/result.md +0 -193
  519. package/skills/sync-docs-workspace/iteration-2/eval-fix-mode/with_skill/run-1/grading.json +0 -72
  520. package/skills/sync-docs-workspace/iteration-2/eval-fix-mode/with_skill/run-1/timing.json +0 -1
  521. package/skills/sync-docs-workspace/iteration-2/eval-fix-mode/without_skill/outputs/result.md +0 -211
  522. package/skills/sync-docs-workspace/iteration-2/eval-fix-mode/without_skill/run-1/grading.json +0 -91
  523. package/skills/sync-docs-workspace/iteration-2/eval-fix-mode/without_skill/run-1/timing.json +0 -5
  524. package/skills/sync-docs-workspace/iteration-2/eval-sprint-closeout/eval_metadata.json +0 -27
  525. package/skills/sync-docs-workspace/iteration-2/eval-sprint-closeout/with_skill/outputs/result.md +0 -182
  526. package/skills/sync-docs-workspace/iteration-2/eval-sprint-closeout/with_skill/run-1/grading.json +0 -95
  527. package/skills/sync-docs-workspace/iteration-2/eval-sprint-closeout/with_skill/run-1/timing.json +0 -1
  528. package/skills/sync-docs-workspace/iteration-2/eval-sprint-closeout/without_skill/outputs/result.md +0 -222
  529. package/skills/sync-docs-workspace/iteration-2/eval-sprint-closeout/without_skill/run-1/grading.json +0 -88
  530. package/skills/sync-docs-workspace/iteration-2/eval-sprint-closeout/without_skill/run-1/timing.json +0 -5
  531. package/skills/sync-docs-workspace/iteration-3/benchmark.json +0 -298
  532. package/skills/sync-docs-workspace/iteration-3/benchmark.md +0 -13
  533. package/skills/sync-docs-workspace/iteration-3/eval-doc-audit/eval_metadata.json +0 -27
  534. package/skills/sync-docs-workspace/iteration-3/eval-doc-audit/with_skill/outputs/result.md +0 -125
  535. package/skills/sync-docs-workspace/iteration-3/eval-doc-audit/with_skill/run-1/grading.json +0 -97
  536. package/skills/sync-docs-workspace/iteration-3/eval-doc-audit/with_skill/run-1/timing.json +0 -5
  537. package/skills/sync-docs-workspace/iteration-3/eval-doc-audit/without_skill/outputs/result.md +0 -144
  538. package/skills/sync-docs-workspace/iteration-3/eval-doc-audit/without_skill/run-1/grading.json +0 -78
  539. package/skills/sync-docs-workspace/iteration-3/eval-doc-audit/without_skill/run-1/timing.json +0 -5
  540. package/skills/sync-docs-workspace/iteration-3/eval-fix-mode/eval_metadata.json +0 -27
  541. package/skills/sync-docs-workspace/iteration-3/eval-fix-mode/with_skill/outputs/result.md +0 -104
  542. package/skills/sync-docs-workspace/iteration-3/eval-fix-mode/with_skill/run-1/grading.json +0 -91
  543. package/skills/sync-docs-workspace/iteration-3/eval-fix-mode/with_skill/run-1/timing.json +0 -5
  544. package/skills/sync-docs-workspace/iteration-3/eval-fix-mode/without_skill/outputs/result.md +0 -79
  545. package/skills/sync-docs-workspace/iteration-3/eval-fix-mode/without_skill/run-1/grading.json +0 -82
  546. package/skills/sync-docs-workspace/iteration-3/eval-fix-mode/without_skill/run-1/timing.json +0 -5
  547. package/skills/sync-docs-workspace/iteration-3/eval-sprint-closeout/eval_metadata.json +0 -27
  548. package/skills/sync-docs-workspace/iteration-3/eval-sprint-closeout/with_skill/outputs/phase1_context.json +0 -302
  549. package/skills/sync-docs-workspace/iteration-3/eval-sprint-closeout/with_skill/outputs/phase2_drift.txt +0 -33
  550. package/skills/sync-docs-workspace/iteration-3/eval-sprint-closeout/with_skill/outputs/phase3_analysis.json +0 -114
  551. package/skills/sync-docs-workspace/iteration-3/eval-sprint-closeout/with_skill/outputs/phase4_fix.txt +0 -118
  552. package/skills/sync-docs-workspace/iteration-3/eval-sprint-closeout/with_skill/outputs/phase5_validate.txt +0 -38
  553. package/skills/sync-docs-workspace/iteration-3/eval-sprint-closeout/with_skill/outputs/result.md +0 -158
  554. package/skills/sync-docs-workspace/iteration-3/eval-sprint-closeout/with_skill/run-1/grading.json +0 -95
  555. package/skills/sync-docs-workspace/iteration-3/eval-sprint-closeout/with_skill/run-1/timing.json +0 -5
  556. package/skills/sync-docs-workspace/iteration-3/eval-sprint-closeout/without_skill/outputs/result.md +0 -71
  557. package/skills/sync-docs-workspace/iteration-3/eval-sprint-closeout/without_skill/run-1/grading.json +0 -90
  558. package/skills/sync-docs-workspace/iteration-3/eval-sprint-closeout/without_skill/run-1/timing.json +0 -5
  559. package/skills/test-planning/SKILL.md +0 -465
  560. package/skills/test-planning/evals/evals.json +0 -23
  561. package/skills/updating-service-skills/SKILL.md +0 -136
  562. package/skills/updating-service-skills/scripts/drift_detector.py +0 -222
  563. package/skills/using-quality-gates/SKILL.md +0 -254
  564. package/skills/using-serena-lsp/README.md +0 -8
  565. package/skills/using-serena-lsp/REFERENCE.md +0 -194
  566. package/skills/using-serena-lsp/SKILL.md +0 -82
  567. package/skills/using-service-skills/SKILL.md +0 -108
  568. package/skills/using-service-skills/scripts/cataloger.py +0 -74
  569. package/skills/using-service-skills/scripts/skill_activator.py +0 -152
  570. package/skills/using-service-skills/scripts/test_skill_activator.py +0 -58
  571. package/skills/using-tdd/SKILL.md +0 -410
  572. package/skills/using-xtrm/SKILL.md +0 -127
  573. package/skills/xt-debugging/SKILL.md +0 -149
  574. package/skills/xt-end/SKILL.md +0 -297
  575. package/skills/xt-merge/SKILL.md +0 -313
  576. /package/{config → .xtrm/config}/.env.example +0 -0
  577. /package/{config/mcp_servers_optional.json → .xtrm/config/claude.mcp.optional.json} +0 -0
  578. /package/{hooks → .xtrm/config}/hooks.json +0 -0
  579. /package/{config → .xtrm/config}/pi/auth.json.template +0 -0
  580. /package/{config → .xtrm/config}/pi/extensions/auto-session-name/index.ts +0 -0
  581. /package/{config → .xtrm/config}/pi/extensions/auto-session-name/package.json +0 -0
  582. /package/{config → .xtrm/config}/pi/extensions/auto-update/index.ts +0 -0
  583. /package/{config → .xtrm/config}/pi/extensions/auto-update/package.json +0 -0
  584. /package/{config → .xtrm/config}/pi/extensions/beads/package.json +0 -0
  585. /package/{config → .xtrm/config}/pi/extensions/compact-header/index.ts +0 -0
  586. /package/{config → .xtrm/config}/pi/extensions/compact-header/package.json +0 -0
  587. /package/{config → .xtrm/config}/pi/extensions/core/adapter.ts +0 -0
  588. /package/{config → .xtrm/config}/pi/extensions/core/guard-rules.ts +0 -0
  589. /package/{config → .xtrm/config}/pi/extensions/core/lib.ts +0 -0
  590. /package/{config → .xtrm/config}/pi/extensions/core/logger.ts +0 -0
  591. /package/{config → .xtrm/config}/pi/extensions/core/package.json +0 -0
  592. /package/{config → .xtrm/config}/pi/extensions/core/runner.ts +0 -0
  593. /package/{config → .xtrm/config}/pi/extensions/core/session-state.ts +0 -0
  594. /package/{config → .xtrm/config}/pi/extensions/custom-footer/package.json +0 -0
  595. /package/{config → .xtrm/config}/pi/extensions/custom-provider-qwen-cli/index.ts +0 -0
  596. /package/{config → .xtrm/config}/pi/extensions/custom-provider-qwen-cli/package.json +0 -0
  597. /package/{config → .xtrm/config}/pi/extensions/git-checkpoint/index.ts +0 -0
  598. /package/{config → .xtrm/config}/pi/extensions/git-checkpoint/package.json +0 -0
  599. /package/{config → .xtrm/config}/pi/extensions/lsp-bootstrap/index.ts +0 -0
  600. /package/{config → .xtrm/config}/pi/extensions/lsp-bootstrap/package.json +0 -0
  601. /package/{config → .xtrm/config}/pi/extensions/pi-serena-compact/index.ts +0 -0
  602. /package/{config → .xtrm/config}/pi/extensions/pi-serena-compact/package.json +0 -0
  603. /package/{config → .xtrm/config}/pi/extensions/quality-gates/index.ts +0 -0
  604. /package/{config → .xtrm/config}/pi/extensions/quality-gates/package.json +0 -0
  605. /package/{config → .xtrm/config}/pi/extensions/service-skills/index.ts +0 -0
  606. /package/{config → .xtrm/config}/pi/extensions/service-skills/package.json +0 -0
  607. /package/{config → .xtrm/config}/pi/extensions/session-flow/index.ts +0 -0
  608. /package/{config → .xtrm/config}/pi/extensions/session-flow/package.json +0 -0
  609. /package/{config → .xtrm/config}/pi/extensions/xtrm-loader/index.ts +0 -0
  610. /package/{config → .xtrm/config}/pi/extensions/xtrm-loader/package.json +0 -0
  611. /package/{config → .xtrm/config}/pi/extensions/xtrm-ui/format.ts +0 -0
  612. /package/{config → .xtrm/config}/pi/extensions/xtrm-ui/package.json +0 -0
  613. /package/{config → .xtrm/config}/pi/extensions/xtrm-ui/themes/pidex-dark.json +0 -0
  614. /package/{config → .xtrm/config}/pi/extensions/xtrm-ui/themes/pidex-light.json +0 -0
  615. /package/{config → .xtrm/config}/pi/models.json.template +0 -0
  616. /package/{config → .xtrm/config}/pi/pi-worktrees-settings.json +0 -0
  617. /package/{config → .xtrm/config}/pi/settings.json.template +0 -0
  618. /package/{hooks → .xtrm/hooks}/beads-claim-sync.mjs +0 -0
  619. /package/{hooks → .xtrm/hooks}/beads-compact-restore.mjs +0 -0
  620. /package/{hooks → .xtrm/hooks}/beads-compact-save.mjs +0 -0
  621. /package/{hooks → .xtrm/hooks}/beads-edit-gate.mjs +0 -0
  622. /package/{hooks → .xtrm/hooks}/beads-gate-core.mjs +0 -0
  623. /package/{hooks → .xtrm/hooks}/beads-gate-messages.mjs +0 -0
  624. /package/{hooks → .xtrm/hooks}/beads-gate-utils.mjs +0 -0
  625. /package/{hooks → .xtrm/hooks}/beads-stop-gate.mjs +0 -0
  626. /package/{hooks → .xtrm/hooks}/gitnexus/gitnexus-hook.cjs +0 -0
  627. /package/{hooks → .xtrm/hooks}/quality-check.cjs +0 -0
  628. /package/{hooks → .xtrm/hooks}/quality-check.py +0 -0
  629. /package/{hooks → .xtrm/hooks}/worktree-boundary.mjs +0 -0
  630. /package/{hooks → .xtrm/hooks}/xtrm-logger.mjs +0 -0
  631. /package/{hooks → .xtrm/hooks}/xtrm-session-logger.mjs +0 -0
  632. /package/{hooks → .xtrm/hooks}/xtrm-tool-logger.mjs +0 -0
@@ -0,0 +1,1044 @@
1
+ /**
2
+ * XTRM UI Extension
3
+ *
4
+ * Wraps pi-dex functionality with XTRM-specific preferences:
5
+ * - Uses pi-dex themes and header
6
+ * - Disables pi-dex footer (let custom-footer handle it)
7
+ * - Provides /xtrm-ui commands for theme/density switching
8
+ *
9
+ * This eliminates the race condition between pi-dex's footer and
10
+ * XTRM's custom-footer extension.
11
+ */
12
+
13
+ import type {
14
+ BashToolDetails,
15
+ EditToolDetails,
16
+ ExtensionAPI,
17
+ ExtensionContext,
18
+ FindToolDetails,
19
+ GrepToolDetails,
20
+ LsToolDetails,
21
+ ReadToolDetails,
22
+ ToolResultEvent,
23
+ } from "@mariozechner/pi-coding-agent";
24
+ import {
25
+ CustomEditor,
26
+ createBashTool,
27
+ createEditTool,
28
+ createFindTool,
29
+ createGrepTool,
30
+ createLsTool,
31
+ createReadTool,
32
+ createWriteTool,
33
+ } from "@mariozechner/pi-coding-agent";
34
+ import { Box, Text, truncateToWidth, visibleWidth } from "@mariozechner/pi-tui";
35
+ import { basename } from "node:path";
36
+ import {
37
+ cleanOutputLines,
38
+ countPrefixedItems,
39
+ diffStats,
40
+ formatDuration,
41
+ formatLineLabel,
42
+ joinMeta,
43
+ lineCount,
44
+ previewLines,
45
+ renderToolSummary,
46
+ shortenCommand,
47
+ shortenPath,
48
+ } from "./format";
49
+
50
+ // ============================================================================
51
+ // Types
52
+ // ============================================================================
53
+
54
+ export type XtrmThemeName = "pidex-dark" | "pidex-light";
55
+ export type XtrmDensity = "compact" | "comfortable";
56
+
57
+ export interface XtrmUiPrefs {
58
+ themeName: XtrmThemeName;
59
+ density: XtrmDensity;
60
+ showHeader: boolean;
61
+ compactTools: boolean;
62
+ showFooter: boolean; // Our key addition - when false, skip setFooter()
63
+ forceTheme: boolean; // When false, skip setTheme (allow external theme override)
64
+ }
65
+
66
+ // ============================================================================
67
+ // Defaults
68
+ // ============================================================================
69
+
70
+ export const XTRM_UI_PREFS_ENTRY = "xtrm-ui-prefs";
71
+
72
+ export const DEFAULT_PREFS: XtrmUiPrefs = {
73
+ themeName: "pidex-dark",
74
+ density: "compact",
75
+ showHeader: true,
76
+ compactTools: true,
77
+ showFooter: false, // XTRM: disable pi-dex footer, use custom-footer
78
+ forceTheme: true,
79
+ };
80
+
81
+ // ============================================================================
82
+ // Preferences
83
+ // ============================================================================
84
+
85
+ type MaybeCustomEntry = {
86
+ type?: string;
87
+ customType?: string;
88
+ data?: unknown;
89
+ };
90
+
91
+ function normalizePrefs(input: unknown): XtrmUiPrefs {
92
+ if (!input || typeof input !== "object") return { ...DEFAULT_PREFS };
93
+ const source = input as Partial<XtrmUiPrefs>;
94
+ return {
95
+ themeName: source.themeName === "pidex-light" ? "pidex-light" : "pidex-dark",
96
+ density: source.density === "comfortable" ? "comfortable" : "compact",
97
+ showHeader: source.showHeader ?? DEFAULT_PREFS.showHeader,
98
+ compactTools: source.compactTools ?? DEFAULT_PREFS.compactTools,
99
+ showFooter: source.showFooter ?? DEFAULT_PREFS.showFooter,
100
+ forceTheme: source.forceTheme ?? DEFAULT_PREFS.forceTheme,
101
+ };
102
+ }
103
+
104
+ function loadPrefs(entries: ReadonlyArray<MaybeCustomEntry>): XtrmUiPrefs {
105
+ for (let i = entries.length - 1; i >= 0; i--) {
106
+ const entry = entries[i];
107
+ if (entry?.type === "custom" && entry.customType === XTRM_UI_PREFS_ENTRY) {
108
+ return normalizePrefs(entry.data);
109
+ }
110
+ }
111
+ return { ...DEFAULT_PREFS };
112
+ }
113
+
114
+ function persistPrefs(pi: ExtensionAPI, prefs: XtrmUiPrefs): void {
115
+ pi.appendEntry(XTRM_UI_PREFS_ENTRY, prefs);
116
+ }
117
+
118
+ // ============================================================================
119
+ // Chrome Application
120
+ // ============================================================================
121
+
122
+ function fitVisible(text: string, width: number): string {
123
+ const truncated = truncateToWidth(text, width);
124
+ return truncated + " ".repeat(Math.max(0, width - visibleWidth(truncated)));
125
+ }
126
+
127
+ function formatThinking(level: string): string {
128
+ return level === "off" ? "standard" : level;
129
+ }
130
+
131
+ function applyXtrmChrome(
132
+ ctx: ExtensionContext,
133
+ prefs: XtrmUiPrefs,
134
+ getThinkingLevel: () => string
135
+ ): void {
136
+ // Theme
137
+ if (prefs.forceTheme) ctx.ui.setTheme(prefs.themeName);
138
+
139
+ // Tool expansion
140
+ ctx.ui.setToolsExpanded(!prefs.compactTools);
141
+
142
+ // Editor — density-aware input padding
143
+ ctx.ui.setEditorComponent((tui, theme, keybindings) => {
144
+ const editor = new XtrmEditor(tui, theme, keybindings);
145
+ editor.setPrefs(prefs);
146
+ return editor;
147
+ });
148
+
149
+ // Header (optional)
150
+ if (prefs.showHeader) {
151
+ ctx.ui.setHeader((_tui, theme) => ({
152
+ invalidate() {},
153
+ render(width: number): string[] {
154
+ const boxWidth = width >= 54 ? 50 : Math.max(24, width);
155
+ const model = ctx.model?.id ?? "no-model";
156
+ const thinking = getThinkingLevel();
157
+ const border = (text: string) => theme.fg("borderAccent", text);
158
+ const leftPad = "";
159
+
160
+ const top = leftPad + border(`╭${"─".repeat(Math.max(0, boxWidth - 2))}╮`);
161
+ const line1 =
162
+ leftPad +
163
+ border("│") +
164
+ fitVisible(
165
+ ` ${theme.fg("dim", ">_")} ${theme.bold("XTRM")} ${theme.fg("dim", `(v1.0.0)`)}`,
166
+ boxWidth - 2
167
+ ) +
168
+ border("│");
169
+ const gap = leftPad + border("│") + fitVisible("", boxWidth - 2) + border("│");
170
+ const line2 =
171
+ leftPad +
172
+ border("│") +
173
+ fitVisible(
174
+ ` ${theme.fg("dim", "model:".padEnd(11))}${model} ${thinking}${theme.fg("accent", " /model")}${theme.fg("dim", " to change")}`,
175
+ boxWidth - 2
176
+ ) +
177
+ border("│");
178
+ const line3 =
179
+ leftPad +
180
+ border("│") +
181
+ fitVisible(
182
+ ` ${theme.fg("dim", "directory:".padEnd(11))}${basename(ctx.cwd)}`,
183
+ boxWidth - 2
184
+ ) +
185
+ border("│");
186
+ const bottom = leftPad + border(`╰${"─".repeat(Math.max(0, boxWidth - 2))}╯`);
187
+
188
+ return [top, line1, gap, line2, line3, bottom];
189
+ },
190
+ }));
191
+ } else {
192
+ ctx.ui.setHeader(undefined);
193
+ }
194
+
195
+ // Footer - ONLY if showFooter is true (default false for XTRM)
196
+ // This is the key difference from pi-dex - we let custom-footer handle it
197
+ if (prefs.showFooter) {
198
+ ctx.ui.setFooter((tui, theme, footerData) => {
199
+ const unsubscribe = footerData.onBranchChange(() => tui.requestRender());
200
+ return {
201
+ dispose: unsubscribe,
202
+ invalidate() {},
203
+ render(width: number): string[] {
204
+ const modelId = ctx.model?.id ?? "no-model";
205
+ const thinking = getThinkingLevel();
206
+ const contextUsage = ctx.getContextUsage();
207
+ const leftPct = contextUsage?.percent != null ? `${100 - Math.round(contextUsage.percent)}% left` : undefined;
208
+ const line = theme.fg(
209
+ "dim",
210
+ [`${modelId} ${thinking}`, leftPct, basename(ctx.cwd)]
211
+ .filter(Boolean)
212
+ .join(" · ")
213
+ );
214
+ return [truncateToWidth(line, width)];
215
+ },
216
+ };
217
+ });
218
+ }
219
+ // If showFooter is false, we do NOT call setFooter - custom-footer will handle it
220
+ }
221
+
222
+ // ============================================================================
223
+ // Tool Render Helpers
224
+ // ============================================================================
225
+
226
+ function renderOutputPreview(theme: any, lines: string[], maxLines: number): string {
227
+ const subset = lines.slice(0, maxLines);
228
+ let text = subset.map((line) => theme.fg("toolOutput", ` ${line}`)).join("\n");
229
+ if (lines.length > maxLines) text += `\n${theme.fg("muted", ` … +${lines.length - maxLines} more`)}`;
230
+ return text;
231
+ }
232
+
233
+ function renderVerticalPreview(theme: any, lines: string[], maxLines: number): string {
234
+ const subset = lines.slice(0, maxLines);
235
+ let text = subset.map((line) => `${theme.fg("muted", "│")} ${theme.fg("toolOutput", line)}`).join("\n");
236
+ if (lines.length > maxLines) text += `\n${theme.fg("muted", "│")} ${theme.fg("muted", `… +${lines.length - maxLines} more lines`)}`;
237
+ return text;
238
+ }
239
+
240
+ function renderDiffPreview(theme: any, diff: string, maxLines: number): string {
241
+ const lines = diff.split("\n").slice(0, maxLines);
242
+ let out = "";
243
+ for (const line of lines) {
244
+ const styled =
245
+ line.startsWith("+") && !line.startsWith("+++") ? theme.fg("toolDiffAdded", ` ${line}`)
246
+ : line.startsWith("-") && !line.startsWith("---") ? theme.fg("toolDiffRemoved", ` ${line}`)
247
+ : theme.fg("toolDiffContext", ` ${line}`);
248
+ out += (out ? "\n" : "") + styled;
249
+ }
250
+ if (diff.split("\n").length > maxLines) out += `\n${theme.fg("muted", ` … +${diff.split("\n").length - maxLines} more`)}`;
251
+ return out;
252
+ }
253
+
254
+ function lineRange(offset?: number, limit?: number): string | undefined {
255
+ if (offset == null && limit == null) return undefined;
256
+ const start = offset ?? 1;
257
+ if (limit == null) return `${start}`;
258
+ return `${start}-${start + limit - 1}`;
259
+ }
260
+
261
+ function summarizeCount(text: string): number {
262
+ return text.split("\n").filter((line) => line.trim().length > 0).length;
263
+ }
264
+
265
+ // ============================================================================
266
+ // Editor (task p38n.3)
267
+ // ============================================================================
268
+
269
+ class XtrmEditor extends CustomEditor {
270
+ constructor(...args: ConstructorParameters<typeof CustomEditor>) {
271
+ super(...args);
272
+ }
273
+
274
+ setPrefs(prefs: XtrmUiPrefs): void {
275
+ this.setPaddingX(prefs.density === "comfortable" ? 2 : 1);
276
+ }
277
+
278
+ render(width: number): string[] {
279
+ return super.render(width);
280
+ }
281
+ }
282
+
283
+ // ============================================================================
284
+ // Commands
285
+ // ============================================================================
286
+
287
+ function sendInfoMessage(pi: ExtensionAPI, title: string, content: string): void {
288
+ pi.sendMessage({
289
+ customType: "xtrm-ui-info",
290
+ content,
291
+ display: true,
292
+ details: { title },
293
+ });
294
+ }
295
+
296
+ function parseThemeArg(arg: string): XtrmThemeName | undefined {
297
+ const normalized = arg.trim().toLowerCase();
298
+ if (normalized === "dark" || normalized === "pidex-dark") return "pidex-dark";
299
+ if (normalized === "light" || normalized === "pidex-light") return "pidex-light";
300
+ return undefined;
301
+ }
302
+
303
+ function parseDensityArg(arg: string): XtrmDensity | undefined {
304
+ const normalized = arg.trim().toLowerCase();
305
+ if (normalized === "compact") return "compact";
306
+ if (normalized === "comfortable" || normalized === "normal") return "comfortable";
307
+ return undefined;
308
+ }
309
+
310
+ function registerCommands(pi: ExtensionAPI, getPrefs: () => XtrmUiPrefs, setPrefs: (p: XtrmUiPrefs) => void, getThinkingLevel: () => string) {
311
+ pi.registerMessageRenderer("xtrm-ui-info", (message, _options, theme) => {
312
+ const title = (message.details as { title?: string } | undefined)?.title ?? "XTRM UI";
313
+ const box = new Box(1, 1, (text) => theme.bg("customMessageBg", text));
314
+ box.addChild(new Text(theme.fg("customMessageLabel", theme.bold(title)), 0, 0));
315
+ box.addChild(new Text(theme.fg("customMessageText", String(message.content ?? "")), 0, 0));
316
+ return box;
317
+ });
318
+
319
+ pi.registerCommand("xtrm-ui", {
320
+ description: "Show XTRM UI status and active preferences",
321
+ handler: async (_args, ctx) => {
322
+ const prefs = getPrefs();
323
+ const contextUsage = ctx.getContextUsage();
324
+ const lines = [
325
+ `Theme: ${prefs.themeName}`,
326
+ `Force theme: ${prefs.forceTheme ? "on" : "off"}`,
327
+ `Density: ${prefs.density}`,
328
+ `Compact tools: ${prefs.compactTools ? "on" : "off"}`,
329
+ `Show header: ${prefs.showHeader ? "yes" : "no"}`,
330
+ `Show footer: ${prefs.showFooter ? "yes" : "no"} (custom-footer handles this)`,
331
+ `Model: ${ctx.model?.id ?? "none"}`,
332
+ `Context: ${contextUsage?.tokens ?? "unknown"}/${contextUsage?.contextWindow ?? "unknown"}`,
333
+ ];
334
+ sendInfoMessage(pi, "XTRM UI status", lines.join("\\n"));
335
+ },
336
+ });
337
+
338
+ pi.registerCommand("xtrm-ui-theme", {
339
+ description: "Switch XTRM UI theme: dark|light",
340
+ getArgumentCompletions: (prefix) => {
341
+ const values = ["dark", "light"].filter((item) => item.startsWith(prefix));
342
+ return values.length > 0 ? values.map((value) => ({ value, label: value })) : null;
343
+ },
344
+ handler: async (args, ctx) => {
345
+ const themeName = parseThemeArg(args);
346
+ if (!themeName) {
347
+ ctx.ui.notify("Usage: /xtrm-ui-theme dark|light", "warning");
348
+ return;
349
+ }
350
+ const prefs = { ...getPrefs(), themeName };
351
+ setPrefs(prefs);
352
+ persistPrefs(pi, prefs);
353
+ applyXtrmChrome(ctx, prefs, getThinkingLevel);
354
+ ctx.ui.notify(`XTRM UI theme set to ${themeName}`, "info");
355
+ },
356
+ });
357
+
358
+ pi.registerCommand("xtrm-ui-density", {
359
+ description: "Switch XTRM UI density: compact|comfortable",
360
+ getArgumentCompletions: (prefix) => {
361
+ const values = ["compact", "comfortable"].filter((item) => item.startsWith(prefix));
362
+ return values.length > 0 ? values.map((value) => ({ value, label: value })) : null;
363
+ },
364
+ handler: async (args, ctx) => {
365
+ const density = parseDensityArg(args);
366
+ if (!density) {
367
+ ctx.ui.notify("Usage: /xtrm-ui-density compact|comfortable", "warning");
368
+ return;
369
+ }
370
+ const prefs = { ...getPrefs(), density };
371
+ setPrefs(prefs);
372
+ persistPrefs(pi, prefs);
373
+ applyXtrmChrome(ctx, prefs, getThinkingLevel);
374
+ ctx.ui.notify(`XTRM UI density set to ${density}`, "info");
375
+ },
376
+ });
377
+
378
+ pi.registerCommand("xtrm-ui-header", {
379
+ description: "Toggle XTRM UI header: on|off",
380
+ getArgumentCompletions: (prefix) => {
381
+ const values = ["on", "off"].filter((item) => item.startsWith(prefix));
382
+ return values.length > 0 ? values.map((value) => ({ value, label: value })) : null;
383
+ },
384
+ handler: async (args, ctx) => {
385
+ const showHeader = args.trim().toLowerCase() === "on";
386
+ const prefs = { ...getPrefs(), showHeader };
387
+ setPrefs(prefs);
388
+ persistPrefs(pi, prefs);
389
+ applyXtrmChrome(ctx, prefs, getThinkingLevel);
390
+ ctx.ui.notify(`XTRM UI header ${showHeader ? "enabled" : "disabled"}`, "info");
391
+ },
392
+ });
393
+
394
+ pi.registerCommand("xtrm-ui-forcetheme", {
395
+ description: "Control whether xtrm-ui overrides the active theme: on|off",
396
+ getArgumentCompletions: (prefix) => {
397
+ const values = ["on", "off"].filter((item) => item.startsWith(prefix));
398
+ return values.length > 0 ? values.map((value) => ({ value, label: value })) : null;
399
+ },
400
+ handler: async (args, ctx) => {
401
+ const normalized = args.trim().toLowerCase();
402
+ if (normalized !== "on" && normalized !== "off") {
403
+ ctx.ui.notify("Usage: /xtrm-ui-forcetheme on|off", "warning");
404
+ return;
405
+ }
406
+ const forceTheme = normalized === "on";
407
+ const prefs = { ...getPrefs(), forceTheme };
408
+ setPrefs(prefs);
409
+ persistPrefs(pi, prefs);
410
+ applyXtrmChrome(ctx, prefs, getThinkingLevel);
411
+ ctx.ui.notify(`XTRM UI force theme ${forceTheme ? "enabled" : "disabled"}`, "info");
412
+ },
413
+ });
414
+
415
+ pi.registerCommand("xtrm-ui-reset", {
416
+ description: "Restore XTRM UI defaults",
417
+ handler: async (_args, ctx) => {
418
+ const prefs = { ...DEFAULT_PREFS };
419
+ setPrefs(prefs);
420
+ persistPrefs(pi, prefs);
421
+ applyXtrmChrome(ctx, prefs, getThinkingLevel);
422
+ ctx.ui.notify("XTRM UI reset to defaults", "info");
423
+ },
424
+ });
425
+ }
426
+
427
+ // ============================================================================
428
+ // Tool Renderers (ported from pi-dex tooling.ts)
429
+ // ============================================================================
430
+
431
+ type BuiltInTools = ReturnType<typeof createBuiltInTools>;
432
+
433
+ type XtrmMeta<TArgs = Record<string, unknown>> = {
434
+ tool: string;
435
+ args: TArgs;
436
+ durationMs: number;
437
+ };
438
+
439
+ type DetailsWithXtrmMeta<TDetails, TArgs = Record<string, unknown>> = TDetails & {
440
+ xtrmMeta?: XtrmMeta<TArgs>;
441
+ };
442
+
443
+ const toolCache = new Map<string, BuiltInTools>();
444
+
445
+ function createBuiltInTools(cwd: string) {
446
+ return {
447
+ bash: createBashTool(cwd),
448
+ read: createReadTool(cwd),
449
+ edit: createEditTool(cwd),
450
+ write: createWriteTool(cwd),
451
+ find: createFindTool(cwd),
452
+ grep: createGrepTool(cwd),
453
+ ls: createLsTool(cwd),
454
+ };
455
+ }
456
+
457
+ function getTools(cwd: string): BuiltInTools {
458
+ let tools = toolCache.get(cwd);
459
+ if (!tools) {
460
+ tools = createBuiltInTools(cwd);
461
+ toolCache.set(cwd, tools);
462
+ }
463
+ return tools;
464
+ }
465
+
466
+ function withXtrmMeta<TDetails extends object, TArgs extends Record<string, unknown>>(
467
+ details: TDetails | undefined,
468
+ tool: string,
469
+ args: TArgs,
470
+ durationMs: number,
471
+ ): DetailsWithXtrmMeta<TDetails, TArgs> {
472
+ return { ...(details ?? ({} as TDetails)), xtrmMeta: { tool, args, durationMs } };
473
+ }
474
+
475
+ function getXtrmMeta<TDetails extends object, TArgs extends Record<string, unknown>>(
476
+ details: TDetails | undefined,
477
+ ): XtrmMeta<TArgs> | undefined {
478
+ if (!details || typeof details !== "object") return undefined;
479
+ return (details as DetailsWithXtrmMeta<TDetails, TArgs>).xtrmMeta;
480
+ }
481
+
482
+ function getTextContent(result: { content: Array<{ type: string; text?: string }> }): string {
483
+ const item = result.content.find((content) => content.type === "text");
484
+ return item?.text ?? "";
485
+ }
486
+
487
+ function renderPendingCall(toolName: string, args: Record<string, unknown>, theme: any): Text {
488
+ return new Text(renderToolSummary(theme, "pending", toolName, summarizeToolSubject(toolName, args), undefined), 0, 0);
489
+ }
490
+
491
+ function stableToolSignature(toolName: string, args: Record<string, unknown>): string {
492
+ return `${toolName}:${JSON.stringify(args)}`;
493
+ }
494
+
495
+ function summarizeToolSubject(toolName: string, args: Record<string, unknown>): string | undefined {
496
+ switch (toolName) {
497
+ case "bash": return shortenCommand(String(args.command ?? ""), 52);
498
+ case "read": {
499
+ const path = shortenPath(String(args.path ?? ""), 42);
500
+ const range = lineRange(args.offset as number | undefined, args.limit as number | undefined);
501
+ return range ? `${path}:${range}` : path;
502
+ }
503
+ case "edit":
504
+ case "write": return shortenPath(String(args.path ?? ""), 42);
505
+ case "find":
506
+ case "grep": return String(args.pattern ?? "");
507
+ case "ls": return shortenPath(String(args.path ?? "."), 42);
508
+ default: return undefined;
509
+ }
510
+ }
511
+
512
+ const SERENA_COMPACT_TOOLS = new Set([
513
+ "find_symbol",
514
+ "find_referencing_symbols",
515
+ "insert_after_symbol",
516
+ "replace_symbol_body",
517
+ "read_file",
518
+ "get_symbols_overview",
519
+ "insert_before_symbol",
520
+ "rename_symbol",
521
+ "restart_language_server",
522
+ "jet_brains_get_symbols_overview",
523
+ "jet_brains_find_symbol",
524
+ "jet_brains_find_referencing_symbols",
525
+ "jet_brains_type_hierarchy",
526
+ "search_for_pattern",
527
+ "list_dir",
528
+ "find_file",
529
+ "create_text_file",
530
+ "replace_content",
531
+ "delete_lines",
532
+ "replace_lines",
533
+ "insert_at_line",
534
+ "execute_shell_command",
535
+ "get_current_config",
536
+ "activate_project",
537
+ "remove_project",
538
+ "switch_modes",
539
+ "open_dashboard",
540
+ "check_onboarding_performed",
541
+ "onboarding",
542
+ "initial_instructions",
543
+ "prepare_for_new_conversation",
544
+ "summarize_changes",
545
+ "think_about_collected_information",
546
+ "think_about_task_adherence",
547
+ "think_about_whether_you_are_done",
548
+ "read_memory",
549
+ "write_memory",
550
+ "list_memories",
551
+ "delete_memory",
552
+ "rename_memory",
553
+ "edit_memory",
554
+ "serena_mcp_reset",
555
+ ]);
556
+
557
+ function parseJson(text: string): unknown | undefined {
558
+ try {
559
+ return JSON.parse(text);
560
+ } catch {
561
+ return undefined;
562
+ }
563
+ }
564
+
565
+ function asRecord(value: unknown): Record<string, unknown> | undefined {
566
+ return value && typeof value === "object" && !Array.isArray(value) ? value as Record<string, unknown> : undefined;
567
+ }
568
+
569
+ function countSearchMatches(payload: unknown): number | undefined {
570
+ const record = asRecord(payload);
571
+ if (!record) return undefined;
572
+ let total = 0;
573
+ for (const value of Object.values(record)) {
574
+ if (Array.isArray(value)) total += value.length;
575
+ }
576
+ return total > 0 ? total : undefined;
577
+ }
578
+
579
+ function countOverviewSymbols(payload: unknown): number {
580
+ if (Array.isArray(payload)) {
581
+ const nested = payload.reduce<number>((total, value) => total + countOverviewSymbols(value), 0);
582
+ return nested || payload.length;
583
+ }
584
+ const record = asRecord(payload);
585
+ if (!record) return 0;
586
+ return Object.values(record).reduce<number>((total, value) => total + countOverviewSymbols(value), 0);
587
+ }
588
+
589
+ function countLines(text: string): number {
590
+ if (!text) return 0;
591
+ return text.split("\n").length;
592
+ }
593
+
594
+ function countJsonItems(payload: unknown): number | undefined {
595
+ if (Array.isArray(payload)) return payload.length;
596
+ const record = asRecord(payload);
597
+ if (!record) return undefined;
598
+
599
+ let total = 0;
600
+ for (const value of Object.values(record)) {
601
+ if (Array.isArray(value)) total += value.length;
602
+ }
603
+ return total > 0 ? total : undefined;
604
+ }
605
+
606
+ function summarizeSerenaSubject(toolName: string, input: Record<string, unknown>): string | undefined {
607
+ switch (toolName) {
608
+ case "find_symbol":
609
+ case "find_referencing_symbols":
610
+ case "replace_symbol_body":
611
+ case "insert_after_symbol":
612
+ case "insert_before_symbol":
613
+ case "rename_symbol":
614
+ case "jet_brains_find_symbol":
615
+ case "jet_brains_find_referencing_symbols":
616
+ case "jet_brains_type_hierarchy":
617
+ return String(input.name_path_pattern ?? input.name_path ?? "symbol");
618
+ case "get_symbols_overview":
619
+ case "jet_brains_get_symbols_overview":
620
+ case "read_file":
621
+ case "create_text_file":
622
+ case "replace_content":
623
+ case "replace_lines":
624
+ case "delete_lines":
625
+ case "insert_at_line":
626
+ case "list_dir":
627
+ case "find_file":
628
+ return shortenPath(String(input.relative_path ?? input.path ?? "."), 42);
629
+ case "search_for_pattern":
630
+ return shortenCommand(String(input.substring_pattern ?? ""), 52);
631
+ case "read_memory":
632
+ case "write_memory":
633
+ case "delete_memory":
634
+ case "rename_memory":
635
+ case "edit_memory":
636
+ return String(input.memory_name ?? input.old_name ?? "memory");
637
+ case "activate_project":
638
+ case "remove_project":
639
+ return String(input.project ?? input.project_name ?? "project");
640
+ case "switch_modes": {
641
+ const modes = input.modes;
642
+ if (Array.isArray(modes)) return modes.map((mode) => String(mode)).join(",");
643
+ return "modes";
644
+ }
645
+ case "execute_shell_command":
646
+ return shortenCommand(String(input.command ?? ""), 52);
647
+ default:
648
+ return undefined;
649
+ }
650
+ }
651
+
652
+ function summarizeSerenaToolResult(
653
+ toolName: string,
654
+ input: Record<string, unknown>,
655
+ text: string,
656
+ durationMs: number | undefined,
657
+ ): string {
658
+ const payload = parseJson(text);
659
+ const duration = formatDuration(durationMs);
660
+ const subject = summarizeSerenaSubject(toolName, input);
661
+ const meta = (...parts: Array<string | undefined>) => {
662
+ const joined = joinMeta(parts);
663
+ return joined ? ` · ${joined}` : "";
664
+ };
665
+
666
+ switch (toolName) {
667
+ case "find_symbol":
668
+ case "find_referencing_symbols":
669
+ case "jet_brains_find_symbol":
670
+ case "jet_brains_find_referencing_symbols": {
671
+ const count = countJsonItems(payload) ?? (text.match(/"name_path"\s*:/g)?.length ?? 0);
672
+ return `• serena ${toolName} ${subject ?? "symbol"}${meta(formatLineLabel(count, "result"), duration)}`;
673
+ }
674
+ case "get_symbols_overview":
675
+ case "jet_brains_get_symbols_overview":
676
+ case "jet_brains_type_hierarchy": {
677
+ const count = Math.max(countOverviewSymbols(payload), text.match(/"name_path"\s*:/g)?.length ?? 0);
678
+ return `• serena ${toolName} ${subject ?? "file"}${meta(formatLineLabel(count, "symbol"), duration)}`;
679
+ }
680
+ case "search_for_pattern": {
681
+ const count = countSearchMatches(payload) ?? (text.match(/^\s*>\s*\d+:/gm)?.length ?? 0);
682
+ return `• serena search ${subject ?? "pattern"}${meta(formatLineLabel(count, "match"), duration)}`;
683
+ }
684
+ case "read_file": {
685
+ return `• serena read ${subject ?? "file"}${meta(formatLineLabel(countLines(text), "line"), duration)}`;
686
+ }
687
+ case "list_dir": {
688
+ const count = countJsonItems(payload) ?? countLines(text);
689
+ return `• serena list_dir ${subject ?? "."}${meta(formatLineLabel(count, "entry"), duration)}`;
690
+ }
691
+ case "find_file": {
692
+ const count = countJsonItems(payload) ?? countLines(text);
693
+ return `• serena find_file ${String(input.file_mask ?? "")}${meta(formatLineLabel(count, "match"), duration)}`;
694
+ }
695
+ case "replace_symbol_body":
696
+ case "insert_after_symbol":
697
+ case "insert_before_symbol":
698
+ case "rename_symbol":
699
+ case "create_text_file":
700
+ case "replace_content":
701
+ case "replace_lines":
702
+ case "delete_lines":
703
+ case "insert_at_line":
704
+ case "write_memory":
705
+ case "delete_memory":
706
+ case "rename_memory":
707
+ case "edit_memory":
708
+ case "activate_project":
709
+ case "remove_project":
710
+ case "switch_modes":
711
+ case "restart_language_server":
712
+ case "onboarding":
713
+ case "serena_mcp_reset":
714
+ return `• serena ${toolName}${subject ? ` ${subject}` : ""}${meta(duration)}`;
715
+ case "execute_shell_command": {
716
+ const count = countLines(text);
717
+ return `• serena shell ${subject ?? "command"}${meta(formatLineLabel(count, "line"), duration)}`;
718
+ }
719
+ default: {
720
+ const count = countJsonItems(payload) ?? countLines(text);
721
+ return `• serena ${toolName}${subject ? ` ${subject}` : ""}${meta(formatLineLabel(count, "item"), duration)}`;
722
+ }
723
+ }
724
+ }
725
+
726
+ function registerXtrmUiTools(pi: ExtensionAPI): void {
727
+ const activeToolCalls = new Map<string, string>();
728
+ const activeSignatureCounts = new Map<string, number>();
729
+ const toolCallStartTimes = new Map<string, number>();
730
+
731
+ const trackToolCallStart = (toolCallId: string, toolName: string, args: Record<string, unknown>) => {
732
+ const signature = stableToolSignature(toolName, args);
733
+ activeToolCalls.set(toolCallId, signature);
734
+ activeSignatureCounts.set(signature, (activeSignatureCounts.get(signature) ?? 0) + 1);
735
+ toolCallStartTimes.set(toolCallId, Date.now());
736
+ };
737
+
738
+ const trackToolCallEnd = (toolCallId: string) => {
739
+ const signature = activeToolCalls.get(toolCallId);
740
+ if (!signature) return;
741
+ activeToolCalls.delete(toolCallId);
742
+ const next = (activeSignatureCounts.get(signature) ?? 1) - 1;
743
+ if (next <= 0) activeSignatureCounts.delete(signature);
744
+ else activeSignatureCounts.set(signature, next);
745
+ toolCallStartTimes.delete(toolCallId);
746
+ };
747
+
748
+ const isToolCallActive = (toolName: string, args: Record<string, unknown>) =>
749
+ activeSignatureCounts.has(stableToolSignature(toolName, args));
750
+
751
+ const renderPendingCallIfActive = (toolName: string, args: Record<string, unknown>, theme: any) =>
752
+ isToolCallActive(toolName, args) ? renderPendingCall(toolName, args, theme) : new Text("", 0, 0);
753
+
754
+ pi.on("tool_call", async (event) => {
755
+ trackToolCallStart(event.toolCallId, event.toolName, event.input as Record<string, unknown>);
756
+ });
757
+
758
+ pi.on("tool_execution_end", async (event) => {
759
+ trackToolCallEnd(event.toolCallId);
760
+ });
761
+
762
+ pi.on("tool_result", async (event: ToolResultEvent, ctx) => {
763
+ if (!SERENA_COMPACT_TOOLS.has(event.toolName)) return undefined;
764
+ if (ctx.ui.getToolsExpanded()) return undefined;
765
+ if (event.isError) return undefined;
766
+
767
+ const text = getTextContent({ content: event.content as Array<{ type: string; text?: string }> });
768
+ if (!text.trim()) return undefined;
769
+
770
+ const startedAt = toolCallStartTimes.get(event.toolCallId);
771
+ const durationMs = startedAt != null ? Date.now() - startedAt : undefined;
772
+ const compactText = summarizeSerenaToolResult(event.toolName, event.input, text, durationMs);
773
+
774
+ return {
775
+ content: [{ type: "text", text: compactText }],
776
+ details: event.details,
777
+ };
778
+ });
779
+
780
+ pi.registerTool({
781
+ name: "bash",
782
+ label: "bash",
783
+ description: getTools(process.cwd()).bash.description,
784
+ parameters: getTools(process.cwd()).bash.parameters,
785
+ async execute(toolCallId, params, signal, onUpdate, ctx) {
786
+ const started = Date.now();
787
+ const result = await getTools(ctx.cwd).bash.execute(toolCallId, params, signal, onUpdate);
788
+ return { ...result, details: withXtrmMeta(result.details as BashToolDetails | undefined, "bash", params as Record<string, unknown>, Date.now() - started) };
789
+ },
790
+ renderCall: (args, theme) => renderPendingCallIfActive("bash", args as Record<string, unknown>, theme),
791
+ renderResult(result, { expanded, isPartial }, theme) {
792
+ const details = (result.details ?? {}) as DetailsWithXtrmMeta<BashToolDetails, Record<string, unknown>>;
793
+ const meta = getXtrmMeta<BashToolDetails, Record<string, unknown>>(details);
794
+ const command = shortenCommand(String(meta?.args.command ?? ""));
795
+ if (isPartial) {
796
+ return new Text(`${theme.fg("accent", "•")} ${theme.fg("toolTitle", "Running ")}${theme.fg("accent", command)}${theme.fg("toolTitle", " in bash")}`, 0, 0);
797
+ }
798
+ const output = getTextContent(result as any);
799
+ const outputLines = cleanOutputLines(output);
800
+ const exitMatch = output.match(/exit code:\s*(-?\d+)/i);
801
+ const exitCode = exitMatch ? Number.parseInt(exitMatch[1] ?? "0", 10) : 0;
802
+ const bullet = exitCode === 0 ? theme.fg("success", "•") : theme.fg("error", "•");
803
+ const summary = joinMeta([formatLineLabel(outputLines.length, "line"), formatDuration(meta?.durationMs), details.truncation?.truncated ? "truncated" : undefined]);
804
+ let text = `${bullet} ${theme.fg("toolTitle", "Ran ")}${theme.fg("accent", command)}`;
805
+ if (summary) text += theme.fg("dim", ` · ${summary}`);
806
+ if (expanded && outputLines.length > 0) text += `\n${renderVerticalPreview(theme, outputLines, 10)}`;
807
+ return new Text(text, 0, 0);
808
+ },
809
+ });
810
+
811
+ pi.registerTool({
812
+ name: "read",
813
+ label: "read",
814
+ description: getTools(process.cwd()).read.description,
815
+ parameters: getTools(process.cwd()).read.parameters,
816
+ async execute(toolCallId, params, signal, onUpdate, ctx) {
817
+ const started = Date.now();
818
+ const result = await getTools(ctx.cwd).read.execute(toolCallId, params, signal, onUpdate);
819
+ return { ...result, details: withXtrmMeta(result.details as ReadToolDetails | undefined, "read", params as Record<string, unknown>, Date.now() - started) };
820
+ },
821
+ renderCall: (args, theme) => renderPendingCallIfActive("read", args as Record<string, unknown>, theme),
822
+ renderResult(result, { expanded, isPartial }, theme) {
823
+ if (isPartial) return new Text(renderToolSummary(theme, "pending", "read", "loading", undefined), 0, 0);
824
+ const details = (result.details ?? {}) as DetailsWithXtrmMeta<ReadToolDetails, Record<string, unknown>>;
825
+ const meta = getXtrmMeta<ReadToolDetails, Record<string, unknown>>(details);
826
+ const subjectBase = shortenPath(String(meta?.args.path ?? ""));
827
+ const range = lineRange(meta?.args.offset as number | undefined, meta?.args.limit as number | undefined);
828
+ const subject = range ? `${subjectBase}:${range}` : subjectBase;
829
+ const first = result.content[0];
830
+ if (first?.type === "image") {
831
+ return new Text(renderToolSummary(theme, "success", "read", subject, joinMeta(["image", formatDuration(meta?.durationMs)])), 0, 0);
832
+ }
833
+ const textContent = getTextContent(result as any);
834
+ const lines = textContent.split("\n");
835
+ let text = renderToolSummary(theme, "success", "read", subject, joinMeta([formatLineLabel(lines.length, "line"), formatDuration(meta?.durationMs), details.truncation?.truncated ? `from ${details.truncation.totalLines}` : undefined]));
836
+ if (expanded && textContent.length > 0) text += `\n${renderOutputPreview(theme, previewLines(textContent, 14), 14)}`;
837
+ return new Text(text, 0, 0);
838
+ },
839
+ });
840
+
841
+ pi.registerTool({
842
+ name: "edit",
843
+ label: "edit",
844
+ description: getTools(process.cwd()).edit.description,
845
+ parameters: getTools(process.cwd()).edit.parameters,
846
+ async execute(toolCallId, params, signal, onUpdate, ctx) {
847
+ const started = Date.now();
848
+ const result = await getTools(ctx.cwd).edit.execute(toolCallId, params, signal, onUpdate);
849
+ return { ...result, details: withXtrmMeta(result.details as EditToolDetails | undefined, "edit", params as Record<string, unknown>, Date.now() - started) };
850
+ },
851
+ renderCall: (args, theme) => renderPendingCallIfActive("edit", args as Record<string, unknown>, theme),
852
+ renderResult(result, { expanded, isPartial }, theme) {
853
+ if (isPartial) return new Text(renderToolSummary(theme, "pending", "edit", "applying", undefined), 0, 0);
854
+ const details = (result.details ?? {}) as DetailsWithXtrmMeta<EditToolDetails, Record<string, unknown>>;
855
+ const meta = getXtrmMeta<EditToolDetails, Record<string, unknown>>(details);
856
+ const textContent = getTextContent(result as any);
857
+ if (/^error/i.test(textContent.trim())) {
858
+ return new Text(renderToolSummary(theme, "error", "edit", shortenPath(String(meta?.args.path ?? "")), textContent.split("\n")[0]), 0, 0);
859
+ }
860
+ const stats = details.diff ? diffStats(details.diff) : { additions: 0, removals: 0 };
861
+ let text = renderToolSummary(theme, "success", "edit", shortenPath(String(meta?.args.path ?? "")), joinMeta([`+${stats.additions}`, `-${stats.removals}`, formatDuration(meta?.durationMs)]));
862
+ if (expanded && details.diff) text += `\n${renderDiffPreview(theme, details.diff, 18)}`;
863
+ return new Text(text, 0, 0);
864
+ },
865
+ });
866
+
867
+ pi.registerTool({
868
+ name: "write",
869
+ label: "write",
870
+ description: getTools(process.cwd()).write.description,
871
+ parameters: getTools(process.cwd()).write.parameters,
872
+ async execute(toolCallId, params, signal, onUpdate, ctx) {
873
+ const started = Date.now();
874
+ const result = await getTools(ctx.cwd).write.execute(toolCallId, params, signal, onUpdate);
875
+ return { ...result, details: withXtrmMeta(result.details as Record<string, never> | undefined, "write", params as Record<string, unknown>, Date.now() - started) };
876
+ },
877
+ renderCall: (args, theme) => renderPendingCallIfActive("write", args as Record<string, unknown>, theme),
878
+ renderResult(result, { isPartial }, theme) {
879
+ if (isPartial) return new Text(renderToolSummary(theme, "pending", "write", "writing", undefined), 0, 0);
880
+ const details = (result.details ?? {}) as DetailsWithXtrmMeta<Record<string, never>, Record<string, unknown>>;
881
+ const meta = getXtrmMeta<Record<string, never>, Record<string, unknown>>(details);
882
+ const textContent = getTextContent(result as any);
883
+ if (/^error/i.test(textContent.trim())) {
884
+ return new Text(renderToolSummary(theme, "error", "write", shortenPath(String(meta?.args.path ?? "")), textContent.split("\n")[0]), 0, 0);
885
+ }
886
+ return new Text(renderToolSummary(theme, "success", "write", shortenPath(String(meta?.args.path ?? "")), joinMeta([formatLineLabel(lineCount(String(meta?.args.content ?? "")), "line"), formatDuration(meta?.durationMs)])), 0, 0);
887
+ },
888
+ });
889
+
890
+ pi.registerTool({
891
+ name: "find",
892
+ label: "find",
893
+ description: getTools(process.cwd()).find.description,
894
+ parameters: getTools(process.cwd()).find.parameters,
895
+ async execute(toolCallId, params, signal, onUpdate, ctx) {
896
+ const started = Date.now();
897
+ const result = await getTools(ctx.cwd).find.execute(toolCallId, params, signal, onUpdate);
898
+ return { ...result, details: withXtrmMeta(result.details as FindToolDetails | undefined, "find", params as Record<string, unknown>, Date.now() - started) };
899
+ },
900
+ renderCall: (args, theme) => renderPendingCallIfActive("find", args as Record<string, unknown>, theme),
901
+ renderResult(result, { expanded, isPartial }, theme) {
902
+ if (isPartial) return new Text(renderToolSummary(theme, "pending", "find", "searching", undefined), 0, 0);
903
+ const details = (result.details ?? {}) as DetailsWithXtrmMeta<FindToolDetails, Record<string, unknown>>;
904
+ const meta = getXtrmMeta<FindToolDetails, Record<string, unknown>>(details);
905
+ const textContent = getTextContent(result as any);
906
+ const count = summarizeCount(textContent);
907
+ let text = renderToolSummary(theme, "success", "find", String(meta?.args.pattern ?? ""), joinMeta([formatLineLabel(count, "match"), formatDuration(meta?.durationMs), details.resultLimitReached ? "limit reached" : undefined]));
908
+ if (expanded && count > 0) text += `\n${renderOutputPreview(theme, previewLines(textContent, 10), 10)}`;
909
+ return new Text(text, 0, 0);
910
+ },
911
+ });
912
+
913
+ pi.registerTool({
914
+ name: "grep",
915
+ label: "grep",
916
+ description: getTools(process.cwd()).grep.description,
917
+ parameters: getTools(process.cwd()).grep.parameters,
918
+ async execute(toolCallId, params, signal, onUpdate, ctx) {
919
+ const started = Date.now();
920
+ const result = await getTools(ctx.cwd).grep.execute(toolCallId, params, signal, onUpdate);
921
+ return { ...result, details: withXtrmMeta(result.details as GrepToolDetails | undefined, "grep", params as Record<string, unknown>, Date.now() - started) };
922
+ },
923
+ renderCall: (args, theme) => renderPendingCallIfActive("grep", args as Record<string, unknown>, theme),
924
+ renderResult(result, { expanded, isPartial }, theme) {
925
+ if (isPartial) return new Text(renderToolSummary(theme, "pending", "grep", "searching", undefined), 0, 0);
926
+ const details = (result.details ?? {}) as DetailsWithXtrmMeta<GrepToolDetails, Record<string, unknown>>;
927
+ const meta = getXtrmMeta<GrepToolDetails, Record<string, unknown>>(details);
928
+ const textContent = getTextContent(result as any);
929
+ const count = countPrefixedItems(textContent, ["-- "]) || summarizeCount(textContent);
930
+ let text = renderToolSummary(theme, "success", "grep", String(meta?.args.pattern ?? ""), joinMeta([formatLineLabel(count, "match"), formatDuration(meta?.durationMs), details.matchLimitReached ? "limit reached" : undefined]));
931
+ if (expanded && textContent.length > 0) text += `\n${renderOutputPreview(theme, previewLines(textContent, 12), 12)}`;
932
+ return new Text(text, 0, 0);
933
+ },
934
+ });
935
+
936
+ pi.registerTool({
937
+ name: "ls",
938
+ label: "ls",
939
+ description: getTools(process.cwd()).ls.description,
940
+ parameters: getTools(process.cwd()).ls.parameters,
941
+ async execute(toolCallId, params, signal, onUpdate, ctx) {
942
+ const started = Date.now();
943
+ const result = await getTools(ctx.cwd).ls.execute(toolCallId, params, signal, onUpdate);
944
+ return { ...result, details: withXtrmMeta(result.details as LsToolDetails | undefined, "ls", params as Record<string, unknown>, Date.now() - started) };
945
+ },
946
+ renderCall: (args, theme) => renderPendingCallIfActive("ls", args as Record<string, unknown>, theme),
947
+ renderResult(result, { expanded, isPartial }, theme) {
948
+ if (isPartial) return new Text(renderToolSummary(theme, "pending", "ls", "listing", undefined), 0, 0);
949
+ const details = (result.details ?? {}) as DetailsWithXtrmMeta<LsToolDetails, Record<string, unknown>>;
950
+ const meta = getXtrmMeta<LsToolDetails, Record<string, unknown>>(details);
951
+ const textContent = getTextContent(result as any);
952
+ const count = summarizeCount(textContent);
953
+ let text = renderToolSummary(theme, "success", "ls", shortenPath(String(meta?.args.path ?? ".")), joinMeta([formatLineLabel(count, "entry"), formatDuration(meta?.durationMs), details.entryLimitReached ? "limit reached" : undefined]));
954
+ if (expanded && count > 0) text += `\n${renderOutputPreview(theme, previewLines(textContent, 12), 12)}`;
955
+ return new Text(text, 0, 0);
956
+ },
957
+ });
958
+ }
959
+
960
+ // ============================================================================
961
+ // Main Extension
962
+ // ============================================================================
963
+
964
+ function isXtrmTheme(name: string | undefined): boolean {
965
+ return name === "pidex-dark" || name === "pidex-light";
966
+ }
967
+
968
+ export default function xtrmUiExtension(pi: ExtensionAPI): void {
969
+ let prefs: XtrmUiPrefs = { ...DEFAULT_PREFS };
970
+ let previousThemeName: string | null = null;
971
+
972
+ const getPrefs = () => prefs;
973
+ const setPrefs = (p: XtrmUiPrefs) => { prefs = p; };
974
+ const getThinkingLevel = () => formatThinking(pi.getThinkingLevel());
975
+
976
+ registerXtrmUiTools(pi);
977
+ registerCommands(pi, getPrefs, setPrefs, getThinkingLevel);
978
+
979
+ const refresh = (ctx: ExtensionContext) => {
980
+ applyXtrmChrome(ctx, prefs, getThinkingLevel);
981
+ };
982
+
983
+ pi.on("session_start", async (_event, ctx) => {
984
+ prefs = loadPrefs(ctx.sessionManager.getEntries() as Array<MaybeCustomEntry>);
985
+ if (!previousThemeName && !isXtrmTheme(ctx.ui.theme.name)) {
986
+ previousThemeName = ctx.ui.theme.name ?? null;
987
+ }
988
+ refresh(ctx);
989
+ });
990
+
991
+ pi.on("session_switch", async (_event, ctx) => {
992
+ if (!previousThemeName && !isXtrmTheme(ctx.ui.theme.name)) {
993
+ previousThemeName = ctx.ui.theme.name ?? null;
994
+ }
995
+ refresh(ctx);
996
+ });
997
+
998
+ pi.on("session_fork", async (_event, ctx) => {
999
+ if (!previousThemeName && !isXtrmTheme(ctx.ui.theme.name)) {
1000
+ previousThemeName = ctx.ui.theme.name ?? null;
1001
+ }
1002
+ refresh(ctx);
1003
+ });
1004
+
1005
+ pi.on("model_select", async (_event, ctx) => {
1006
+ refresh(ctx);
1007
+ });
1008
+
1009
+ pi.on("session_shutdown", async (_event, ctx) => {
1010
+ if (previousThemeName) {
1011
+ ctx.ui.setTheme(previousThemeName);
1012
+ }
1013
+ });
1014
+
1015
+ pi.on("input", async (event) => {
1016
+ if (event.source === "extension") return { action: "continue" as const };
1017
+ if (!event.text.trim()) return { action: "continue" as const };
1018
+ if (event.text.startsWith("/") || event.text.startsWith("!")) return { action: "continue" as const };
1019
+ if (event.text.startsWith("› ")) return { action: "continue" as const };
1020
+ return event.images
1021
+ ? { action: "transform" as const, text: `› ${event.text}`, images: event.images }
1022
+ : { action: "transform" as const, text: `› ${event.text}` };
1023
+ });
1024
+
1025
+ pi.on("context", async (event) => {
1026
+ const messages = event.messages.map((message) => {
1027
+ if (message.role === "user" && typeof message.content === "string" && message.content.startsWith("› ")) {
1028
+ return { ...message, content: message.content.slice(2) };
1029
+ }
1030
+ if (message.role === "user" && Array.isArray(message.content)) {
1031
+ return {
1032
+ ...message,
1033
+ content: message.content.map((item, index) =>
1034
+ index === 0 && item.type === "text" && item.text.startsWith("› ")
1035
+ ? { ...item, text: item.text.slice(2) }
1036
+ : item
1037
+ ),
1038
+ };
1039
+ }
1040
+ return message;
1041
+ });
1042
+ return { messages };
1043
+ });
1044
+ }