universal-dev-standards 4.2.0 → 5.0.0-beta.10
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/README.md +3 -3
- package/bin/uds.js +165 -5
- package/bundled/core/acceptance-test-driven-development.md +19 -721
- package/bundled/core/accessibility-standards.md +862 -0
- package/bundled/core/ai-agreement-standards.md +95 -0
- package/bundled/core/ai-friendly-architecture.md +2 -0
- package/bundled/core/ai-instruction-standards.md +2 -0
- package/bundled/core/anti-hallucination.md +90 -637
- package/bundled/core/behavior-driven-development.md +20 -735
- package/bundled/core/changelog-standards.md +4 -0
- package/bundled/core/checkin-standards.md +21 -4
- package/bundled/core/code-review-checklist.md +3 -0
- package/bundled/core/commit-message-guide.md +14 -3
- package/bundled/core/deployment-standards.md +296 -0
- package/bundled/core/developer-memory.md +568 -0
- package/bundled/core/documentation-structure.md +114 -18
- package/bundled/core/documentation-writing-standards.md +272 -2
- package/bundled/core/error-code-standards.md +3 -0
- package/bundled/core/forward-derivation-standards.md +134 -8
- package/bundled/core/git-workflow.md +72 -686
- package/bundled/core/guides/anti-hallucination-guide.md +517 -0
- package/bundled/core/guides/git-workflow-guide.md +954 -0
- package/bundled/core/guides/performance-guide.md +508 -0
- package/bundled/core/guides/refactoring-guide.md +608 -0
- package/bundled/core/guides/security-guide.md +485 -0
- package/bundled/core/logging-standards.md +337 -2
- package/bundled/core/performance-standards.md +231 -0
- package/bundled/core/project-context-memory.md +180 -0
- package/bundled/core/project-structure.md +315 -2
- package/bundled/core/refactoring-standards.md +81 -761
- package/bundled/core/requirement-engineering.md +39 -0
- package/bundled/core/reverse-engineering-standards.md +6 -4
- package/bundled/core/security-standards.md +244 -0
- package/bundled/core/spec-driven-development.md +20 -319
- package/bundled/core/test-completeness-dimensions.md +213 -11
- package/bundled/core/test-driven-development.md +22 -978
- package/bundled/core/testing-standards.md +222 -2903
- package/bundled/core/versioning.md +16 -55
- package/bundled/core/virtual-organization-standards.md +85 -0
- package/bundled/locales/README.md +4 -4
- package/bundled/locales/zh-CN/CHANGELOG.md +18 -18
- package/bundled/locales/zh-CN/CLAUDE.md +3 -3
- package/bundled/locales/zh-CN/MAINTENANCE.md +7 -7
- package/bundled/locales/zh-CN/README.md +2 -2
- package/bundled/locales/zh-CN/STANDARDS-MAPPING.md +1 -1
- package/bundled/locales/zh-CN/adoption/ADOPTION-GUIDE.md +3 -3
- package/bundled/locales/zh-CN/adoption/DAILY-WORKFLOW-GUIDE.md +66 -7
- package/bundled/locales/zh-CN/adoption/STATIC-DYNAMIC-GUIDE.md +22 -22
- package/bundled/locales/zh-CN/adoption/checklists/enterprise.md +5 -5
- package/bundled/locales/zh-CN/adoption/checklists/minimal.md +4 -4
- package/bundled/locales/zh-CN/adoption/checklists/recommended.md +5 -5
- package/bundled/locales/zh-CN/ai/MAINTENANCE.md +13 -13
- package/bundled/locales/zh-CN/core/ai-instruction-standards.md +1 -1
- package/bundled/locales/zh-CN/core/anti-hallucination.md +39 -3
- package/bundled/locales/zh-CN/core/checkin-standards.md +18 -5
- package/bundled/locales/zh-CN/core/commit-message-guide.md +1 -1
- package/bundled/locales/zh-CN/core/developer-memory.md +576 -0
- package/bundled/locales/zh-CN/core/documentation-structure.md +43 -5
- package/bundled/locales/zh-CN/core/documentation-writing-standards.md +146 -5
- package/bundled/locales/zh-CN/core/git-workflow.md +179 -4
- package/bundled/locales/zh-CN/core/logging-standards.md +177 -4
- package/bundled/locales/zh-CN/core/project-structure.md +117 -5
- package/bundled/locales/zh-CN/core/refactoring-standards.md +3 -3
- package/bundled/locales/zh-CN/core/reverse-engineering-standards.md +6 -6
- package/bundled/locales/zh-CN/core/spec-driven-development.md +516 -14
- package/bundled/locales/zh-CN/core/test-completeness-dimensions.md +155 -24
- package/bundled/locales/zh-CN/core/test-driven-development.md +71 -20
- package/bundled/locales/zh-CN/core/testing-standards.md +4 -4
- package/bundled/locales/zh-CN/core/versioning.md +1 -1
- package/bundled/locales/zh-CN/docs/AI-AGENT-ROADMAP.md +90 -51
- package/bundled/locales/zh-CN/docs/CHEATSHEET.md +184 -0
- package/bundled/locales/zh-CN/docs/CLI-FLOW.md +239 -0
- package/bundled/locales/zh-CN/docs/FEATURE-REFERENCE.md +320 -0
- package/bundled/locales/zh-CN/docs/OPERATION-WORKFLOW.md +43 -43
- package/bundled/locales/zh-CN/docs/STANDARDS-REFERENCE.md +440 -0
- package/bundled/locales/zh-CN/docs/USAGE-MODES-COMPARISON.md +1 -1
- package/bundled/locales/zh-CN/docs/WINDOWS-GUIDE.md +1 -1
- package/bundled/locales/zh-CN/integrations/codex/README.md +3 -3
- package/bundled/locales/zh-CN/integrations/gemini-cli/README.md +3 -3
- package/bundled/locales/zh-CN/integrations/github-copilot/README.md +5 -5
- package/bundled/locales/zh-CN/integrations/github-copilot/copilot-instructions.md +9 -9
- package/bundled/locales/zh-CN/integrations/github-copilot/skills-mapping.md +18 -6
- package/bundled/locales/zh-CN/integrations/google-antigravity/README.md +2 -2
- package/bundled/locales/zh-CN/integrations/opencode/README.md +3 -3
- package/bundled/locales/zh-CN/integrations/opencode/skills-mapping.md +22 -10
- package/bundled/locales/zh-CN/integrations/openspec/README.md +1 -1
- package/bundled/locales/zh-CN/integrations/spec-kit/AGENTS.md +3 -3
- package/bundled/locales/zh-CN/integrations/spec-kit/README.md +1 -1
- package/bundled/locales/zh-CN/options/commit-message/bilingual.md +1 -1
- package/bundled/locales/zh-CN/options/commit-message/english.md +1 -1
- package/bundled/locales/zh-CN/options/commit-message/traditional-chinese.md +1 -1
- package/bundled/locales/zh-CN/options/git-workflow/gitflow.md +1 -1
- package/bundled/locales/zh-CN/options/git-workflow/github-flow.md +1 -1
- package/bundled/locales/zh-CN/options/git-workflow/merge-commit.md +1 -1
- package/bundled/locales/zh-CN/options/git-workflow/rebase-ff.md +1 -1
- package/bundled/locales/zh-CN/options/git-workflow/squash-merge.md +1 -1
- package/bundled/locales/zh-CN/options/git-workflow/trunk-based.md +1 -1
- package/bundled/locales/zh-CN/options/project-structure/dotnet.md +1 -1
- package/bundled/locales/zh-CN/options/project-structure/go.md +1 -1
- package/bundled/locales/zh-CN/options/project-structure/java.md +1 -1
- package/bundled/locales/zh-CN/options/project-structure/nodejs.md +1 -1
- package/bundled/locales/zh-CN/options/project-structure/python.md +1 -1
- package/bundled/locales/zh-CN/options/testing/e2e-testing.md +1 -1
- package/bundled/locales/zh-CN/options/testing/integration-testing.md +1 -1
- package/bundled/locales/zh-CN/options/testing/system-testing.md +1 -1
- package/bundled/locales/zh-CN/options/testing/unit-testing.md +1 -1
- package/bundled/locales/zh-CN/skills/{claude-code/CONTRIBUTING.template.md → CONTRIBUTING.template.md} +2 -2
- package/bundled/locales/zh-CN/skills/README.md +131 -81
- package/bundled/locales/zh-CN/skills/agents/README.md +281 -0
- package/bundled/locales/zh-CN/skills/{claude-code/ai-collaboration-standards → ai-collaboration-standards}/SKILL.md +10 -10
- package/bundled/locales/zh-CN/skills/{claude-code/ai-collaboration-standards → ai-collaboration-standards}/anti-hallucination.md +8 -8
- package/bundled/locales/zh-CN/skills/{claude-code/ai-collaboration-standards → ai-collaboration-standards}/certainty-labels.md +8 -8
- package/bundled/locales/zh-CN/skills/ai-friendly-architecture/SKILL.md +221 -0
- package/bundled/locales/zh-CN/skills/ai-instruction-standards/SKILL.md +214 -0
- package/bundled/locales/zh-CN/skills/atdd-assistant/SKILL.md +71 -0
- package/bundled/locales/zh-CN/skills/atdd-assistant/acceptance-criteria-guide.md +428 -0
- package/bundled/locales/zh-CN/skills/atdd-assistant/atdd-workflow.md +484 -0
- package/bundled/locales/zh-CN/skills/atdd-assistant/guide.md +368 -0
- package/bundled/locales/zh-CN/skills/bdd-assistant/SKILL.md +68 -0
- package/bundled/locales/zh-CN/skills/bdd-assistant/bdd-workflow.md +406 -0
- package/bundled/locales/zh-CN/skills/bdd-assistant/gherkin-guide.md +454 -0
- package/bundled/locales/zh-CN/skills/bdd-assistant/guide.md +324 -0
- package/bundled/locales/zh-CN/skills/changelog-guide/SKILL.md +64 -0
- package/bundled/locales/zh-CN/skills/{claude-code/changelog-guide/SKILL.md → changelog-guide/guide.md} +6 -7
- package/bundled/locales/zh-CN/skills/checkin-assistant/SKILL.md +56 -0
- package/bundled/locales/zh-CN/skills/{claude-code/checkin-assistant/SKILL.md → checkin-assistant/guide.md} +6 -7
- package/bundled/locales/zh-CN/skills/code-review-assistant/SKILL.md +56 -0
- package/bundled/locales/zh-CN/skills/{claude-code/code-review-assistant → code-review-assistant}/checkin-checklist.md +4 -4
- package/bundled/locales/zh-CN/skills/{claude-code/code-review-assistant/SKILL.md → code-review-assistant/guide.md} +5 -6
- package/bundled/locales/zh-CN/skills/{claude-code/code-review-assistant → code-review-assistant}/review-checklist.md +4 -4
- package/bundled/locales/zh-CN/skills/{claude-code/commands → commands}/bdd.md +2 -2
- package/bundled/locales/zh-CN/skills/{claude-code/commands → commands}/methodology.md +3 -3
- package/bundled/locales/zh-CN/skills/{claude-code/commands → commands}/refactor.md +3 -3
- package/bundled/locales/zh-CN/skills/commit-standards/SKILL.md +61 -0
- package/bundled/locales/zh-CN/skills/{claude-code/commit-standards → commit-standards}/conventional-commits.md +4 -4
- package/bundled/locales/zh-CN/skills/{claude-code/commit-standards/SKILL.md → commit-standards/guide.md} +5 -6
- package/bundled/locales/zh-CN/skills/{claude-code/commit-standards → commit-standards}/language-options.md +3 -3
- package/bundled/locales/zh-CN/skills/docs-generator/SKILL.md +59 -0
- package/bundled/locales/zh-CN/skills/docs-generator/guide.md +262 -0
- package/bundled/locales/zh-CN/skills/{claude-code/documentation-guide → documentation-guide}/SKILL.md +7 -8
- package/bundled/locales/zh-CN/skills/{claude-code/documentation-guide → documentation-guide}/documentation-structure.md +4 -4
- package/bundled/locales/zh-CN/skills/{claude-code/documentation-guide → documentation-guide}/readme-template.md +3 -3
- package/bundled/locales/zh-CN/skills/{claude-code/error-code-guide → error-code-guide}/SKILL.md +6 -6
- package/bundled/locales/zh-CN/skills/forward-derivation/SKILL.md +62 -0
- package/bundled/locales/zh-CN/skills/forward-derivation/guide.md +130 -0
- package/bundled/locales/zh-CN/skills/{claude-code/git-workflow-guide → git-workflow-guide}/SKILL.md +6 -6
- package/bundled/locales/zh-CN/skills/{claude-code/git-workflow-guide → git-workflow-guide}/branch-naming.md +3 -3
- package/bundled/locales/zh-CN/skills/{claude-code/git-workflow-guide → git-workflow-guide}/git-workflow.md +4 -4
- package/bundled/locales/zh-CN/skills/{claude-code/logging-guide → logging-guide}/SKILL.md +6 -6
- package/bundled/locales/zh-CN/skills/methodology-system/SKILL.md +78 -0
- package/bundled/locales/zh-CN/skills/{claude-code/methodology-system → methodology-system}/create-methodology.md +2 -2
- package/bundled/locales/zh-CN/skills/{claude-code/methodology-system/SKILL.md → methodology-system/guide.md} +2 -2
- package/bundled/locales/zh-CN/skills/{claude-code/methodology-system → methodology-system}/runtime.md +3 -3
- package/bundled/locales/zh-CN/skills/project-discovery/SKILL.md +66 -0
- package/bundled/locales/zh-CN/skills/project-discovery/guide.md +371 -0
- package/bundled/locales/zh-CN/skills/{claude-code/project-structure-guide → project-structure-guide}/SKILL.md +4 -4
- package/bundled/locales/zh-CN/skills/{claude-code/project-structure-guide → project-structure-guide}/language-patterns.md +1 -1
- package/bundled/locales/zh-CN/skills/refactoring-assistant/SKILL.md +67 -0
- package/bundled/locales/zh-CN/skills/{claude-code/refactoring-assistant/SKILL.md → refactoring-assistant/guide.md} +7 -8
- package/bundled/locales/zh-CN/skills/release-standards/SKILL.md +64 -0
- package/bundled/locales/zh-CN/skills/{claude-code/release-standards → release-standards}/changelog-format.md +3 -3
- package/bundled/locales/zh-CN/skills/{claude-code/release-standards/SKILL.md → release-standards/guide.md} +5 -6
- package/bundled/locales/zh-CN/skills/{claude-code/release-standards → release-standards}/release-workflow.md +7 -7
- package/bundled/locales/zh-CN/skills/{claude-code/release-standards → release-standards}/semantic-versioning.md +3 -3
- package/bundled/locales/zh-CN/skills/requirement-assistant/SKILL.md +67 -0
- package/bundled/locales/zh-CN/skills/{claude-code/requirement-assistant/SKILL.md → requirement-assistant/guide.md} +4 -5
- package/bundled/locales/zh-CN/skills/{claude-code/requirement-assistant → requirement-assistant}/requirement-checklist.md +3 -3
- package/bundled/locales/zh-CN/skills/{claude-code/requirement-assistant → requirement-assistant}/requirement-writing.md +3 -3
- package/bundled/locales/zh-CN/skills/reverse-engineer/SKILL.md +67 -0
- package/bundled/locales/zh-CN/skills/{claude-code/reverse-engineer → reverse-engineer}/bdd-extraction.md +2 -2
- package/bundled/locales/zh-CN/skills/{claude-code/reverse-engineer/SKILL.md → reverse-engineer/guide.md} +17 -18
- package/bundled/locales/zh-CN/skills/{claude-code/reverse-engineer → reverse-engineer}/tdd-analysis.md +2 -2
- package/bundled/locales/zh-CN/skills/{claude-code/reverse-engineer → reverse-engineer}/workflow.md +3 -3
- package/bundled/locales/zh-CN/skills/spec-driven-dev/SKILL.md +75 -0
- package/bundled/locales/zh-CN/skills/{claude-code/spec-driven-dev/SKILL.md → spec-driven-dev/guide.md} +10 -11
- package/bundled/locales/zh-CN/skills/tdd-assistant/SKILL.md +66 -0
- package/bundled/locales/zh-CN/skills/{claude-code/tdd-assistant/SKILL.md → tdd-assistant/guide.md} +12 -16
- package/bundled/locales/zh-CN/skills/{claude-code/tdd-assistant → tdd-assistant}/language-examples.md +3 -3
- package/bundled/locales/zh-CN/skills/{claude-code/tdd-assistant → tdd-assistant}/tdd-workflow.md +3 -3
- package/bundled/locales/zh-CN/skills/test-coverage-assistant/SKILL.md +65 -0
- package/bundled/locales/zh-CN/skills/test-coverage-assistant/guide.md +284 -0
- package/bundled/locales/zh-CN/skills/{claude-code/testing-guide → testing-guide}/SKILL.md +8 -8
- package/bundled/locales/zh-CN/skills/{claude-code/testing-guide → testing-guide}/testing-pyramid.md +4 -4
- package/bundled/locales/zh-CN/skills/{cline → tools/cline}/README.md +1 -1
- package/bundled/locales/zh-CN/skills/{copilot → tools/copilot}/README.md +1 -1
- package/bundled/locales/zh-CN/skills/{copilot → tools/copilot}/copilot-instructions.md +1 -1
- package/bundled/locales/zh-CN/skills/{cursor → tools/cursor}/README.md +1 -1
- package/bundled/locales/zh-CN/skills/{windsurf → tools/windsurf}/README.md +1 -1
- package/bundled/locales/zh-TW/CHANGELOG.md +16 -16
- package/bundled/locales/zh-TW/CLAUDE.md +3 -3
- package/bundled/locales/zh-TW/MAINTENANCE.md +7 -7
- package/bundled/locales/zh-TW/README.md +13 -7
- package/bundled/locales/zh-TW/STANDARDS-MAPPING.md +1 -1
- package/bundled/locales/zh-TW/adoption/ADOPTION-GUIDE.md +4 -4
- package/bundled/locales/zh-TW/adoption/DAILY-WORKFLOW-GUIDE.md +66 -7
- package/bundled/locales/zh-TW/adoption/STATIC-DYNAMIC-GUIDE.md +22 -22
- package/bundled/locales/zh-TW/adoption/checklists/enterprise.md +5 -5
- package/bundled/locales/zh-TW/adoption/checklists/minimal.md +4 -4
- package/bundled/locales/zh-TW/adoption/checklists/recommended.md +5 -5
- package/bundled/locales/zh-TW/ai/MAINTENANCE.md +13 -13
- package/bundled/locales/zh-TW/ai/standards/anti-hallucination.ai.yaml +3 -2
- package/bundled/locales/zh-TW/ai/standards/git-workflow.ai.yaml +4 -3
- package/bundled/locales/zh-TW/ai/standards/spec-driven-development.ai.yaml +3 -3
- package/bundled/locales/zh-TW/ai/standards/testing.ai.yaml +1 -0
- package/bundled/locales/zh-TW/core/ai-instruction-standards.md +1 -1
- package/bundled/locales/zh-TW/core/anti-hallucination.md +38 -701
- package/bundled/locales/zh-TW/core/changelog-standards.md +1 -1
- package/bundled/locales/zh-TW/core/checkin-standards.md +18 -5
- package/bundled/locales/zh-TW/core/code-review-checklist.md +1 -1
- package/bundled/locales/zh-TW/core/commit-message-guide.md +1 -1
- package/bundled/locales/zh-TW/core/developer-memory.md +576 -0
- package/bundled/locales/zh-TW/core/documentation-structure.md +115 -22
- package/bundled/locales/zh-TW/core/documentation-writing-standards.md +126 -5
- package/bundled/locales/zh-TW/core/forward-derivation-standards.md +2 -2
- package/bundled/locales/zh-TW/core/git-workflow.md +38 -812
- package/bundled/locales/zh-TW/core/guides/anti-hallucination-guide.md +779 -0
- package/bundled/locales/zh-TW/core/guides/git-workflow-guide.md +1016 -0
- package/bundled/locales/zh-TW/core/guides/refactoring-guide.md +864 -0
- package/bundled/locales/zh-TW/core/guides/testing-guide.md +2280 -0
- package/bundled/locales/zh-TW/core/logging-standards.md +159 -4
- package/bundled/locales/zh-TW/core/project-structure.md +102 -9
- package/bundled/locales/zh-TW/core/refactoring-standards.md +37 -823
- package/bundled/locales/zh-TW/core/reverse-engineering-standards.md +6 -6
- package/bundled/locales/zh-TW/core/spec-driven-development.md +17 -268
- package/bundled/locales/zh-TW/core/test-completeness-dimensions.md +128 -14
- package/bundled/locales/zh-TW/core/test-driven-development.md +20 -983
- package/bundled/locales/zh-TW/core/testing-standards.md +120 -2105
- package/bundled/locales/zh-TW/core/versioning.md +13 -55
- package/bundled/locales/zh-TW/docs/AI-AGENT-ROADMAP.md +90 -51
- package/bundled/locales/zh-TW/docs/CHEATSHEET.md +184 -0
- package/bundled/locales/zh-TW/docs/CLI-FLOW.md +239 -0
- package/bundled/locales/zh-TW/docs/FEATURE-REFERENCE.md +320 -0
- package/bundled/locales/zh-TW/docs/MIGRATION-V5.md +71 -0
- package/bundled/locales/zh-TW/docs/OPERATION-WORKFLOW.md +42 -42
- package/bundled/locales/zh-TW/docs/STANDARDS-REFERENCE.md +440 -0
- package/bundled/locales/zh-TW/docs/USAGE-MODES-COMPARISON.md +1 -1
- package/bundled/locales/zh-TW/docs/WINDOWS-GUIDE.md +1 -1
- package/bundled/locales/zh-TW/integrations/claude-code/README.md +44 -0
- package/bundled/locales/zh-TW/integrations/github-copilot/copilot-instructions.md +3 -3
- package/bundled/locales/zh-TW/integrations/github-copilot/skills-mapping.md +18 -6
- package/bundled/locales/zh-TW/integrations/opencode/skills-mapping.md +22 -10
- package/bundled/locales/zh-TW/methodologies/guides/sdd-guide.md +338 -0
- package/bundled/locales/zh-TW/methodologies/guides/tdd-guide.md +1055 -0
- package/bundled/locales/zh-TW/options/commit-message/bilingual.md +1 -1
- package/bundled/locales/zh-TW/options/commit-message/english.md +1 -1
- package/bundled/locales/zh-TW/options/commit-message/traditional-chinese.md +1 -1
- package/bundled/locales/zh-TW/options/git-workflow/gitflow.md +1 -1
- package/bundled/locales/zh-TW/options/git-workflow/github-flow.md +1 -1
- package/bundled/locales/zh-TW/options/git-workflow/merge-commit.md +1 -1
- package/bundled/locales/zh-TW/options/git-workflow/rebase-ff.md +1 -1
- package/bundled/locales/zh-TW/options/git-workflow/squash-merge.md +1 -1
- package/bundled/locales/zh-TW/options/git-workflow/trunk-based.md +1 -1
- package/bundled/locales/zh-TW/options/project-structure/dotnet.md +1 -1
- package/bundled/locales/zh-TW/options/project-structure/go.md +1 -1
- package/bundled/locales/zh-TW/options/project-structure/java.md +1 -1
- package/bundled/locales/zh-TW/options/project-structure/nodejs.md +1 -1
- package/bundled/locales/zh-TW/options/project-structure/python.md +1 -1
- package/bundled/locales/zh-TW/options/testing/e2e-testing.md +1 -1
- package/bundled/locales/zh-TW/options/testing/integration-testing.md +1 -1
- package/bundled/locales/zh-TW/options/testing/system-testing.md +1 -1
- package/bundled/locales/zh-TW/options/testing/unit-testing.md +1 -1
- package/bundled/locales/zh-TW/skills/{claude-code/CONTRIBUTING.template.md → CONTRIBUTING.template.md} +2 -2
- package/bundled/locales/zh-TW/skills/README.md +131 -79
- package/bundled/locales/zh-TW/skills/agents/README.md +281 -0
- package/bundled/locales/zh-TW/skills/{claude-code/ai-collaboration-standards → ai-collaboration-standards}/SKILL.md +7 -7
- package/bundled/locales/zh-TW/skills/{claude-code/ai-collaboration-standards → ai-collaboration-standards}/anti-hallucination.md +8 -8
- package/bundled/locales/zh-TW/skills/{claude-code/ai-collaboration-standards → ai-collaboration-standards}/certainty-labels.md +8 -8
- package/bundled/locales/zh-TW/skills/ai-friendly-architecture/SKILL.md +221 -0
- package/bundled/locales/zh-TW/skills/ai-instruction-standards/SKILL.md +214 -0
- package/bundled/locales/zh-TW/skills/atdd-assistant/SKILL.md +71 -0
- package/bundled/locales/zh-TW/skills/atdd-assistant/acceptance-criteria-guide.md +428 -0
- package/bundled/locales/zh-TW/skills/atdd-assistant/atdd-workflow.md +484 -0
- package/bundled/locales/zh-TW/skills/atdd-assistant/guide.md +368 -0
- package/bundled/locales/zh-TW/skills/bdd-assistant/SKILL.md +68 -0
- package/bundled/locales/zh-TW/skills/bdd-assistant/bdd-workflow.md +406 -0
- package/bundled/locales/zh-TW/skills/bdd-assistant/gherkin-guide.md +454 -0
- package/bundled/locales/zh-TW/skills/bdd-assistant/guide.md +324 -0
- package/bundled/locales/zh-TW/skills/changelog-guide/SKILL.md +64 -0
- package/bundled/locales/zh-TW/skills/{claude-code/changelog-guide/SKILL.md → changelog-guide/guide.md} +6 -7
- package/bundled/locales/zh-TW/skills/checkin-assistant/SKILL.md +56 -0
- package/bundled/locales/zh-TW/skills/{claude-code/checkin-assistant/SKILL.md → checkin-assistant/guide.md} +6 -7
- package/bundled/locales/zh-TW/skills/code-review-assistant/SKILL.md +56 -0
- package/bundled/locales/zh-TW/skills/{claude-code/code-review-assistant → code-review-assistant}/checkin-checklist.md +4 -4
- package/bundled/locales/zh-TW/skills/{claude-code/code-review-assistant/SKILL.md → code-review-assistant/guide.md} +2 -3
- package/bundled/locales/zh-TW/skills/{claude-code/code-review-assistant → code-review-assistant}/review-checklist.md +4 -4
- package/bundled/locales/zh-TW/skills/{claude-code/commands → commands}/bdd.md +2 -2
- package/bundled/locales/zh-TW/skills/{claude-code/commands → commands}/methodology.md +3 -3
- package/bundled/locales/zh-TW/skills/{claude-code/commands → commands}/refactor.md +3 -3
- package/bundled/locales/zh-TW/skills/commit-standards/SKILL.md +61 -0
- package/bundled/locales/zh-TW/skills/{claude-code/commit-standards → commit-standards}/conventional-commits.md +4 -4
- package/bundled/locales/zh-TW/skills/{claude-code/commit-standards/SKILL.md → commit-standards/guide.md} +5 -6
- package/bundled/locales/zh-TW/skills/{claude-code/commit-standards → commit-standards}/language-options.md +3 -3
- package/bundled/locales/zh-TW/skills/docs-generator/SKILL.md +59 -0
- package/bundled/locales/zh-TW/skills/docs-generator/guide.md +262 -0
- package/bundled/locales/zh-TW/skills/{claude-code/documentation-guide → documentation-guide}/SKILL.md +7 -8
- package/bundled/locales/zh-TW/skills/{claude-code/documentation-guide → documentation-guide}/documentation-structure.md +4 -4
- package/bundled/locales/zh-TW/skills/{claude-code/documentation-guide → documentation-guide}/readme-template.md +3 -3
- package/bundled/locales/zh-TW/skills/{claude-code/error-code-guide → error-code-guide}/SKILL.md +6 -6
- package/bundled/locales/zh-TW/skills/forward-derivation/SKILL.md +62 -0
- package/bundled/locales/zh-TW/skills/{claude-code/forward-derivation/SKILL.md → forward-derivation/guide.md} +24 -19
- package/bundled/locales/zh-TW/skills/{claude-code/git-workflow-guide → git-workflow-guide}/SKILL.md +3 -3
- package/bundled/locales/zh-TW/skills/{claude-code/git-workflow-guide → git-workflow-guide}/branch-naming.md +3 -3
- package/bundled/locales/zh-TW/skills/{claude-code/git-workflow-guide → git-workflow-guide}/git-workflow.md +4 -4
- package/bundled/locales/zh-TW/skills/{claude-code/logging-guide → logging-guide}/SKILL.md +6 -6
- package/bundled/locales/zh-TW/skills/methodology-system/SKILL.md +78 -0
- package/bundled/locales/zh-TW/skills/{claude-code/methodology-system → methodology-system}/create-methodology.md +2 -2
- package/bundled/locales/zh-TW/skills/{claude-code/methodology-system/SKILL.md → methodology-system/guide.md} +2 -2
- package/bundled/locales/zh-TW/skills/{claude-code/methodology-system → methodology-system}/runtime.md +3 -3
- package/bundled/locales/zh-TW/skills/project-discovery/SKILL.md +66 -0
- package/bundled/locales/zh-TW/skills/project-discovery/guide.md +371 -0
- package/bundled/locales/zh-TW/skills/project-discovery/workflow.md +574 -0
- package/bundled/locales/zh-TW/skills/{claude-code/project-structure-guide → project-structure-guide}/SKILL.md +4 -4
- package/bundled/locales/zh-TW/skills/{claude-code/project-structure-guide → project-structure-guide}/language-patterns.md +1 -1
- package/bundled/locales/zh-TW/skills/refactoring-assistant/SKILL.md +67 -0
- package/bundled/locales/zh-TW/skills/{claude-code/refactoring-assistant/SKILL.md → refactoring-assistant/guide.md} +7 -8
- package/bundled/locales/zh-TW/skills/release-standards/SKILL.md +64 -0
- package/bundled/locales/zh-TW/skills/{claude-code/release-standards → release-standards}/changelog-format.md +3 -3
- package/bundled/locales/zh-TW/skills/{claude-code/release-standards/SKILL.md → release-standards/guide.md} +2 -3
- package/bundled/locales/zh-TW/skills/{claude-code/release-standards → release-standards}/release-workflow.md +60 -28
- package/bundled/locales/zh-TW/skills/{claude-code/release-standards → release-standards}/semantic-versioning.md +3 -3
- package/bundled/locales/zh-TW/skills/requirement-assistant/SKILL.md +67 -0
- package/bundled/locales/zh-TW/skills/{claude-code/requirement-assistant/SKILL.md → requirement-assistant/guide.md} +2 -3
- package/bundled/locales/zh-TW/skills/{claude-code/requirement-assistant → requirement-assistant}/requirement-checklist.md +3 -3
- package/bundled/locales/zh-TW/skills/{claude-code/requirement-assistant → requirement-assistant}/requirement-writing.md +3 -3
- package/bundled/locales/zh-TW/skills/reverse-engineer/SKILL.md +67 -0
- package/bundled/locales/zh-TW/skills/{claude-code/reverse-engineer → reverse-engineer}/bdd-extraction.md +2 -2
- package/bundled/locales/zh-TW/skills/{claude-code/reverse-engineer/SKILL.md → reverse-engineer/guide.md} +17 -18
- package/bundled/locales/zh-TW/skills/{claude-code/reverse-engineer → reverse-engineer}/tdd-analysis.md +2 -2
- package/bundled/locales/zh-TW/skills/{claude-code/reverse-engineer → reverse-engineer}/workflow.md +3 -3
- package/bundled/locales/zh-TW/skills/spec-driven-dev/SKILL.md +75 -0
- package/bundled/locales/zh-TW/skills/{claude-code/spec-driven-dev/SKILL.md → spec-driven-dev/guide.md} +9 -10
- package/bundled/locales/zh-TW/skills/tdd-assistant/SKILL.md +66 -0
- package/bundled/locales/zh-TW/skills/{claude-code/tdd-assistant/SKILL.md → tdd-assistant/guide.md} +9 -10
- package/bundled/locales/zh-TW/skills/{claude-code/tdd-assistant → tdd-assistant}/language-examples.md +3 -3
- package/bundled/locales/zh-TW/skills/{claude-code/tdd-assistant → tdd-assistant}/tdd-workflow.md +3 -3
- package/bundled/locales/zh-TW/skills/test-coverage-assistant/SKILL.md +65 -0
- package/bundled/locales/zh-TW/skills/{claude-code/test-coverage-assistant/SKILL.md → test-coverage-assistant/guide.md} +27 -24
- package/bundled/locales/zh-TW/skills/{claude-code/testing-guide → testing-guide}/SKILL.md +6 -6
- package/bundled/locales/zh-TW/skills/{claude-code/testing-guide → testing-guide}/testing-pyramid.md +4 -4
- package/bundled/locales/zh-TW/skills/{cline → tools/cline}/README.md +1 -1
- package/bundled/locales/zh-TW/skills/{copilot → tools/copilot}/README.md +1 -1
- package/bundled/locales/zh-TW/skills/{copilot → tools/copilot}/copilot-instructions.md +1 -1
- package/bundled/locales/zh-TW/skills/{cursor → tools/cursor}/README.md +1 -1
- package/bundled/locales/zh-TW/skills/{windsurf → tools/windsurf}/README.md +1 -1
- package/bundled/skills/INTEGRATION-GUIDE.md +210 -0
- package/bundled/skills/README.md +95 -0
- package/bundled/skills/_shared/README.md +60 -0
- package/bundled/skills/{claude-code/agents → agents}/README.md +2 -2
- package/bundled/skills/{claude-code/agents → agents}/code-architect.md +1 -1
- package/bundled/skills/{claude-code/agents → agents}/doc-writer.md +1 -1
- package/bundled/skills/{claude-code/agents → agents}/reviewer.md +1 -1
- package/bundled/skills/{claude-code/agents → agents}/spec-analyst.md +1 -1
- package/bundled/skills/{claude-code/agents → agents}/test-specialist.md +1 -1
- package/bundled/skills/{claude-code/ai-collaboration-standards → ai-collaboration-standards}/SKILL.md +28 -5
- package/bundled/skills/{claude-code/ai-collaboration-standards → ai-collaboration-standards}/anti-hallucination.md +24 -5
- package/bundled/skills/{claude-code/ai-collaboration-standards → ai-collaboration-standards}/certainty-labels.md +31 -6
- package/bundled/skills/ai-friendly-architecture/SKILL.md +216 -0
- package/bundled/skills/ai-instruction-standards/SKILL.md +209 -0
- package/bundled/skills/atdd-assistant/SKILL.md +74 -0
- package/bundled/skills/{claude-code/atdd-assistant → atdd-assistant}/acceptance-criteria-guide.md +1 -1
- package/bundled/skills/{claude-code/atdd-assistant → atdd-assistant}/atdd-workflow.md +1 -1
- package/bundled/skills/{claude-code/atdd-assistant/SKILL.md → atdd-assistant/guide.md} +11 -11
- package/bundled/skills/bdd-assistant/SKILL.md +70 -0
- package/bundled/skills/{claude-code/bdd-assistant → bdd-assistant}/bdd-workflow.md +1 -1
- package/bundled/skills/{claude-code/bdd-assistant → bdd-assistant}/gherkin-guide.md +1 -1
- package/bundled/skills/{claude-code/bdd-assistant/SKILL.md → bdd-assistant/guide.md} +11 -11
- package/bundled/skills/changelog-guide/SKILL.md +66 -0
- package/bundled/skills/{claude-code/changelog-guide/SKILL.md → changelog-guide/guide.md} +8 -6
- package/bundled/skills/checkin-assistant/SKILL.md +52 -0
- package/bundled/skills/{claude-code/checkin-assistant/SKILL.md → checkin-assistant/guide.md} +6 -6
- package/bundled/skills/code-review-assistant/SKILL.md +53 -0
- package/bundled/skills/{claude-code/code-review-assistant → code-review-assistant}/checkin-checklist.md +3 -3
- package/bundled/skills/{claude-code/code-review-assistant/SKILL.md → code-review-assistant/guide.md} +7 -5
- package/bundled/skills/{claude-code/code-review-assistant → code-review-assistant}/review-checklist.md +3 -3
- package/bundled/skills/commands/COMMAND-FAMILY-OVERVIEW.md +290 -0
- package/bundled/skills/{claude-code/commands → commands}/README.md +13 -3
- package/bundled/skills/{claude-code/commands → commands}/atdd.md +3 -3
- package/bundled/skills/{claude-code/commands → commands}/bdd.md +2 -2
- package/bundled/skills/commands/changelog.md +58 -0
- package/bundled/skills/{claude-code/commands → commands}/check.md +1 -1
- package/bundled/skills/commands/checkin.md +53 -0
- package/bundled/skills/{claude-code/commands → commands}/commit.md +3 -3
- package/bundled/skills/{claude-code/commands → commands}/config.md +1 -1
- package/bundled/skills/{claude-code/commands → commands}/coverage.md +5 -4
- package/bundled/skills/commands/derive-all.md +53 -0
- package/bundled/skills/commands/derive-atdd.md +49 -0
- package/bundled/skills/commands/derive-bdd.md +47 -0
- package/bundled/skills/commands/derive-tdd.md +48 -0
- package/bundled/skills/commands/derive.md +72 -0
- package/bundled/skills/commands/discover.md +80 -0
- package/bundled/skills/commands/docgen.md +61 -0
- package/bundled/skills/commands/docs.md +59 -0
- package/bundled/skills/commands/guide.md +44 -0
- package/bundled/skills/{claude-code/commands → commands}/init.md +2 -2
- package/bundled/skills/{claude-code/commands → commands}/methodology.md +32 -16
- package/bundled/skills/{claude-code/commands → commands}/refactor.md +2 -2
- package/bundled/skills/commands/release.md +56 -0
- package/bundled/skills/{claude-code/commands → commands}/requirement.md +3 -3
- package/bundled/skills/commands/reverse-bdd.md +47 -0
- package/bundled/skills/commands/reverse-sdd.md +51 -0
- package/bundled/skills/commands/reverse-tdd.md +51 -0
- package/bundled/skills/commands/reverse.md +63 -0
- package/bundled/skills/{claude-code/commands → commands}/review.md +3 -3
- package/bundled/skills/commands/sdd.md +135 -0
- package/bundled/skills/{claude-code/commands → commands}/tdd.md +3 -3
- package/bundled/skills/{claude-code/commands → commands}/update.md +2 -2
- package/bundled/skills/commit-standards/SKILL.md +60 -0
- package/bundled/skills/{claude-code/commit-standards → commit-standards}/conventional-commits.md +3 -3
- package/bundled/skills/{claude-code/commit-standards/SKILL.md → commit-standards/guide.md} +17 -5
- package/bundled/skills/{claude-code/commit-standards → commit-standards}/language-options.md +2 -2
- package/bundled/skills/docs-generator/SKILL.md +69 -0
- package/bundled/skills/docs-generator/guide.md +258 -0
- package/bundled/skills/{claude-code/documentation-guide → documentation-guide}/SKILL.md +7 -7
- package/bundled/skills/{claude-code/documentation-guide → documentation-guide}/documentation-structure.md +3 -3
- package/bundled/skills/{claude-code/documentation-guide → documentation-guide}/readme-template.md +2 -2
- package/bundled/skills/{claude-code/error-code-guide → error-code-guide}/SKILL.md +7 -5
- package/bundled/skills/forward-derivation/SKILL.md +61 -0
- package/bundled/skills/{claude-code/forward-derivation/SKILL.md → forward-derivation/guide.md} +44 -29
- package/bundled/skills/{claude-code/git-workflow-guide → git-workflow-guide}/SKILL.md +7 -5
- package/bundled/skills/{claude-code/git-workflow-guide → git-workflow-guide}/branch-naming.md +2 -2
- package/bundled/skills/{claude-code/git-workflow-guide → git-workflow-guide}/git-workflow.md +3 -3
- package/bundled/skills/{claude-code/logging-guide → logging-guide}/SKILL.md +7 -5
- package/bundled/skills/methodology-system/SKILL.md +75 -0
- package/bundled/skills/{claude-code/methodology-system → methodology-system}/create-methodology.md +1 -1
- package/bundled/skills/{claude-code/methodology-system/SKILL.md → methodology-system/guide.md} +51 -16
- package/bundled/skills/methodology-system/integrated-flow.md +454 -0
- package/bundled/skills/{claude-code/methodology-system → methodology-system}/runtime.md +2 -2
- package/bundled/skills/project-discovery/SKILL.md +63 -0
- package/bundled/skills/project-discovery/guide.md +367 -0
- package/bundled/skills/project-discovery/workflow.md +566 -0
- package/bundled/skills/{claude-code/project-structure-guide → project-structure-guide}/SKILL.md +14 -4
- package/bundled/skills/refactoring-assistant/SKILL.md +78 -0
- package/bundled/skills/{claude-code/refactoring-assistant/SKILL.md → refactoring-assistant/guide.md} +7 -7
- package/bundled/skills/release-standards/SKILL.md +61 -0
- package/bundled/skills/{claude-code/release-standards → release-standards}/changelog-format.md +2 -2
- package/bundled/skills/{claude-code/release-standards/SKILL.md → release-standards/guide.md} +7 -5
- package/bundled/skills/{claude-code/release-standards → release-standards}/release-workflow.md +59 -24
- package/bundled/skills/{claude-code/release-standards → release-standards}/semantic-versioning.md +2 -2
- package/bundled/skills/requirement-assistant/SKILL.md +66 -0
- package/bundled/skills/{claude-code/requirement-assistant/SKILL.md → requirement-assistant/guide.md} +14 -6
- package/bundled/skills/{claude-code/requirement-assistant → requirement-assistant}/requirement-checklist.md +2 -2
- package/bundled/skills/{claude-code/requirement-assistant → requirement-assistant}/requirement-writing.md +2 -2
- package/bundled/skills/reverse-engineer/SKILL.md +64 -0
- package/bundled/skills/{claude-code/reverse-engineer → reverse-engineer}/bdd-extraction.md +1 -1
- package/bundled/skills/{claude-code/reverse-engineer/SKILL.md → reverse-engineer/guide.md} +21 -18
- package/bundled/skills/{claude-code/reverse-engineer → reverse-engineer}/tdd-analysis.md +1 -1
- package/bundled/skills/{claude-code/reverse-engineer → reverse-engineer}/workflow.md +2 -2
- package/bundled/skills/spec-driven-dev/SKILL.md +80 -0
- package/bundled/skills/{claude-code/spec-driven-dev/SKILL.md → spec-driven-dev/guide.md} +50 -8
- package/bundled/skills/tdd-assistant/SKILL.md +65 -0
- package/bundled/skills/{claude-code/tdd-assistant/SKILL.md → tdd-assistant/guide.md} +10 -10
- package/bundled/skills/{claude-code/tdd-assistant → tdd-assistant}/language-examples.md +3 -3
- package/bundled/skills/{claude-code/tdd-assistant → tdd-assistant}/tdd-workflow.md +2 -2
- package/bundled/skills/test-coverage-assistant/SKILL.md +63 -0
- package/bundled/skills/{claude-code/test-coverage-assistant/SKILL.md → test-coverage-assistant/guide.md} +39 -24
- package/bundled/skills/{claude-code/testing-guide → testing-guide}/SKILL.md +12 -7
- package/bundled/skills/{claude-code/testing-guide → testing-guide}/testing-pyramid.md +3 -3
- package/bundled/skills/testing-guide/testing-theory.md +2291 -0
- package/bundled/skills/tools/cline/.clinerules +79 -0
- package/bundled/skills/tools/cline/README.md +50 -0
- package/bundled/skills/tools/copilot/README.md +99 -0
- package/bundled/skills/tools/copilot/copilot-instructions.md +71 -0
- package/bundled/skills/tools/cursor/.cursorrules +101 -0
- package/bundled/skills/tools/cursor/README.md +50 -0
- package/bundled/skills/tools/windsurf/.windsurfrules +76 -0
- package/bundled/skills/tools/windsurf/README.md +51 -0
- package/bundled/skills/{claude-code/workflows → workflows}/README.md +1 -1
- package/bundled/skills/workflows/release.workflow.yaml +893 -0
- package/package.json +4 -1
- package/src/commands/check.js +195 -130
- package/src/commands/config.js +1262 -0
- package/src/commands/configure.js +3 -950
- package/src/commands/fix.js +53 -0
- package/src/commands/hitl.js +19 -0
- package/src/commands/init.js +320 -1030
- package/src/commands/list.js +1 -1
- package/src/commands/simulate.js +61 -0
- package/src/commands/spec.js +288 -0
- package/src/commands/start.js +373 -0
- package/src/commands/sweep.js +142 -0
- package/src/commands/update.js +136 -19
- package/src/commands/workflow.js +265 -1
- package/src/config/ai-agent-paths.js +89 -29
- package/src/core/constants.js +7 -1
- package/src/core/manifest.js +1 -0
- package/src/flows/init-flow.js +243 -0
- package/src/hitl/checkpoint.js +80 -0
- package/src/hitl/classifier.js +54 -0
- package/src/hitl/manager.js +88 -0
- package/src/i18n/messages.js +907 -99
- package/src/index.js +1 -0
- package/src/installers/integration-installer.js +237 -0
- package/src/installers/manifest-installer.js +131 -0
- package/src/installers/skills-installer.js +286 -0
- package/src/installers/standards-installer.js +193 -0
- package/src/missions/MissionManager.js +501 -0
- package/src/prompts/init.js +228 -130
- package/src/prompts/integrations.js +13 -1
- package/src/schemas/standard.schema.json +117 -0
- package/src/utils/agents-installer.js +2 -2
- package/src/utils/config-loader.js +47 -0
- package/src/utils/config-manager.js +108 -0
- package/src/utils/config-merger.js +47 -0
- package/src/utils/github.js +22 -18
- package/src/utils/inquirer-patch.js +98 -0
- package/src/utils/integration-generator.js +392 -58
- package/src/utils/reference-sync.js +69 -19
- package/src/utils/skills-installer.js +6 -3
- package/src/utils/standard-fixer.js +141 -0
- package/src/utils/standard-validator.js +329 -0
- package/src/utils/workflow-executor.js +886 -0
- package/src/utils/workflow-state.js +404 -0
- package/src/utils/workflows-installer.js +2 -2
- package/src/vibe/auto-sweep.js +349 -0
- package/src/vibe/micro-spec.js +428 -0
- package/standards-registry.json +278 -102
- package/bundled/locales/zh-CN/skills/claude-code/README.md +0 -174
- package/bundled/locales/zh-CN/skills/claude-code/test-coverage-assistant/SKILL.md +0 -282
- package/bundled/locales/zh-TW/skills/claude-code/README.md +0 -174
- package/bundled/skills/claude-code/README.md +0 -215
- package/bundled/skills/claude-code/commands/changelog.md +0 -57
- package/bundled/skills/claude-code/commands/derive-all.md +0 -214
- package/bundled/skills/claude-code/commands/derive-atdd.md +0 -177
- package/bundled/skills/claude-code/commands/derive-bdd.md +0 -158
- package/bundled/skills/claude-code/commands/derive-tdd.md +0 -259
- package/bundled/skills/claude-code/commands/docs.md +0 -75
- package/bundled/skills/claude-code/commands/release.md +0 -50
- package/bundled/skills/claude-code/commands/reverse-bdd.md +0 -264
- package/bundled/skills/claude-code/commands/reverse-spec.md +0 -185
- package/bundled/skills/claude-code/commands/reverse-tdd.md +0 -351
- package/bundled/skills/claude-code/commands/spec.md +0 -69
- package/bundled/skills/claude-code/methodology-system/integrated-flow.md +0 -322
- /package/bundled/skills/{claude-code/CONTRIBUTING.template.md → CONTRIBUTING.template.md} +0 -0
- /package/bundled/skills/{claude-code/ai → ai}/standards/checkin.ai.yaml +0 -0
- /package/bundled/skills/{claude-code/ai → ai}/standards/commit.ai.yaml +0 -0
- /package/bundled/skills/{claude-code/ai → ai}/standards/refactoring.ai.yaml +0 -0
- /package/bundled/skills/{claude-code/ai → ai}/standards/testing.ai.yaml +0 -0
- /package/bundled/skills/{claude-code/project-structure-guide → project-structure-guide}/language-patterns.md +0 -0
- /package/bundled/skills/{claude-code/workflows → workflows}/code-review.workflow.yaml +0 -0
- /package/bundled/skills/{claude-code/workflows → workflows}/feature-dev.workflow.yaml +0 -0
- /package/bundled/skills/{claude-code/workflows → workflows}/integrated-flow.workflow.yaml +0 -0
- /package/bundled/skills/{claude-code/workflows → workflows}/large-codebase-analysis.workflow.yaml +0 -0
|
@@ -0,0 +1,608 @@
|
|
|
1
|
+
# Refactoring Guide
|
|
2
|
+
|
|
3
|
+
> **Language**: English | [繁體中文](../../locales/zh-TW/core/guides/refactoring-guide.md)
|
|
4
|
+
|
|
5
|
+
**Version**: 1.0.0
|
|
6
|
+
**Last Updated**: 2026-01-29
|
|
7
|
+
**Related Standard**: [Refactoring Standards](../refactoring-standards.md)
|
|
8
|
+
|
|
9
|
+
---
|
|
10
|
+
|
|
11
|
+
## Purpose
|
|
12
|
+
|
|
13
|
+
This guide provides detailed explanations, patterns, and tutorials for code refactoring. For actionable rules, checklists, and thresholds, see [Refactoring Standards](../refactoring-standards.md).
|
|
14
|
+
|
|
15
|
+
---
|
|
16
|
+
|
|
17
|
+
## Table of Contents
|
|
18
|
+
|
|
19
|
+
1. [Tactical Refactoring Strategies](#tactical-refactoring-strategies)
|
|
20
|
+
2. [Strategic Refactoring Strategies](#strategic-refactoring-strategies)
|
|
21
|
+
3. [Safety Strategies for Legacy Code](#safety-strategies-for-legacy-code)
|
|
22
|
+
4. [Database Refactoring Patterns](#database-refactoring-patterns)
|
|
23
|
+
5. [Team Collaboration Practices](#team-collaboration-practices)
|
|
24
|
+
6. [Technical Debt Management](#technical-debt-management)
|
|
25
|
+
7. [References](#references)
|
|
26
|
+
|
|
27
|
+
---
|
|
28
|
+
|
|
29
|
+
## Tactical Refactoring Strategies
|
|
30
|
+
|
|
31
|
+
Tactical strategies are applied during daily development work. They operate at minute-to-hour timescales and require minimal coordination.
|
|
32
|
+
|
|
33
|
+
### Preparatory Refactoring
|
|
34
|
+
|
|
35
|
+
**Definition**: Restructuring existing code to make an upcoming change easier to implement.
|
|
36
|
+
|
|
37
|
+
> "First make the change easy (this might be hard), then make the easy change." — Kent Beck
|
|
38
|
+
|
|
39
|
+
**When to Use**:
|
|
40
|
+
- Existing architecture resists the feature you need to add
|
|
41
|
+
- Code structure needs adjustment to accommodate new requirements
|
|
42
|
+
- You want to reduce friction for upcoming changes
|
|
43
|
+
|
|
44
|
+
**Workflow**:
|
|
45
|
+
|
|
46
|
+
```
|
|
47
|
+
1. Identify the change you want to make
|
|
48
|
+
2. Identify what makes this change difficult
|
|
49
|
+
3. Refactor to make the change easy
|
|
50
|
+
4. Make the (now easy) change
|
|
51
|
+
```
|
|
52
|
+
|
|
53
|
+
**Example**:
|
|
54
|
+
- Before: Adding caching to a tightly-coupled service is complex
|
|
55
|
+
- Preparatory refactoring: Extract interface, inject dependencies
|
|
56
|
+
- After: Adding caching becomes straightforward
|
|
57
|
+
|
|
58
|
+
**Key Principles**:
|
|
59
|
+
- The preparatory refactoring is a separate commit from the feature
|
|
60
|
+
- Each step maintains passing tests
|
|
61
|
+
- Don't combine refactoring with feature work in the same commit
|
|
62
|
+
|
|
63
|
+
### The Boy Scout Rule
|
|
64
|
+
|
|
65
|
+
**Definition**: Leave the code cleaner than you found it. This is "opportunistic refactoring" — instead of scheduling refactoring sprints, clean up code as you touch it during bug fixes or feature work.
|
|
66
|
+
|
|
67
|
+
> "Leave the campground cleaner than you found it." — Robert C. Martin
|
|
68
|
+
|
|
69
|
+
**When to Use**:
|
|
70
|
+
- Any maintenance task
|
|
71
|
+
- Bug fixes
|
|
72
|
+
- Feature additions
|
|
73
|
+
- Fighting software entropy
|
|
74
|
+
|
|
75
|
+
**Guidelines**:
|
|
76
|
+
- Make only small improvements (minutes, not hours)
|
|
77
|
+
- Don't change behavior
|
|
78
|
+
- Don't break existing tests
|
|
79
|
+
- Keep scope within your current task
|
|
80
|
+
|
|
81
|
+
**Examples of Boy Scout Improvements**:
|
|
82
|
+
- Rename a confusingly-named variable
|
|
83
|
+
- Extract a few lines into a well-named method
|
|
84
|
+
- Remove dead code you notice
|
|
85
|
+
- Add a clarifying comment
|
|
86
|
+
- Fix a minor code style issue
|
|
87
|
+
|
|
88
|
+
**Anti-patterns to Avoid**:
|
|
89
|
+
- Turning a bug fix into a major refactoring project
|
|
90
|
+
- Refactoring unrelated code
|
|
91
|
+
- Making changes without test coverage
|
|
92
|
+
- Scope creep beyond the original task
|
|
93
|
+
|
|
94
|
+
### Red-Green-Refactor
|
|
95
|
+
|
|
96
|
+
Part of the Test-Driven Development (TDD) cycle. See [Test-Driven Development](../test-driven-development.md) for complete details.
|
|
97
|
+
|
|
98
|
+
**Characteristics**:
|
|
99
|
+
- Duration: 5-15 minutes per cycle
|
|
100
|
+
- Scope: Single method or class
|
|
101
|
+
- Tests: Must remain green after refactoring
|
|
102
|
+
|
|
103
|
+
**The Cycle**:
|
|
104
|
+
|
|
105
|
+
```
|
|
106
|
+
┌─────────────────────────────────────────┐
|
|
107
|
+
│ │
|
|
108
|
+
│ ┌─────┐ ┌─────┐ ┌─────────┐ │
|
|
109
|
+
│ │ RED │ ──► │GREEN│ ──► │REFACTOR │ │
|
|
110
|
+
│ └─────┘ └─────┘ └─────────┘ │
|
|
111
|
+
│ ▲ │ │
|
|
112
|
+
│ └──────────────────────────┘ │
|
|
113
|
+
│ │
|
|
114
|
+
└─────────────────────────────────────────┘
|
|
115
|
+
```
|
|
116
|
+
|
|
117
|
+
**Common Refactoring Techniques**:
|
|
118
|
+
- Extract Method
|
|
119
|
+
- Rename
|
|
120
|
+
- Inline Variable
|
|
121
|
+
- Replace Magic Number with Constant
|
|
122
|
+
- Remove Duplication
|
|
123
|
+
|
|
124
|
+
---
|
|
125
|
+
|
|
126
|
+
## Strategic Refactoring Strategies
|
|
127
|
+
|
|
128
|
+
Strategic strategies are used for significant architectural changes. They operate at week-to-month timescales and require team coordination.
|
|
129
|
+
|
|
130
|
+
### Strangler Fig Pattern
|
|
131
|
+
|
|
132
|
+
**Definition**: Gradually replacing a legacy system by incrementally routing functionality to a new system.
|
|
133
|
+
|
|
134
|
+
**Origin**: Named after strangler fig trees that grow around a host tree, eventually replacing it.
|
|
135
|
+
|
|
136
|
+
**When to Use**:
|
|
137
|
+
- Gradually replacing a legacy system
|
|
138
|
+
- Cannot afford big-bang rewrite
|
|
139
|
+
- Need to maintain service during migration
|
|
140
|
+
|
|
141
|
+
**Architecture**:
|
|
142
|
+
|
|
143
|
+
```
|
|
144
|
+
┌─────────────────────────────────────────────────────────────────┐
|
|
145
|
+
│ Strangler Fig Pattern │
|
|
146
|
+
├─────────────────────────────────────────────────────────────────┤
|
|
147
|
+
│ │
|
|
148
|
+
│ Phase 1: INTERCEPT │
|
|
149
|
+
│ ┌─────────┐ ┌─────────┐ ┌─────────────┐ │
|
|
150
|
+
│ │ Request │────▶│ Facade │────▶│ Legacy (100%)│ │
|
|
151
|
+
│ └─────────┘ └─────────┘ └─────────────┘ │
|
|
152
|
+
│ │
|
|
153
|
+
│ Phase 2: MIGRATE │
|
|
154
|
+
│ ┌─────────┐ ┌─────────┐ ┌─────────────┐ │
|
|
155
|
+
│ │ Request │────▶│ Facade │──┬─▶│ New (Feature A)│ │
|
|
156
|
+
│ └─────────┘ └─────────┘ │ └─────────────┘ │
|
|
157
|
+
│ └─▶│ Legacy (Rest) │ │
|
|
158
|
+
│ └─────────────┘ │
|
|
159
|
+
│ │
|
|
160
|
+
│ Phase 3: COMPLETE │
|
|
161
|
+
│ ┌─────────┐ ┌─────────────┐ │
|
|
162
|
+
│ │ Request │────▶│ New (100%) │ [Legacy decommissioned] │
|
|
163
|
+
│ └─────────┘ └─────────────┘ │
|
|
164
|
+
│ │
|
|
165
|
+
└─────────────────────────────────────────────────────────────────┘
|
|
166
|
+
```
|
|
167
|
+
|
|
168
|
+
**Implementation Checklist**:
|
|
169
|
+
- [ ] Identify interception point (API gateway, facade, proxy)
|
|
170
|
+
- [ ] Create event capture layer
|
|
171
|
+
- [ ] Implement first feature in new system
|
|
172
|
+
- [ ] Route traffic incrementally
|
|
173
|
+
- [ ] Monitor and compare results
|
|
174
|
+
- [ ] Decommission legacy component
|
|
175
|
+
|
|
176
|
+
### Anti-Corruption Layer
|
|
177
|
+
|
|
178
|
+
**Definition**: A translation layer between a legacy system and a new system that prevents the legacy system's chaotic domain model from "corrupting" the new system's clean architecture.
|
|
179
|
+
|
|
180
|
+
**Origin**: Eric Evans, Domain-Driven Design (2003)
|
|
181
|
+
|
|
182
|
+
**When to Use**:
|
|
183
|
+
- New and legacy systems must coexist and interact frequently
|
|
184
|
+
- Legacy system has a complex/chaotic domain model
|
|
185
|
+
- Protecting the new system's Bounded Context
|
|
186
|
+
|
|
187
|
+
**Architecture**:
|
|
188
|
+
|
|
189
|
+
```
|
|
190
|
+
┌────────────────────────────────────────────────────────────┐
|
|
191
|
+
│ Anti-Corruption Layer (ACL) │
|
|
192
|
+
├────────────────────────────────────────────────────────────┤
|
|
193
|
+
│ │
|
|
194
|
+
│ ┌─────────────┐ ┌─────────────┐ ┌─────────────┐ │
|
|
195
|
+
│ │ New System │────▶│ ACL │────▶│Legacy System│ │
|
|
196
|
+
│ │ (Clean API) │ │ │ │(Messy Model)│ │
|
|
197
|
+
│ └─────────────┘ │ ┌─────────┐ │ └─────────────┘ │
|
|
198
|
+
│ │ │ Adapter │ │ │
|
|
199
|
+
│ │ │ Facade │ │ │
|
|
200
|
+
│ │ │Translator││ │
|
|
201
|
+
│ │ └─────────┘ │ │
|
|
202
|
+
│ └─────────────┘ │
|
|
203
|
+
│ │
|
|
204
|
+
└────────────────────────────────────────────────────────────┘
|
|
205
|
+
```
|
|
206
|
+
|
|
207
|
+
**Components**:
|
|
208
|
+
|
|
209
|
+
| Component | Purpose |
|
|
210
|
+
|-----------|---------|
|
|
211
|
+
| **Facade** | Simplifies complex legacy interfaces |
|
|
212
|
+
| **Adapter** | Converts legacy data formats to new domain model |
|
|
213
|
+
| **Translator** | Maps legacy terminology to ubiquitous language |
|
|
214
|
+
|
|
215
|
+
**Implementation Checklist**:
|
|
216
|
+
- [ ] Define clear interface for the ACL
|
|
217
|
+
- [ ] Map legacy entities to new domain model
|
|
218
|
+
- [ ] Handle data format conversions
|
|
219
|
+
- [ ] Implement error translation
|
|
220
|
+
- [ ] Add logging for debugging
|
|
221
|
+
- [ ] Thoroughly test ACL isolation
|
|
222
|
+
|
|
223
|
+
**Comparison with Strangler Fig**:
|
|
224
|
+
|
|
225
|
+
| Aspect | Strangler Fig | Anti-Corruption Layer |
|
|
226
|
+
|--------|---------------|----------------------|
|
|
227
|
+
| **Goal** | Replace legacy system | Coexist with legacy system |
|
|
228
|
+
| **Direction** | Migrate away from legacy | Integrate with legacy |
|
|
229
|
+
| **End state** | Legacy decommissioned | Both systems continue |
|
|
230
|
+
|
|
231
|
+
### Branch by Abstraction
|
|
232
|
+
|
|
233
|
+
**Definition**: Refactoring shared code without long-lived branches by introducing an abstraction layer.
|
|
234
|
+
|
|
235
|
+
**When to Use**:
|
|
236
|
+
- Refactoring shared code without long-lived branches
|
|
237
|
+
- Need trunk-based development
|
|
238
|
+
- Changes are too risky for single commit
|
|
239
|
+
|
|
240
|
+
**Steps**:
|
|
241
|
+
|
|
242
|
+
```
|
|
243
|
+
Step 1: Introduce Abstraction
|
|
244
|
+
Client → Abstraction (interface) → Old Implementation
|
|
245
|
+
|
|
246
|
+
Step 2: Add New Implementation
|
|
247
|
+
Client → Abstraction → Old Implementation
|
|
248
|
+
└─→ New Implementation (feature-toggled)
|
|
249
|
+
|
|
250
|
+
Step 3: Switch and Remove
|
|
251
|
+
Client → New Implementation
|
|
252
|
+
[Old Implementation removed]
|
|
253
|
+
```
|
|
254
|
+
|
|
255
|
+
**Key Principles**:
|
|
256
|
+
- All changes on main/trunk (no long branches)
|
|
257
|
+
- Feature toggles control which implementation is active
|
|
258
|
+
- Both implementations can coexist during transition
|
|
259
|
+
|
|
260
|
+
### Parallel Change (Expand-Migrate-Contract)
|
|
261
|
+
|
|
262
|
+
**Definition**: Changing interfaces used by multiple clients through a three-phase approach.
|
|
263
|
+
|
|
264
|
+
**When to Use**:
|
|
265
|
+
- Changing interfaces used by multiple clients
|
|
266
|
+
- Database schema migration
|
|
267
|
+
- Need zero-downtime migration
|
|
268
|
+
|
|
269
|
+
**Phases**:
|
|
270
|
+
|
|
271
|
+
```
|
|
272
|
+
Phase 1: EXPAND
|
|
273
|
+
├─ Add new field/method alongside old
|
|
274
|
+
├─ New code uses new interface
|
|
275
|
+
└─ Old code still works
|
|
276
|
+
|
|
277
|
+
Phase 2: MIGRATE
|
|
278
|
+
├─ Update all clients to use new interface
|
|
279
|
+
├─ Verify all clients migrated
|
|
280
|
+
└─ Data migration (if needed)
|
|
281
|
+
|
|
282
|
+
Phase 3: CONTRACT
|
|
283
|
+
├─ Remove old field/method
|
|
284
|
+
├─ Clean up migration code
|
|
285
|
+
└─ Update documentation
|
|
286
|
+
```
|
|
287
|
+
|
|
288
|
+
---
|
|
289
|
+
|
|
290
|
+
## Safety Strategies for Legacy Code
|
|
291
|
+
|
|
292
|
+
Based on Michael Feathers' "Working Effectively with Legacy Code".
|
|
293
|
+
|
|
294
|
+
### The Legacy Code Dilemma
|
|
295
|
+
|
|
296
|
+
**Definition**: Legacy code = code without tests (regardless of age)
|
|
297
|
+
|
|
298
|
+
**The Dilemma**:
|
|
299
|
+
- To change code safely, we need tests
|
|
300
|
+
- To add tests, we often need to change code
|
|
301
|
+
- Changing code without tests is risky
|
|
302
|
+
|
|
303
|
+
**Solution**: Use safe techniques to add tests before making changes.
|
|
304
|
+
|
|
305
|
+
### Characterization Tests
|
|
306
|
+
|
|
307
|
+
**Definition**: Tests that capture existing behavior (not verify correctness).
|
|
308
|
+
|
|
309
|
+
**Purpose**: Create a safety net before refactoring legacy code.
|
|
310
|
+
|
|
311
|
+
**Process**:
|
|
312
|
+
|
|
313
|
+
```
|
|
314
|
+
1. Call the code you want to understand
|
|
315
|
+
2. Write an assertion you expect to FAIL
|
|
316
|
+
3. Run the test and see what actually happens
|
|
317
|
+
4. Update the assertion to match actual behavior
|
|
318
|
+
5. Repeat until you've covered the behavior you need to change
|
|
319
|
+
```
|
|
320
|
+
|
|
321
|
+
**Example**:
|
|
322
|
+
|
|
323
|
+
```javascript
|
|
324
|
+
// Step 1: Initial (expected to fail)
|
|
325
|
+
test('calculateDiscount returns... something', () => {
|
|
326
|
+
const result = calculateDiscount(100, 'GOLD');
|
|
327
|
+
expect(result).toBe(0); // Guess - will probably fail
|
|
328
|
+
});
|
|
329
|
+
|
|
330
|
+
// Step 2: After running, update with actual value
|
|
331
|
+
test('calculateDiscount returns 15 for GOLD customers', () => {
|
|
332
|
+
const result = calculateDiscount(100, 'GOLD');
|
|
333
|
+
expect(result).toBe(15); // Actual behavior
|
|
334
|
+
});
|
|
335
|
+
```
|
|
336
|
+
|
|
337
|
+
**Key Principle**: Characterization tests document what the code *does*, not what it *should do*.
|
|
338
|
+
|
|
339
|
+
### Scratch Refactoring
|
|
340
|
+
|
|
341
|
+
**Definition**: Refactoring to understand code, without keeping the changes.
|
|
342
|
+
|
|
343
|
+
**Purpose**: Explore and understand undocumented code through hands-on modification.
|
|
344
|
+
|
|
345
|
+
**Workflow**:
|
|
346
|
+
|
|
347
|
+
```
|
|
348
|
+
1. Create a scratch branch (or use git stash)
|
|
349
|
+
2. Aggressively refactor to understand the code
|
|
350
|
+
3. Take notes on what you learn
|
|
351
|
+
4. Discard all changes (git reset --hard)
|
|
352
|
+
5. Apply learnings to write characterization tests
|
|
353
|
+
```
|
|
354
|
+
|
|
355
|
+
**When to Use**:
|
|
356
|
+
- Code is too complex to understand by reading
|
|
357
|
+
- No documentation exists
|
|
358
|
+
- You need to build a mental model quickly
|
|
359
|
+
|
|
360
|
+
**Key Principle**: The goal is understanding, not clean code. Discard everything when done.
|
|
361
|
+
|
|
362
|
+
### Finding Seams
|
|
363
|
+
|
|
364
|
+
**Definition**: A seam is a place where you can alter behavior without editing code.
|
|
365
|
+
|
|
366
|
+
| Seam Type | How It Works | Example |
|
|
367
|
+
|-----------|--------------|---------|
|
|
368
|
+
| **Object Seam** | Override via polymorphism | Inject test double via interface |
|
|
369
|
+
| **Preprocessing Seam** | Compile-time substitution | Conditional compilation, macros |
|
|
370
|
+
| **Link Seam** | Replace at link time | Dependency injection, module replacement |
|
|
371
|
+
|
|
372
|
+
**Purpose**: Inject test doubles without modifying legacy code.
|
|
373
|
+
|
|
374
|
+
### Sprout and Wrap Techniques
|
|
375
|
+
|
|
376
|
+
| Technique | When to Use | How |
|
|
377
|
+
|-----------|-------------|-----|
|
|
378
|
+
| **Sprout Method** | Adding new logic to existing method | Create new method, call from old |
|
|
379
|
+
| **Sprout Class** | New logic needs to evolve independently | Create new class, reference from old |
|
|
380
|
+
| **Wrap Method** | Need to add behavior before/after | Rename original, create wrapper |
|
|
381
|
+
| **Wrap Class** | Decorate existing class | Decorator pattern |
|
|
382
|
+
|
|
383
|
+
**Principle**: New code uses TDD; legacy code stays untouched until tested.
|
|
384
|
+
|
|
385
|
+
### Code Archaeology
|
|
386
|
+
|
|
387
|
+
Techniques for understanding undocumented code:
|
|
388
|
+
|
|
389
|
+
```
|
|
390
|
+
1. Scratch Refactoring (see above)
|
|
391
|
+
├─ Refactor to understand, not to keep
|
|
392
|
+
├─ Use git stash or branch
|
|
393
|
+
└─ Discard when done (git reset --hard)
|
|
394
|
+
|
|
395
|
+
2. Trace Variable Flow
|
|
396
|
+
├─ Follow data from input to output
|
|
397
|
+
├─ Mark key transformation points
|
|
398
|
+
└─ Document as you discover
|
|
399
|
+
|
|
400
|
+
3. Runtime Observation
|
|
401
|
+
├─ Add temporary logging
|
|
402
|
+
├─ Use debugger step-through
|
|
403
|
+
└─ Build mental model
|
|
404
|
+
|
|
405
|
+
4. Git Archaeology
|
|
406
|
+
├─ git log -p <file> (see all changes)
|
|
407
|
+
├─ git blame (find original author)
|
|
408
|
+
└─ Search commit messages for context
|
|
409
|
+
```
|
|
410
|
+
|
|
411
|
+
---
|
|
412
|
+
|
|
413
|
+
## Database Refactoring Patterns
|
|
414
|
+
|
|
415
|
+
### Expand-Contract Pattern for Schema Changes
|
|
416
|
+
|
|
417
|
+
```
|
|
418
|
+
┌─────────────────────────────────────────────────────────────────┐
|
|
419
|
+
│ Database Refactoring (Expand-Contract) │
|
|
420
|
+
├─────────────────────────────────────────────────────────────────┤
|
|
421
|
+
│ │
|
|
422
|
+
│ Phase 1: EXPAND (Add new, keep old) │
|
|
423
|
+
│ ├─ Add new column/table │
|
|
424
|
+
│ ├─ Application writes to BOTH old and new │
|
|
425
|
+
│ └─ Safe to rollback at this point │
|
|
426
|
+
│ │
|
|
427
|
+
│ Phase 2: MIGRATE (Move data) │
|
|
428
|
+
│ ├─ Copy data from old to new │
|
|
429
|
+
│ ├─ Verify data consistency │
|
|
430
|
+
│ └─ Application starts reading from new │
|
|
431
|
+
│ │
|
|
432
|
+
│ Phase 3: CONTRACT (Remove old) │
|
|
433
|
+
│ ├─ Confirm old column/table no longer read │
|
|
434
|
+
│ ├─ Remove old column/table │
|
|
435
|
+
│ └─ Clean up dual-write code │
|
|
436
|
+
│ │
|
|
437
|
+
└─────────────────────────────────────────────────────────────────┘
|
|
438
|
+
```
|
|
439
|
+
|
|
440
|
+
### Common Schema Refactoring Scenarios
|
|
441
|
+
|
|
442
|
+
| Scenario | Strategy | Risk Level |
|
|
443
|
+
|----------|----------|------------|
|
|
444
|
+
| **Rename column** | Add new → Migrate → Drop old | Medium |
|
|
445
|
+
| **Split table** | New table + FK → Migrate → Adjust app | High |
|
|
446
|
+
| **Merge tables** | New table → Merge data → Switch app | High |
|
|
447
|
+
| **Change data type** | New column → Convert → Switch app | Medium |
|
|
448
|
+
| **Add NOT NULL** | Fill defaults → Add constraint | Low |
|
|
449
|
+
|
|
450
|
+
### Database Migration Safety Checklist
|
|
451
|
+
|
|
452
|
+
```
|
|
453
|
+
Pre-Migration:
|
|
454
|
+
□ Full backup completed
|
|
455
|
+
□ Migration script tested in staging
|
|
456
|
+
□ Rollback script prepared
|
|
457
|
+
□ Migration time estimated (consider data volume)
|
|
458
|
+
□ Maintenance window communicated
|
|
459
|
+
|
|
460
|
+
During Migration:
|
|
461
|
+
□ Monitor database performance
|
|
462
|
+
□ Verify data integrity incrementally
|
|
463
|
+
□ Application health checks passing
|
|
464
|
+
|
|
465
|
+
Post-Migration:
|
|
466
|
+
□ Data consistency verification
|
|
467
|
+
□ Application functionality verification
|
|
468
|
+
□ Performance baseline comparison
|
|
469
|
+
□ Backup retained for rollback period
|
|
470
|
+
```
|
|
471
|
+
|
|
472
|
+
### Zero-Downtime Migration Techniques
|
|
473
|
+
|
|
474
|
+
| Technique | Description | Use Case |
|
|
475
|
+
|-----------|-------------|----------|
|
|
476
|
+
| **Online Schema Change** | pt-osc, gh-ost | MySQL large table changes |
|
|
477
|
+
| **Blue-Green Database** | Dual database switchover | High availability requirements |
|
|
478
|
+
| **Shadow Write** | Write to both DBs, compare | Verify migration correctness |
|
|
479
|
+
| **Feature Flag** | Control read source | Gradual cutover |
|
|
480
|
+
|
|
481
|
+
---
|
|
482
|
+
|
|
483
|
+
## Team Collaboration Practices
|
|
484
|
+
|
|
485
|
+
### Refactoring Project Kickoff
|
|
486
|
+
|
|
487
|
+
```
|
|
488
|
+
Kickoff Meeting Agenda:
|
|
489
|
+
1. Scope Definition
|
|
490
|
+
├─ What modules/files are in scope
|
|
491
|
+
└─ What is explicitly excluded
|
|
492
|
+
|
|
493
|
+
2. Success Criteria Alignment
|
|
494
|
+
├─ Quantitative goals (complexity reduction X%)
|
|
495
|
+
└─ Functional goals (behavior unchanged)
|
|
496
|
+
|
|
497
|
+
3. Work Division
|
|
498
|
+
├─ By module (vertical slicing)
|
|
499
|
+
└─ By layer (horizontal slicing)
|
|
500
|
+
|
|
501
|
+
4. Risk Assessment
|
|
502
|
+
├─ Highest-risk areas
|
|
503
|
+
└─ Rollback strategy
|
|
504
|
+
```
|
|
505
|
+
|
|
506
|
+
### Division Strategies
|
|
507
|
+
|
|
508
|
+
| Strategy | Use When | Caution |
|
|
509
|
+
|----------|----------|---------|
|
|
510
|
+
| **Vertical Slicing** | Independent modules | Ensure interfaces unchanged |
|
|
511
|
+
| **Horizontal Slicing** | Cross-module refactoring (e.g., naming conventions) | Strict synchronization needed |
|
|
512
|
+
| **Strangler Division** | Large system replacement | One person per Strangler slice |
|
|
513
|
+
| **Mob Programming** | Core/high-risk areas | Entire team, reduces risk |
|
|
514
|
+
|
|
515
|
+
### Communication Mechanisms
|
|
516
|
+
|
|
517
|
+
```
|
|
518
|
+
Daily Communication:
|
|
519
|
+
├─ Sync refactoring progress in standup
|
|
520
|
+
├─ Shared Refactoring Board (Kanban)
|
|
521
|
+
└─ Dedicated channel (#refactoring-xxx)
|
|
522
|
+
|
|
523
|
+
PR Standards:
|
|
524
|
+
├─ [Refactor] prefix in title
|
|
525
|
+
├─ Explain what changed and why
|
|
526
|
+
├─ Include before/after complexity comparison
|
|
527
|
+
└─ Require Characterization Tests for legacy code
|
|
528
|
+
|
|
529
|
+
Conflict Resolution:
|
|
530
|
+
├─ Small scope: Resolve immediately
|
|
531
|
+
├─ Medium scope: Daily sync meeting
|
|
532
|
+
└─ Large scope: Consider Branch by Abstraction
|
|
533
|
+
```
|
|
534
|
+
|
|
535
|
+
---
|
|
536
|
+
|
|
537
|
+
## Technical Debt Management
|
|
538
|
+
|
|
539
|
+
### Technical Debt Quadrant
|
|
540
|
+
|
|
541
|
+
Based on Martin Fowler's Technical Debt Quadrant:
|
|
542
|
+
|
|
543
|
+
```
|
|
544
|
+
Deliberate
|
|
545
|
+
│
|
|
546
|
+
┌───────────────┼───────────────┐
|
|
547
|
+
│ │ │
|
|
548
|
+
│ Prudent │ Reckless │
|
|
549
|
+
│ "We know │ "We don't │
|
|
550
|
+
│ this is │ have time │
|
|
551
|
+
│ debt" │ for design" │
|
|
552
|
+
│ │ │
|
|
553
|
+
Prudent ├───────────────┼───────────────┤ Reckless
|
|
554
|
+
│ │ │
|
|
555
|
+
│ Prudent │ Reckless │
|
|
556
|
+
│ "Now we │ "What's │
|
|
557
|
+
│ know how │ layering?" │
|
|
558
|
+
│ we should │ │
|
|
559
|
+
│ have done it"│ │
|
|
560
|
+
│ │ │
|
|
561
|
+
└───────────────┼───────────────┘
|
|
562
|
+
│
|
|
563
|
+
Inadvertent
|
|
564
|
+
```
|
|
565
|
+
|
|
566
|
+
### Tracking Technical Debt
|
|
567
|
+
|
|
568
|
+
```
|
|
569
|
+
For each debt item, record:
|
|
570
|
+
├─ Description: What is the issue?
|
|
571
|
+
├─ Impact: How does it affect development?
|
|
572
|
+
├─ Estimated Effort: How long to fix?
|
|
573
|
+
├─ Risk if Ignored: What happens if not addressed?
|
|
574
|
+
└─ Related Code: Links to affected files/modules
|
|
575
|
+
```
|
|
576
|
+
|
|
577
|
+
---
|
|
578
|
+
|
|
579
|
+
## References
|
|
580
|
+
|
|
581
|
+
### Books
|
|
582
|
+
|
|
583
|
+
- Martin Fowler - "Refactoring: Improving the Design of Existing Code" (2nd Edition, 2018)
|
|
584
|
+
- Michael Feathers - "Working Effectively with Legacy Code" (2004)
|
|
585
|
+
- Joshua Kerievsky - "Refactoring to Patterns" (2004)
|
|
586
|
+
- Kent Beck - "Implementation Patterns" (2007)
|
|
587
|
+
- Robert C. Martin - "Clean Code" (2008)
|
|
588
|
+
- Eric Evans - "Domain-Driven Design" (2003)
|
|
589
|
+
|
|
590
|
+
### Articles
|
|
591
|
+
|
|
592
|
+
- Martin Fowler - [Strangler Fig Application](https://martinfowler.com/bliki/StranglerFigApplication.html)
|
|
593
|
+
- Martin Fowler - [Branch by Abstraction](https://martinfowler.com/bliki/BranchByAbstraction.html)
|
|
594
|
+
- Martin Fowler - [Preparatory Refactoring](https://martinfowler.com/articles/preparatory-refactoring-example.html)
|
|
595
|
+
- Pete Hodgson - [Feature Toggles](https://martinfowler.com/articles/feature-toggles.html)
|
|
596
|
+
- Martin Fowler - [Technical Debt Quadrant](https://martinfowler.com/bliki/TechnicalDebtQuadrant.html)
|
|
597
|
+
|
|
598
|
+
### Tools
|
|
599
|
+
|
|
600
|
+
- [Refactoring Guru](https://refactoring.guru/) - Catalog of refactoring techniques
|
|
601
|
+
- [SonarQube](https://www.sonarqube.org/) - Code quality and complexity analysis
|
|
602
|
+
- [ApprovalTests](https://approvaltests.com/) - Golden Master testing
|
|
603
|
+
|
|
604
|
+
---
|
|
605
|
+
|
|
606
|
+
## License
|
|
607
|
+
|
|
608
|
+
This guide is released under [CC BY 4.0](https://creativecommons.org/licenses/by/4.0/).
|