xtrm-tools 0.5.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (333) hide show
  1. package/CHANGELOG.md +504 -0
  2. package/README.md +201 -0
  3. package/cli/dist/index.cjs +57378 -0
  4. package/cli/dist/index.cjs.map +1 -0
  5. package/cli/dist/index.d.cts +2 -0
  6. package/cli/package.json +47 -0
  7. package/config/.env.example +40 -0
  8. package/config/hooks.json +72 -0
  9. package/config/instructions/agents-top.md +30 -0
  10. package/config/instructions/claude-top.md +30 -0
  11. package/config/mcp_servers.json +57 -0
  12. package/config/mcp_servers_optional.json +53 -0
  13. package/config/pi/auth.json.template +14 -0
  14. package/config/pi/extensions/auto-session-name/index.ts +29 -0
  15. package/config/pi/extensions/auto-session-name/package.json +16 -0
  16. package/config/pi/extensions/auto-update/index.ts +71 -0
  17. package/config/pi/extensions/auto-update/package.json +16 -0
  18. package/config/pi/extensions/beads/index.ts +166 -0
  19. package/config/pi/extensions/beads/package.json +16 -0
  20. package/config/pi/extensions/bg-process/index.ts +230 -0
  21. package/config/pi/extensions/bg-process/package.json +16 -0
  22. package/config/pi/extensions/compact-header/index.ts +69 -0
  23. package/config/pi/extensions/compact-header/package.json +16 -0
  24. package/config/pi/extensions/core/adapter.ts +52 -0
  25. package/config/pi/extensions/core/guard-rules.ts +102 -0
  26. package/config/pi/extensions/core/lib.ts +3 -0
  27. package/config/pi/extensions/core/logger.ts +45 -0
  28. package/config/pi/extensions/core/runner.ts +71 -0
  29. package/config/pi/extensions/core/session-state.ts +59 -0
  30. package/config/pi/extensions/custom-footer/index.ts +160 -0
  31. package/config/pi/extensions/custom-footer/package.json +16 -0
  32. package/config/pi/extensions/custom-provider-qwen-cli/index.ts +363 -0
  33. package/config/pi/extensions/custom-provider-qwen-cli/package.json +1 -0
  34. package/config/pi/extensions/git-checkpoint/index.ts +53 -0
  35. package/config/pi/extensions/git-checkpoint/package.json +16 -0
  36. package/config/pi/extensions/minimal-mode/index.ts +201 -0
  37. package/config/pi/extensions/minimal-mode/package.json +16 -0
  38. package/config/pi/extensions/plan-mode/README.md +65 -0
  39. package/config/pi/extensions/plan-mode/index.ts +417 -0
  40. package/config/pi/extensions/plan-mode/package.json +12 -0
  41. package/config/pi/extensions/plan-mode/utils.ts +324 -0
  42. package/config/pi/extensions/quality-gates/index.ts +67 -0
  43. package/config/pi/extensions/quality-gates/package.json +16 -0
  44. package/config/pi/extensions/service-skills/index.ts +108 -0
  45. package/config/pi/extensions/service-skills/package.json +16 -0
  46. package/config/pi/extensions/session-flow/index.ts +131 -0
  47. package/config/pi/extensions/session-flow/package.json +16 -0
  48. package/config/pi/extensions/todo/index.ts +299 -0
  49. package/config/pi/extensions/todo/package.json +16 -0
  50. package/config/pi/extensions/xtrm-loader/index.ts +89 -0
  51. package/config/pi/extensions/xtrm-loader/package.json +16 -0
  52. package/config/pi/install-schema.json +44 -0
  53. package/config/pi/models.json.template +76 -0
  54. package/config/pi/pi-worktrees-settings.json +6 -0
  55. package/config/pi/settings.json.template +16 -0
  56. package/config/settings.json +70 -0
  57. package/hooks/README.md +75 -0
  58. package/hooks/agent_context.py +105 -0
  59. package/hooks/beads-claim-sync.mjs +166 -0
  60. package/hooks/beads-commit-gate.mjs +55 -0
  61. package/hooks/beads-compact-restore.mjs +69 -0
  62. package/hooks/beads-compact-save.mjs +51 -0
  63. package/hooks/beads-edit-gate.mjs +45 -0
  64. package/hooks/beads-gate-core.mjs +215 -0
  65. package/hooks/beads-gate-messages.mjs +87 -0
  66. package/hooks/beads-gate-utils.mjs +185 -0
  67. package/hooks/beads-memory-gate.mjs +61 -0
  68. package/hooks/beads-stop-gate.mjs +32 -0
  69. package/hooks/branch-state.mjs +39 -0
  70. package/hooks/gitnexus/gitnexus-hook.cjs +222 -0
  71. package/hooks/guard-rules.mjs +118 -0
  72. package/hooks/hooks.json +116 -0
  73. package/hooks/main-guard-post-push.mjs +71 -0
  74. package/hooks/main-guard.mjs +119 -0
  75. package/hooks/quality-check.cjs +1286 -0
  76. package/hooks/quality-check.py +345 -0
  77. package/hooks/serena-workflow-reminder.py +74 -0
  78. package/package.json +77 -0
  79. package/project-skills/quality-gates/.claude/hooks/hook-config.json +66 -0
  80. package/project-skills/quality-gates/.claude/hooks/quality-check.cjs +1286 -0
  81. package/project-skills/quality-gates/.claude/hooks/quality-check.py +334 -0
  82. package/project-skills/quality-gates/.claude/settings.json +3 -0
  83. package/project-skills/quality-gates/.claude/skills/using-quality-gates/SKILL.md +254 -0
  84. package/project-skills/quality-gates/README.md +109 -0
  85. package/project-skills/quality-gates/evals/evals.json +181 -0
  86. package/project-skills/quality-gates/workspace/iteration-1/FINAL-EVAL-SUMMARY.md +75 -0
  87. package/project-skills/quality-gates/workspace/iteration-1/edge-case-auto-fix-verification/with_skill/outputs/response.md +59 -0
  88. package/project-skills/quality-gates/workspace/iteration-1/edge-case-mixed-language-project/with_skill/outputs/response.md +60 -0
  89. package/project-skills/quality-gates/workspace/iteration-1/eval-summary.md +105 -0
  90. package/project-skills/quality-gates/workspace/iteration-1/partial-install-python-only/with_skill/outputs/response.md +93 -0
  91. package/project-skills/quality-gates/workspace/iteration-1/python-refactor-request/with_skill/outputs/response.md +104 -0
  92. package/project-skills/quality-gates/workspace/iteration-1/quality-gate-error-fix/with_skill/outputs/response.md +74 -0
  93. package/project-skills/quality-gates/workspace/iteration-1/should-not-trigger-general-chat/with_skill/outputs/response.md +18 -0
  94. package/project-skills/quality-gates/workspace/iteration-1/should-not-trigger-math-question/with_skill/outputs/response.md +18 -0
  95. package/project-skills/quality-gates/workspace/iteration-1/should-not-trigger-unrelated-coding/with_skill/outputs/response.md +56 -0
  96. package/project-skills/quality-gates/workspace/iteration-1/tdd-guard-blocking-confusion/with_skill/outputs/response.md +67 -0
  97. package/project-skills/quality-gates/workspace/iteration-1/typescript-feature-with-tests/with_skill/outputs/response.md +97 -0
  98. package/project-skills/service-skills-set/.claude/git-hooks/doc_reminder.py +67 -0
  99. package/project-skills/service-skills-set/.claude/git-hooks/skill_staleness.py +194 -0
  100. package/project-skills/service-skills-set/.claude/service-registry.json +4 -0
  101. package/project-skills/service-skills-set/.claude/settings.json +37 -0
  102. package/project-skills/service-skills-set/.claude/skills/creating-service-skills/SKILL.md +433 -0
  103. package/project-skills/service-skills-set/.claude/skills/creating-service-skills/references/script_quality_standards.md +425 -0
  104. package/project-skills/service-skills-set/.claude/skills/creating-service-skills/references/service_skill_system_guide.md +278 -0
  105. package/project-skills/service-skills-set/.claude/skills/creating-service-skills/scripts/bootstrap.py +308 -0
  106. package/project-skills/service-skills-set/.claude/skills/creating-service-skills/scripts/deep_dive.py +304 -0
  107. package/project-skills/service-skills-set/.claude/skills/creating-service-skills/scripts/scaffolder.py +482 -0
  108. package/project-skills/service-skills-set/.claude/skills/scoping-service-skills/SKILL.md +231 -0
  109. package/project-skills/service-skills-set/.claude/skills/scoping-service-skills/scripts/scope.py +74 -0
  110. package/project-skills/service-skills-set/.claude/skills/updating-service-skills/SKILL.md +136 -0
  111. package/project-skills/service-skills-set/.claude/skills/updating-service-skills/scripts/drift_detector.py +222 -0
  112. package/project-skills/service-skills-set/.claude/skills/using-service-skills/SKILL.md +108 -0
  113. package/project-skills/service-skills-set/.claude/skills/using-service-skills/scripts/cataloger.py +74 -0
  114. package/project-skills/service-skills-set/.claude/skills/using-service-skills/scripts/skill_activator.py +152 -0
  115. package/project-skills/service-skills-set/README.md +93 -0
  116. package/project-skills/service-skills-set/install-service-skills.py +193 -0
  117. package/project-skills/service-skills-set/service-skills-readme.md +236 -0
  118. package/skills/README.txt +31 -0
  119. package/skills/clean-code/SKILL.md +201 -0
  120. package/skills/creating-service-skills/SKILL.md +433 -0
  121. package/skills/creating-service-skills/references/script_quality_standards.md +425 -0
  122. package/skills/creating-service-skills/references/service_skill_system_guide.md +278 -0
  123. package/skills/creating-service-skills/scripts/bootstrap.py +326 -0
  124. package/skills/creating-service-skills/scripts/deep_dive.py +304 -0
  125. package/skills/creating-service-skills/scripts/scaffolder.py +482 -0
  126. package/skills/delegating/SKILL.md +196 -0
  127. package/skills/delegating/config.yaml +210 -0
  128. package/skills/delegating/references/orchestration-protocols.md +41 -0
  129. package/skills/docker-expert/SKILL.md +409 -0
  130. package/skills/documenting/CHANGELOG.md +23 -0
  131. package/skills/documenting/README.md +148 -0
  132. package/skills/documenting/SKILL.md +113 -0
  133. package/skills/documenting/examples/example_pattern.md +70 -0
  134. package/skills/documenting/examples/example_reference.md +70 -0
  135. package/skills/documenting/examples/example_ssot_analytics.md +64 -0
  136. package/skills/documenting/examples/example_workflow.md +141 -0
  137. package/skills/documenting/references/changelog-format.md +97 -0
  138. package/skills/documenting/references/metadata-schema.md +136 -0
  139. package/skills/documenting/references/taxonomy.md +81 -0
  140. package/skills/documenting/references/versioning-rules.md +78 -0
  141. package/skills/documenting/scripts/bump_version.sh +60 -0
  142. package/skills/documenting/scripts/changelog/__init__.py +0 -0
  143. package/skills/documenting/scripts/changelog/add_entry.py +216 -0
  144. package/skills/documenting/scripts/changelog/bump_release.py +117 -0
  145. package/skills/documenting/scripts/changelog/init_changelog.py +54 -0
  146. package/skills/documenting/scripts/changelog/validate_changelog.py +128 -0
  147. package/skills/documenting/scripts/drift_detector.py +266 -0
  148. package/skills/documenting/scripts/generate_template.py +311 -0
  149. package/skills/documenting/scripts/list_by_category.sh +84 -0
  150. package/skills/documenting/scripts/orchestrator.py +255 -0
  151. package/skills/documenting/scripts/validate_metadata.py +242 -0
  152. package/skills/documenting/templates/CHANGELOG.md.template +13 -0
  153. package/skills/find-skills/SKILL.md +133 -0
  154. package/skills/gitnexus-debugging/SKILL.md +85 -0
  155. package/skills/gitnexus-exploring/SKILL.md +75 -0
  156. package/skills/gitnexus-impact-analysis/SKILL.md +94 -0
  157. package/skills/gitnexus-refactoring/SKILL.md +113 -0
  158. package/skills/hook-development/SKILL.md +797 -0
  159. package/skills/hook-development/examples/load-context.sh +55 -0
  160. package/skills/hook-development/examples/quality-check.js +1168 -0
  161. package/skills/hook-development/examples/validate-bash.sh +43 -0
  162. package/skills/hook-development/examples/validate-write.sh +38 -0
  163. package/skills/hook-development/references/advanced.md +527 -0
  164. package/skills/hook-development/references/migration.md +369 -0
  165. package/skills/hook-development/references/patterns.md +412 -0
  166. package/skills/hook-development/scripts/README.md +164 -0
  167. package/skills/hook-development/scripts/hook-linter.sh +153 -0
  168. package/skills/hook-development/scripts/test-hook.sh +252 -0
  169. package/skills/hook-development/scripts/validate-hook-schema.sh +159 -0
  170. package/skills/obsidian-cli/SKILL.md +106 -0
  171. package/skills/orchestrating-agents/SKILL.md +135 -0
  172. package/skills/orchestrating-agents/config.yaml +45 -0
  173. package/skills/orchestrating-agents/references/agent-context-integration.md +37 -0
  174. package/skills/orchestrating-agents/references/examples.md +45 -0
  175. package/skills/orchestrating-agents/references/handover-protocol.md +31 -0
  176. package/skills/orchestrating-agents/references/workflows.md +42 -0
  177. package/skills/orchestrating-agents/scripts/detect_neighbors.py +23 -0
  178. package/skills/prompt-improving/README.md +162 -0
  179. package/skills/prompt-improving/SKILL.md +74 -0
  180. package/skills/prompt-improving/references/analysis_commands.md +24 -0
  181. package/skills/prompt-improving/references/chain_of_thought.md +24 -0
  182. package/skills/prompt-improving/references/mcp_definitions.md +20 -0
  183. package/skills/prompt-improving/references/multishot.md +23 -0
  184. package/skills/prompt-improving/references/xml_core.md +60 -0
  185. package/skills/python-testing/SKILL.md +815 -0
  186. package/skills/scoping-service-skills/SKILL.md +231 -0
  187. package/skills/scoping-service-skills/scripts/scope.py +74 -0
  188. package/skills/senior-backend/SKILL.md +209 -0
  189. package/skills/senior-backend/references/api_design_patterns.md +103 -0
  190. package/skills/senior-backend/references/backend_security_practices.md +103 -0
  191. package/skills/senior-backend/references/database_optimization_guide.md +103 -0
  192. package/skills/senior-backend/scripts/api_load_tester.py +114 -0
  193. package/skills/senior-backend/scripts/api_scaffolder.py +114 -0
  194. package/skills/senior-backend/scripts/database_migration_tool.py +114 -0
  195. package/skills/senior-data-scientist/SKILL.md +226 -0
  196. package/skills/senior-data-scientist/references/experiment_design_frameworks.md +80 -0
  197. package/skills/senior-data-scientist/references/feature_engineering_patterns.md +80 -0
  198. package/skills/senior-data-scientist/references/statistical_methods_advanced.md +80 -0
  199. package/skills/senior-data-scientist/scripts/experiment_designer.py +100 -0
  200. package/skills/senior-data-scientist/scripts/feature_engineering_pipeline.py +100 -0
  201. package/skills/senior-data-scientist/scripts/model_evaluation_suite.py +100 -0
  202. package/skills/senior-devops/SKILL.md +209 -0
  203. package/skills/senior-devops/references/cicd_pipeline_guide.md +103 -0
  204. package/skills/senior-devops/references/deployment_strategies.md +103 -0
  205. package/skills/senior-devops/references/infrastructure_as_code.md +103 -0
  206. package/skills/senior-devops/scripts/deployment_manager.py +114 -0
  207. package/skills/senior-devops/scripts/pipeline_generator.py +114 -0
  208. package/skills/senior-devops/scripts/terraform_scaffolder.py +114 -0
  209. package/skills/senior-security/SKILL.md +209 -0
  210. package/skills/senior-security/references/cryptography_implementation.md +103 -0
  211. package/skills/senior-security/references/penetration_testing_guide.md +103 -0
  212. package/skills/senior-security/references/security_architecture_patterns.md +103 -0
  213. package/skills/senior-security/scripts/pentest_automator.py +114 -0
  214. package/skills/senior-security/scripts/security_auditor.py +114 -0
  215. package/skills/senior-security/scripts/threat_modeler.py +114 -0
  216. package/skills/skill-creator/LICENSE.txt +202 -0
  217. package/skills/skill-creator/SKILL.md +479 -0
  218. package/skills/skill-creator/agents/analyzer.md +274 -0
  219. package/skills/skill-creator/agents/comparator.md +202 -0
  220. package/skills/skill-creator/agents/grader.md +223 -0
  221. package/skills/skill-creator/assets/eval_review.html +146 -0
  222. package/skills/skill-creator/eval-viewer/generate_review.py +471 -0
  223. package/skills/skill-creator/eval-viewer/viewer.html +1325 -0
  224. package/skills/skill-creator/references/schemas.md +430 -0
  225. package/skills/skill-creator/scripts/__init__.py +0 -0
  226. package/skills/skill-creator/scripts/aggregate_benchmark.py +401 -0
  227. package/skills/skill-creator/scripts/generate_report.py +326 -0
  228. package/skills/skill-creator/scripts/improve_description.py +248 -0
  229. package/skills/skill-creator/scripts/package_skill.py +136 -0
  230. package/skills/skill-creator/scripts/quick_validate.py +103 -0
  231. package/skills/skill-creator/scripts/run_eval.py +310 -0
  232. package/skills/skill-creator/scripts/run_loop.py +332 -0
  233. package/skills/skill-creator/scripts/utils.py +47 -0
  234. package/skills/sync-docs/SKILL.md +132 -0
  235. package/skills/sync-docs/evals/evals.json +89 -0
  236. package/skills/sync-docs/references/doc-structure.md +99 -0
  237. package/skills/sync-docs/references/schema.md +103 -0
  238. package/skills/sync-docs/scripts/changelog/add_entry.py +216 -0
  239. package/skills/sync-docs/scripts/context_gatherer.py +240 -0
  240. package/skills/sync-docs/scripts/doc_structure_analyzer.py +495 -0
  241. package/skills/sync-docs/scripts/drift_detector.py +327 -0
  242. package/skills/sync-docs/scripts/validate_doc.py +365 -0
  243. package/skills/sync-docs/scripts/validate_metadata.py +185 -0
  244. package/skills/sync-docs-workspace/iteration-1/benchmark.json +293 -0
  245. package/skills/sync-docs-workspace/iteration-1/benchmark.md +13 -0
  246. package/skills/sync-docs-workspace/iteration-1/eval-doc-audit/eval_metadata.json +27 -0
  247. package/skills/sync-docs-workspace/iteration-1/eval-doc-audit/with_skill/outputs/result.md +210 -0
  248. package/skills/sync-docs-workspace/iteration-1/eval-doc-audit/with_skill/run-1/grading.json +28 -0
  249. package/skills/sync-docs-workspace/iteration-1/eval-doc-audit/with_skill/run-1/timing.json +1 -0
  250. package/skills/sync-docs-workspace/iteration-1/eval-doc-audit/without_skill/outputs/result.md +101 -0
  251. package/skills/sync-docs-workspace/iteration-1/eval-doc-audit/without_skill/run-1/grading.json +28 -0
  252. package/skills/sync-docs-workspace/iteration-1/eval-doc-audit/without_skill/run-1/timing.json +5 -0
  253. package/skills/sync-docs-workspace/iteration-1/eval-doc-audit/without_skill/timing.json +5 -0
  254. package/skills/sync-docs-workspace/iteration-1/eval-fix-mode/eval_metadata.json +27 -0
  255. package/skills/sync-docs-workspace/iteration-1/eval-fix-mode/with_skill/outputs/result.md +198 -0
  256. package/skills/sync-docs-workspace/iteration-1/eval-fix-mode/with_skill/run-1/grading.json +28 -0
  257. package/skills/sync-docs-workspace/iteration-1/eval-fix-mode/with_skill/run-1/timing.json +1 -0
  258. package/skills/sync-docs-workspace/iteration-1/eval-fix-mode/without_skill/outputs/result.md +94 -0
  259. package/skills/sync-docs-workspace/iteration-1/eval-fix-mode/without_skill/run-1/grading.json +28 -0
  260. package/skills/sync-docs-workspace/iteration-1/eval-fix-mode/without_skill/run-1/timing.json +1 -0
  261. package/skills/sync-docs-workspace/iteration-1/eval-sprint-closeout/eval_metadata.json +27 -0
  262. package/skills/sync-docs-workspace/iteration-1/eval-sprint-closeout/with_skill/outputs/result.md +237 -0
  263. package/skills/sync-docs-workspace/iteration-1/eval-sprint-closeout/with_skill/run-1/grading.json +28 -0
  264. package/skills/sync-docs-workspace/iteration-1/eval-sprint-closeout/with_skill/run-1/timing.json +1 -0
  265. package/skills/sync-docs-workspace/iteration-1/eval-sprint-closeout/without_skill/outputs/result.md +134 -0
  266. package/skills/sync-docs-workspace/iteration-1/eval-sprint-closeout/without_skill/run-1/grading.json +28 -0
  267. package/skills/sync-docs-workspace/iteration-1/eval-sprint-closeout/without_skill/run-1/timing.json +1 -0
  268. package/skills/sync-docs-workspace/iteration-2/benchmark.json +297 -0
  269. package/skills/sync-docs-workspace/iteration-2/benchmark.md +13 -0
  270. package/skills/sync-docs-workspace/iteration-2/eval-doc-audit/eval_metadata.json +27 -0
  271. package/skills/sync-docs-workspace/iteration-2/eval-doc-audit/with_skill/outputs/result.md +137 -0
  272. package/skills/sync-docs-workspace/iteration-2/eval-doc-audit/with_skill/run-1/grading.json +92 -0
  273. package/skills/sync-docs-workspace/iteration-2/eval-doc-audit/with_skill/run-1/timing.json +1 -0
  274. package/skills/sync-docs-workspace/iteration-2/eval-doc-audit/without_skill/outputs/result.md +134 -0
  275. package/skills/sync-docs-workspace/iteration-2/eval-doc-audit/without_skill/run-1/grading.json +86 -0
  276. package/skills/sync-docs-workspace/iteration-2/eval-doc-audit/without_skill/run-1/timing.json +1 -0
  277. package/skills/sync-docs-workspace/iteration-2/eval-fix-mode/eval_metadata.json +27 -0
  278. package/skills/sync-docs-workspace/iteration-2/eval-fix-mode/with_skill/outputs/result.md +193 -0
  279. package/skills/sync-docs-workspace/iteration-2/eval-fix-mode/with_skill/run-1/grading.json +72 -0
  280. package/skills/sync-docs-workspace/iteration-2/eval-fix-mode/with_skill/run-1/timing.json +1 -0
  281. package/skills/sync-docs-workspace/iteration-2/eval-fix-mode/without_skill/outputs/result.md +211 -0
  282. package/skills/sync-docs-workspace/iteration-2/eval-fix-mode/without_skill/run-1/grading.json +91 -0
  283. package/skills/sync-docs-workspace/iteration-2/eval-fix-mode/without_skill/run-1/timing.json +5 -0
  284. package/skills/sync-docs-workspace/iteration-2/eval-sprint-closeout/eval_metadata.json +27 -0
  285. package/skills/sync-docs-workspace/iteration-2/eval-sprint-closeout/with_skill/outputs/result.md +182 -0
  286. package/skills/sync-docs-workspace/iteration-2/eval-sprint-closeout/with_skill/run-1/grading.json +95 -0
  287. package/skills/sync-docs-workspace/iteration-2/eval-sprint-closeout/with_skill/run-1/timing.json +1 -0
  288. package/skills/sync-docs-workspace/iteration-2/eval-sprint-closeout/without_skill/outputs/result.md +222 -0
  289. package/skills/sync-docs-workspace/iteration-2/eval-sprint-closeout/without_skill/run-1/grading.json +88 -0
  290. package/skills/sync-docs-workspace/iteration-2/eval-sprint-closeout/without_skill/run-1/timing.json +5 -0
  291. package/skills/sync-docs-workspace/iteration-3/benchmark.json +298 -0
  292. package/skills/sync-docs-workspace/iteration-3/benchmark.md +13 -0
  293. package/skills/sync-docs-workspace/iteration-3/eval-doc-audit/eval_metadata.json +27 -0
  294. package/skills/sync-docs-workspace/iteration-3/eval-doc-audit/with_skill/outputs/result.md +125 -0
  295. package/skills/sync-docs-workspace/iteration-3/eval-doc-audit/with_skill/run-1/grading.json +97 -0
  296. package/skills/sync-docs-workspace/iteration-3/eval-doc-audit/with_skill/run-1/timing.json +5 -0
  297. package/skills/sync-docs-workspace/iteration-3/eval-doc-audit/without_skill/outputs/result.md +144 -0
  298. package/skills/sync-docs-workspace/iteration-3/eval-doc-audit/without_skill/run-1/grading.json +78 -0
  299. package/skills/sync-docs-workspace/iteration-3/eval-doc-audit/without_skill/run-1/timing.json +5 -0
  300. package/skills/sync-docs-workspace/iteration-3/eval-fix-mode/eval_metadata.json +27 -0
  301. package/skills/sync-docs-workspace/iteration-3/eval-fix-mode/with_skill/outputs/result.md +104 -0
  302. package/skills/sync-docs-workspace/iteration-3/eval-fix-mode/with_skill/run-1/grading.json +91 -0
  303. package/skills/sync-docs-workspace/iteration-3/eval-fix-mode/with_skill/run-1/timing.json +5 -0
  304. package/skills/sync-docs-workspace/iteration-3/eval-fix-mode/without_skill/outputs/result.md +79 -0
  305. package/skills/sync-docs-workspace/iteration-3/eval-fix-mode/without_skill/run-1/grading.json +82 -0
  306. package/skills/sync-docs-workspace/iteration-3/eval-fix-mode/without_skill/run-1/timing.json +5 -0
  307. package/skills/sync-docs-workspace/iteration-3/eval-sprint-closeout/eval_metadata.json +27 -0
  308. package/skills/sync-docs-workspace/iteration-3/eval-sprint-closeout/with_skill/outputs/phase1_context.json +302 -0
  309. package/skills/sync-docs-workspace/iteration-3/eval-sprint-closeout/with_skill/outputs/phase2_drift.txt +33 -0
  310. package/skills/sync-docs-workspace/iteration-3/eval-sprint-closeout/with_skill/outputs/phase3_analysis.json +114 -0
  311. package/skills/sync-docs-workspace/iteration-3/eval-sprint-closeout/with_skill/outputs/phase4_fix.txt +118 -0
  312. package/skills/sync-docs-workspace/iteration-3/eval-sprint-closeout/with_skill/outputs/phase5_validate.txt +38 -0
  313. package/skills/sync-docs-workspace/iteration-3/eval-sprint-closeout/with_skill/outputs/result.md +158 -0
  314. package/skills/sync-docs-workspace/iteration-3/eval-sprint-closeout/with_skill/run-1/grading.json +95 -0
  315. package/skills/sync-docs-workspace/iteration-3/eval-sprint-closeout/with_skill/run-1/timing.json +5 -0
  316. package/skills/sync-docs-workspace/iteration-3/eval-sprint-closeout/without_skill/outputs/result.md +71 -0
  317. package/skills/sync-docs-workspace/iteration-3/eval-sprint-closeout/without_skill/run-1/grading.json +90 -0
  318. package/skills/sync-docs-workspace/iteration-3/eval-sprint-closeout/without_skill/run-1/timing.json +5 -0
  319. package/skills/test-planning/SKILL.md +208 -0
  320. package/skills/test-planning/evals/evals.json +23 -0
  321. package/skills/updating-service-skills/SKILL.md +136 -0
  322. package/skills/updating-service-skills/scripts/drift_detector.py +222 -0
  323. package/skills/using-TDD/SKILL.md +410 -0
  324. package/skills/using-quality-gates/SKILL.md +254 -0
  325. package/skills/using-serena-lsp/README.md +8 -0
  326. package/skills/using-serena-lsp/REFERENCE.md +194 -0
  327. package/skills/using-serena-lsp/SKILL.md +82 -0
  328. package/skills/using-service-skills/SKILL.md +108 -0
  329. package/skills/using-service-skills/scripts/cataloger.py +74 -0
  330. package/skills/using-service-skills/scripts/skill_activator.py +152 -0
  331. package/skills/using-service-skills/scripts/test_skill_activator.py +58 -0
  332. package/skills/using-xtrm/SKILL.md +245 -0
  333. package/skills/xt-end/SKILL.md +128 -0
