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,334 @@
1
+ #!/usr/bin/env python3
2
+ """
3
+ Python Quality Gate - PostToolUse hook for Claude Code.
4
+ Runs ruff (linting/formatting) and mypy (type checking) on edited Python files.
5
+
6
+ Exit codes:
7
+ 0 - All checks passed
8
+ 1 - Fatal error
9
+ 2 - Blocking errors found (Claude must fix)
10
+ """
11
+
12
+ import json
13
+ import os
14
+ import sys
15
+ import subprocess
16
+ import shutil
17
+ from pathlib import Path
18
+
19
+ # Colors for output
20
+ class Colors:
21
+ RED = '\x1b[0;31m'
22
+ GREEN = '\x1b[0;32m'
23
+ YELLOW = '\x1b[0;33m'
24
+ BLUE = '\x1b[0;34m'
25
+ CYAN = '\x1b[0;36m'
26
+ RESET = '\x1b[0m'
27
+
28
+ def log_info(msg: str):
29
+ print(f"{Colors.BLUE}[INFO]{Colors.RESET} {msg}", file=sys.stderr)
30
+
31
+ def log_error(msg: str):
32
+ print(f"{Colors.RED}[ERROR]{Colors.RESET} {msg}", file=sys.stderr)
33
+
34
+ def log_success(msg: str):
35
+ print(f"{Colors.GREEN}[OK]{Colors.RESET} {msg}", file=sys.stderr)
36
+
37
+ def log_warning(msg: str):
38
+ print(f"{Colors.YELLOW}[WARN]{Colors.RESET} {msg}", file=sys.stderr)
39
+
40
+ def log_debug(msg: str):
41
+ if os.environ.get('CLAUDE_HOOKS_DEBUG', 'false').lower() == 'true':
42
+ print(f"{Colors.CYAN}[DEBUG]{Colors.RESET} {msg}", file=sys.stderr)
43
+
44
+ def find_project_root(file_path: str) -> str:
45
+ """Find project root by looking for pyproject.toml, setup.py, or .git"""
46
+ path = Path(file_path).parent
47
+ while path != path.parent:
48
+ if (path / 'pyproject.toml').exists() or \
49
+ (path / 'setup.py').exists() or \
50
+ (path / '.git').exists():
51
+ return str(path)
52
+ path = path.parent
53
+ return str(path)
54
+
55
+ def is_python_file(file_path: str) -> bool:
56
+ """Check if file is a Python source file"""
57
+ return file_path.endswith('.py') and not file_path.endswith('__init__.py')
58
+
59
+ def check_ruff(file_path: str, project_root: str, autofix: bool = False) -> tuple[bool, list[str], list[str]]:
60
+ """
61
+ Run ruff linting and formatting checks.
62
+ Returns: (passed, errors, autofixes)
63
+ """
64
+ errors = []
65
+ autofixes = []
66
+
67
+ # Check if ruff is available
68
+ ruff_path = shutil.which('ruff')
69
+ if not ruff_path:
70
+ log_debug('Ruff not found in PATH - skipping ruff checks')
71
+ return True, errors, autofixes
72
+
73
+ log_info('Running Ruff linting...')
74
+
75
+ # Run ruff check
76
+ cmd = ['ruff', 'check', '--output-format=full', file_path]
77
+ try:
78
+ result = subprocess.run(cmd, capture_output=True, text=True, cwd=project_root)
79
+
80
+ if result.returncode != 0:
81
+ if autofix:
82
+ log_warning('Ruff issues found, attempting auto-fix...')
83
+ fix_cmd = ['ruff', 'check', '--fix', file_path]
84
+ fix_result = subprocess.run(fix_cmd, capture_output=True, text=True, cwd=project_root)
85
+
86
+ if fix_result.returncode == 0:
87
+ log_success('Ruff auto-fixed all issues!')
88
+ autofixes.append('Ruff auto-fixed linting issues')
89
+ else:
90
+ errors.append(f'Ruff found issues that could not be auto-fixed')
91
+ errors.extend(result.stdout.strip().split('\n'))
92
+ else:
93
+ errors.append(f'Ruff found linting issues in {os.path.basename(file_path)}')
94
+ errors.extend(result.stdout.strip().split('\n'))
95
+ else:
96
+ log_success('Ruff linting passed')
97
+
98
+ except Exception as e:
99
+ log_debug(f'Ruff check error: {e}')
100
+
101
+ # Run ruff format check
102
+ log_info('Running Ruff format check...')
103
+ format_cmd = ['ruff', 'format', '--check', file_path]
104
+ try:
105
+ result = subprocess.run(format_cmd, capture_output=True, text=True, cwd=project_root)
106
+
107
+ if result.returncode != 0:
108
+ if autofix:
109
+ log_warning('Ruff format issues found, auto-formatting...')
110
+ format_fix_cmd = ['ruff', 'format', file_path]
111
+ format_fix_result = subprocess.run(format_fix_cmd, capture_output=True, text=True, cwd=project_root)
112
+
113
+ if format_fix_result.returncode == 0:
114
+ log_success('Ruff auto-formatted the file!')
115
+ autofixes.append('Ruff auto-formatted the file')
116
+ else:
117
+ errors.append(f'Ruff formatting issues in {os.path.basename(file_path)}')
118
+ else:
119
+ errors.append(f'Ruff formatting issues in {os.path.basename(file_path)}')
120
+ else:
121
+ log_success('Ruff formatting correct')
122
+
123
+ except Exception as e:
124
+ log_debug(f'Ruff format error: {e}')
125
+
126
+ return len(errors) == 0, errors, autofixes
127
+
128
+ def check_mypy(file_path: str, project_root: str) -> tuple[bool, list[str]]:
129
+ """
130
+ Run mypy type checking.
131
+ Returns: (passed, errors)
132
+ """
133
+ errors = []
134
+
135
+ # Check if mypy is available
136
+ mypy_path = shutil.which('mypy')
137
+ if not mypy_path:
138
+ log_debug('Mypy not found in PATH - skipping type checking')
139
+ return True, errors
140
+
141
+ log_info('Running Mypy type checking...')
142
+
143
+ # Build mypy command with strictness flags
144
+ # Default: --disallow-untyped-defs catches untyped function parameters
145
+ # Opt-in: CLAUDE_HOOKS_MYPY_STRICT=true enables full --strict mode
146
+ mypy_strict = os.environ.get('CLAUDE_HOOKS_MYPY_STRICT', 'false').lower() == 'true'
147
+
148
+ if mypy_strict:
149
+ cmd = ['mypy', '--strict', '--pretty', file_path]
150
+ log_debug('Running mypy with --strict (full strictness)')
151
+ else:
152
+ cmd = ['mypy', '--disallow-untyped-defs', '--pretty', file_path]
153
+ log_debug('Running mypy with --disallow-untyped-defs (baseline strictness)')
154
+ try:
155
+ result = subprocess.run(cmd, capture_output=True, text=True, cwd=project_root)
156
+
157
+ if result.returncode != 0:
158
+ errors.append(f'Mypy found type errors in {os.path.basename(file_path)}')
159
+ if result.stdout:
160
+ errors.extend(result.stdout.strip().split('\n'))
161
+ if result.stderr:
162
+ errors.extend(result.stderr.strip().split('\n'))
163
+ else:
164
+ log_success('Mypy type checking passed')
165
+
166
+ except Exception as e:
167
+ log_debug(f'Mypy error: {e}')
168
+
169
+ return len(errors) == 0, errors
170
+
171
+ def check_pytest_suggestions(file_path: str, project_root: str):
172
+ """Suggest running tests if test file exists"""
173
+ base_name = file_path.replace('.py', '')
174
+ test_paths = [
175
+ f'{base_name}_test.py',
176
+ f'{base_name}_tests.py',
177
+ f'test_{Path(file_path).name}',
178
+ ]
179
+
180
+ # Check same directory
181
+ for test_path in test_paths:
182
+ if Path(test_path).exists():
183
+ log_warning(f'💡 Related test found: {os.path.basename(test_path)}')
184
+ log_warning(' Consider running: pytest')
185
+ return
186
+
187
+ # Check __tests__ directory
188
+ tests_dir = Path(file_path).parent / '__tests__'
189
+ if tests_dir.exists():
190
+ for test_path in tests_dir.glob(f'test_{Path(file_path).name}'):
191
+ log_warning(f'💡 Related test found: __tests__/{test_path.name}')
192
+ log_warning(' Consider running: pytest')
193
+ return
194
+
195
+ log_warning(f'💡 No test file found for {os.path.basename(file_path)}')
196
+
197
+ def print_summary(errors: list[str], autofixes: list[str]):
198
+ """Print summary of errors and autofixes"""
199
+ if autofixes:
200
+ print(f'\n{Colors.BLUE}═══ Auto-fixes Applied ═══{Colors.RESET}', file=sys.stderr)
201
+ for fix in autofixes:
202
+ print(f'{Colors.GREEN}✨{Colors.RESET} {fix}', file=sys.stderr)
203
+ print(f'{Colors.GREEN}Automatically fixed {len(autofixes)} issue(s)!{Colors.RESET}', file=sys.stderr)
204
+
205
+ if errors:
206
+ print(f'\n{Colors.BLUE}═══ Quality Check Summary ═══{Colors.RESET}', file=sys.stderr)
207
+ for error in errors:
208
+ print(f'{Colors.RED}❌{Colors.RESET} {error}', file=sys.stderr)
209
+ print(f'\n{Colors.RED}Found {len(errors)} issue(s) that MUST be fixed!{Colors.RESET}', file=sys.stderr)
210
+ print(f'{Colors.RED}══════════════════════════════════════{Colors.RESET}', file=sys.stderr)
211
+ print(f'{Colors.RED}❌ ALL ISSUES ARE BLOCKING ❌{Colors.RESET}', file=sys.stderr)
212
+ print(f'{Colors.RED}══════════════════════════════════════{Colors.RESET}', file=sys.stderr)
213
+ print(f'{Colors.RED}Fix EVERYTHING above until all checks are ✅ GREEN{Colors.RESET}', file=sys.stderr)
214
+
215
+ def parse_json_input() -> dict:
216
+ """Parse JSON input from stdin"""
217
+ input_data = sys.stdin.read().strip()
218
+
219
+ if not input_data:
220
+ log_warning('No JSON input provided.')
221
+ print(f'\n{Colors.YELLOW}👉 Hook executed but no input to process.{Colors.RESET}', file=sys.stderr)
222
+ sys.exit(0)
223
+
224
+ try:
225
+ return json.loads(input_data)
226
+ except json.JSONDecodeError as e:
227
+ log_error(f'Failed to parse JSON: {e}')
228
+ sys.exit(1)
229
+
230
+ def extract_file_path(input_data: dict) -> str | None:
231
+ """Extract file path from tool input, including Serena relative_path."""
232
+ tool_input = input_data.get('tool_input', {})
233
+ file_path = (
234
+ tool_input.get('file_path')
235
+ or tool_input.get('path')
236
+ or tool_input.get('relative_path')
237
+ )
238
+ if not file_path:
239
+ return None
240
+
241
+ # Serena tools pass relative_path relative to the project root.
242
+ if not os.path.isabs(file_path):
243
+ project_root = os.environ.get('CLAUDE_PROJECT_DIR') or os.getcwd()
244
+ return str(Path(project_root) / file_path)
245
+
246
+ return file_path
247
+
248
+ def main():
249
+ """Main entry point"""
250
+ print('', file=sys.stderr)
251
+ print(f'📦 Python Quality Check - Starting...', file=sys.stderr)
252
+ print('─────────────────────────────────────', file=sys.stderr)
253
+
254
+ # Parse input
255
+ input_data = parse_json_input()
256
+ file_path = extract_file_path(input_data)
257
+
258
+ if not file_path:
259
+ log_warning('No file path found in JSON input.')
260
+ print(f'\n{Colors.YELLOW}👉 No file to check - tool may not be file-related.{Colors.RESET}', file=sys.stderr)
261
+ sys.exit(0)
262
+
263
+ # Check if file exists
264
+ if not Path(file_path).exists():
265
+ log_info(f'File does not exist: {file_path}')
266
+ print(f'\n{Colors.YELLOW}👉 File skipped - doesn\'t exist.{Colors.RESET}', file=sys.stderr)
267
+ sys.exit(0)
268
+
269
+ # Skip non-Python files
270
+ if not is_python_file(file_path):
271
+ log_info(f'Skipping non-Python file: {file_path}')
272
+ print(f'\n{Colors.GREEN}✅ No checks needed for {os.path.basename(file_path)}{Colors.RESET}', file=sys.stderr)
273
+ sys.exit(0)
274
+
275
+ # Update header
276
+ print('', file=sys.stderr)
277
+ print(f'🔍 Validating: {os.path.basename(file_path)}', file=sys.stderr)
278
+ print('─────────────────────────────────────', file=sys.stderr)
279
+ log_info(f'Checking: {file_path}')
280
+
281
+ # Find project root
282
+ project_root = find_project_root(file_path)
283
+ log_debug(f'Project root: {project_root}')
284
+
285
+ # Get config from environment
286
+ autofix = os.environ.get('CLAUDE_HOOKS_AUTOFIX', 'true').lower() == 'true'
287
+ ruff_enabled = os.environ.get('CLAUDE_HOOKS_RUFF_ENABLED', 'true').lower() != 'false'
288
+ mypy_enabled = os.environ.get('CLAUDE_HOOKS_MYPY_ENABLED', 'true').lower() != 'false'
289
+
290
+ all_errors = []
291
+ all_autofixes = []
292
+
293
+ # Run ruff checks
294
+ if ruff_enabled:
295
+ ruff_passed, ruff_errors, ruff_autofixes = check_ruff(file_path, project_root, autofix)
296
+ all_errors.extend(ruff_errors)
297
+ all_autofixes.extend(ruff_autofixes)
298
+
299
+ # Run mypy checks
300
+ if mypy_enabled:
301
+ mypy_passed, mypy_errors = check_mypy(file_path, project_root)
302
+ all_errors.extend(mypy_errors)
303
+
304
+ # Print summary
305
+ print_summary(all_errors, all_autofixes)
306
+
307
+ # Exit with appropriate code
308
+ if all_errors:
309
+ print(f'\n{Colors.RED}🛑 FAILED - Fix issues in your edited file! 🛑{Colors.RESET}', file=sys.stderr)
310
+ print(f'{Colors.CYAN}💡 CLAUDE.md CHECK:{Colors.RESET}', file=sys.stderr)
311
+ print(f'{Colors.CYAN} → What CLAUDE.md pattern would have prevented this?{Colors.RESET}', file=sys.stderr)
312
+ print(f'{Colors.YELLOW}📋 NEXT STEPS:{Colors.RESET}', file=sys.stderr)
313
+ print(f'{Colors.YELLOW} 1. Fix the issues listed above{Colors.RESET}', file=sys.stderr)
314
+ print(f'{Colors.YELLOW} 2. The hook will run again automatically{Colors.RESET}', file=sys.stderr)
315
+ print(f'{Colors.YELLOW} 3. Continue once all checks pass{Colors.RESET}', file=sys.stderr)
316
+ sys.exit(2)
317
+ else:
318
+ print(f'\n{Colors.GREEN}✅ Quality check passed for {os.path.basename(file_path)}{Colors.RESET}', file=sys.stderr)
319
+ if all_autofixes:
320
+ print(f'\n{Colors.YELLOW}👉 File quality verified. Auto-fixes applied. Continue with your task.{Colors.RESET}', file=sys.stderr)
321
+ else:
322
+ print(f'\n{Colors.YELLOW}👉 File quality verified. Continue with your task.{Colors.RESET}', file=sys.stderr)
323
+
324
+ # Suggest tests
325
+ check_pytest_suggestions(file_path, project_root)
326
+
327
+ sys.exit(0)
328
+
329
+ if __name__ == '__main__':
330
+ try:
331
+ main()
332
+ except Exception as e:
333
+ log_error(f'Fatal error: {e}')
334
+ sys.exit(1)
@@ -0,0 +1,3 @@
1
+ {
2
+ "hooks": {}
3
+ }
@@ -0,0 +1,254 @@
1
+ ---
2
+ name: using-quality-gates
3
+ description: 'Quality Gates workflow for Claude Code. Use when editing code in projects with quality enforcement. Covers the full cycle: TDD guard (write failing test first) → implement → auto-lint/typecheck. Activates on code edits, quality issues, or when user asks about testing/linting workflow.'
4
+ ---
5
+
6
+ # Using Quality Gates
7
+
8
+ **Quality Gates** provides automated code quality enforcement through PostToolUse hooks:
9
+
10
+ 1. **TypeScript Quality Gate** — Runs after TS/JS edits: TypeScript + ESLint + Prettier
11
+ 2. **Python Quality Gate** — Runs after Python edits: Ruff + Mypy
12
+
13
+ **Separate Installation Required for TDD:**
14
+ - **TDD Guard** is a separate tool (not included) — See "TDD Guard Setup" below
15
+
16
+ ## Architecture Overview
17
+
18
+ ```
19
+ ┌─────────────────────────────────────────────────────────────────┐
20
+ │ QUALITY GATES (this skill) │
21
+ │ ───────────────────────────── │
22
+ │ PostToolUse Hooks (installed by this skill): │
23
+ │ • .claude/hooks/quality-check.cjs → TS/JS files │
24
+ │ • .claude/hooks/quality-check.py → Python files │
25
+ │ • .claude/settings.json → Hook registration │
26
+ └─────────────────────────────────────────────────────────────────┘
27
+
28
+ ┌─────────────────────────────────────────────────────────────────┐
29
+ │ TDD GUARD (separate installation) │
30
+ │ ─────────────────────────────────── │
31
+ │ PreToolUse Hook (requires xtrm install project tdd-guard): │
32
+ │ • Global CLI: npm install -g tdd-guard │
33
+ │ • Test reporter: tdd-guard-vitest / tdd-guard-pytest / etc. │
34
+ │ • Hook: .claude/hooks/tdd-guard-pretool-bridge.cjs │
35
+ └─────────────────────────────────────────────────────────────────┘
36
+ ```
37
+
38
+ ## Installation
39
+
40
+ ### Step 1: Install This Skill
41
+
42
+ ```bash
43
+ xtrm install project quality-gates
44
+ ```
45
+
46
+ This installs:
47
+ - `.claude/hooks/quality-check.cjs` — TypeScript/JavaScript checks
48
+ - `.claude/hooks/quality-check.py` — Python checks
49
+ - `.claude/settings.json` — PostToolUse hook registration
50
+ - `.claude/skills/using-quality-gates/` — This documentation
51
+
52
+ ### Step 2: Install Language Dependencies
53
+
54
+ **TypeScript Projects:**
55
+ ```bash
56
+ npm install --save-dev typescript eslint prettier
57
+ ```
58
+
59
+ **Python Projects:**
60
+ ```bash
61
+ pip install ruff mypy
62
+ ```
63
+
64
+ ### Step 3: (Optional) Install TDD Guard
65
+
66
+ For test-first enforcement, install TDD Guard separately:
67
+
68
+ ```bash
69
+ # 1. Install global CLI
70
+ npm install -g tdd-guard
71
+
72
+ # 2. Install project-skill for hook wiring
73
+ xtrm install project tdd-guard
74
+
75
+ # 3. Install test reporter (choose one)
76
+ npm install --save-dev tdd-guard-vitest # Vitest
77
+ npm install --save-dev tdd-guard-jest # Jest
78
+ pip install tdd-guard-pytest # pytest
79
+ ```
80
+
81
+ **Configure test reporter** (see https://github.com/nizos/tdd-guard):
82
+
83
+ **Vitest:**
84
+ ```typescript
85
+ // vitest.config.ts
86
+ import { defineConfig } from 'vitest/config'
87
+ import { VitestReporter } from 'tdd-guard-vitest'
88
+
89
+ export default defineConfig({
90
+ test: {
91
+ reporters: ['default', new VitestReporter('/path/to/project')],
92
+ },
93
+ })
94
+ ```
95
+
96
+ **pytest:**
97
+ ```toml
98
+ # pyproject.toml
99
+ [tool.pytest.ini_options]
100
+ tdd_guard_project_root = "/path/to/project"
101
+ ```
102
+
103
+ ## How Quality Gates Work
104
+
105
+ ### TypeScript Quality Gate (PostToolUse)
106
+
107
+ **Runs after:** Every `.ts`, `.tsx`, `.js`, `.jsx` file edit
108
+
109
+ **Checks:**
110
+ 1. TypeScript compilation (type errors)
111
+ 2. ESLint validation (style, best practices)
112
+ 3. Prettier formatting (consistency)
113
+
114
+ **Configuration** (`.claude/hooks/hook-config.json`):
115
+ ```json
116
+ {
117
+ "typescript": { "enabled": true, "showDependencyErrors": false },
118
+ "eslint": { "enabled": true, "autofix": true },
119
+ "prettier": { "enabled": true, "autofix": true },
120
+ "general": { "autofixSilent": true }
121
+ }
122
+ ```
123
+
124
+ ### Python Quality Gate (PostToolUse)
125
+
126
+ **Runs after:** Every `.py` file edit
127
+
128
+ **Checks:**
129
+ 1. Ruff linting (errors, style, best practices)
130
+ 2. Ruff formatting (Black-compatible)
131
+ 3. Mypy type checking (static types)
132
+
133
+ **Configuration** (environment variables):
134
+ ```bash
135
+ CLAUDE_HOOKS_RUFF_ENABLED=true
136
+ CLAUDE_HOOKS_MYPY_ENABLED=true
137
+ CLAUDE_HOOKS_AUTOFIX=true
138
+ ```
139
+
140
+ ## Exit Codes
141
+
142
+ | Code | Meaning | Action |
143
+ |------|---------|--------|
144
+ | 0 | All checks passed | Continue |
145
+ | 1 | Fatal error (missing deps) | Install missing tool |
146
+ | 2 | Blocking errors | Claude must fix |
147
+
148
+ ## Handling Quality Gate Errors
149
+
150
+ When blocked with exit code 2:
151
+
152
+ 1. **Read the error output** — Specific issues listed
153
+ 2. **Auto-fix applies automatically** — ESLint/Prettier/Ruff fix what they can
154
+ 3. **Fix remaining issues manually** — Type errors, complex violations
155
+ 4. **Gate re-runs on next edit** — No manual trigger needed
156
+
157
+ **Example:**
158
+ ```
159
+ [ERROR] TypeScript compilation failed:
160
+ src/auth.ts:42:5 - error TS2322: Type 'string' is not assignable to type 'number'
161
+
162
+ [WARN] Auto-fix applied: 2 issues fixed
163
+ [BLOCK] 1 issue remains - fix before continuing
164
+ ```
165
+
166
+ ## TDD Guard Integration
167
+
168
+ When TDD Guard is installed alongside Quality Gates:
169
+
170
+ ```
171
+ User Request: "Add feature X"
172
+
173
+ ┌───────────────────────────────────┐
174
+ │ TDD Guard (PreToolUse) │
175
+ │ Checks: Failing test exists? │
176
+ │ • NO → BLOCK: "Write test first" │
177
+ │ • YES → Allow implementation │
178
+ └───────────────────────────────────┘
179
+
180
+ Implementation (Write/Edit)
181
+
182
+ ┌───────────────────────────────────┐
183
+ │ Quality Gates (PostToolUse) │
184
+ │ Runs: Lint + Typecheck + Format │
185
+ │ • Errors → BLOCK, fix issues │
186
+ │ • Pass → Continue │
187
+ └───────────────────────────────────┘
188
+
189
+ Tests pass → Commit
190
+ ```
191
+
192
+ ## Troubleshooting
193
+
194
+ **"ESLint not found" / "Prettier not found"**
195
+ ```bash
196
+ npm install --save-dev eslint prettier
197
+ ```
198
+
199
+ **"Ruff not found" / "Mypy not found"**
200
+ ```bash
201
+ pip install ruff mypy
202
+ ```
203
+
204
+ **"tdd-guard: command not found"**
205
+ ```bash
206
+ npm install -g tdd-guard
207
+ ```
208
+
209
+ **"TDD Guard: No failing test found"**
210
+ - Write a failing test first
211
+ - Ensure test reporter is configured
212
+ - Run tests to generate reporter JSON
213
+
214
+ **Hook not running**
215
+ - Verify `.claude/settings.json` exists
216
+ - Check hook script paths are correct
217
+ - Ensure file extension matches (`.ts`/`.py`)
218
+
219
+ ## When This Skill Activates
220
+
221
+ **Triggers:**
222
+ - Quality gate reports errors
223
+ - User asks about linting, type checking, or quality workflow
224
+ - Session starts in a project with quality gates installed
225
+
226
+ **Response Modes:**
227
+
228
+ **Full Workflow Mode** (user mentions quality/testing, blocked by gate errors):
229
+ - Explain complete quality pipeline
230
+ - Provide troubleshooting guidance
231
+
232
+ **Minimal Mode** (general coding tasks without quality context):
233
+ - Complete the task directly
234
+ - Brief note: "Consider adding tests. If TDD Guard is installed, write failing test first."
235
+
236
+ ## Files Installed
237
+
238
+ ```
239
+ .claude/
240
+ ├── settings.json # PostToolUse hook registration
241
+ ├── hooks/
242
+ │ ├── quality-check.cjs # TypeScript/JavaScript checks
243
+ │ ├── quality-check.py # Python checks
244
+ │ └── hook-config.json # TS hook configuration
245
+ ├── skills/
246
+ │ └── using-quality-gates/ # This skill
247
+ └── docs/
248
+ └── quality-gates-readme.md
249
+ ```
250
+
251
+ ## Related
252
+
253
+ - **TDD Guard**: https://github.com/nizos/tdd-guard
254
+ - **xtrm install project tdd-guard**: Install TDD Guard hooks
@@ -0,0 +1,109 @@
1
+ # Quality Gates
2
+
3
+ **PostToolUse code quality hooks** for Claude Code. Runs automatically after file edits to enforce linting, type checking, and formatting standards.
4
+
5
+ ## What This Installs
6
+
7
+ **TypeScript Quality Gate** (`.ts`, `.tsx`, `.js`, `.jsx`):
8
+ - TypeScript compilation check
9
+ - ESLint validation + auto-fix
10
+ - Prettier formatting + auto-fix
11
+
12
+ **Python Quality Gate** (`.py`):
13
+ - Ruff linting + auto-fix
14
+ - Ruff formatting + auto-fix
15
+ - Mypy type checking
16
+
17
+ ## Installation
18
+
19
+ ```bash
20
+ # 1. Install this skill
21
+ xtrm install project quality-gates
22
+
23
+ # 2. Install language dependencies
24
+ npm install --save-dev typescript eslint prettier # TypeScript
25
+ pip install ruff mypy # Python
26
+ ```
27
+
28
+ ## What Gets Installed
29
+
30
+ ```
31
+ .claude/
32
+ ├── settings.json # PostToolUse hook registration
33
+ ├── hooks/
34
+ │ ├── quality-check.cjs # TypeScript/JavaScript checks
35
+ │ ├── quality-check.py # Python checks
36
+ │ └── hook-config.json # TS hook configuration
37
+ ├── skills/
38
+ │ └── using-quality-gates/ # Skill documentation
39
+ └── docs/
40
+ └── quality-gates-readme.md
41
+ ```
42
+
43
+ ## How It Works
44
+
45
+ After every file edit:
46
+ 1. Hook detects file type (TS/JS or Python)
47
+ 2. Runs appropriate quality checks
48
+ 3. Auto-fixes issues when possible
49
+ 4. Returns exit code:
50
+ - `0` = All checks passed
51
+ - `2` = Blocking errors (Claude must fix)
52
+
53
+ ## Configuration
54
+
55
+ ### TypeScript
56
+
57
+ Edit `.claude/hooks/hook-config.json`:
58
+
59
+ ```json
60
+ {
61
+ "typescript": { "enabled": true, "showDependencyErrors": false },
62
+ "eslint": { "enabled": true, "autofix": true },
63
+ "prettier": { "enabled": true, "autofix": true }
64
+ }
65
+ ```
66
+
67
+ ### Python
68
+
69
+ Set environment variables:
70
+
71
+ ```bash
72
+ export CLAUDE_HOOKS_RUFF_ENABLED=true
73
+ export CLAUDE_HOOKS_MYPY_ENABLED=true
74
+ export CLAUDE_HOOKS_AUTOFIX=true
75
+ ```
76
+
77
+ ## TDD Guard (Separate Installation)
78
+
79
+ For test-first enforcement, install TDD Guard separately:
80
+
81
+ ```bash
82
+ # 1. Global CLI
83
+ npm install -g tdd-guard
84
+
85
+ # 2. Project skill for hooks
86
+ xtrm install project tdd-guard
87
+
88
+ # 3. Test reporter (choose one)
89
+ npm install --save-dev tdd-guard-vitest # Vitest
90
+ npm install --save-dev tdd-guard-jest # Jest
91
+ pip install tdd-guard-pytest # pytest
92
+ ```
93
+
94
+ See: https://github.com/nizos/tdd-guard
95
+
96
+ ## Troubleshooting
97
+
98
+ | Error | Fix |
99
+ |-------|-----|
100
+ | "ESLint not found" | `npm install --save-dev eslint prettier` |
101
+ | "Ruff not found" | `pip install ruff mypy` |
102
+ | "tdd-guard: command not found" | `npm install -g tdd-guard` |
103
+ | Hook not running | Check `.claude/settings.json` exists |
104
+
105
+ ## Related
106
+
107
+ - **TDD Guard**: https://github.com/nizos/tdd-guard
108
+ - **Ruff**: https://docs.astral.sh/ruff/
109
+ - **Mypy**: https://mypy.readthedocs.io/