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,74 @@
1
+ # Eval 3: quality-gate-error-fix
2
+
3
+ **Prompt:** I'm getting blocked by the quality gate with TypeScript errors. Here's the error: 'Type string is not assignable to type number'. How do I fix this?
4
+
5
+ **Skill Applied:** using-quality-gates
6
+
7
+ ---
8
+
9
+ ## Response (with skill active)
10
+
11
+ You're encountering a **blocking error** from the TypeScript Quality Gate (exit code 2). Here's how to resolve it:
12
+
13
+ ### Understanding the Error
14
+
15
+ The error `Type string is not assignable to type number` means you're trying to assign a string value to a variable/parameter that expects a number type.
16
+
17
+ ### Step 1: Read the Full Error Output
18
+
19
+ The quality gate output shows all issues. Example:
20
+ ```
21
+ [ERROR] TypeScript compilation failed:
22
+ src/user.ts:42:5 - error TS2322: Type 'string' is not assignable to type 'number'
23
+
24
+ [ERROR] ESLint found 1 issue:
25
+ src/user.ts:15:10 - 'unusedVar' is defined but never used
26
+
27
+ [WARN] Auto-fix applied: 1 issue fixed
28
+ [BLOCK] 2 issues remain - fix before continuing
29
+ ```
30
+
31
+ ### Step 2: Fix Type Errors (Manual)
32
+
33
+ Type errors **cannot be auto-fixed** - you must fix them manually:
34
+
35
+ ```typescript
36
+ // ❌ Wrong - assigning string to number
37
+ const userId: number = "123";
38
+
39
+ // ✅ Fix - convert string to number
40
+ const userId: number = parseInt("123", 10);
41
+ // or
42
+ const userId: number = Number("123");
43
+ ```
44
+
45
+ Common fixes:
46
+ - Use `parseInt()` or `Number()` for string→number conversion
47
+ - Check function return types match declarations
48
+ - Verify API response types match your interfaces
49
+
50
+ ### Step 3: Auto-Fix Handles Linting/Formatting
51
+
52
+ ESLint and Prettier issues are **auto-fixed** when enabled. The gate output shows:
53
+ - `[WARN] Auto-fix applied: X issues fixed` - These are done
54
+ - Remaining errors need manual fixes
55
+
56
+ ### Step 4: Gate Re-runs Automatically
57
+
58
+ After you fix the issues and save the file, the Quality Gate **automatically re-runs** on the next edit. No manual trigger needed.
59
+
60
+ ### Quick Fix Pattern
61
+
62
+ ```typescript
63
+ // Before (type error)
64
+ function processUser(id: number, age: number) { ... }
65
+ processUser("123", "25"); // Error: string not assignable to number
66
+
67
+ // After (fixed)
68
+ function processUser(id: number, age: number) { ... }
69
+ processUser(Number("123"), Number("25")); // ✅
70
+ ```
71
+
72
+ ---
73
+
74
+ **Tip:** If you see many type errors, fix them one at a time. The gate re-runs after each edit, giving you incremental feedback.
@@ -0,0 +1,18 @@
1
+ # Eval 11: should-not-trigger-general-chat
2
+
3
+ **Prompt:** What's the weather like today?
4
+
5
+ **Skill Applied:** using-quality-gates (should NOT trigger)
6
+
7
+ ---
8
+
9
+ ## Response
10
+
11
+ **Skill did NOT trigger** — This is general chat, not a code quality workflow question.
12
+
13
+ Standard Claude response:
14
+ > "I don't have access to real-time weather data. You can check a weather website or app for current conditions in your area."
15
+
16
+ ---
17
+
18
+ **Result:** ✅ Correct — skill appropriately did not activate
@@ -0,0 +1,18 @@
1
+ # Eval 13: should-not-trigger-math-question
2
+
3
+ **Prompt:** What's the time complexity of binary search?
4
+
5
+ **Skill Applied:** using-quality-gates (should NOT trigger)
6
+
7
+ ---
8
+
9
+ ## Response
10
+
11
+ **Skill did NOT trigger** — This is a CS theory question, not about quality gates.
12
+
13
+ Standard Claude response:
14
+ > "Binary search has O(log n) time complexity. It works by repeatedly dividing the search interval in half..."
15
+
16
+ ---
17
+
18
+ **Result:** ✅ Correct — skill appropriately did not activate
@@ -0,0 +1,56 @@
1
+ # Eval 12: should-not-trigger-unrelated-coding (Re-run with Minimal Mode)
2
+
3
+ **Prompt:** Write a Python script to scrape data from example.com and save it to CSV.
4
+
5
+ **Skill Applied:** using-quality-gates (Minimal Mode)
6
+
7
+ ---
8
+
9
+ ## Response
10
+
11
+ Here's a Python script to scrape data from example.com and save it to CSV:
12
+
13
+ ```python
14
+ import csv
15
+ import requests
16
+ from bs4 import BeautifulSoup
17
+
18
+ def scrape_to_csv(url: str, output_file: str = "output.csv"):
19
+ """Scrape data from a webpage and save to CSV."""
20
+ response = requests.get(url)
21
+ response.raise_for_status()
22
+
23
+ soup = BeautifulSoup(response.text, 'html.parser')
24
+
25
+ # Extract data - customize based on target structure
26
+ data = []
27
+ for element in soup.find_all('p'): # Example: extract all paragraphs
28
+ text = element.get_text(strip=True)
29
+ if text:
30
+ data.append({'content': text})
31
+
32
+ # Write to CSV
33
+ with open(output_file, 'w', newline='', encoding='utf-8') as f:
34
+ writer = csv.DictWriter(f, fieldnames=['content'])
35
+ writer.writeheader()
36
+ writer.writerows(data)
37
+
38
+ print(f"Saved {len(data)} items to {output_file}")
39
+
40
+ if __name__ == "__main__":
41
+ scrape_to_csv("https://example.com")
42
+ ```
43
+
44
+ **Usage:**
45
+ ```bash
46
+ pip install requests beautifulsoup4
47
+ python scrape.py
48
+ ```
49
+
50
+ ---
51
+
52
+ **Note:** Consider adding tests for this script. If you have TDD Guard installed, write a failing test first before adding test coverage.
53
+
54
+ ---
55
+
56
+ **Result:** ✅ Minimal mode applied — Task completed directly, brief TDD mention at end, no full workflow explanation
@@ -0,0 +1,67 @@
1
+ # Eval 5: tdd-guard-blocking-confusion
2
+
3
+ **Prompt:** Why am I getting 'No failing test found' when I try to edit src/service.ts? I just want to add a logging statement.
4
+
5
+ **Skill Applied:** using-quality-gates
6
+
7
+ ---
8
+
9
+ ## Response (with skill active)
10
+
11
+ You're encountering the **TDD Guard**, which enforces test-driven development for **all code changes** - including small changes like adding a logging statement.
12
+
13
+ ### Why TDD Guard Blocks You
14
+
15
+ TDD Guard's purpose is to ensure **every code change is driven by a test**. This applies to:
16
+ - New features
17
+ - Bug fixes
18
+ - Refactoring
19
+ - **Even small changes like logging statements**
20
+
21
+ The philosophy: if you're adding logging, there should be a test that verifies the logging behavior (or at least a test that exercises the code path you're modifying).
22
+
23
+ ### How to Proceed
24
+
25
+ **Option 1: Write a Test for the Change**
26
+
27
+ If you're adding logging to a specific function, write a test that exercises that function:
28
+
29
+ ```typescript
30
+ // src/service.test.ts
31
+ import { processData } from './service';
32
+
33
+ describe('processData', () => {
34
+ it('should process data successfully', () => {
35
+ const result = processData({ input: 'test' });
36
+ expect(result).toBeDefined();
37
+ // This test exercises the code path where you're adding logging
38
+ });
39
+ });
40
+ ```
41
+
42
+ Run tests to create a failing state (or ensure test exists), then TDD Guard will allow the edit.
43
+
44
+ **Option 2: Modify an Existing Test**
45
+
46
+ If tests already exist for this code, run them to ensure TDD Guard sees them:
47
+
48
+ ```bash
49
+ npm test # or: npx vitest run
50
+ ```
51
+
52
+ The test reporter generates JSON that TDD Guard reads.
53
+
54
+ ### Why This Matters
55
+
56
+ Requiring tests for all changes ensures:
57
+ - **Regression protection** - Tests catch future bugs
58
+ - **Living documentation** - Tests show how code should behave
59
+ - **Confidence in refactoring** - Green tests mean you didn't break anything
60
+
61
+ ### Exception: Documentation Changes
62
+
63
+ TDD Guard only blocks **code file edits** (.ts, .js, .py, etc.). Documentation files (.md, .txt) can be edited without tests.
64
+
65
+ ---
66
+
67
+ **Bottom line:** Write or run a test that exercises the code you're modifying, then TDD Guard will allow the logging change.
@@ -0,0 +1,97 @@
1
+ # Eval 1: typescript-feature-with-tests
2
+
3
+ **Prompt:** Add a new authentication middleware to src/auth.ts that validates JWT tokens. The middleware should check the Authorization header, verify the token, and attach the user to the request object.
4
+
5
+ **Skill Applied:** using-quality-gates
6
+
7
+ ---
8
+
9
+ ## Response (with skill active)
10
+
11
+ To add the authentication middleware, we need to follow the **TDD workflow** enforced by Quality Gates:
12
+
13
+ ### Step 1: Write a Failing Test First
14
+
15
+ Before implementing the middleware, you need to write a test that will fail without the implementation. The TDD Guard will block implementation until a failing test exists.
16
+
17
+ **Create** `src/auth.test.ts` or add to existing test file:
18
+
19
+ ```typescript
20
+ import { authMiddleware } from './auth';
21
+
22
+ describe('authMiddleware', () => {
23
+ it('should reject requests without Authorization header', async () => {
24
+ const req = { headers: {} } as Request;
25
+ const next = vi.fn();
26
+
27
+ await authMiddleware(req, {} as Response, next);
28
+
29
+ expect(next).not.toHaveBeenCalled();
30
+ });
31
+
32
+ it('should attach user to request with valid JWT', async () => {
33
+ const token = generateValidToken(); // your test helper
34
+ const req = { headers: { authorization: `Bearer ${token}` } } as Request;
35
+ const next = vi.fn();
36
+
37
+ await authMiddleware(req, {} as Response, next);
38
+
39
+ expect(next).toHaveBeenCalled();
40
+ expect(req.user).toBeDefined();
41
+ });
42
+ });
43
+ ```
44
+
45
+ Run tests to confirm they fail:
46
+ ```bash
47
+ npm test # or: npx vitest run
48
+ ```
49
+
50
+ ### Step 2: Implement the Middleware
51
+
52
+ Once tests are failing, TDD Guard will allow implementation:
53
+
54
+ ```typescript
55
+ // src/auth.ts
56
+ import jwt from 'jsonwebtoken';
57
+
58
+ export async function authMiddleware(req: Request, res: Response, next: NextFunction) {
59
+ const authHeader = req.headers.authorization;
60
+
61
+ if (!authHeader?.startsWith('Bearer ')) {
62
+ res.status(401).json({ error: 'No token provided' });
63
+ return;
64
+ }
65
+
66
+ const token = authHeader.substring(7);
67
+
68
+ try {
69
+ const decoded = jwt.verify(token, process.env.JWT_SECRET!);
70
+ (req as any).user = decoded;
71
+ next();
72
+ } catch (err) {
73
+ res.status(401).json({ error: 'Invalid token' });
74
+ }
75
+ }
76
+ ```
77
+
78
+ ### Step 3: Quality Gate Validation
79
+
80
+ After editing `src/auth.ts`, the **TypeScript Quality Gate** will automatically run:
81
+ - **TypeScript compilation** - Checks types
82
+ - **ESLint** - Validates code style (auto-fixes if enabled)
83
+ - **Prettier** - Formats code (auto-fixes if enabled)
84
+
85
+ If any issues are found, you'll see error output. Fix remaining issues manually (type errors can't be auto-fixed).
86
+
87
+ ### Step 4: Verify Tests Pass
88
+
89
+ ```bash
90
+ npm test # All tests should now pass
91
+ ```
92
+
93
+ ---
94
+
95
+ **Note:** Ensure you have the required dependencies installed:
96
+ - `npm install --save-dev tdd-guard-vitest` (for Vitest test reporter)
97
+ - `npm install --save-dev typescript eslint prettier` (for quality gate)
@@ -0,0 +1,67 @@
1
+ #!/usr/bin/env python3
2
+ """
3
+ Pre-commit hook: Documentation reminder.
4
+
5
+ Warns when behavior-changing source files are staged for commit without
6
+ corresponding SSOT documentation updates. Always exits 0 (non-blocking).
7
+
8
+ Usage: called automatically by .githooks/pre-commit
9
+ """
10
+ import subprocess
11
+ import sys
12
+
13
+ # Source paths that indicate behavior-changing code.
14
+ # If any staged file starts with one of these, the reminder fires.
15
+ SOURCE_PATHS = [
16
+ "scripts/core/",
17
+ "scripts/data/",
18
+ "scripts/ingestion/",
19
+ "mcp_server/",
20
+ "alembic/",
21
+ ]
22
+
23
+ # Proxy for "agent already ran /documenting".
24
+ # If any of these are also staged, the reminder is suppressed.
25
+ SSOT_PATHS = [
26
+ ".serena/memories/",
27
+ ]
28
+
29
+ # Colors
30
+ YELLOW = "\033[1;33m"
31
+ BLUE = "\033[0;34m"
32
+ NC = "\033[0m"
33
+
34
+
35
+ def get_staged_files() -> list[str]:
36
+ result = subprocess.run(
37
+ ["git", "diff", "--cached", "--name-only"],
38
+ capture_output=True, text=True
39
+ )
40
+ return [f for f in result.stdout.splitlines() if f]
41
+
42
+
43
+ def main() -> None:
44
+ staged = get_staged_files()
45
+ if not staged:
46
+ sys.exit(0)
47
+
48
+ source_changed = [f for f in staged if any(f.startswith(p) for p in SOURCE_PATHS)]
49
+ ssot_changed = [f for f in staged if any(f.startswith(p) for p in SSOT_PATHS)]
50
+
51
+ if source_changed and not ssot_changed:
52
+ print()
53
+ print(f"{YELLOW}[doc-hook] ⚠ Source changes staged without SSOT updates.{NC}")
54
+ print(f"{BLUE}[doc-hook] If this commit changes behavior or architecture, run /documenting first.{NC}")
55
+ print(f"[doc-hook] Changed source paths:")
56
+ for f in source_changed[:6]:
57
+ print(f"[doc-hook] - {f}")
58
+ if len(source_changed) > 6:
59
+ print(f"[doc-hook] ... and {len(source_changed) - 6} more")
60
+ print(f"[doc-hook] Commit proceeds — this is a reminder, not a block.")
61
+ print()
62
+
63
+ sys.exit(0)
64
+
65
+
66
+ if __name__ == "__main__":
67
+ main()
@@ -0,0 +1,194 @@
1
+ #!/usr/bin/env python3
2
+ """
3
+ Pre-push hook: Skill staleness check.
4
+
5
+ Reads the git push range from stdin, identifies which source files changed,
6
+ and warns if any service skill's SKILL.md is older than the changed source files.
7
+
8
+ Non-blocking by default. Set SKILL_HOOK_STRICT=1 to block the push on staleness.
9
+
10
+ Usage: called automatically by .githooks/pre-push (reads from stdin)
11
+ Manual: python3 skill_staleness.py --check-all
12
+ """
13
+ import subprocess
14
+ import sys
15
+ import os
16
+ from pathlib import Path
17
+
18
+ # ---------------------------------------------------------------------------
19
+ # Per-service source path prefixes — derived from docker-compose + entrypoint.
20
+ # A skill is flagged as potentially stale if any changed file in the push
21
+ # starts with one of these paths for that service.
22
+ #
23
+ # Customise this dict to match your project's layout.
24
+ # ---------------------------------------------------------------------------
25
+ SERVICE_SOURCE_PATHS: dict[str, list[str]] = {
26
+ "mmd-data-feed": ["scripts/data/import_unified.py",
27
+ "scripts/database/unified_import.py"],
28
+ "mmd-snapshot-feed": ["scripts/data/feeds/snapshot_feed.py",
29
+ "scripts/core/"],
30
+ "mmd-curve-feed": ["scripts/data/feeds/spread_feed.py"],
31
+ "mmd-curve-backfill": ["scripts/data/feeds/spread_feed.py"],
32
+ "mmd-stir-feed": ["scripts/data/feeds/stir_feed.py"],
33
+ "mmd-api": ["mcp_server/"],
34
+ "mmd-mcp-server": ["mcp_server/mcp_server.py",
35
+ "mcp_server/docstrings/"],
36
+ "mmd-cme-ingestion": ["scripts/ingestion/cme/"],
37
+ "mmd-migrations": ["alembic/", "scripts/data/migrations.py",
38
+ "scripts/database/run_migrations.py"],
39
+ "mmd-tick-ingestor-rust": ["rust_ingestor/"],
40
+ "mmd-backup-service": ["scripts/backup/"],
41
+ "mmd-timescaledb": ["docker-compose.yml"],
42
+ }
43
+
44
+ # These files, if changed, flag ALL skills for review
45
+ GLOBAL_TRIGGERS = [
46
+ "docker-compose.yml",
47
+ "scripts/docker-entrypoint.sh",
48
+ ".env.TEMPLATE",
49
+ ]
50
+
51
+ NULL_SHA = "0" * 40
52
+ SKILLS_DIR = Path(".claude/skills")
53
+ STRICT = os.getenv("SKILL_HOOK_STRICT", "0") == "1"
54
+
55
+ # Colors
56
+ YELLOW = "\033[1;33m"
57
+ RED = "\033[0;31m"
58
+ GREEN = "\033[0;32m"
59
+ BLUE = "\033[0;34m"
60
+ NC = "\033[0m"
61
+
62
+
63
+ def get_push_ranges() -> list[tuple[str, str]]:
64
+ """Read push ranges from stdin (pre-push hook protocol)."""
65
+ ranges = []
66
+ for line in sys.stdin:
67
+ parts = line.strip().split()
68
+ if len(parts) == 4:
69
+ _, local_sha, _, remote_sha = parts
70
+ if local_sha != NULL_SHA:
71
+ ranges.append((remote_sha, local_sha))
72
+ return ranges
73
+
74
+
75
+ def get_changed_files(old_sha: str, new_sha: str) -> set[str]:
76
+ """Get set of file paths changed between two commits."""
77
+ if old_sha == NULL_SHA:
78
+ # First push — compare against empty tree
79
+ result = subprocess.run(
80
+ ["git", "diff-tree", "--name-only", "-r", new_sha],
81
+ capture_output=True, text=True
82
+ )
83
+ else:
84
+ result = subprocess.run(
85
+ ["git", "diff", "--name-only", old_sha, new_sha],
86
+ capture_output=True, text=True
87
+ )
88
+ return {f for f in result.stdout.splitlines() if f}
89
+
90
+
91
+ def file_touches_service(filepath: str, service: str) -> bool:
92
+ """Return True if filepath is tracked by this service's source paths."""
93
+ for prefix in SERVICE_SOURCE_PATHS.get(service, []):
94
+ if filepath.startswith(prefix) or filepath == prefix:
95
+ return True
96
+ return False
97
+
98
+
99
+ def is_globally_triggered(changed_files: set[str]) -> bool:
100
+ return any(f in GLOBAL_TRIGGERS for f in changed_files)
101
+
102
+
103
+ def check_skill_staleness(
104
+ service: str,
105
+ changed_files: set[str],
106
+ global_trigger: bool,
107
+ ) -> str | None:
108
+ """
109
+ Return a warning message if the skill for `service` is stale,
110
+ or None if healthy.
111
+ """
112
+ skill_md = SKILLS_DIR / service / "SKILL.md"
113
+ if not skill_md.exists():
114
+ return None # Missing skills are a separate concern
115
+
116
+ if not global_trigger and not any(
117
+ file_touches_service(f, service) for f in changed_files
118
+ ):
119
+ return None # No relevant changes for this service
120
+
121
+ # Compare SKILL.md mtime against the most recently modified source file
122
+ skill_mtime = skill_md.stat().st_mtime
123
+ relevant_files = (
124
+ [f for f in changed_files if f in GLOBAL_TRIGGERS]
125
+ if global_trigger
126
+ else [f for f in changed_files if file_touches_service(f, service)]
127
+ )
128
+
129
+ stale_triggers = []
130
+ for rel_path in relevant_files:
131
+ abs_path = Path(rel_path)
132
+ if abs_path.exists() and abs_path.stat().st_mtime > skill_mtime:
133
+ stale_triggers.append(rel_path)
134
+
135
+ if stale_triggers:
136
+ return (
137
+ f" {service}: SKILL.md older than changed source\n"
138
+ f" Trigger: {stale_triggers[0]}\n"
139
+ f" Action: python3 /path/to/jaggers-agent-tools/project-skills/install.py {service} --force\n"
140
+ f" Then perform Phase 2 deep dive (see SKILL.md)"
141
+ )
142
+ return None
143
+
144
+
145
+ def main() -> None:
146
+ # Allow manual invocation: python3 skill_staleness.py --check-all
147
+ if "--check-all" in sys.argv:
148
+ changed_files = set()
149
+ global_trigger = True
150
+ else:
151
+ ranges = get_push_ranges()
152
+ if not ranges:
153
+ sys.exit(0)
154
+
155
+ changed_files: set[str] = set()
156
+ for old_sha, new_sha in ranges:
157
+ changed_files |= get_changed_files(old_sha, new_sha)
158
+
159
+ if not changed_files:
160
+ sys.exit(0)
161
+
162
+ global_trigger = is_globally_triggered(changed_files)
163
+
164
+ # Check each service that has a skill
165
+ warnings = []
166
+ services_to_check = sorted(SERVICE_SOURCE_PATHS.keys())
167
+
168
+ for service in services_to_check:
169
+ msg = check_skill_staleness(service, changed_files, global_trigger)
170
+ if msg:
171
+ warnings.append(msg)
172
+
173
+ if not warnings:
174
+ sys.exit(0)
175
+
176
+ print()
177
+ print(f"{YELLOW}[skill-hook] ⚠ The following service skills may be stale:{NC}")
178
+ for w in warnings:
179
+ print(f"{YELLOW}{w}{NC}")
180
+ print()
181
+
182
+ if STRICT:
183
+ print(f"{RED}[skill-hook] SKILL_HOOK_STRICT=1: blocking push until skills are updated.{NC}")
184
+ print(f"[skill-hook] Bypass: git push --no-verify")
185
+ print()
186
+ sys.exit(1)
187
+ else:
188
+ print(f"{BLUE}[skill-hook] Set SKILL_HOOK_STRICT=1 to block pushes on staleness.{NC}")
189
+ print()
190
+ sys.exit(0)
191
+
192
+
193
+ if __name__ == "__main__":
194
+ main()
@@ -0,0 +1,4 @@
1
+ {
2
+ "version": "1.0.0",
3
+ "services": {}
4
+ }
@@ -0,0 +1,37 @@
1
+ {
2
+ "hooks": {
3
+ "SessionStart": [
4
+ {
5
+ "hooks": [
6
+ {
7
+ "type": "command",
8
+ "command": "python3 \"$CLAUDE_PROJECT_DIR/.claude/skills/using-service-skills/scripts/cataloger.py\""
9
+ }
10
+ ]
11
+ }
12
+ ],
13
+ "PreToolUse": [
14
+ {
15
+ "matcher": "Read|Write|Edit|Glob|Grep|Bash|mcp__serena__rename_symbol|mcp__serena__replace_symbol_body|mcp__serena__insert_after_symbol|mcp__serena__insert_before_symbol",
16
+ "hooks": [
17
+ {
18
+ "type": "command",
19
+ "command": "python3 \"$CLAUDE_PROJECT_DIR/.claude/skills/using-service-skills/scripts/skill_activator.py\""
20
+ }
21
+ ]
22
+ }
23
+ ],
24
+ "PostToolUse": [
25
+ {
26
+ "matcher": "Write|Edit|mcp__serena__rename_symbol|mcp__serena__replace_symbol_body|mcp__serena__insert_after_symbol|mcp__serena__insert_before_symbol",
27
+ "hooks": [
28
+ {
29
+ "type": "command",
30
+ "command": "python3 \"$CLAUDE_PROJECT_DIR/.claude/skills/updating-service-skills/scripts/drift_detector.py\" check-hook",
31
+ "timeout": 10
32
+ }
33
+ ]
34
+ }
35
+ ]
36
+ }
37
+ }