@@ -0,0 +1,482 @@
1
+ #!/usr/bin/env python3
2
+ """
3
+ Scaffolder for creating-service-skills.
4
+
5
+ Phase 1 of the two-phase workflow: generates a structural skeleton for a new
6
+ service skill by parsing docker-compose.yml, Dockerfiles, and dependency files.
7
+ The skeleton contains [PENDING RESEARCH] markers for the agent to fill in Phase 2.
8
+
9
+ Output location: .claude/skills/<service-id>/
10
+ """
11
+
12
+ import sys
13
+ from pathlib import Path
14
+
15
+ # Resolve bootstrap from this script's directory
16
+ script_dir = Path(__file__).parent
17
+ sys.path.insert(0, str(script_dir))
18
+
19
+ from bootstrap import RootResolutionError, get_project_root, register_service # noqa: E402
20
+
21
+ # ---------------------------------------------------------------------------
22
+ # Official documentation map — populated from detected technologies
23
+ # ---------------------------------------------------------------------------
24
+ OFFICIAL_DOCS: dict[str, tuple[str, str]] = {
25
+ # Docker images / databases
26
+ "postgres": ("PostgreSQL", "https://www.postgresql.org/docs/"),
27
+ "timescale": ("TimescaleDB", "https://docs.timescale.com/"),
28
+ "timescaledb": ("TimescaleDB", "https://docs.timescale.com/"),
29
+ "redis": ("Redis", "https://redis.io/docs/"),
30
+ "mysql": ("MySQL", "https://dev.mysql.com/doc/"),
31
+ "mongodb": ("MongoDB", "https://www.mongodb.com/docs/"),
32
+ "mongo": ("MongoDB", "https://www.mongodb.com/docs/"),
33
+ "elasticsearch": ("Elasticsearch", "https://www.elastic.co/guide/"),
34
+ "rabbitmq": ("RabbitMQ", "https://www.rabbitmq.com/documentation.html"),
35
+ "kafka": ("Apache Kafka", "https://kafka.apache.org/documentation/"),
36
+ "clickhouse": ("ClickHouse", "https://clickhouse.com/docs/"),
37
+ # Python packages
38
+ "fastapi": ("FastAPI", "https://fastapi.tiangolo.com/"),
39
+ "flask": ("Flask", "https://flask.palletsprojects.com/"),
40
+ "django": ("Django", "https://docs.djangoproject.com/"),
41
+ "sqlalchemy": ("SQLAlchemy", "https://docs.sqlalchemy.org/"),
42
+ "alembic": ("Alembic", "https://alembic.sqlalchemy.org/en/latest/"),
43
+ "prisma": ("Prisma", "https://www.prisma.io/docs/"),
44
+ "celery": ("Celery", "https://docs.celeryq.dev/"),
45
+ "pydantic": ("Pydantic", "https://docs.pydantic.dev/"),
46
+ "asyncpg": ("asyncpg", "https://magicstack.github.io/asyncpg/"),
47
+ "psycopg2": ("psycopg2", "https://www.psycopg.org/docs/"),
48
+ "psycopg": ("psycopg3", "https://www.psycopg.org/psycopg3/docs/"),
49
+ "aiohttp": ("aiohttp", "https://docs.aiohttp.org/"),
50
+ "httpx": ("HTTPX", "https://www.python-httpx.org/"),
51
+ }
52
+
53
+
54
+ def scaffold_service_skill(service_id: str, compose_data: dict) -> Path:
55
+ """
56
+ Main entry point for Phase 1 scaffolding.
57
+ """
58
+ try:
59
+ project_root = get_project_root()
60
+ except RootResolutionError as e:
61
+ print(f"Error: {e}")
62
+ sys.exit(1)
63
+
64
+ skill_dir = Path(project_root) / ".claude" / "skills" / service_id
65
+ if skill_dir.exists():
66
+ print(f"Skill directory already exists: {skill_dir}")
67
+ print("Aborting to prevent overwriting. Delete it manually if you want to re-scaffold.")
68
+ sys.exit(1)
69
+
70
+ print(f"Scaffolding new service skill: {service_id}")
71
+ print(f"Target directory: {skill_dir}")
72
+
73
+ skill_dir.mkdir(parents=True)
74
+ (skill_dir / "scripts").mkdir()
75
+ (skill_dir / "references").mkdir()
76
+ (skill_dir / "assets").mkdir()
77
+
78
+ # Detect service details from compose
79
+ service_config = compose_data.get("services", {}).get(service_id, {})
80
+
81
+ # 1. Generate SKILL.md
82
+ write_skill_md(service_id, service_config, skill_dir)
83
+
84
+ # 2. Generate script stubs
85
+ write_script_stubs(service_id, skill_dir)
86
+
87
+ # 3. Generate reference stubs
88
+ write_reference_stubs(service_id, skill_dir)
89
+
90
+ # 4. Register service in bootstrap state
91
+ # [TODO] Fill in territory and name properly
92
+ register_service(
93
+ service_id, service_id, [], str((skill_dir / "SKILL.md").relative_to(project_root))
94
+ )
95
+
96
+ print(f"\n✅ Phase 1 Complete for {service_id}")
97
+ print("Next step: Run Phase 2 deep dive for this service.")
98
+ return skill_dir
99
+
100
+
101
+ def write_skill_md(service_id: str, config: dict, skill_dir: Path) -> None:
102
+ """Generate the root SKILL.md file."""
103
+ name = service_id.replace("-", " ").replace("_", " ").title()
104
+ persona = f"{name} Expert"
105
+
106
+ # Detect docs to link
107
+ docs_section = ""
108
+ # [PENDING] Implement documentation auto-detection logic here
109
+
110
+ content = f"""---
111
+ name: {service_id}
112
+ description: >-
113
+ [PENDING RESEARCH] Specialized knowledge for the {name} service.
114
+ Use when debugging, analyzing performance, or understanding this service.
115
+ allowed-tools: Bash(python3 *), Read, Grep, Glob
116
+ ---
117
+
118
+ # {name}
119
+
120
+ ## Service Overview
121
+
122
+ [PENDING RESEARCH] Describe what this service does, its role in the system,
123
+ and whether it runs continuously, as a one-shot job, or on a schedule.
124
+
125
+ **Persona**: {persona}
126
+
127
+ ## Architecture
128
+
129
+ [PENDING RESEARCH]
130
+
131
+ **Entry Point**: [Verify in Dockerfile CMD and docker-compose `command:` field]
132
+ **Container Name**: {service_id}
133
+ **Restart Policy**: [PENDING RESEARCH]
134
+
135
+ **Primary Modules**:
136
+ - [PENDING RESEARCH] List key modules after reading the source tree
137
+
138
+ **Dependencies**: [PENDING RESEARCH] PostgreSQL? Redis? External APIs?
139
+
140
+ ## ⚠️ CRITICAL REQUIREMENTS
141
+
142
+ [PENDING RESEARCH] Add any mandatory patterns, initialization calls, or
143
+ invariants that must not be violated when modifying this service.
144
+
145
+ ## Data Flows
146
+
147
+ [PENDING RESEARCH] Trace the primary data paths through the service.
148
+
149
+ ## Database Interactions
150
+
151
+ [PENDING RESEARCH]
152
+
153
+ | Table | Operation | Timestamp Column | Stale Threshold |
154
+ |-------|-----------|-----------------|-----------------|
155
+ | [table] | INSERT/SELECT | [col] | [N min] |
156
+
157
+ ## Common Operations
158
+
159
+ ### Service Management
160
+
161
+ ```bash
162
+ # Start the service
163
+ docker compose up -d {service_id}
164
+
165
+ # Check logs
166
+ docker logs {service_id} --tail 50
167
+
168
+ # Restart
169
+ docker compose restart {service_id}
170
+ ```
171
+
172
+ ### Data Inspection
173
+
174
+ - **Health check**: `python3 .claude/skills/{service_id}/scripts/health_probe.py`
175
+ - **Log analysis**: `python3 .claude/skills/{service_id}/scripts/log_hunter.py`
176
+ - **Data explorer**: `python3 .claude/skills/{service_id}/scripts/data_explorer.py`
177
+
178
+ ## Troubleshooting Guide
179
+
180
+ [PENDING RESEARCH] Fill from exception handlers and code comments.
181
+
182
+ | Symptom | Likely Cause | Resolution |
183
+ |---------|-------------|------------|
184
+ | [what you see] | [root cause] | [exact command to fix] |
185
+
186
+ Minimum 5 rows required.
187
+
188
+ <!-- SEMANTIC_START -->
189
+ ## Semantic Deep Dive (Human/Agent Refined)
190
+
191
+ [PENDING RESEARCH] Add deep operational knowledge after Phase 2 deep dive.
192
+
193
+ <!-- SEMANTIC_END -->
194
+
195
+ ## Scripts
196
+
197
+ - `scripts/health_probe.py` — Container status + table freshness check
198
+ - `scripts/log_hunter.py` — Service-specific log pattern analysis
199
+ - `scripts/data_explorer.py` — Safe database inspection (read-only)
200
+
201
+ ## References
202
+ {docs_section}
203
+ - `references/deep_dive.md` — Detailed Phase 2 research notes
204
+ - `references/architecture_ssot.md` — Architecture SSOT (link from project SSOT if available)
205
+
206
+ ---
207
+
208
+ *Generated by creating-service-skills Phase 1. Run Phase 2 to fill [PENDING RESEARCH] markers.*
209
+ """ # nosec B608
210
+ (skill_dir / "SKILL.md").write_text(content, encoding="utf-8")
211
+
212
+
213
+ def write_script_stubs(service_id: str, skill_dir: Path) -> None:
214
+ """
215
+ Write Phase 1 script stubs into the skill's scripts/ directory.
216
+ """
217
+ scripts_dir = skill_dir / "scripts"
218
+ scripts_dir.mkdir(parents=True, exist_ok=True)
219
+
220
+ # health_probe.py stub (using replace to avoid f-string escaping hell)
221
+ health_probe_tpl = '''#!/usr/bin/env python3
222
+ """Health probe for {{SERVICE_ID}}.
223
+
224
+ [PENDING RESEARCH] Replace all [FILL] markers during Phase 2 deep dive.
225
+ """
226
+ import json
227
+ import subprocess
228
+ import sys
229
+
230
+ CONTAINER = "{{SERVICE_ID}}"
231
+ # [PENDING RESEARCH] Set the actual external-mapped DB port (e.g. 5433 for host, 5432 for container)
232
+ DB_PORT = 5433
233
+ # [PENDING RESEARCH] Set the actual output table(s) and stale thresholds in minutes
234
+ STALE_CHECKS: list[dict] = [
235
+ # {"table": "table_name", "ts_col": "created_at", "stale_minutes": 10},
236
+ ]
237
+
238
+
239
+ def check_container() -> bool:
240
+ result = subprocess.run(
241
+ ["docker", "inspect", "-f", "{{.State.Running}}", CONTAINER],
242
+ capture_output=True, text=True
243
+ )
244
+ running = result.stdout.strip() == "true"
245
+ print(f"Container {CONTAINER}: {'RUNNING' if running else 'STOPPED'}")
246
+ return running
247
+
248
+
249
+ def check_table_freshness() -> bool:
250
+ """[PENDING RESEARCH] Query actual output tables with correct stale thresholds."""
251
+ if not STALE_CHECKS:
252
+ print("Table freshness: NOT CONFIGURED (Phase 2 required)")
253
+ return True
254
+ # [PENDING RESEARCH] Implement actual DB checks here
255
+ return True
256
+
257
+
258
+ def main(as_json: bool = False) -> None:
259
+ ok = check_container()
260
+ ok &= check_table_freshness()
261
+ if as_json:
262
+ print(json.dumps({"healthy": ok, "service": CONTAINER}))
263
+ else:
264
+ print(f"\\nOverall: {'HEALTHY' if ok else 'UNHEALTHY'}")
265
+ sys.exit(0 if ok else 1)
266
+
267
+
268
+ if __name__ == "__main__":
269
+ import argparse
270
+ p = argparse.ArgumentParser()
271
+ p.add_argument("--json", action="store_true")
272
+ args = p.parse_args()
273
+ main(as_json=args.json)
274
+ '''
275
+ (scripts_dir / "health_probe.py").write_text(
276
+ health_probe_tpl.replace("{{SERVICE_ID}}", service_id), encoding="utf-8"
277
+ )
278
+
279
+ # log_hunter.py stub
280
+ log_hunter_tpl = '''#!/usr/bin/env python3
281
+ """Log hunter for {{SERVICE_ID}}.
282
+
283
+ [PENDING RESEARCH] Replace generic patterns with actual error strings
284
+ found in the codebase exception handlers during Phase 2 deep dive.
285
+ """
286
+ import json
287
+ import re
288
+ import subprocess
289
+ import sys
290
+ from collections import defaultdict
291
+
292
+ CONTAINER = "{{SERVICE_ID}}"
293
+
294
+ # [PENDING RESEARCH] Replace with patterns sourced from the actual codebase.
295
+ # Find them with: search_for_pattern("logger.error|raise|panic!")
296
+ PATTERNS: list[tuple[str, str, str]] = [
297
+ ("ConnectionError", "ERROR", "Database or Redis connectivity issue"),
298
+ ("TimeoutError", "WARNING", "External service latency detected"),
299
+ ]
300
+
301
+
302
+ def hunt_logs(tail: int = 200) -> dict:
303
+ """Tails logs and matches against patterns."""
304
+ result = subprocess.run(
305
+ ["docker", "logs", "--tail", str(tail), CONTAINER],
306
+ capture_output=True, text=True
307
+ )
308
+ logs = result.stdout + result.stderr
309
+ matches = defaultdict(int)
310
+
311
+ for line in logs.splitlines():
312
+ for pattern, level, desc in PATTERNS:
313
+ if pattern in line:
314
+ matches[pattern] += 1
315
+
316
+ return dict(matches)
317
+
318
+
319
+ def main() -> None:
320
+ results = hunt_logs()
321
+ print(f"Log anomalies for {CONTAINER}:")
322
+ if not results:
323
+ print(" ✓ No known error patterns detected in recent logs.")
324
+ else:
325
+ for p, count in results.items():
326
+ print(f" - {p}: {count} occurrences")
327
+
328
+
329
+ if __name__ == "__main__":
330
+ main()
331
+ '''
332
+ (scripts_dir / "log_hunter.py").write_text(
333
+ log_hunter_tpl.replace("{{SERVICE_ID}}", service_id), encoding="utf-8"
334
+ )
335
+
336
+ # data_explorer.py stub
337
+ data_explorer_tpl = '''#!/usr/bin/env python3
338
+ """Data explorer for {{SERVICE_ID}} — read-only DB inspection.
339
+
340
+ [PENDING RESEARCH] Fill in actual table names, columns, and host port
341
+ during Phase 2 deep dive. All queries must use parameterized %s placeholders.
342
+ """
343
+ import json
344
+ import sys
345
+
346
+ # [PENDING RESEARCH] Set the actual table and connection settings
347
+ TABLE = "[PENDING RESEARCH]"
348
+ DB_HOST = "localhost"
349
+ DB_PORT = 5433 # [PENDING RESEARCH] external mapped port, not container-internal
350
+ DB_NAME = "[PENDING RESEARCH]"
351
+ DB_USER = "postgres"
352
+
353
+
354
+ def recent_rows(limit: int = 20, as_json: bool = False) -> None:
355
+ """[PENDING RESEARCH] Query most recent rows from the output table."""
356
+ print(f"[PENDING RESEARCH] Implement: SELECT * FROM {TABLE} ORDER BY created_at DESC LIMIT %s")
357
+ print("Use parameterized queries only — no f-strings in SQL.")
358
+
359
+
360
+ def main() -> None:
361
+ import argparse
362
+ p = argparse.ArgumentParser()
363
+ p.add_argument("--limit", type=int, default=20)
364
+ p.add_argument("--json", action="store_true")
365
+ args = p.parse_args()
366
+ recent_rows(args.limit, args.json)
367
+
368
+
369
+ if __name__ == "__main__":
370
+ main()
371
+ '''
372
+ (scripts_dir / "data_explorer.py").write_text(
373
+ data_explorer_tpl.replace("{{SERVICE_ID}}", service_id), encoding="utf-8"
374
+ )
375
+
376
+ # Makefile — standard diagnostic runner for every skill
377
+ makefile_tpl = """# Skill diagnostic scripts for {{SERVICE_ID}}
378
+ # Usage: make <target> (from this directory)
379
+ # Override python: make health PYTHON=/path/to/python3
380
+
381
+ # Auto-detect: prefer project venv (4 levels up), fall back to system python3
382
+ _VENV := $(wildcard ../../../../venv/bin/python3)
383
+ PYTHON ?= $(if $(_VENV),../../../../venv/bin/python3,python3)
384
+
385
+ .PHONY: health health-json data data-json logs errors db help
386
+
387
+ help:
388
+ \t@echo "Available targets:"
389
+ \t@echo " health - Run health probe (human readable)"
390
+ \t@echo " health-json - Run health probe (JSON output)"
391
+ \t@echo " data - Show latest DB records"
392
+ \t@echo " data-json - Show latest DB records (JSON, limit 5)"
393
+ \t@echo " logs - Tail and analyze recent logs"
394
+ \t@echo " errors - Show errors/criticals only"
395
+ \t@echo " db - Run DB helper example queries"
396
+ \t@echo ""
397
+ \t@echo "Python: $(PYTHON)"
398
+
399
+ health:
400
+ \t$(PYTHON) health_probe.py
401
+
402
+ health-json:
403
+ \t$(PYTHON) health_probe.py --json
404
+
405
+ data:
406
+ \t$(PYTHON) data_explorer.py
407
+
408
+ data-json:
409
+ \t$(PYTHON) data_explorer.py --json --limit 5
410
+
411
+ logs:
412
+ \t$(PYTHON) log_hunter.py --tail 50
413
+
414
+ errors:
415
+ \t$(PYTHON) log_hunter.py --errors-only --tail 50
416
+
417
+ db:
418
+ \t$(PYTHON) db_helper.py
419
+ """
420
+ (scripts_dir / "Makefile").write_text(
421
+ makefile_tpl.replace("{{SERVICE_ID}}", service_id), encoding="utf-8"
422
+ )
423
+
424
+
425
+ def write_reference_stubs(service_id: str, skill_dir: Path) -> None:
426
+ """Generate reference markdown files."""
427
+ name = service_id.replace("-", " ").replace("_", " ").title()
428
+
429
+ # deep_dive.md
430
+ (skill_dir / "references" / "deep_dive.md").write_text(
431
+ f"""# Phase 2 Research: {name}
432
+
433
+ ## Source Analysis
434
+ - **Entry Point**: [FILL]
435
+ - **Main Loop**: [FILL]
436
+ - **Error Handlers**: [FILL]
437
+
438
+ ## Logic Trace
439
+ 1. [Step 1]
440
+ 2. [Step 2]
441
+
442
+ ## Invariants
443
+ - [Must always X]
444
+ - [Must never Y]
445
+ """,
446
+ encoding="utf-8",
447
+ )
448
+
449
+ # architecture_ssot.md (stub)
450
+ (skill_dir / "references" / "architecture_ssot.md").write_text(
451
+ f"""# {name} Architecture
452
+
453
+ [PENDING RESEARCH] Replace with link to project-level SSOT if exists,
454
+ otherwise document high-level components here.
455
+ """,
456
+ encoding="utf-8",
457
+ )
458
+
459
+
460
+ if __name__ == "__main__":
461
+ import yaml
462
+
463
+ if len(sys.argv) < 2:
464
+ print("Usage: scaffolder.py <docker-compose-path> [service-id]")
465
+ sys.exit(1)
466
+
467
+ compose_path = Path(sys.argv[1])
468
+ if not compose_path.exists():
469
+ print(f"Compose file not found: {compose_path}")
470
+ sys.exit(1)
471
+
472
+ with open(compose_path) as f:
473
+ data = yaml.safe_load(f)
474
+
475
+ if len(sys.argv) > 2:
476
+ # Scaffold specific service
477
+ sid = sys.argv[2]
478
+ scaffold_service_skill(sid, data)
479
+ else:
480
+ # Scaffold all services in compose
481
+ for sid in data.get("services", {}).keys():
482
+ scaffold_service_skill(sid, data)
@@ -0,0 +1,196 @@
1
+ ---
2
+ name: delegating
3
+ description: >-
4
+ Proactively delegates tasks to cost-optimized agents before working in main session.
5
+ MUST suggest for: tests, typos, formatting, docs, refactors, code reviews, feature
6
+ implementation, debugging, commit validation. Skips main session token usage by routing
7
+ to GLM (simple/deterministic), Gemini (reasoning/analysis), Qwen (quality/patterns),
8
+ or multi-agent orchestration (review, feature dev, bug hunt). Never suggest for:
9
+ architecture decisions, security-critical code, unknown-cause bugs, performance optimization.
10
+ allowed-tools: Bash
11
+ ---
12
+
13
+ # Delegating Tasks
14
+
15
+ Delegate tasks to cost-optimized models (CCS) or multi-agent orchestration workflows (Gemini/Qwen).
16
+
17
+ ## When to Suggest
18
+
19
+ **Task Pattern → Backend Mapping** (auto-selection logic):
20
+
21
+ | Task Pattern | Backend | Cost | Reason |
22
+ |-------------------------------|-------------|--------|--------------------------------|
23
+ | `typo\|test\|doc\|format` | CCS (GLM) | LOW | Simple deterministic |
24
+ | `think\|analyze\|reason` | CCS (Gemini)| MEDIUM | Requires reasoning |
25
+ | `review.*(code\|security)` | Orchestration| HIGH | Multi-agent code review |
26
+ | `implement.*feature` | Orchestration| HIGH | Full development workflow |
27
+ | `validate.*commit` | Orchestration| MEDIUM | Security+Quality validation |
28
+ | `debug\|bug.*unknown` | Orchestration| HIGH | Root cause investigation |
29
+
30
+ **Never Suggest For:**
31
+ - Architecture decisions requiring human judgment
32
+ - Security-critical without review
33
+ - Performance optimization (needs profiling first)
34
+
35
+ ---
36
+
37
+ ## Interactive Menu
38
+
39
+ ### Step 1: Delegation Choice
40
+
41
+ Use AskUserQuestion with:
42
+ - question: "This task can be delegated. How would you like to proceed?"
43
+ - header: "Execution"
44
+ - options:
45
+ - "Delegate (Recommended)" — Execute via optimal backend. Saves main session tokens and uses cost-efficient models.
46
+ - "Work in main session" — Execute in current Claude session. Better for tasks requiring discussion or complex context.
47
+
48
+ **If user selects "Delegate"** → Continue to Step 2
49
+ **If user selects "Work in main session"** → Execute task normally (don't delegate)
50
+
51
+ ### Step 2: Backend Selection
52
+
53
+ Use AskUserQuestion with:
54
+ - question: "Which backend should handle this task?"
55
+ - header: "Backend"
56
+ - options:
57
+ - "Auto-select (Recommended)" — Analyzes task keywords and selects optimal backend/profile automatically.
58
+ - "GLM - Cost-optimized" — Fast model for tests, typos, formatting [LOW COST]
59
+ - "Gemini - Reasoning" — Analysis, thinking, architecture tasks [MEDIUM COST]
60
+ - "Qwen - Quality" — Code quality, pattern detection [MEDIUM COST]
61
+ - "Multi-Agent Orchestration" — Direct Gemini/Qwen collaboration for complex tasks (review, feature dev, debugging) [HIGH COST]
62
+
63
+ ---
64
+
65
+ ## Auto-Selection Logic
66
+
67
+ **Configuration-Driven:** All pattern matching is defined in [config.yaml](config.yaml), not hardcoded.
68
+
69
+ ### Configuration Structure
70
+
71
+ The skill reads `config.yaml` to determine:
72
+ 1. **Available backends** (CCS profiles + Orchestration workflows)
73
+ 2. **Pattern mappings** (task keywords → backend selection)
74
+ 3. **Priority order** (Orchestration workflows checked before CCS)
75
+ 4. **Default fallback** (when no pattern matches)
76
+
77
+ ---
78
+
79
+ ## Orchestration Workflow Selection (Autonomous)
80
+
81
+ When `backend: 'orchestration'` is selected, **Claude autonomously** chooses the appropriate workflow and orchestrates between `gemini` and `qwen` CLI tools.
82
+
83
+ ### Selection Process
84
+
85
+ 1. **Load config** - Read workflow definitions from `config.yaml`
86
+ 2. **Match patterns** - Determine which orchestration pattern (collaborative, handshake, troubleshoot) applies.
87
+ 3. **Execute turn protocol** - Use CLI commands sequentially:
88
+ - `gemini -p "..."`
89
+ - `qwen "..."`
90
+ - `gemini -r latest -p "..."` (to refine)
91
+
92
+ ### Turn Protocols
93
+
94
+ | Workflow | Protocol |
95
+ | :--- | :--- |
96
+ | **handshake** | 1 turn: Agent A (Gemini) proposes -> Agent B (Qwen) validates. |
97
+ | **collaborative** | 3 turns: Gemini designs -> Qwen critiques -> Gemini refines. |
98
+ | **troubleshoot** | 4 turns: Gemini hypothesis -> Qwen verification -> Gemini root cause -> Final synthesis. |
99
+
100
+ ---
101
+
102
+ ## Execution Flow
103
+
104
+ ### For Direct Invocation (`/delegation [task]` or `/delegate [task]`)
105
+
106
+ 1. **Parse override flag** (if present: `--glm`, `--gemini`, `--orchestrate`, etc.)
107
+ 2. **Auto-select backend** using keyword-based logic.
108
+ 3. **Route to appropriate backend** (see sections below).
109
+ 4. **Report results**: Backend, Workflow (if Orchestration), Cost indicator, Duration.
110
+
111
+ ---
112
+
113
+ ### CCS / GLM Execution
114
+
115
+ CCS wraps the `claude` CLI and **only works with GLM**. It requires a PTY for output and is blocked by the `CLAUDECODE` nested-session guard — always run via tmux:
116
+
117
+ ```bash
118
+ tmux new-session -d -s ccs_task "env -u CLAUDECODE ccs glm -p '{task}' > /tmp/ccs_out.txt 2>&1"
119
+ sleep 30 # or poll until session exits
120
+ cat /tmp/ccs_out.txt
121
+ ```
122
+
123
+ **If the task requires file modifications**, add `--dangerously-skip-permissions`:
124
+
125
+ ```bash
126
+ tmux new-session -d -s ccs_task "env -u CLAUDECODE ccs glm --dangerously-skip-permissions -p '{task}' > /tmp/ccs_out.txt 2>&1"
127
+ ```
128
+
129
+ ---
130
+
131
+ ### Gemini CLI Execution
132
+
133
+ Gemini is a **direct CLI** — no tmux workaround needed:
134
+
135
+ ```bash
136
+ gemini -p "task description"
137
+ ```
138
+
139
+ **If the task requires file modifications**, add `-y` to auto-approve all tool calls:
140
+
141
+ ```bash
142
+ gemini -y -p "task description"
143
+ ```
144
+
145
+ ---
146
+
147
+ ### Qwen CLI Execution
148
+
149
+ Qwen is a **direct CLI** — no tmux workaround needed:
150
+
151
+ ```bash
152
+ qwen "task description"
153
+ ```
154
+
155
+ **If the task requires file modifications**, add `-y` to auto-approve all tool calls:
156
+
157
+ ```bash
158
+ qwen -y "task description"
159
+ ```
160
+
161
+ ---
162
+
163
+ ### Orchestration Execution
164
+
165
+ Multi-turn sequences use Gemini and Qwen **direct CLIs**. Add `-y` to all turns when modifications are expected:
166
+
167
+ ```bash
168
+ gemini -y -p "..." # Turn 1
169
+ qwen -y "..." # Turn 2
170
+ gemini -y -r latest -p "..." # Turn 3 (refine)
171
+ ```
172
+
173
+ ---
174
+
175
+ ## Examples
176
+
177
+ ### Auto-Selection Examples
178
+
179
+ **CCS Simple:**
180
+ - `/delegate add unit tests for UserService` → CCS (GLM)
181
+ - `/delegate think about the best database schema` → CCS (Gemini)
182
+
183
+ **Orchestration Workflows:**
184
+ - `/delegate review this code for security issues` → Orchestration (parallel-review)
185
+ - `/delegate implement OAuth authentication feature` → Orchestration (feature-design)
186
+ - `/delegate debug crash on startup` → Orchestration (bug-hunt)
187
+
188
+ ---
189
+
190
+ ## Notes
191
+
192
+ ### Version 7.0.0 - Direct Orchestration
193
+ - **Independent of unitAI**: Now uses direct `gemini` and `qwen` CLI calls.
194
+ - **Unified backends**: CCS (cost-optimized) + Direct Orchestration.
195
+ - **Config-driven**: All behavior defined in `config.yaml`.
196
+ - **Reference**: Uses patterns from [orchestrating-agents](../orchestrating-agents/SKILL.md).