xtrm-tools 0.6.0 → 0.7.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.xtrm/config/README.md +10 -0
- package/{config/mcp_servers.json → .xtrm/config/claude.mcp.json} +0 -28
- package/{config → .xtrm/config}/instructions/agents-top.md +12 -3
- package/{config → .xtrm/config}/instructions/claude-top.md +12 -3
- package/{config → .xtrm/config}/pi/extensions/beads/index.ts +44 -13
- package/{config → .xtrm/config}/pi/extensions/custom-footer/index.ts +59 -82
- package/{config → .xtrm/config}/pi/extensions/xtrm-ui/index.ts +3 -3
- package/{config → .xtrm/config}/pi/install-schema.json +2 -2
- package/.xtrm/config/pi.mcp.json +39 -0
- package/.xtrm/config/settings.json +41 -0
- package/.xtrm/extensions/auto-session-name/index.ts +29 -0
- package/.xtrm/extensions/auto-session-name/package.json +16 -0
- package/.xtrm/extensions/auto-update/index.ts +71 -0
- package/.xtrm/extensions/auto-update/package.json +16 -0
- package/.xtrm/extensions/beads/index.ts +232 -0
- package/.xtrm/extensions/beads/package.json +19 -0
- package/.xtrm/extensions/compact-header/index.ts +69 -0
- package/.xtrm/extensions/compact-header/package.json +16 -0
- package/.xtrm/extensions/core/adapter.ts +52 -0
- package/.xtrm/extensions/core/guard-rules.ts +100 -0
- package/.xtrm/extensions/core/lib.ts +3 -0
- package/.xtrm/extensions/core/logger.ts +45 -0
- package/.xtrm/extensions/core/package.json +18 -0
- package/.xtrm/extensions/core/runner.ts +71 -0
- package/.xtrm/extensions/core/session-state.ts +59 -0
- package/.xtrm/extensions/custom-footer/index.ts +398 -0
- package/.xtrm/extensions/custom-footer/package.json +19 -0
- package/.xtrm/extensions/custom-provider-qwen-cli/index.ts +363 -0
- package/.xtrm/extensions/custom-provider-qwen-cli/package.json +1 -0
- package/.xtrm/extensions/git-checkpoint/index.ts +53 -0
- package/.xtrm/extensions/git-checkpoint/package.json +16 -0
- package/.xtrm/extensions/lsp-bootstrap/index.ts +134 -0
- package/.xtrm/extensions/lsp-bootstrap/package.json +17 -0
- package/.xtrm/extensions/pi-serena-compact/index.ts +121 -0
- package/.xtrm/extensions/pi-serena-compact/package.json +16 -0
- package/.xtrm/extensions/quality-gates/index.ts +66 -0
- package/.xtrm/extensions/quality-gates/package.json +19 -0
- package/.xtrm/extensions/service-skills/index.ts +108 -0
- package/.xtrm/extensions/service-skills/package.json +19 -0
- package/.xtrm/extensions/session-flow/index.ts +96 -0
- package/.xtrm/extensions/session-flow/package.json +19 -0
- package/.xtrm/extensions/xtrm-loader/index.ts +152 -0
- package/.xtrm/extensions/xtrm-loader/package.json +19 -0
- package/.xtrm/extensions/xtrm-ui/format.ts +93 -0
- package/.xtrm/extensions/xtrm-ui/index.ts +1044 -0
- package/.xtrm/extensions/xtrm-ui/package.json +10 -0
- package/.xtrm/extensions/xtrm-ui/themes/pidex-dark.json +85 -0
- package/.xtrm/extensions/xtrm-ui/themes/pidex-light.json +85 -0
- package/{hooks → .xtrm/hooks}/README.md +2 -1
- package/{hooks → .xtrm/hooks}/beads-commit-gate.mjs +4 -0
- package/.xtrm/hooks/beads-memory-gate.mjs +119 -0
- package/{plugins/xtrm-tools → .xtrm}/hooks/quality-check-env.mjs +1 -4
- package/.xtrm/hooks/statusline.mjs +156 -0
- package/{plugins/xtrm-tools → .xtrm}/hooks/using-xtrm-reminder.mjs +8 -7
- package/.xtrm/registry.json +1323 -0
- package/CHANGELOG.md +27 -0
- package/README.md +3 -1
- package/cli/dist/index.cjs +27025 -30731
- package/cli/dist/index.cjs.map +1 -1
- package/cli/package.json +2 -1
- package/package.json +12 -12
- package/.claude-plugin/marketplace.json +0 -19
- package/.claude-plugin/plugin.json +0 -9
- package/config/hooks.json +0 -83
- package/config/settings.json +0 -70
- package/hooks/beads-memory-gate.mjs +0 -94
- package/hooks/quality-check-env.mjs +0 -79
- package/hooks/statusline.mjs +0 -183
- package/hooks/tsconfig-cache.json +0 -14
- package/hooks/using-xtrm-reminder.mjs +0 -47
- package/plugins/xtrm-tools/.claude-plugin/plugin.json +0 -9
- package/plugins/xtrm-tools/.mcp.json +0 -18
- package/plugins/xtrm-tools/hooks/README.md +0 -61
- package/plugins/xtrm-tools/hooks/beads-claim-sync.mjs +0 -154
- package/plugins/xtrm-tools/hooks/beads-commit-gate.mjs +0 -70
- package/plugins/xtrm-tools/hooks/beads-compact-restore.mjs +0 -77
- package/plugins/xtrm-tools/hooks/beads-compact-save.mjs +0 -63
- package/plugins/xtrm-tools/hooks/beads-edit-gate.mjs +0 -85
- package/plugins/xtrm-tools/hooks/beads-gate-core.mjs +0 -236
- package/plugins/xtrm-tools/hooks/beads-gate-messages.mjs +0 -75
- package/plugins/xtrm-tools/hooks/beads-gate-utils.mjs +0 -176
- package/plugins/xtrm-tools/hooks/beads-memory-gate.mjs +0 -94
- package/plugins/xtrm-tools/hooks/beads-stop-gate.mjs +0 -53
- package/plugins/xtrm-tools/hooks/gitnexus/gitnexus-hook.cjs +0 -222
- package/plugins/xtrm-tools/hooks/hooks.json +0 -129
- package/plugins/xtrm-tools/hooks/quality-check.cjs +0 -1286
- package/plugins/xtrm-tools/hooks/quality-check.py +0 -345
- package/plugins/xtrm-tools/hooks/statusline.mjs +0 -183
- package/plugins/xtrm-tools/hooks/tsconfig-cache.json +0 -14
- package/plugins/xtrm-tools/hooks/worktree-boundary.mjs +0 -33
- package/plugins/xtrm-tools/hooks/xtrm-logger.mjs +0 -123
- package/plugins/xtrm-tools/hooks/xtrm-session-logger.mjs +0 -27
- package/plugins/xtrm-tools/hooks/xtrm-tool-logger.mjs +0 -53
- package/plugins/xtrm-tools/skills/README.txt +0 -31
- package/plugins/xtrm-tools/skills/clean-code/SKILL.md +0 -201
- package/plugins/xtrm-tools/skills/creating-service-skills/SKILL.md +0 -433
- package/plugins/xtrm-tools/skills/creating-service-skills/references/script_quality_standards.md +0 -425
- package/plugins/xtrm-tools/skills/creating-service-skills/references/service_skill_system_guide.md +0 -278
- package/plugins/xtrm-tools/skills/creating-service-skills/scripts/bootstrap.py +0 -326
- package/plugins/xtrm-tools/skills/creating-service-skills/scripts/deep_dive.py +0 -304
- package/plugins/xtrm-tools/skills/creating-service-skills/scripts/scaffolder.py +0 -482
- package/plugins/xtrm-tools/skills/delegating/SKILL.md +0 -196
- package/plugins/xtrm-tools/skills/delegating/config.yaml +0 -210
- package/plugins/xtrm-tools/skills/delegating/references/orchestration-protocols.md +0 -41
- package/plugins/xtrm-tools/skills/docker-expert/SKILL.md +0 -409
- package/plugins/xtrm-tools/skills/documenting/CHANGELOG.md +0 -23
- package/plugins/xtrm-tools/skills/documenting/README.md +0 -148
- package/plugins/xtrm-tools/skills/documenting/SKILL.md +0 -113
- package/plugins/xtrm-tools/skills/documenting/examples/example_pattern.md +0 -70
- package/plugins/xtrm-tools/skills/documenting/examples/example_reference.md +0 -70
- package/plugins/xtrm-tools/skills/documenting/examples/example_ssot_analytics.md +0 -64
- package/plugins/xtrm-tools/skills/documenting/examples/example_workflow.md +0 -141
- package/plugins/xtrm-tools/skills/documenting/references/changelog-format.md +0 -97
- package/plugins/xtrm-tools/skills/documenting/references/metadata-schema.md +0 -136
- package/plugins/xtrm-tools/skills/documenting/references/taxonomy.md +0 -81
- package/plugins/xtrm-tools/skills/documenting/references/versioning-rules.md +0 -78
- package/plugins/xtrm-tools/skills/documenting/scripts/bump_version.sh +0 -60
- package/plugins/xtrm-tools/skills/documenting/scripts/changelog/__init__.py +0 -0
- package/plugins/xtrm-tools/skills/documenting/scripts/changelog/add_entry.py +0 -216
- package/plugins/xtrm-tools/skills/documenting/scripts/changelog/bump_release.py +0 -117
- package/plugins/xtrm-tools/skills/documenting/scripts/changelog/init_changelog.py +0 -54
- package/plugins/xtrm-tools/skills/documenting/scripts/changelog/validate_changelog.py +0 -128
- package/plugins/xtrm-tools/skills/documenting/scripts/drift_detector.py +0 -266
- package/plugins/xtrm-tools/skills/documenting/scripts/generate_template.py +0 -311
- package/plugins/xtrm-tools/skills/documenting/scripts/list_by_category.sh +0 -84
- package/plugins/xtrm-tools/skills/documenting/scripts/orchestrator.py +0 -255
- package/plugins/xtrm-tools/skills/documenting/scripts/validate_metadata.py +0 -242
- package/plugins/xtrm-tools/skills/documenting/templates/CHANGELOG.md.template +0 -13
- package/plugins/xtrm-tools/skills/documenting/tests/integration_test.sh +0 -70
- package/plugins/xtrm-tools/skills/documenting/tests/test_changelog.py +0 -201
- package/plugins/xtrm-tools/skills/documenting/tests/test_drift_detector.py +0 -80
- package/plugins/xtrm-tools/skills/documenting/tests/test_orchestrator.py +0 -52
- package/plugins/xtrm-tools/skills/documenting/tests/test_validate_metadata.py +0 -64
- package/plugins/xtrm-tools/skills/find-skills/SKILL.md +0 -133
- package/plugins/xtrm-tools/skills/gitnexus-exploring/SKILL.md +0 -75
- package/plugins/xtrm-tools/skills/gitnexus-impact-analysis/SKILL.md +0 -94
- package/plugins/xtrm-tools/skills/gitnexus-refactoring/SKILL.md +0 -113
- package/plugins/xtrm-tools/skills/hook-development/SKILL.md +0 -797
- package/plugins/xtrm-tools/skills/hook-development/examples/load-context.sh +0 -55
- package/plugins/xtrm-tools/skills/hook-development/examples/quality-check.js +0 -1168
- package/plugins/xtrm-tools/skills/hook-development/examples/validate-bash.sh +0 -43
- package/plugins/xtrm-tools/skills/hook-development/examples/validate-write.sh +0 -38
- package/plugins/xtrm-tools/skills/hook-development/references/advanced.md +0 -527
- package/plugins/xtrm-tools/skills/hook-development/references/migration.md +0 -369
- package/plugins/xtrm-tools/skills/hook-development/references/patterns.md +0 -412
- package/plugins/xtrm-tools/skills/hook-development/scripts/README.md +0 -164
- package/plugins/xtrm-tools/skills/hook-development/scripts/hook-linter.sh +0 -153
- package/plugins/xtrm-tools/skills/hook-development/scripts/test-hook.sh +0 -252
- package/plugins/xtrm-tools/skills/hook-development/scripts/validate-hook-schema.sh +0 -159
- package/plugins/xtrm-tools/skills/obsidian-cli/SKILL.md +0 -106
- package/plugins/xtrm-tools/skills/orchestrating-agents/SKILL.md +0 -135
- package/plugins/xtrm-tools/skills/orchestrating-agents/config.yaml +0 -45
- package/plugins/xtrm-tools/skills/orchestrating-agents/references/agent-context-integration.md +0 -37
- package/plugins/xtrm-tools/skills/orchestrating-agents/references/examples.md +0 -45
- package/plugins/xtrm-tools/skills/orchestrating-agents/references/handover-protocol.md +0 -31
- package/plugins/xtrm-tools/skills/orchestrating-agents/references/workflows.md +0 -42
- package/plugins/xtrm-tools/skills/orchestrating-agents/scripts/detect_neighbors.py +0 -23
- package/plugins/xtrm-tools/skills/planning/SKILL.md +0 -405
- package/plugins/xtrm-tools/skills/planning/evals/evals.json +0 -19
- package/plugins/xtrm-tools/skills/prompt-improving/README.md +0 -162
- package/plugins/xtrm-tools/skills/prompt-improving/SKILL.md +0 -74
- package/plugins/xtrm-tools/skills/prompt-improving/references/analysis_commands.md +0 -24
- package/plugins/xtrm-tools/skills/prompt-improving/references/chain_of_thought.md +0 -24
- package/plugins/xtrm-tools/skills/prompt-improving/references/mcp_definitions.md +0 -20
- package/plugins/xtrm-tools/skills/prompt-improving/references/multishot.md +0 -23
- package/plugins/xtrm-tools/skills/prompt-improving/references/xml_core.md +0 -60
- package/plugins/xtrm-tools/skills/python-testing/SKILL.md +0 -815
- package/plugins/xtrm-tools/skills/scoping-service-skills/SKILL.md +0 -231
- package/plugins/xtrm-tools/skills/scoping-service-skills/scripts/scope.py +0 -74
- package/plugins/xtrm-tools/skills/senior-backend/SKILL.md +0 -209
- package/plugins/xtrm-tools/skills/senior-backend/references/api_design_patterns.md +0 -103
- package/plugins/xtrm-tools/skills/senior-backend/references/backend_security_practices.md +0 -103
- package/plugins/xtrm-tools/skills/senior-backend/references/database_optimization_guide.md +0 -103
- package/plugins/xtrm-tools/skills/senior-backend/scripts/api_load_tester.py +0 -114
- package/plugins/xtrm-tools/skills/senior-backend/scripts/api_scaffolder.py +0 -114
- package/plugins/xtrm-tools/skills/senior-backend/scripts/database_migration_tool.py +0 -114
- package/plugins/xtrm-tools/skills/senior-data-scientist/SKILL.md +0 -226
- package/plugins/xtrm-tools/skills/senior-data-scientist/references/experiment_design_frameworks.md +0 -80
- package/plugins/xtrm-tools/skills/senior-data-scientist/references/feature_engineering_patterns.md +0 -80
- package/plugins/xtrm-tools/skills/senior-data-scientist/references/statistical_methods_advanced.md +0 -80
- package/plugins/xtrm-tools/skills/senior-data-scientist/scripts/experiment_designer.py +0 -100
- package/plugins/xtrm-tools/skills/senior-data-scientist/scripts/feature_engineering_pipeline.py +0 -100
- package/plugins/xtrm-tools/skills/senior-data-scientist/scripts/model_evaluation_suite.py +0 -100
- package/plugins/xtrm-tools/skills/senior-devops/SKILL.md +0 -209
- package/plugins/xtrm-tools/skills/senior-devops/references/cicd_pipeline_guide.md +0 -103
- package/plugins/xtrm-tools/skills/senior-devops/references/deployment_strategies.md +0 -103
- package/plugins/xtrm-tools/skills/senior-devops/references/infrastructure_as_code.md +0 -103
- package/plugins/xtrm-tools/skills/senior-devops/scripts/deployment_manager.py +0 -114
- package/plugins/xtrm-tools/skills/senior-devops/scripts/pipeline_generator.py +0 -114
- package/plugins/xtrm-tools/skills/senior-devops/scripts/terraform_scaffolder.py +0 -114
- package/plugins/xtrm-tools/skills/senior-security/SKILL.md +0 -209
- package/plugins/xtrm-tools/skills/senior-security/references/cryptography_implementation.md +0 -103
- package/plugins/xtrm-tools/skills/senior-security/references/penetration_testing_guide.md +0 -103
- package/plugins/xtrm-tools/skills/senior-security/references/security_architecture_patterns.md +0 -103
- package/plugins/xtrm-tools/skills/senior-security/scripts/pentest_automator.py +0 -114
- package/plugins/xtrm-tools/skills/senior-security/scripts/security_auditor.py +0 -114
- package/plugins/xtrm-tools/skills/senior-security/scripts/threat_modeler.py +0 -114
- package/plugins/xtrm-tools/skills/skill-creator/LICENSE.txt +0 -202
- package/plugins/xtrm-tools/skills/skill-creator/SKILL.md +0 -479
- package/plugins/xtrm-tools/skills/skill-creator/agents/analyzer.md +0 -274
- package/plugins/xtrm-tools/skills/skill-creator/agents/comparator.md +0 -202
- package/plugins/xtrm-tools/skills/skill-creator/agents/grader.md +0 -223
- package/plugins/xtrm-tools/skills/skill-creator/assets/eval_review.html +0 -146
- package/plugins/xtrm-tools/skills/skill-creator/eval-viewer/generate_review.py +0 -471
- package/plugins/xtrm-tools/skills/skill-creator/eval-viewer/viewer.html +0 -1325
- package/plugins/xtrm-tools/skills/skill-creator/references/schemas.md +0 -430
- package/plugins/xtrm-tools/skills/skill-creator/scripts/__init__.py +0 -0
- package/plugins/xtrm-tools/skills/skill-creator/scripts/aggregate_benchmark.py +0 -401
- package/plugins/xtrm-tools/skills/skill-creator/scripts/generate_report.py +0 -326
- package/plugins/xtrm-tools/skills/skill-creator/scripts/improve_description.py +0 -248
- package/plugins/xtrm-tools/skills/skill-creator/scripts/package_skill.py +0 -136
- package/plugins/xtrm-tools/skills/skill-creator/scripts/quick_validate.py +0 -103
- package/plugins/xtrm-tools/skills/skill-creator/scripts/run_eval.py +0 -310
- package/plugins/xtrm-tools/skills/skill-creator/scripts/run_loop.py +0 -332
- package/plugins/xtrm-tools/skills/skill-creator/scripts/utils.py +0 -47
- package/plugins/xtrm-tools/skills/sync-docs/SKILL.md +0 -286
- package/plugins/xtrm-tools/skills/sync-docs/evals/evals.json +0 -89
- package/plugins/xtrm-tools/skills/sync-docs/references/doc-structure.md +0 -99
- package/plugins/xtrm-tools/skills/sync-docs/references/schema.md +0 -103
- package/plugins/xtrm-tools/skills/sync-docs/scripts/changelog/add_entry.py +0 -216
- package/plugins/xtrm-tools/skills/sync-docs/scripts/context_gatherer.py +0 -240
- package/plugins/xtrm-tools/skills/sync-docs/scripts/doc_structure_analyzer.py +0 -495
- package/plugins/xtrm-tools/skills/sync-docs/scripts/drift_detector.py +0 -563
- package/plugins/xtrm-tools/skills/sync-docs/scripts/validate_doc.py +0 -365
- package/plugins/xtrm-tools/skills/sync-docs/scripts/validate_metadata.py +0 -185
- package/plugins/xtrm-tools/skills/sync-docs-workspace/iteration-1/benchmark.json +0 -293
- package/plugins/xtrm-tools/skills/sync-docs-workspace/iteration-1/benchmark.md +0 -13
- package/plugins/xtrm-tools/skills/sync-docs-workspace/iteration-1/eval-doc-audit/eval_metadata.json +0 -27
- package/plugins/xtrm-tools/skills/sync-docs-workspace/iteration-1/eval-doc-audit/with_skill/outputs/result.md +0 -210
- package/plugins/xtrm-tools/skills/sync-docs-workspace/iteration-1/eval-doc-audit/with_skill/run-1/grading.json +0 -28
- package/plugins/xtrm-tools/skills/sync-docs-workspace/iteration-1/eval-doc-audit/with_skill/run-1/timing.json +0 -1
- package/plugins/xtrm-tools/skills/sync-docs-workspace/iteration-1/eval-doc-audit/without_skill/outputs/result.md +0 -101
- package/plugins/xtrm-tools/skills/sync-docs-workspace/iteration-1/eval-doc-audit/without_skill/run-1/grading.json +0 -28
- package/plugins/xtrm-tools/skills/sync-docs-workspace/iteration-1/eval-doc-audit/without_skill/run-1/timing.json +0 -5
- package/plugins/xtrm-tools/skills/sync-docs-workspace/iteration-1/eval-doc-audit/without_skill/timing.json +0 -5
- package/plugins/xtrm-tools/skills/sync-docs-workspace/iteration-1/eval-fix-mode/eval_metadata.json +0 -27
- package/plugins/xtrm-tools/skills/sync-docs-workspace/iteration-1/eval-fix-mode/with_skill/outputs/result.md +0 -198
- package/plugins/xtrm-tools/skills/sync-docs-workspace/iteration-1/eval-fix-mode/with_skill/run-1/grading.json +0 -28
- package/plugins/xtrm-tools/skills/sync-docs-workspace/iteration-1/eval-fix-mode/with_skill/run-1/timing.json +0 -1
- package/plugins/xtrm-tools/skills/sync-docs-workspace/iteration-1/eval-fix-mode/without_skill/outputs/result.md +0 -94
- package/plugins/xtrm-tools/skills/sync-docs-workspace/iteration-1/eval-fix-mode/without_skill/run-1/grading.json +0 -28
- package/plugins/xtrm-tools/skills/sync-docs-workspace/iteration-1/eval-fix-mode/without_skill/run-1/timing.json +0 -1
- package/plugins/xtrm-tools/skills/sync-docs-workspace/iteration-1/eval-sprint-closeout/eval_metadata.json +0 -27
- package/plugins/xtrm-tools/skills/sync-docs-workspace/iteration-1/eval-sprint-closeout/with_skill/outputs/result.md +0 -237
- package/plugins/xtrm-tools/skills/sync-docs-workspace/iteration-1/eval-sprint-closeout/with_skill/run-1/grading.json +0 -28
- package/plugins/xtrm-tools/skills/sync-docs-workspace/iteration-1/eval-sprint-closeout/with_skill/run-1/timing.json +0 -1
- package/plugins/xtrm-tools/skills/sync-docs-workspace/iteration-1/eval-sprint-closeout/without_skill/outputs/result.md +0 -134
- package/plugins/xtrm-tools/skills/sync-docs-workspace/iteration-1/eval-sprint-closeout/without_skill/run-1/grading.json +0 -28
- package/plugins/xtrm-tools/skills/sync-docs-workspace/iteration-1/eval-sprint-closeout/without_skill/run-1/timing.json +0 -1
- package/plugins/xtrm-tools/skills/sync-docs-workspace/iteration-2/benchmark.json +0 -297
- package/plugins/xtrm-tools/skills/sync-docs-workspace/iteration-2/benchmark.md +0 -13
- package/plugins/xtrm-tools/skills/sync-docs-workspace/iteration-2/eval-doc-audit/eval_metadata.json +0 -27
- package/plugins/xtrm-tools/skills/sync-docs-workspace/iteration-2/eval-doc-audit/with_skill/outputs/result.md +0 -137
- package/plugins/xtrm-tools/skills/sync-docs-workspace/iteration-2/eval-doc-audit/with_skill/run-1/grading.json +0 -92
- package/plugins/xtrm-tools/skills/sync-docs-workspace/iteration-2/eval-doc-audit/with_skill/run-1/timing.json +0 -1
- package/plugins/xtrm-tools/skills/sync-docs-workspace/iteration-2/eval-doc-audit/without_skill/outputs/result.md +0 -134
- package/plugins/xtrm-tools/skills/sync-docs-workspace/iteration-2/eval-doc-audit/without_skill/run-1/grading.json +0 -86
- package/plugins/xtrm-tools/skills/sync-docs-workspace/iteration-2/eval-doc-audit/without_skill/run-1/timing.json +0 -1
- package/plugins/xtrm-tools/skills/sync-docs-workspace/iteration-2/eval-fix-mode/eval_metadata.json +0 -27
- package/plugins/xtrm-tools/skills/sync-docs-workspace/iteration-2/eval-fix-mode/with_skill/outputs/result.md +0 -193
- package/plugins/xtrm-tools/skills/sync-docs-workspace/iteration-2/eval-fix-mode/with_skill/run-1/grading.json +0 -72
- package/plugins/xtrm-tools/skills/sync-docs-workspace/iteration-2/eval-fix-mode/with_skill/run-1/timing.json +0 -1
- package/plugins/xtrm-tools/skills/sync-docs-workspace/iteration-2/eval-fix-mode/without_skill/outputs/result.md +0 -211
- package/plugins/xtrm-tools/skills/sync-docs-workspace/iteration-2/eval-fix-mode/without_skill/run-1/grading.json +0 -91
- package/plugins/xtrm-tools/skills/sync-docs-workspace/iteration-2/eval-fix-mode/without_skill/run-1/timing.json +0 -5
- package/plugins/xtrm-tools/skills/sync-docs-workspace/iteration-2/eval-sprint-closeout/eval_metadata.json +0 -27
- package/plugins/xtrm-tools/skills/sync-docs-workspace/iteration-2/eval-sprint-closeout/with_skill/outputs/result.md +0 -182
- package/plugins/xtrm-tools/skills/sync-docs-workspace/iteration-2/eval-sprint-closeout/with_skill/run-1/grading.json +0 -95
- package/plugins/xtrm-tools/skills/sync-docs-workspace/iteration-2/eval-sprint-closeout/with_skill/run-1/timing.json +0 -1
- package/plugins/xtrm-tools/skills/sync-docs-workspace/iteration-2/eval-sprint-closeout/without_skill/outputs/result.md +0 -222
- package/plugins/xtrm-tools/skills/sync-docs-workspace/iteration-2/eval-sprint-closeout/without_skill/run-1/grading.json +0 -88
- package/plugins/xtrm-tools/skills/sync-docs-workspace/iteration-2/eval-sprint-closeout/without_skill/run-1/timing.json +0 -5
- package/plugins/xtrm-tools/skills/sync-docs-workspace/iteration-3/benchmark.json +0 -298
- package/plugins/xtrm-tools/skills/sync-docs-workspace/iteration-3/benchmark.md +0 -13
- package/plugins/xtrm-tools/skills/sync-docs-workspace/iteration-3/eval-doc-audit/eval_metadata.json +0 -27
- package/plugins/xtrm-tools/skills/sync-docs-workspace/iteration-3/eval-doc-audit/with_skill/outputs/result.md +0 -125
- package/plugins/xtrm-tools/skills/sync-docs-workspace/iteration-3/eval-doc-audit/with_skill/run-1/grading.json +0 -97
- package/plugins/xtrm-tools/skills/sync-docs-workspace/iteration-3/eval-doc-audit/with_skill/run-1/timing.json +0 -5
- package/plugins/xtrm-tools/skills/sync-docs-workspace/iteration-3/eval-doc-audit/without_skill/outputs/result.md +0 -144
- package/plugins/xtrm-tools/skills/sync-docs-workspace/iteration-3/eval-doc-audit/without_skill/run-1/grading.json +0 -78
- package/plugins/xtrm-tools/skills/sync-docs-workspace/iteration-3/eval-doc-audit/without_skill/run-1/timing.json +0 -5
- package/plugins/xtrm-tools/skills/sync-docs-workspace/iteration-3/eval-fix-mode/eval_metadata.json +0 -27
- package/plugins/xtrm-tools/skills/sync-docs-workspace/iteration-3/eval-fix-mode/with_skill/outputs/result.md +0 -104
- package/plugins/xtrm-tools/skills/sync-docs-workspace/iteration-3/eval-fix-mode/with_skill/run-1/grading.json +0 -91
- package/plugins/xtrm-tools/skills/sync-docs-workspace/iteration-3/eval-fix-mode/with_skill/run-1/timing.json +0 -5
- package/plugins/xtrm-tools/skills/sync-docs-workspace/iteration-3/eval-fix-mode/without_skill/outputs/result.md +0 -79
- package/plugins/xtrm-tools/skills/sync-docs-workspace/iteration-3/eval-fix-mode/without_skill/run-1/grading.json +0 -82
- package/plugins/xtrm-tools/skills/sync-docs-workspace/iteration-3/eval-fix-mode/without_skill/run-1/timing.json +0 -5
- package/plugins/xtrm-tools/skills/sync-docs-workspace/iteration-3/eval-sprint-closeout/eval_metadata.json +0 -27
- package/plugins/xtrm-tools/skills/sync-docs-workspace/iteration-3/eval-sprint-closeout/with_skill/outputs/phase1_context.json +0 -302
- package/plugins/xtrm-tools/skills/sync-docs-workspace/iteration-3/eval-sprint-closeout/with_skill/outputs/phase2_drift.txt +0 -33
- package/plugins/xtrm-tools/skills/sync-docs-workspace/iteration-3/eval-sprint-closeout/with_skill/outputs/phase3_analysis.json +0 -114
- package/plugins/xtrm-tools/skills/sync-docs-workspace/iteration-3/eval-sprint-closeout/with_skill/outputs/phase4_fix.txt +0 -118
- package/plugins/xtrm-tools/skills/sync-docs-workspace/iteration-3/eval-sprint-closeout/with_skill/outputs/phase5_validate.txt +0 -38
- package/plugins/xtrm-tools/skills/sync-docs-workspace/iteration-3/eval-sprint-closeout/with_skill/outputs/result.md +0 -158
- package/plugins/xtrm-tools/skills/sync-docs-workspace/iteration-3/eval-sprint-closeout/with_skill/run-1/grading.json +0 -95
- package/plugins/xtrm-tools/skills/sync-docs-workspace/iteration-3/eval-sprint-closeout/with_skill/run-1/timing.json +0 -5
- package/plugins/xtrm-tools/skills/sync-docs-workspace/iteration-3/eval-sprint-closeout/without_skill/outputs/result.md +0 -71
- package/plugins/xtrm-tools/skills/sync-docs-workspace/iteration-3/eval-sprint-closeout/without_skill/run-1/grading.json +0 -90
- package/plugins/xtrm-tools/skills/sync-docs-workspace/iteration-3/eval-sprint-closeout/without_skill/run-1/timing.json +0 -5
- package/plugins/xtrm-tools/skills/test-planning/SKILL.md +0 -465
- package/plugins/xtrm-tools/skills/test-planning/evals/evals.json +0 -23
- package/plugins/xtrm-tools/skills/updating-service-skills/SKILL.md +0 -136
- package/plugins/xtrm-tools/skills/updating-service-skills/scripts/drift_detector.py +0 -222
- package/plugins/xtrm-tools/skills/using-quality-gates/SKILL.md +0 -254
- package/plugins/xtrm-tools/skills/using-serena-lsp/README.md +0 -8
- package/plugins/xtrm-tools/skills/using-serena-lsp/REFERENCE.md +0 -194
- package/plugins/xtrm-tools/skills/using-serena-lsp/SKILL.md +0 -82
- package/plugins/xtrm-tools/skills/using-service-skills/SKILL.md +0 -108
- package/plugins/xtrm-tools/skills/using-service-skills/scripts/cataloger.py +0 -74
- package/plugins/xtrm-tools/skills/using-service-skills/scripts/skill_activator.py +0 -152
- package/plugins/xtrm-tools/skills/using-service-skills/scripts/test_skill_activator.py +0 -58
- package/plugins/xtrm-tools/skills/using-tdd/SKILL.md +0 -410
- package/plugins/xtrm-tools/skills/using-xtrm/SKILL.md +0 -127
- package/plugins/xtrm-tools/skills/xt-debugging/SKILL.md +0 -149
- package/plugins/xtrm-tools/skills/xt-end/SKILL.md +0 -297
- package/plugins/xtrm-tools/skills/xt-merge/SKILL.md +0 -313
- package/project-skills/quality-gates/.claude/hooks/hook-config.json +0 -66
- package/project-skills/quality-gates/.claude/hooks/quality-check.cjs +0 -1286
- package/project-skills/quality-gates/.claude/hooks/quality-check.py +0 -334
- package/project-skills/quality-gates/.claude/settings.json +0 -3
- package/project-skills/quality-gates/.claude/skills/using-quality-gates/SKILL.md +0 -254
- package/project-skills/quality-gates/README.md +0 -109
- package/project-skills/quality-gates/evals/evals.json +0 -181
- package/project-skills/quality-gates/workspace/iteration-1/FINAL-EVAL-SUMMARY.md +0 -75
- package/project-skills/quality-gates/workspace/iteration-1/edge-case-auto-fix-verification/with_skill/outputs/response.md +0 -59
- package/project-skills/quality-gates/workspace/iteration-1/edge-case-mixed-language-project/with_skill/outputs/response.md +0 -60
- package/project-skills/quality-gates/workspace/iteration-1/eval-summary.md +0 -105
- package/project-skills/quality-gates/workspace/iteration-1/partial-install-python-only/with_skill/outputs/response.md +0 -93
- package/project-skills/quality-gates/workspace/iteration-1/python-refactor-request/with_skill/outputs/response.md +0 -104
- package/project-skills/quality-gates/workspace/iteration-1/quality-gate-error-fix/with_skill/outputs/response.md +0 -74
- package/project-skills/quality-gates/workspace/iteration-1/should-not-trigger-general-chat/with_skill/outputs/response.md +0 -18
- package/project-skills/quality-gates/workspace/iteration-1/should-not-trigger-math-question/with_skill/outputs/response.md +0 -18
- package/project-skills/quality-gates/workspace/iteration-1/should-not-trigger-unrelated-coding/with_skill/outputs/response.md +0 -56
- package/project-skills/quality-gates/workspace/iteration-1/tdd-guard-blocking-confusion/with_skill/outputs/response.md +0 -67
- package/project-skills/quality-gates/workspace/iteration-1/typescript-feature-with-tests/with_skill/outputs/response.md +0 -97
- package/project-skills/service-skills-set/.claude/git-hooks/doc_reminder.py +0 -67
- package/project-skills/service-skills-set/.claude/git-hooks/skill_staleness.py +0 -194
- package/project-skills/service-skills-set/.claude/service-registry.json +0 -4
- package/project-skills/service-skills-set/.claude/settings.json +0 -37
- package/project-skills/service-skills-set/.claude/skills/creating-service-skills/SKILL.md +0 -433
- package/project-skills/service-skills-set/.claude/skills/creating-service-skills/references/script_quality_standards.md +0 -425
- package/project-skills/service-skills-set/.claude/skills/creating-service-skills/references/service_skill_system_guide.md +0 -278
- package/project-skills/service-skills-set/.claude/skills/creating-service-skills/scripts/bootstrap.py +0 -308
- package/project-skills/service-skills-set/.claude/skills/creating-service-skills/scripts/deep_dive.py +0 -304
- package/project-skills/service-skills-set/.claude/skills/creating-service-skills/scripts/scaffolder.py +0 -482
- package/project-skills/service-skills-set/.claude/skills/scoping-service-skills/SKILL.md +0 -231
- package/project-skills/service-skills-set/.claude/skills/scoping-service-skills/scripts/scope.py +0 -74
- package/project-skills/service-skills-set/.claude/skills/updating-service-skills/SKILL.md +0 -136
- package/project-skills/service-skills-set/.claude/skills/updating-service-skills/scripts/drift_detector.py +0 -222
- package/project-skills/service-skills-set/.claude/skills/using-service-skills/SKILL.md +0 -108
- package/project-skills/service-skills-set/.claude/skills/using-service-skills/scripts/cataloger.py +0 -74
- package/project-skills/service-skills-set/.claude/skills/using-service-skills/scripts/skill_activator.py +0 -152
- package/project-skills/service-skills-set/README.md +0 -93
- package/project-skills/service-skills-set/install-service-skills.py +0 -193
- package/project-skills/service-skills-set/service-skills-readme.md +0 -236
- package/skills/README.txt +0 -31
- package/skills/clean-code/SKILL.md +0 -201
- package/skills/creating-service-skills/SKILL.md +0 -433
- package/skills/creating-service-skills/references/script_quality_standards.md +0 -425
- package/skills/creating-service-skills/references/service_skill_system_guide.md +0 -278
- package/skills/creating-service-skills/scripts/bootstrap.py +0 -326
- package/skills/creating-service-skills/scripts/deep_dive.py +0 -304
- package/skills/creating-service-skills/scripts/scaffolder.py +0 -482
- package/skills/delegating/SKILL.md +0 -196
- package/skills/delegating/config.yaml +0 -210
- package/skills/delegating/references/orchestration-protocols.md +0 -41
- package/skills/docker-expert/SKILL.md +0 -409
- package/skills/documenting/CHANGELOG.md +0 -23
- package/skills/documenting/README.md +0 -148
- package/skills/documenting/SKILL.md +0 -113
- package/skills/documenting/examples/example_pattern.md +0 -70
- package/skills/documenting/examples/example_reference.md +0 -70
- package/skills/documenting/examples/example_ssot_analytics.md +0 -64
- package/skills/documenting/examples/example_workflow.md +0 -141
- package/skills/documenting/references/changelog-format.md +0 -97
- package/skills/documenting/references/metadata-schema.md +0 -136
- package/skills/documenting/references/taxonomy.md +0 -81
- package/skills/documenting/references/versioning-rules.md +0 -78
- package/skills/documenting/scripts/bump_version.sh +0 -60
- package/skills/documenting/scripts/changelog/__init__.py +0 -0
- package/skills/documenting/scripts/changelog/add_entry.py +0 -216
- package/skills/documenting/scripts/changelog/bump_release.py +0 -117
- package/skills/documenting/scripts/changelog/init_changelog.py +0 -54
- package/skills/documenting/scripts/changelog/validate_changelog.py +0 -128
- package/skills/documenting/scripts/drift_detector.py +0 -266
- package/skills/documenting/scripts/generate_template.py +0 -311
- package/skills/documenting/scripts/list_by_category.sh +0 -84
- package/skills/documenting/scripts/orchestrator.py +0 -255
- package/skills/documenting/scripts/validate_metadata.py +0 -242
- package/skills/documenting/templates/CHANGELOG.md.template +0 -13
- package/skills/find-skills/SKILL.md +0 -133
- package/skills/gitnexus-exploring/SKILL.md +0 -75
- package/skills/gitnexus-impact-analysis/SKILL.md +0 -94
- package/skills/gitnexus-refactoring/SKILL.md +0 -113
- package/skills/hook-development/SKILL.md +0 -797
- package/skills/hook-development/examples/load-context.sh +0 -55
- package/skills/hook-development/examples/quality-check.js +0 -1168
- package/skills/hook-development/examples/validate-bash.sh +0 -43
- package/skills/hook-development/examples/validate-write.sh +0 -38
- package/skills/hook-development/references/advanced.md +0 -527
- package/skills/hook-development/references/migration.md +0 -369
- package/skills/hook-development/references/patterns.md +0 -412
- package/skills/hook-development/scripts/README.md +0 -164
- package/skills/hook-development/scripts/hook-linter.sh +0 -153
- package/skills/hook-development/scripts/test-hook.sh +0 -252
- package/skills/hook-development/scripts/validate-hook-schema.sh +0 -159
- package/skills/obsidian-cli/SKILL.md +0 -106
- package/skills/orchestrating-agents/SKILL.md +0 -135
- package/skills/orchestrating-agents/config.yaml +0 -45
- package/skills/orchestrating-agents/references/agent-context-integration.md +0 -37
- package/skills/orchestrating-agents/references/examples.md +0 -45
- package/skills/orchestrating-agents/references/handover-protocol.md +0 -31
- package/skills/orchestrating-agents/references/workflows.md +0 -42
- package/skills/orchestrating-agents/scripts/detect_neighbors.py +0 -23
- package/skills/planning/SKILL.md +0 -405
- package/skills/planning/evals/evals.json +0 -19
- package/skills/prompt-improving/README.md +0 -162
- package/skills/prompt-improving/SKILL.md +0 -74
- package/skills/prompt-improving/references/analysis_commands.md +0 -24
- package/skills/prompt-improving/references/chain_of_thought.md +0 -24
- package/skills/prompt-improving/references/mcp_definitions.md +0 -20
- package/skills/prompt-improving/references/multishot.md +0 -23
- package/skills/prompt-improving/references/xml_core.md +0 -60
- package/skills/python-testing/SKILL.md +0 -815
- package/skills/scoping-service-skills/SKILL.md +0 -231
- package/skills/scoping-service-skills/scripts/scope.py +0 -74
- package/skills/senior-backend/SKILL.md +0 -209
- package/skills/senior-backend/references/api_design_patterns.md +0 -103
- package/skills/senior-backend/references/backend_security_practices.md +0 -103
- package/skills/senior-backend/references/database_optimization_guide.md +0 -103
- package/skills/senior-backend/scripts/api_load_tester.py +0 -114
- package/skills/senior-backend/scripts/api_scaffolder.py +0 -114
- package/skills/senior-backend/scripts/database_migration_tool.py +0 -114
- package/skills/senior-data-scientist/SKILL.md +0 -226
- package/skills/senior-data-scientist/references/experiment_design_frameworks.md +0 -80
- package/skills/senior-data-scientist/references/feature_engineering_patterns.md +0 -80
- package/skills/senior-data-scientist/references/statistical_methods_advanced.md +0 -80
- package/skills/senior-data-scientist/scripts/experiment_designer.py +0 -100
- package/skills/senior-data-scientist/scripts/feature_engineering_pipeline.py +0 -100
- package/skills/senior-data-scientist/scripts/model_evaluation_suite.py +0 -100
- package/skills/senior-devops/SKILL.md +0 -209
- package/skills/senior-devops/references/cicd_pipeline_guide.md +0 -103
- package/skills/senior-devops/references/deployment_strategies.md +0 -103
- package/skills/senior-devops/references/infrastructure_as_code.md +0 -103
- package/skills/senior-devops/scripts/deployment_manager.py +0 -114
- package/skills/senior-devops/scripts/pipeline_generator.py +0 -114
- package/skills/senior-devops/scripts/terraform_scaffolder.py +0 -114
- package/skills/senior-security/SKILL.md +0 -209
- package/skills/senior-security/references/cryptography_implementation.md +0 -103
- package/skills/senior-security/references/penetration_testing_guide.md +0 -103
- package/skills/senior-security/references/security_architecture_patterns.md +0 -103
- package/skills/senior-security/scripts/pentest_automator.py +0 -114
- package/skills/senior-security/scripts/security_auditor.py +0 -114
- package/skills/senior-security/scripts/threat_modeler.py +0 -114
- package/skills/skill-creator/LICENSE.txt +0 -202
- package/skills/skill-creator/SKILL.md +0 -479
- package/skills/skill-creator/agents/analyzer.md +0 -274
- package/skills/skill-creator/agents/comparator.md +0 -202
- package/skills/skill-creator/agents/grader.md +0 -223
- package/skills/skill-creator/assets/eval_review.html +0 -146
- package/skills/skill-creator/eval-viewer/generate_review.py +0 -471
- package/skills/skill-creator/eval-viewer/viewer.html +0 -1325
- package/skills/skill-creator/references/schemas.md +0 -430
- package/skills/skill-creator/scripts/__init__.py +0 -0
- package/skills/skill-creator/scripts/aggregate_benchmark.py +0 -401
- package/skills/skill-creator/scripts/generate_report.py +0 -326
- package/skills/skill-creator/scripts/improve_description.py +0 -248
- package/skills/skill-creator/scripts/package_skill.py +0 -136
- package/skills/skill-creator/scripts/quick_validate.py +0 -103
- package/skills/skill-creator/scripts/run_eval.py +0 -310
- package/skills/skill-creator/scripts/run_loop.py +0 -332
- package/skills/skill-creator/scripts/utils.py +0 -47
- package/skills/sync-docs/SKILL.md +0 -286
- package/skills/sync-docs/evals/evals.json +0 -89
- package/skills/sync-docs/references/doc-structure.md +0 -99
- package/skills/sync-docs/references/schema.md +0 -103
- package/skills/sync-docs/scripts/changelog/add_entry.py +0 -216
- package/skills/sync-docs/scripts/context_gatherer.py +0 -240
- package/skills/sync-docs/scripts/doc_structure_analyzer.py +0 -495
- package/skills/sync-docs/scripts/drift_detector.py +0 -563
- package/skills/sync-docs/scripts/validate_doc.py +0 -365
- package/skills/sync-docs/scripts/validate_metadata.py +0 -185
- package/skills/sync-docs-workspace/iteration-1/benchmark.json +0 -293
- package/skills/sync-docs-workspace/iteration-1/benchmark.md +0 -13
- package/skills/sync-docs-workspace/iteration-1/eval-doc-audit/eval_metadata.json +0 -27
- package/skills/sync-docs-workspace/iteration-1/eval-doc-audit/with_skill/outputs/result.md +0 -210
- package/skills/sync-docs-workspace/iteration-1/eval-doc-audit/with_skill/run-1/grading.json +0 -28
- package/skills/sync-docs-workspace/iteration-1/eval-doc-audit/with_skill/run-1/timing.json +0 -1
- package/skills/sync-docs-workspace/iteration-1/eval-doc-audit/without_skill/outputs/result.md +0 -101
- package/skills/sync-docs-workspace/iteration-1/eval-doc-audit/without_skill/run-1/grading.json +0 -28
- package/skills/sync-docs-workspace/iteration-1/eval-doc-audit/without_skill/run-1/timing.json +0 -5
- package/skills/sync-docs-workspace/iteration-1/eval-doc-audit/without_skill/timing.json +0 -5
- package/skills/sync-docs-workspace/iteration-1/eval-fix-mode/eval_metadata.json +0 -27
- package/skills/sync-docs-workspace/iteration-1/eval-fix-mode/with_skill/outputs/result.md +0 -198
- package/skills/sync-docs-workspace/iteration-1/eval-fix-mode/with_skill/run-1/grading.json +0 -28
- package/skills/sync-docs-workspace/iteration-1/eval-fix-mode/with_skill/run-1/timing.json +0 -1
- package/skills/sync-docs-workspace/iteration-1/eval-fix-mode/without_skill/outputs/result.md +0 -94
- package/skills/sync-docs-workspace/iteration-1/eval-fix-mode/without_skill/run-1/grading.json +0 -28
- package/skills/sync-docs-workspace/iteration-1/eval-fix-mode/without_skill/run-1/timing.json +0 -1
- package/skills/sync-docs-workspace/iteration-1/eval-sprint-closeout/eval_metadata.json +0 -27
- package/skills/sync-docs-workspace/iteration-1/eval-sprint-closeout/with_skill/outputs/result.md +0 -237
- package/skills/sync-docs-workspace/iteration-1/eval-sprint-closeout/with_skill/run-1/grading.json +0 -28
- package/skills/sync-docs-workspace/iteration-1/eval-sprint-closeout/with_skill/run-1/timing.json +0 -1
- package/skills/sync-docs-workspace/iteration-1/eval-sprint-closeout/without_skill/outputs/result.md +0 -134
- package/skills/sync-docs-workspace/iteration-1/eval-sprint-closeout/without_skill/run-1/grading.json +0 -28
- package/skills/sync-docs-workspace/iteration-1/eval-sprint-closeout/without_skill/run-1/timing.json +0 -1
- package/skills/sync-docs-workspace/iteration-2/benchmark.json +0 -297
- package/skills/sync-docs-workspace/iteration-2/benchmark.md +0 -13
- package/skills/sync-docs-workspace/iteration-2/eval-doc-audit/eval_metadata.json +0 -27
- package/skills/sync-docs-workspace/iteration-2/eval-doc-audit/with_skill/outputs/result.md +0 -137
- package/skills/sync-docs-workspace/iteration-2/eval-doc-audit/with_skill/run-1/grading.json +0 -92
- package/skills/sync-docs-workspace/iteration-2/eval-doc-audit/with_skill/run-1/timing.json +0 -1
- package/skills/sync-docs-workspace/iteration-2/eval-doc-audit/without_skill/outputs/result.md +0 -134
- package/skills/sync-docs-workspace/iteration-2/eval-doc-audit/without_skill/run-1/grading.json +0 -86
- package/skills/sync-docs-workspace/iteration-2/eval-doc-audit/without_skill/run-1/timing.json +0 -1
- package/skills/sync-docs-workspace/iteration-2/eval-fix-mode/eval_metadata.json +0 -27
- package/skills/sync-docs-workspace/iteration-2/eval-fix-mode/with_skill/outputs/result.md +0 -193
- package/skills/sync-docs-workspace/iteration-2/eval-fix-mode/with_skill/run-1/grading.json +0 -72
- package/skills/sync-docs-workspace/iteration-2/eval-fix-mode/with_skill/run-1/timing.json +0 -1
- package/skills/sync-docs-workspace/iteration-2/eval-fix-mode/without_skill/outputs/result.md +0 -211
- package/skills/sync-docs-workspace/iteration-2/eval-fix-mode/without_skill/run-1/grading.json +0 -91
- package/skills/sync-docs-workspace/iteration-2/eval-fix-mode/without_skill/run-1/timing.json +0 -5
- package/skills/sync-docs-workspace/iteration-2/eval-sprint-closeout/eval_metadata.json +0 -27
- package/skills/sync-docs-workspace/iteration-2/eval-sprint-closeout/with_skill/outputs/result.md +0 -182
- package/skills/sync-docs-workspace/iteration-2/eval-sprint-closeout/with_skill/run-1/grading.json +0 -95
- package/skills/sync-docs-workspace/iteration-2/eval-sprint-closeout/with_skill/run-1/timing.json +0 -1
- package/skills/sync-docs-workspace/iteration-2/eval-sprint-closeout/without_skill/outputs/result.md +0 -222
- package/skills/sync-docs-workspace/iteration-2/eval-sprint-closeout/without_skill/run-1/grading.json +0 -88
- package/skills/sync-docs-workspace/iteration-2/eval-sprint-closeout/without_skill/run-1/timing.json +0 -5
- package/skills/sync-docs-workspace/iteration-3/benchmark.json +0 -298
- package/skills/sync-docs-workspace/iteration-3/benchmark.md +0 -13
- package/skills/sync-docs-workspace/iteration-3/eval-doc-audit/eval_metadata.json +0 -27
- package/skills/sync-docs-workspace/iteration-3/eval-doc-audit/with_skill/outputs/result.md +0 -125
- package/skills/sync-docs-workspace/iteration-3/eval-doc-audit/with_skill/run-1/grading.json +0 -97
- package/skills/sync-docs-workspace/iteration-3/eval-doc-audit/with_skill/run-1/timing.json +0 -5
- package/skills/sync-docs-workspace/iteration-3/eval-doc-audit/without_skill/outputs/result.md +0 -144
- package/skills/sync-docs-workspace/iteration-3/eval-doc-audit/without_skill/run-1/grading.json +0 -78
- package/skills/sync-docs-workspace/iteration-3/eval-doc-audit/without_skill/run-1/timing.json +0 -5
- package/skills/sync-docs-workspace/iteration-3/eval-fix-mode/eval_metadata.json +0 -27
- package/skills/sync-docs-workspace/iteration-3/eval-fix-mode/with_skill/outputs/result.md +0 -104
- package/skills/sync-docs-workspace/iteration-3/eval-fix-mode/with_skill/run-1/grading.json +0 -91
- package/skills/sync-docs-workspace/iteration-3/eval-fix-mode/with_skill/run-1/timing.json +0 -5
- package/skills/sync-docs-workspace/iteration-3/eval-fix-mode/without_skill/outputs/result.md +0 -79
- package/skills/sync-docs-workspace/iteration-3/eval-fix-mode/without_skill/run-1/grading.json +0 -82
- package/skills/sync-docs-workspace/iteration-3/eval-fix-mode/without_skill/run-1/timing.json +0 -5
- package/skills/sync-docs-workspace/iteration-3/eval-sprint-closeout/eval_metadata.json +0 -27
- package/skills/sync-docs-workspace/iteration-3/eval-sprint-closeout/with_skill/outputs/phase1_context.json +0 -302
- package/skills/sync-docs-workspace/iteration-3/eval-sprint-closeout/with_skill/outputs/phase2_drift.txt +0 -33
- package/skills/sync-docs-workspace/iteration-3/eval-sprint-closeout/with_skill/outputs/phase3_analysis.json +0 -114
- package/skills/sync-docs-workspace/iteration-3/eval-sprint-closeout/with_skill/outputs/phase4_fix.txt +0 -118
- package/skills/sync-docs-workspace/iteration-3/eval-sprint-closeout/with_skill/outputs/phase5_validate.txt +0 -38
- package/skills/sync-docs-workspace/iteration-3/eval-sprint-closeout/with_skill/outputs/result.md +0 -158
- package/skills/sync-docs-workspace/iteration-3/eval-sprint-closeout/with_skill/run-1/grading.json +0 -95
- package/skills/sync-docs-workspace/iteration-3/eval-sprint-closeout/with_skill/run-1/timing.json +0 -5
- package/skills/sync-docs-workspace/iteration-3/eval-sprint-closeout/without_skill/outputs/result.md +0 -71
- package/skills/sync-docs-workspace/iteration-3/eval-sprint-closeout/without_skill/run-1/grading.json +0 -90
- package/skills/sync-docs-workspace/iteration-3/eval-sprint-closeout/without_skill/run-1/timing.json +0 -5
- package/skills/test-planning/SKILL.md +0 -465
- package/skills/test-planning/evals/evals.json +0 -23
- package/skills/updating-service-skills/SKILL.md +0 -136
- package/skills/updating-service-skills/scripts/drift_detector.py +0 -222
- package/skills/using-quality-gates/SKILL.md +0 -254
- package/skills/using-serena-lsp/README.md +0 -8
- package/skills/using-serena-lsp/REFERENCE.md +0 -194
- package/skills/using-serena-lsp/SKILL.md +0 -82
- package/skills/using-service-skills/SKILL.md +0 -108
- package/skills/using-service-skills/scripts/cataloger.py +0 -74
- package/skills/using-service-skills/scripts/skill_activator.py +0 -152
- package/skills/using-service-skills/scripts/test_skill_activator.py +0 -58
- package/skills/using-tdd/SKILL.md +0 -410
- package/skills/using-xtrm/SKILL.md +0 -127
- package/skills/xt-debugging/SKILL.md +0 -149
- package/skills/xt-end/SKILL.md +0 -297
- package/skills/xt-merge/SKILL.md +0 -313
- /package/{config → .xtrm/config}/.env.example +0 -0
- /package/{config/mcp_servers_optional.json → .xtrm/config/claude.mcp.optional.json} +0 -0
- /package/{hooks → .xtrm/config}/hooks.json +0 -0
- /package/{config → .xtrm/config}/pi/auth.json.template +0 -0
- /package/{config → .xtrm/config}/pi/extensions/auto-session-name/index.ts +0 -0
- /package/{config → .xtrm/config}/pi/extensions/auto-session-name/package.json +0 -0
- /package/{config → .xtrm/config}/pi/extensions/auto-update/index.ts +0 -0
- /package/{config → .xtrm/config}/pi/extensions/auto-update/package.json +0 -0
- /package/{config → .xtrm/config}/pi/extensions/beads/package.json +0 -0
- /package/{config → .xtrm/config}/pi/extensions/compact-header/index.ts +0 -0
- /package/{config → .xtrm/config}/pi/extensions/compact-header/package.json +0 -0
- /package/{config → .xtrm/config}/pi/extensions/core/adapter.ts +0 -0
- /package/{config → .xtrm/config}/pi/extensions/core/guard-rules.ts +0 -0
- /package/{config → .xtrm/config}/pi/extensions/core/lib.ts +0 -0
- /package/{config → .xtrm/config}/pi/extensions/core/logger.ts +0 -0
- /package/{config → .xtrm/config}/pi/extensions/core/package.json +0 -0
- /package/{config → .xtrm/config}/pi/extensions/core/runner.ts +0 -0
- /package/{config → .xtrm/config}/pi/extensions/core/session-state.ts +0 -0
- /package/{config → .xtrm/config}/pi/extensions/custom-footer/package.json +0 -0
- /package/{config → .xtrm/config}/pi/extensions/custom-provider-qwen-cli/index.ts +0 -0
- /package/{config → .xtrm/config}/pi/extensions/custom-provider-qwen-cli/package.json +0 -0
- /package/{config → .xtrm/config}/pi/extensions/git-checkpoint/index.ts +0 -0
- /package/{config → .xtrm/config}/pi/extensions/git-checkpoint/package.json +0 -0
- /package/{config → .xtrm/config}/pi/extensions/lsp-bootstrap/index.ts +0 -0
- /package/{config → .xtrm/config}/pi/extensions/lsp-bootstrap/package.json +0 -0
- /package/{config → .xtrm/config}/pi/extensions/pi-serena-compact/index.ts +0 -0
- /package/{config → .xtrm/config}/pi/extensions/pi-serena-compact/package.json +0 -0
- /package/{config → .xtrm/config}/pi/extensions/quality-gates/index.ts +0 -0
- /package/{config → .xtrm/config}/pi/extensions/quality-gates/package.json +0 -0
- /package/{config → .xtrm/config}/pi/extensions/service-skills/index.ts +0 -0
- /package/{config → .xtrm/config}/pi/extensions/service-skills/package.json +0 -0
- /package/{config → .xtrm/config}/pi/extensions/session-flow/index.ts +0 -0
- /package/{config → .xtrm/config}/pi/extensions/session-flow/package.json +0 -0
- /package/{config → .xtrm/config}/pi/extensions/xtrm-loader/index.ts +0 -0
- /package/{config → .xtrm/config}/pi/extensions/xtrm-loader/package.json +0 -0
- /package/{config → .xtrm/config}/pi/extensions/xtrm-ui/format.ts +0 -0
- /package/{config → .xtrm/config}/pi/extensions/xtrm-ui/package.json +0 -0
- /package/{config → .xtrm/config}/pi/extensions/xtrm-ui/themes/pidex-dark.json +0 -0
- /package/{config → .xtrm/config}/pi/extensions/xtrm-ui/themes/pidex-light.json +0 -0
- /package/{config → .xtrm/config}/pi/models.json.template +0 -0
- /package/{config → .xtrm/config}/pi/pi-worktrees-settings.json +0 -0
- /package/{config → .xtrm/config}/pi/settings.json.template +0 -0
- /package/{hooks → .xtrm/hooks}/beads-claim-sync.mjs +0 -0
- /package/{hooks → .xtrm/hooks}/beads-compact-restore.mjs +0 -0
- /package/{hooks → .xtrm/hooks}/beads-compact-save.mjs +0 -0
- /package/{hooks → .xtrm/hooks}/beads-edit-gate.mjs +0 -0
- /package/{hooks → .xtrm/hooks}/beads-gate-core.mjs +0 -0
- /package/{hooks → .xtrm/hooks}/beads-gate-messages.mjs +0 -0
- /package/{hooks → .xtrm/hooks}/beads-gate-utils.mjs +0 -0
- /package/{hooks → .xtrm/hooks}/beads-stop-gate.mjs +0 -0
- /package/{hooks → .xtrm/hooks}/gitnexus/gitnexus-hook.cjs +0 -0
- /package/{hooks → .xtrm/hooks}/quality-check.cjs +0 -0
- /package/{hooks → .xtrm/hooks}/quality-check.py +0 -0
- /package/{hooks → .xtrm/hooks}/worktree-boundary.mjs +0 -0
- /package/{hooks → .xtrm/hooks}/xtrm-logger.mjs +0 -0
- /package/{hooks → .xtrm/hooks}/xtrm-session-logger.mjs +0 -0
- /package/{hooks → .xtrm/hooks}/xtrm-tool-logger.mjs +0 -0
|
@@ -1,334 +0,0 @@
|
|
|
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)
|
|
@@ -1,254 +0,0 @@
|
|
|
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
|
|
@@ -1,109 +0,0 @@
|
|
|
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/
|