universal-dev-standards 3.5.1-beta.1 → 3.5.1-beta.11
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/bin/uds.js +2 -0
- package/bundled/core/ai-instruction-standards.md +205 -0
- package/bundled/core/anti-hallucination.md +684 -0
- package/bundled/core/changelog-standards.md +556 -0
- package/bundled/core/checkin-standards.md +935 -0
- package/bundled/core/code-review-checklist.md +684 -0
- package/bundled/core/commit-message-guide.md +915 -0
- package/bundled/core/documentation-structure.md +1117 -0
- package/bundled/core/documentation-writing-standards.md +487 -0
- package/bundled/core/error-code-standards.md +382 -0
- package/bundled/core/git-workflow.md +859 -0
- package/bundled/core/logging-standards.md +323 -0
- package/bundled/core/project-structure.md +354 -0
- package/bundled/core/refactoring-standards.md +636 -0
- package/bundled/core/spec-driven-development.md +207 -0
- package/bundled/core/test-completeness-dimensions.md +536 -0
- package/bundled/core/test-driven-development.md +995 -0
- package/bundled/core/testing-standards.md +3061 -0
- package/bundled/core/versioning.md +902 -0
- package/bundled/locales/README.md +88 -0
- package/bundled/locales/zh-CN/CHANGELOG.md +705 -0
- package/bundled/locales/zh-CN/CLAUDE.md +213 -0
- package/bundled/locales/zh-CN/MAINTENANCE.md +689 -0
- package/bundled/locales/zh-CN/README.md +707 -0
- package/bundled/locales/zh-CN/STANDARDS-MAPPING.md +177 -0
- package/bundled/locales/zh-CN/adoption/ADOPTION-GUIDE.md +392 -0
- package/bundled/locales/zh-CN/adoption/STATIC-DYNAMIC-GUIDE.md +302 -0
- package/bundled/locales/zh-CN/adoption/checklists/enterprise.md +332 -0
- package/bundled/locales/zh-CN/adoption/checklists/minimal.md +141 -0
- package/bundled/locales/zh-CN/adoption/checklists/recommended.md +272 -0
- package/bundled/locales/zh-CN/ai/MAINTENANCE.md +739 -0
- package/bundled/locales/zh-CN/ai/options/changelog/auto-generated.ai.yaml +76 -0
- package/bundled/locales/zh-CN/ai/options/changelog/keep-a-changelog.ai.yaml +99 -0
- package/bundled/locales/zh-CN/ai/options/code-review/automated-review.ai.yaml +120 -0
- package/bundled/locales/zh-CN/ai/options/code-review/pair-programming.ai.yaml +109 -0
- package/bundled/locales/zh-CN/ai/options/code-review/pr-review.ai.yaml +104 -0
- package/bundled/locales/zh-CN/ai/options/commit-message/bilingual.ai.yaml +105 -0
- package/bundled/locales/zh-CN/ai/options/commit-message/english.ai.yaml +79 -0
- package/bundled/locales/zh-CN/ai/options/commit-message/traditional-chinese.ai.yaml +100 -0
- package/bundled/locales/zh-CN/ai/options/documentation/api-docs.ai.yaml +140 -0
- package/bundled/locales/zh-CN/ai/options/documentation/markdown-docs.ai.yaml +89 -0
- package/bundled/locales/zh-CN/ai/options/documentation/wiki-style.ai.yaml +119 -0
- package/bundled/locales/zh-CN/ai/options/git-workflow/gitflow.ai.yaml +133 -0
- package/bundled/locales/zh-CN/ai/options/git-workflow/github-flow.ai.yaml +73 -0
- package/bundled/locales/zh-CN/ai/options/git-workflow/merge-commit.ai.yaml +88 -0
- package/bundled/locales/zh-CN/ai/options/git-workflow/rebase-ff.ai.yaml +113 -0
- package/bundled/locales/zh-CN/ai/options/git-workflow/squash-merge.ai.yaml +85 -0
- package/bundled/locales/zh-CN/ai/options/git-workflow/trunk-based.ai.yaml +117 -0
- package/bundled/locales/zh-CN/ai/options/project-structure/dotnet.ai.yaml +108 -0
- package/bundled/locales/zh-CN/ai/options/project-structure/go.ai.yaml +115 -0
- package/bundled/locales/zh-CN/ai/options/project-structure/java.ai.yaml +113 -0
- package/bundled/locales/zh-CN/ai/options/project-structure/kotlin.ai.yaml +123 -0
- package/bundled/locales/zh-CN/ai/options/project-structure/nodejs.ai.yaml +101 -0
- package/bundled/locales/zh-CN/ai/options/project-structure/php.ai.yaml +147 -0
- package/bundled/locales/zh-CN/ai/options/project-structure/python.ai.yaml +116 -0
- package/bundled/locales/zh-CN/ai/options/project-structure/ruby.ai.yaml +140 -0
- package/bundled/locales/zh-CN/ai/options/project-structure/rust.ai.yaml +117 -0
- package/bundled/locales/zh-CN/ai/options/project-structure/swift.ai.yaml +143 -0
- package/bundled/locales/zh-CN/ai/options/testing/contract-testing.ai.yaml +254 -0
- package/bundled/locales/zh-CN/ai/options/testing/e2e-testing.ai.yaml +116 -0
- package/bundled/locales/zh-CN/ai/options/testing/industry-pyramid.ai.yaml +144 -0
- package/bundled/locales/zh-CN/ai/options/testing/integration-testing.ai.yaml +90 -0
- package/bundled/locales/zh-CN/ai/options/testing/istqb-framework.ai.yaml +108 -0
- package/bundled/locales/zh-CN/ai/options/testing/performance-testing.ai.yaml +272 -0
- package/bundled/locales/zh-CN/ai/options/testing/security-testing.ai.yaml +160 -0
- package/bundled/locales/zh-CN/ai/options/testing/system-testing.ai.yaml +101 -0
- package/bundled/locales/zh-CN/ai/options/testing/unit-testing.ai.yaml +82 -0
- package/bundled/locales/zh-CN/ai/standards/anti-hallucination.ai.yaml +145 -0
- package/bundled/locales/zh-CN/ai/standards/changelog.ai.yaml +146 -0
- package/bundled/locales/zh-CN/ai/standards/checkin-standards.ai.yaml +170 -0
- package/bundled/locales/zh-CN/ai/standards/code-review.ai.yaml +148 -0
- package/bundled/locales/zh-CN/ai/standards/commit-message.ai.yaml +175 -0
- package/bundled/locales/zh-CN/ai/standards/documentation-structure.ai.yaml +124 -0
- package/bundled/locales/zh-CN/ai/standards/documentation-writing-standards.ai.yaml +190 -0
- package/bundled/locales/zh-CN/ai/standards/error-codes.ai.yaml +139 -0
- package/bundled/locales/zh-CN/ai/standards/git-workflow.ai.yaml +95 -0
- package/bundled/locales/zh-CN/ai/standards/logging.ai.yaml +128 -0
- package/bundled/locales/zh-CN/ai/standards/project-structure.ai.yaml +134 -0
- package/bundled/locales/zh-CN/ai/standards/spec-driven-development.ai.yaml +169 -0
- package/bundled/locales/zh-CN/ai/standards/test-completeness-dimensions.ai.yaml +220 -0
- package/bundled/locales/zh-CN/ai/standards/testing.ai.yaml +137 -0
- package/bundled/locales/zh-CN/ai/standards/versioning.ai.yaml +211 -0
- package/bundled/locales/zh-CN/core/ai-instruction-standards.md +213 -0
- package/bundled/locales/zh-CN/core/anti-hallucination.md +691 -0
- package/bundled/locales/zh-CN/core/changelog-standards.md +147 -0
- package/bundled/locales/zh-CN/core/checkin-standards.md +943 -0
- package/bundled/locales/zh-CN/core/code-review-guide.md +693 -0
- package/bundled/locales/zh-CN/core/commit-message-guide.md +129 -0
- package/bundled/locales/zh-CN/core/documentation-structure.md +173 -0
- package/bundled/locales/zh-CN/core/documentation-writing-standards.md +495 -0
- package/bundled/locales/zh-CN/core/error-code-standards.md +180 -0
- package/bundled/locales/zh-CN/core/git-workflow.md +193 -0
- package/bundled/locales/zh-CN/core/logging-standards.md +174 -0
- package/bundled/locales/zh-CN/core/project-structure.md +184 -0
- package/bundled/locales/zh-CN/core/refactoring-standards.md +642 -0
- package/bundled/locales/zh-CN/core/spec-driven-development.md +215 -0
- package/bundled/locales/zh-CN/core/test-completeness-dimensions.md +544 -0
- package/bundled/locales/zh-CN/core/test-driven-development.md +1002 -0
- package/bundled/locales/zh-CN/core/testing-standards.md +170 -0
- package/bundled/locales/zh-CN/core/versioning.md +177 -0
- package/bundled/locales/zh-CN/docs/AI-AGENT-ROADMAP.md +303 -0
- package/bundled/locales/zh-CN/docs/CLI-INIT-OPTIONS.md +990 -0
- package/bundled/locales/zh-CN/docs/OPERATION-WORKFLOW.md +1064 -0
- package/bundled/locales/zh-CN/docs/USAGE-MODES-COMPARISON.md +333 -0
- package/bundled/locales/zh-CN/docs/WINDOWS-GUIDE.md +215 -0
- package/bundled/locales/zh-CN/integrations/codex/AGENTS.md +115 -0
- package/bundled/locales/zh-CN/integrations/codex/README.md +67 -0
- package/bundled/locales/zh-CN/integrations/gemini-cli/GEMINI.md +102 -0
- package/bundled/locales/zh-CN/integrations/gemini-cli/README.md +140 -0
- package/bundled/locales/zh-CN/integrations/github-copilot/COPILOT-CHAT-REFERENCE.md +269 -0
- package/bundled/locales/zh-CN/integrations/github-copilot/README.md +167 -0
- package/bundled/locales/zh-CN/integrations/github-copilot/copilot-instructions.md +263 -0
- package/bundled/locales/zh-CN/integrations/github-copilot/skills-mapping.md +192 -0
- package/bundled/locales/zh-CN/integrations/google-antigravity/INSTRUCTIONS.md +61 -0
- package/bundled/locales/zh-CN/integrations/google-antigravity/README.md +84 -0
- package/bundled/locales/zh-CN/integrations/opencode/AGENTS.md +111 -0
- package/bundled/locales/zh-CN/integrations/opencode/README.md +176 -0
- package/bundled/locales/zh-CN/integrations/opencode/skills-mapping.md +396 -0
- package/bundled/locales/zh-CN/integrations/openspec/AGENTS.md +301 -0
- package/bundled/locales/zh-CN/integrations/openspec/README.md +43 -0
- package/bundled/locales/zh-CN/integrations/spec-kit/AGENTS.md +184 -0
- package/bundled/locales/zh-CN/integrations/spec-kit/README.md +43 -0
- package/bundled/locales/zh-CN/options/commit-message/bilingual.md +161 -0
- package/bundled/locales/zh-CN/options/commit-message/english.md +137 -0
- package/bundled/locales/zh-CN/options/commit-message/traditional-chinese.md +162 -0
- package/bundled/locales/zh-CN/options/git-workflow/gitflow.md +147 -0
- package/bundled/locales/zh-CN/options/git-workflow/github-flow.md +124 -0
- package/bundled/locales/zh-CN/options/git-workflow/merge-commit.md +124 -0
- package/bundled/locales/zh-CN/options/git-workflow/rebase-ff.md +160 -0
- package/bundled/locales/zh-CN/options/git-workflow/squash-merge.md +117 -0
- package/bundled/locales/zh-CN/options/git-workflow/trunk-based.md +125 -0
- package/bundled/locales/zh-CN/options/project-structure/dotnet.md +183 -0
- package/bundled/locales/zh-CN/options/project-structure/go.md +226 -0
- package/bundled/locales/zh-CN/options/project-structure/java.md +213 -0
- package/bundled/locales/zh-CN/options/project-structure/nodejs.md +185 -0
- package/bundled/locales/zh-CN/options/project-structure/python.md +229 -0
- package/bundled/locales/zh-CN/options/testing/e2e-testing.md +207 -0
- package/bundled/locales/zh-CN/options/testing/integration-testing.md +230 -0
- package/bundled/locales/zh-CN/options/testing/system-testing.md +183 -0
- package/bundled/locales/zh-CN/options/testing/unit-testing.md +165 -0
- package/bundled/locales/zh-CN/skills/INTEGRATION-GUIDE.md +218 -0
- package/bundled/locales/zh-CN/skills/README.md +134 -0
- package/bundled/locales/zh-CN/skills/_shared/README.md +68 -0
- package/bundled/locales/zh-CN/skills/claude-code/CONTRIBUTING.template.md +151 -0
- package/bundled/locales/zh-CN/skills/claude-code/README.md +174 -0
- package/bundled/locales/zh-CN/skills/claude-code/ai-collaboration-standards/SKILL.md +175 -0
- package/bundled/locales/zh-CN/skills/claude-code/ai-collaboration-standards/anti-hallucination.md +223 -0
- package/bundled/locales/zh-CN/skills/claude-code/ai-collaboration-standards/certainty-labels.md +132 -0
- package/bundled/locales/zh-CN/skills/claude-code/changelog-guide/SKILL.md +237 -0
- package/bundled/locales/zh-CN/skills/claude-code/checkin-assistant/SKILL.md +407 -0
- package/bundled/locales/zh-CN/skills/claude-code/code-review-assistant/SKILL.md +154 -0
- package/bundled/locales/zh-CN/skills/claude-code/code-review-assistant/checkin-checklist.md +257 -0
- package/bundled/locales/zh-CN/skills/claude-code/code-review-assistant/review-checklist.md +246 -0
- package/bundled/locales/zh-CN/skills/claude-code/commands/bdd.md +142 -0
- package/bundled/locales/zh-CN/skills/claude-code/commands/methodology.md +274 -0
- package/bundled/locales/zh-CN/skills/claude-code/commit-standards/SKILL.md +191 -0
- package/bundled/locales/zh-CN/skills/claude-code/commit-standards/conventional-commits.md +264 -0
- package/bundled/locales/zh-CN/skills/claude-code/commit-standards/language-options.md +172 -0
- package/bundled/locales/zh-CN/skills/claude-code/documentation-guide/SKILL.md +421 -0
- package/bundled/locales/zh-CN/skills/claude-code/documentation-guide/documentation-structure.md +357 -0
- package/bundled/locales/zh-CN/skills/claude-code/documentation-guide/readme-template.md +412 -0
- package/bundled/locales/zh-CN/skills/claude-code/error-code-guide/SKILL.md +269 -0
- package/bundled/locales/zh-CN/skills/claude-code/git-workflow-guide/SKILL.md +218 -0
- package/bundled/locales/zh-CN/skills/claude-code/git-workflow-guide/branch-naming.md +220 -0
- package/bundled/locales/zh-CN/skills/claude-code/git-workflow-guide/git-workflow.md +321 -0
- package/bundled/locales/zh-CN/skills/claude-code/logging-guide/SKILL.md +285 -0
- package/bundled/locales/zh-CN/skills/claude-code/methodology-system/SKILL.md +131 -0
- package/bundled/locales/zh-CN/skills/claude-code/methodology-system/create-methodology.md +350 -0
- package/bundled/locales/zh-CN/skills/claude-code/methodology-system/runtime.md +279 -0
- package/bundled/locales/zh-CN/skills/claude-code/project-structure-guide/SKILL.md +143 -0
- package/bundled/locales/zh-CN/skills/claude-code/project-structure-guide/language-patterns.md +271 -0
- package/bundled/locales/zh-CN/skills/claude-code/refactoring-assistant/SKILL.md +162 -0
- package/bundled/locales/zh-CN/skills/claude-code/release-standards/SKILL.md +191 -0
- package/bundled/locales/zh-CN/skills/claude-code/release-standards/changelog-format.md +247 -0
- package/bundled/locales/zh-CN/skills/claude-code/release-standards/release-workflow.md +345 -0
- package/bundled/locales/zh-CN/skills/claude-code/release-standards/semantic-versioning.md +250 -0
- package/bundled/locales/zh-CN/skills/claude-code/requirement-assistant/SKILL.md +227 -0
- package/bundled/locales/zh-CN/skills/claude-code/requirement-assistant/requirement-checklist.md +325 -0
- package/bundled/locales/zh-CN/skills/claude-code/requirement-assistant/requirement-writing.md +399 -0
- package/bundled/locales/zh-CN/skills/claude-code/spec-driven-dev/SKILL.md +243 -0
- package/bundled/locales/zh-CN/skills/claude-code/tdd-assistant/SKILL.md +332 -0
- package/bundled/locales/zh-CN/skills/claude-code/tdd-assistant/language-examples.md +639 -0
- package/bundled/locales/zh-CN/skills/claude-code/tdd-assistant/tdd-workflow.md +486 -0
- package/bundled/locales/zh-CN/skills/claude-code/test-coverage-assistant/SKILL.md +282 -0
- package/bundled/locales/zh-CN/skills/claude-code/testing-guide/SKILL.md +234 -0
- package/bundled/locales/zh-CN/skills/claude-code/testing-guide/testing-pyramid.md +448 -0
- package/bundled/locales/zh-CN/skills/cline/README.md +58 -0
- package/bundled/locales/zh-CN/skills/copilot/README.md +61 -0
- package/bundled/locales/zh-CN/skills/copilot/copilot-instructions.md +79 -0
- package/bundled/locales/zh-CN/skills/cursor/README.md +58 -0
- package/bundled/locales/zh-CN/skills/windsurf/README.md +59 -0
- package/bundled/locales/zh-TW/CHANGELOG.md +707 -0
- package/bundled/locales/zh-TW/CLAUDE.md +213 -0
- package/bundled/locales/zh-TW/MAINTENANCE.md +683 -0
- package/bundled/locales/zh-TW/README.md +687 -0
- package/bundled/locales/zh-TW/STANDARDS-MAPPING.md +177 -0
- package/bundled/locales/zh-TW/adoption/ADOPTION-GUIDE.md +392 -0
- package/bundled/locales/zh-TW/adoption/STATIC-DYNAMIC-GUIDE.md +299 -0
- package/bundled/locales/zh-TW/adoption/checklists/enterprise.md +332 -0
- package/bundled/locales/zh-TW/adoption/checklists/minimal.md +141 -0
- package/bundled/locales/zh-TW/adoption/checklists/recommended.md +272 -0
- package/bundled/locales/zh-TW/ai/MAINTENANCE.md +754 -0
- package/bundled/locales/zh-TW/ai/options/changelog/auto-generated.ai.yaml +76 -0
- package/bundled/locales/zh-TW/ai/options/changelog/keep-a-changelog.ai.yaml +99 -0
- package/bundled/locales/zh-TW/ai/options/code-review/automated-review.ai.yaml +120 -0
- package/bundled/locales/zh-TW/ai/options/code-review/pair-programming.ai.yaml +109 -0
- package/bundled/locales/zh-TW/ai/options/code-review/pr-review.ai.yaml +104 -0
- package/bundled/locales/zh-TW/ai/options/commit-message/bilingual.ai.yaml +105 -0
- package/bundled/locales/zh-TW/ai/options/commit-message/english.ai.yaml +79 -0
- package/bundled/locales/zh-TW/ai/options/commit-message/traditional-chinese.ai.yaml +100 -0
- package/bundled/locales/zh-TW/ai/options/documentation/api-docs.ai.yaml +140 -0
- package/bundled/locales/zh-TW/ai/options/documentation/markdown-docs.ai.yaml +89 -0
- package/bundled/locales/zh-TW/ai/options/documentation/wiki-style.ai.yaml +119 -0
- package/bundled/locales/zh-TW/ai/options/git-workflow/gitflow.ai.yaml +133 -0
- package/bundled/locales/zh-TW/ai/options/git-workflow/github-flow.ai.yaml +73 -0
- package/bundled/locales/zh-TW/ai/options/git-workflow/merge-commit.ai.yaml +88 -0
- package/bundled/locales/zh-TW/ai/options/git-workflow/rebase-ff.ai.yaml +113 -0
- package/bundled/locales/zh-TW/ai/options/git-workflow/squash-merge.ai.yaml +85 -0
- package/bundled/locales/zh-TW/ai/options/git-workflow/trunk-based.ai.yaml +117 -0
- package/bundled/locales/zh-TW/ai/options/project-structure/dotnet.ai.yaml +108 -0
- package/bundled/locales/zh-TW/ai/options/project-structure/go.ai.yaml +115 -0
- package/bundled/locales/zh-TW/ai/options/project-structure/java.ai.yaml +113 -0
- package/bundled/locales/zh-TW/ai/options/project-structure/kotlin.ai.yaml +123 -0
- package/bundled/locales/zh-TW/ai/options/project-structure/nodejs.ai.yaml +101 -0
- package/bundled/locales/zh-TW/ai/options/project-structure/php.ai.yaml +147 -0
- package/bundled/locales/zh-TW/ai/options/project-structure/python.ai.yaml +116 -0
- package/bundled/locales/zh-TW/ai/options/project-structure/ruby.ai.yaml +140 -0
- package/bundled/locales/zh-TW/ai/options/project-structure/rust.ai.yaml +117 -0
- package/bundled/locales/zh-TW/ai/options/project-structure/swift.ai.yaml +143 -0
- package/bundled/locales/zh-TW/ai/options/testing/contract-testing.ai.yaml +254 -0
- package/bundled/locales/zh-TW/ai/options/testing/e2e-testing.ai.yaml +116 -0
- package/bundled/locales/zh-TW/ai/options/testing/industry-pyramid.ai.yaml +144 -0
- package/bundled/locales/zh-TW/ai/options/testing/integration-testing.ai.yaml +90 -0
- package/bundled/locales/zh-TW/ai/options/testing/istqb-framework.ai.yaml +108 -0
- package/bundled/locales/zh-TW/ai/options/testing/performance-testing.ai.yaml +272 -0
- package/bundled/locales/zh-TW/ai/options/testing/security-testing.ai.yaml +160 -0
- package/bundled/locales/zh-TW/ai/options/testing/system-testing.ai.yaml +101 -0
- package/bundled/locales/zh-TW/ai/options/testing/unit-testing.ai.yaml +82 -0
- package/bundled/locales/zh-TW/ai/standards/anti-hallucination.ai.yaml +145 -0
- package/bundled/locales/zh-TW/ai/standards/changelog.ai.yaml +146 -0
- package/bundled/locales/zh-TW/ai/standards/checkin-standards.ai.yaml +170 -0
- package/bundled/locales/zh-TW/ai/standards/code-review.ai.yaml +148 -0
- package/bundled/locales/zh-TW/ai/standards/commit-message.ai.yaml +175 -0
- package/bundled/locales/zh-TW/ai/standards/documentation-structure.ai.yaml +124 -0
- package/bundled/locales/zh-TW/ai/standards/documentation-writing-standards.ai.yaml +190 -0
- package/bundled/locales/zh-TW/ai/standards/error-codes.ai.yaml +139 -0
- package/bundled/locales/zh-TW/ai/standards/git-workflow.ai.yaml +95 -0
- package/bundled/locales/zh-TW/ai/standards/logging.ai.yaml +128 -0
- package/bundled/locales/zh-TW/ai/standards/project-structure.ai.yaml +134 -0
- package/bundled/locales/zh-TW/ai/standards/spec-driven-development.ai.yaml +169 -0
- package/bundled/locales/zh-TW/ai/standards/test-completeness-dimensions.ai.yaml +220 -0
- package/bundled/locales/zh-TW/ai/standards/testing.ai.yaml +137 -0
- package/bundled/locales/zh-TW/ai/standards/versioning.ai.yaml +211 -0
- package/bundled/locales/zh-TW/core/ai-instruction-standards.md +213 -0
- package/bundled/locales/zh-TW/core/anti-hallucination.md +691 -0
- package/bundled/locales/zh-TW/core/changelog-standards.md +564 -0
- package/bundled/locales/zh-TW/core/checkin-standards.md +943 -0
- package/bundled/locales/zh-TW/core/code-review-checklist.md +693 -0
- package/bundled/locales/zh-TW/core/commit-message-guide.md +809 -0
- package/bundled/locales/zh-TW/core/documentation-structure.md +1125 -0
- package/bundled/locales/zh-TW/core/documentation-writing-standards.md +495 -0
- package/bundled/locales/zh-TW/core/error-code-standards.md +384 -0
- package/bundled/locales/zh-TW/core/git-workflow.md +860 -0
- package/bundled/locales/zh-TW/core/logging-standards.md +325 -0
- package/bundled/locales/zh-TW/core/project-structure.md +362 -0
- package/bundled/locales/zh-TW/core/refactoring-standards.md +642 -0
- package/bundled/locales/zh-TW/core/spec-driven-development.md +215 -0
- package/bundled/locales/zh-TW/core/test-completeness-dimensions.md +544 -0
- package/bundled/locales/zh-TW/core/test-driven-development.md +1004 -0
- package/bundled/locales/zh-TW/core/testing-standards.md +2158 -0
- package/bundled/locales/zh-TW/core/versioning.md +909 -0
- package/bundled/locales/zh-TW/docs/AI-AGENT-ROADMAP.md +303 -0
- package/bundled/locales/zh-TW/docs/CLI-INIT-OPTIONS.md +990 -0
- package/bundled/locales/zh-TW/docs/OPERATION-WORKFLOW.md +1064 -0
- package/bundled/locales/zh-TW/docs/USAGE-MODES-COMPARISON.md +333 -0
- package/bundled/locales/zh-TW/docs/WINDOWS-GUIDE.md +215 -0
- package/bundled/locales/zh-TW/integrations/codex/AGENTS.md +115 -0
- package/bundled/locales/zh-TW/integrations/codex/README.md +113 -0
- package/bundled/locales/zh-TW/integrations/gemini-cli/GEMINI.md +102 -0
- package/bundled/locales/zh-TW/integrations/gemini-cli/README.md +140 -0
- package/bundled/locales/zh-TW/integrations/github-copilot/COPILOT-CHAT-REFERENCE.md +269 -0
- package/bundled/locales/zh-TW/integrations/github-copilot/README.md +167 -0
- package/bundled/locales/zh-TW/integrations/github-copilot/copilot-instructions.md +263 -0
- package/bundled/locales/zh-TW/integrations/github-copilot/skills-mapping.md +192 -0
- package/bundled/locales/zh-TW/integrations/google-antigravity/INSTRUCTIONS.md +61 -0
- package/bundled/locales/zh-TW/integrations/google-antigravity/README.md +84 -0
- package/bundled/locales/zh-TW/integrations/opencode/AGENTS.md +111 -0
- package/bundled/locales/zh-TW/integrations/opencode/README.md +176 -0
- package/bundled/locales/zh-TW/integrations/opencode/skills-mapping.md +396 -0
- package/bundled/locales/zh-TW/integrations/openspec/AGENTS.md +301 -0
- package/bundled/locales/zh-TW/integrations/openspec/README.md +43 -0
- package/bundled/locales/zh-TW/integrations/spec-kit/AGENTS.md +184 -0
- package/bundled/locales/zh-TW/integrations/spec-kit/README.md +43 -0
- package/bundled/locales/zh-TW/options/commit-message/bilingual.md +161 -0
- package/bundled/locales/zh-TW/options/commit-message/english.md +137 -0
- package/bundled/locales/zh-TW/options/commit-message/traditional-chinese.md +162 -0
- package/bundled/locales/zh-TW/options/git-workflow/gitflow.md +147 -0
- package/bundled/locales/zh-TW/options/git-workflow/github-flow.md +124 -0
- package/bundled/locales/zh-TW/options/git-workflow/merge-commit.md +124 -0
- package/bundled/locales/zh-TW/options/git-workflow/rebase-ff.md +160 -0
- package/bundled/locales/zh-TW/options/git-workflow/squash-merge.md +117 -0
- package/bundled/locales/zh-TW/options/git-workflow/trunk-based.md +125 -0
- package/bundled/locales/zh-TW/options/project-structure/dotnet.md +183 -0
- package/bundled/locales/zh-TW/options/project-structure/go.md +226 -0
- package/bundled/locales/zh-TW/options/project-structure/java.md +213 -0
- package/bundled/locales/zh-TW/options/project-structure/nodejs.md +185 -0
- package/bundled/locales/zh-TW/options/project-structure/python.md +229 -0
- package/bundled/locales/zh-TW/options/testing/e2e-testing.md +207 -0
- package/bundled/locales/zh-TW/options/testing/integration-testing.md +230 -0
- package/bundled/locales/zh-TW/options/testing/system-testing.md +183 -0
- package/bundled/locales/zh-TW/options/testing/unit-testing.md +165 -0
- package/bundled/locales/zh-TW/skills/INTEGRATION-GUIDE.md +218 -0
- package/bundled/locales/zh-TW/skills/README.md +132 -0
- package/bundled/locales/zh-TW/skills/_shared/README.md +68 -0
- package/bundled/locales/zh-TW/skills/claude-code/CONTRIBUTING.template.md +151 -0
- package/bundled/locales/zh-TW/skills/claude-code/README.md +174 -0
- package/bundled/locales/zh-TW/skills/claude-code/ai-collaboration-standards/SKILL.md +175 -0
- package/bundled/locales/zh-TW/skills/claude-code/ai-collaboration-standards/anti-hallucination.md +223 -0
- package/bundled/locales/zh-TW/skills/claude-code/ai-collaboration-standards/certainty-labels.md +132 -0
- package/bundled/locales/zh-TW/skills/claude-code/changelog-guide/SKILL.md +237 -0
- package/bundled/locales/zh-TW/skills/claude-code/checkin-assistant/SKILL.md +407 -0
- package/bundled/locales/zh-TW/skills/claude-code/code-review-assistant/SKILL.md +154 -0
- package/bundled/locales/zh-TW/skills/claude-code/code-review-assistant/checkin-checklist.md +257 -0
- package/bundled/locales/zh-TW/skills/claude-code/code-review-assistant/review-checklist.md +246 -0
- package/bundled/locales/zh-TW/skills/claude-code/commands/bdd.md +142 -0
- package/bundled/locales/zh-TW/skills/claude-code/commands/methodology.md +274 -0
- package/bundled/locales/zh-TW/skills/claude-code/commit-standards/SKILL.md +191 -0
- package/bundled/locales/zh-TW/skills/claude-code/commit-standards/conventional-commits.md +264 -0
- package/bundled/locales/zh-TW/skills/claude-code/commit-standards/language-options.md +172 -0
- package/bundled/locales/zh-TW/skills/claude-code/documentation-guide/SKILL.md +421 -0
- package/bundled/locales/zh-TW/skills/claude-code/documentation-guide/documentation-structure.md +357 -0
- package/bundled/locales/zh-TW/skills/claude-code/documentation-guide/readme-template.md +412 -0
- package/bundled/locales/zh-TW/skills/claude-code/error-code-guide/SKILL.md +269 -0
- package/bundled/locales/zh-TW/skills/claude-code/git-workflow-guide/SKILL.md +218 -0
- package/bundled/locales/zh-TW/skills/claude-code/git-workflow-guide/branch-naming.md +220 -0
- package/bundled/locales/zh-TW/skills/claude-code/git-workflow-guide/git-workflow.md +321 -0
- package/bundled/locales/zh-TW/skills/claude-code/logging-guide/SKILL.md +285 -0
- package/bundled/locales/zh-TW/skills/claude-code/methodology-system/SKILL.md +131 -0
- package/bundled/locales/zh-TW/skills/claude-code/methodology-system/create-methodology.md +350 -0
- package/bundled/locales/zh-TW/skills/claude-code/methodology-system/runtime.md +279 -0
- package/bundled/locales/zh-TW/skills/claude-code/project-structure-guide/SKILL.md +143 -0
- package/bundled/locales/zh-TW/skills/claude-code/project-structure-guide/language-patterns.md +271 -0
- package/bundled/locales/zh-TW/skills/claude-code/refactoring-assistant/SKILL.md +162 -0
- package/bundled/locales/zh-TW/skills/claude-code/release-standards/SKILL.md +191 -0
- package/bundled/locales/zh-TW/skills/claude-code/release-standards/changelog-format.md +247 -0
- package/bundled/locales/zh-TW/skills/claude-code/release-standards/release-workflow.md +345 -0
- package/bundled/locales/zh-TW/skills/claude-code/release-standards/semantic-versioning.md +250 -0
- package/bundled/locales/zh-TW/skills/claude-code/requirement-assistant/SKILL.md +227 -0
- package/bundled/locales/zh-TW/skills/claude-code/requirement-assistant/requirement-checklist.md +325 -0
- package/bundled/locales/zh-TW/skills/claude-code/requirement-assistant/requirement-writing.md +399 -0
- package/bundled/locales/zh-TW/skills/claude-code/spec-driven-dev/SKILL.md +243 -0
- package/bundled/locales/zh-TW/skills/claude-code/tdd-assistant/SKILL.md +332 -0
- package/bundled/locales/zh-TW/skills/claude-code/tdd-assistant/language-examples.md +639 -0
- package/bundled/locales/zh-TW/skills/claude-code/tdd-assistant/tdd-workflow.md +486 -0
- package/bundled/locales/zh-TW/skills/claude-code/test-coverage-assistant/SKILL.md +282 -0
- package/bundled/locales/zh-TW/skills/claude-code/testing-guide/SKILL.md +234 -0
- package/bundled/locales/zh-TW/skills/claude-code/testing-guide/testing-pyramid.md +448 -0
- package/bundled/locales/zh-TW/skills/cline/README.md +58 -0
- package/bundled/locales/zh-TW/skills/copilot/README.md +61 -0
- package/bundled/locales/zh-TW/skills/copilot/copilot-instructions.md +79 -0
- package/bundled/locales/zh-TW/skills/cursor/README.md +58 -0
- package/bundled/locales/zh-TW/skills/windsurf/README.md +59 -0
- package/bundled/skills/claude-code/CONTRIBUTING.template.md +141 -0
- package/bundled/skills/claude-code/README.md +196 -0
- package/bundled/skills/claude-code/ai/standards/checkin.ai.yaml +21 -0
- package/bundled/skills/claude-code/ai/standards/commit.ai.yaml +20 -0
- package/bundled/skills/claude-code/ai/standards/refactoring.ai.yaml +34 -0
- package/bundled/skills/claude-code/ai/standards/testing.ai.yaml +41 -0
- package/bundled/skills/claude-code/ai-collaboration-standards/SKILL.md +175 -0
- package/bundled/skills/claude-code/ai-collaboration-standards/anti-hallucination.md +215 -0
- package/bundled/skills/claude-code/ai-collaboration-standards/certainty-labels.md +124 -0
- package/bundled/skills/claude-code/changelog-guide/SKILL.md +232 -0
- package/bundled/skills/claude-code/checkin-assistant/SKILL.md +402 -0
- package/bundled/skills/claude-code/code-review-assistant/SKILL.md +220 -0
- package/bundled/skills/claude-code/code-review-assistant/checkin-checklist.md +249 -0
- package/bundled/skills/claude-code/code-review-assistant/review-checklist.md +238 -0
- package/bundled/skills/claude-code/commands/README.md +78 -0
- package/bundled/skills/claude-code/commands/bdd.md +142 -0
- package/bundled/skills/claude-code/commands/changelog.md +57 -0
- package/bundled/skills/claude-code/commands/check.md +91 -0
- package/bundled/skills/claude-code/commands/commit.md +48 -0
- package/bundled/skills/claude-code/commands/config.md +97 -0
- package/bundled/skills/claude-code/commands/coverage.md +58 -0
- package/bundled/skills/claude-code/commands/docs.md +75 -0
- package/bundled/skills/claude-code/commands/init.md +88 -0
- package/bundled/skills/claude-code/commands/methodology.md +268 -0
- package/bundled/skills/claude-code/commands/release.md +50 -0
- package/bundled/skills/claude-code/commands/requirement.md +54 -0
- package/bundled/skills/claude-code/commands/review.md +50 -0
- package/bundled/skills/claude-code/commands/spec.md +69 -0
- package/bundled/skills/claude-code/commands/tdd.md +86 -0
- package/bundled/skills/claude-code/commands/update.md +122 -0
- package/bundled/skills/claude-code/commit-standards/SKILL.md +249 -0
- package/bundled/skills/claude-code/commit-standards/conventional-commits.md +256 -0
- package/bundled/skills/claude-code/commit-standards/language-options.md +164 -0
- package/bundled/skills/claude-code/documentation-guide/SKILL.md +416 -0
- package/bundled/skills/claude-code/documentation-guide/documentation-structure.md +349 -0
- package/bundled/skills/claude-code/documentation-guide/readme-template.md +404 -0
- package/bundled/skills/claude-code/error-code-guide/SKILL.md +264 -0
- package/bundled/skills/claude-code/git-workflow-guide/SKILL.md +226 -0
- package/bundled/skills/claude-code/git-workflow-guide/branch-naming.md +212 -0
- package/bundled/skills/claude-code/git-workflow-guide/git-workflow.md +313 -0
- package/bundled/skills/claude-code/logging-guide/SKILL.md +280 -0
- package/bundled/skills/claude-code/methodology-system/SKILL.md +215 -0
- package/bundled/skills/claude-code/methodology-system/create-methodology.md +450 -0
- package/bundled/skills/claude-code/methodology-system/runtime.md +271 -0
- package/bundled/skills/claude-code/project-structure-guide/SKILL.md +143 -0
- package/bundled/skills/claude-code/project-structure-guide/language-patterns.md +263 -0
- package/bundled/skills/claude-code/refactoring-assistant/SKILL.md +205 -0
- package/bundled/skills/claude-code/release-standards/SKILL.md +191 -0
- package/bundled/skills/claude-code/release-standards/changelog-format.md +239 -0
- package/bundled/skills/claude-code/release-standards/release-workflow.md +337 -0
- package/bundled/skills/claude-code/release-standards/semantic-versioning.md +242 -0
- package/bundled/skills/claude-code/requirement-assistant/SKILL.md +222 -0
- package/bundled/skills/claude-code/requirement-assistant/requirement-checklist.md +317 -0
- package/bundled/skills/claude-code/requirement-assistant/requirement-writing.md +391 -0
- package/bundled/skills/claude-code/spec-driven-dev/SKILL.md +238 -0
- package/bundled/skills/claude-code/tdd-assistant/SKILL.md +384 -0
- package/bundled/skills/claude-code/tdd-assistant/language-examples.md +1276 -0
- package/bundled/skills/claude-code/tdd-assistant/tdd-workflow.md +659 -0
- package/bundled/skills/claude-code/test-coverage-assistant/SKILL.md +277 -0
- package/bundled/skills/claude-code/testing-guide/SKILL.md +317 -0
- package/bundled/skills/claude-code/testing-guide/testing-pyramid.md +440 -0
- package/package.json +4 -2
- package/src/commands/check.js +38 -6
- package/src/commands/init.js +20 -6
- package/src/commands/list.js +7 -2
- package/src/commands/skills.js +0 -2
- package/src/commands/update.js +271 -0
- package/src/i18n/messages.js +161 -11
- package/src/utils/copier.js +63 -10
- package/src/utils/skills-installer.js +47 -11
- package/standards-registry.json +6 -3
|
@@ -0,0 +1,117 @@
|
|
|
1
|
+
---
|
|
2
|
+
source: ../../../../options/git-workflow/squash-merge.md
|
|
3
|
+
source_version: 1.0.0
|
|
4
|
+
translation_version: 1.0.0
|
|
5
|
+
last_synced: 2025-12-30
|
|
6
|
+
status: current
|
|
7
|
+
---
|
|
8
|
+
|
|
9
|
+
# Squash Merge 合并策略
|
|
10
|
+
|
|
11
|
+
> **语言**: [English](../../../../options/git-workflow/squash-merge.md) | 繁体中文
|
|
12
|
+
|
|
13
|
+
**上层标准**: [Git 工作流程](../../core/git-workflow.md)
|
|
14
|
+
|
|
15
|
+
---
|
|
16
|
+
|
|
17
|
+
## 概述
|
|
18
|
+
|
|
19
|
+
Squash merge 在合并时将功能分支的所有 commit 压缩成单一 commit。这在主分支上建立干净、线性的历史,每个合并代表一个完整的功能或变更。
|
|
20
|
+
|
|
21
|
+
## 适用情境
|
|
22
|
+
|
|
23
|
+
- 重视主分支历史整洁的团队
|
|
24
|
+
- 开发过程中有许多小型 commit 的专案
|
|
25
|
+
- 程式码审查流程中最终结果比过程重要
|
|
26
|
+
- 接受外部贡献的开源专案
|
|
27
|
+
|
|
28
|
+
## 运作方式
|
|
29
|
+
|
|
30
|
+
```
|
|
31
|
+
功能分支: 合并后的 main 分支:
|
|
32
|
+
A---B---C---D X---Y---Z(单一压缩 commit)
|
|
33
|
+
\ |
|
|
34
|
+
E---F---G---H → S(包含 E+F+G+H)
|
|
35
|
+
(功能 commits)
|
|
36
|
+
```
|
|
37
|
+
|
|
38
|
+
## 工作流程
|
|
39
|
+
|
|
40
|
+
### 透过 CLI 进行 Squash Merge
|
|
41
|
+
|
|
42
|
+
```bash
|
|
43
|
+
# 切到 main 分支
|
|
44
|
+
git checkout main
|
|
45
|
+
git pull origin main
|
|
46
|
+
|
|
47
|
+
# Squash merge
|
|
48
|
+
git merge --squash feature/user-profile
|
|
49
|
+
|
|
50
|
+
# 建立有意义的单一 commit
|
|
51
|
+
git commit -m "feat(users): add user profile with avatar upload
|
|
52
|
+
|
|
53
|
+
- Add profile page component
|
|
54
|
+
- Implement avatar upload functionality
|
|
55
|
+
- Add comprehensive test coverage
|
|
56
|
+
|
|
57
|
+
Closes #123"
|
|
58
|
+
|
|
59
|
+
# 推送并清理
|
|
60
|
+
git push origin main
|
|
61
|
+
git branch -d feature/user-profile
|
|
62
|
+
git push origin --delete feature/user-profile
|
|
63
|
+
```
|
|
64
|
+
|
|
65
|
+
### 透过 GitHub 进行
|
|
66
|
+
|
|
67
|
+
1. 开启 Pull Request
|
|
68
|
+
2. 点击「Squash and merge」按钮
|
|
69
|
+
3. 编辑 commit 讯息使其有意义
|
|
70
|
+
4. 确认合并
|
|
71
|
+
5. 删除功能分支
|
|
72
|
+
|
|
73
|
+
## Commit 讯息最佳实践
|
|
74
|
+
|
|
75
|
+
进行 squash merge 时,撰写完整的 commit 讯息:
|
|
76
|
+
|
|
77
|
+
```
|
|
78
|
+
feat(scope): 简洁描述
|
|
79
|
+
|
|
80
|
+
- 主要变更 1
|
|
81
|
+
- 主要变更 2
|
|
82
|
+
- 主要变更 3
|
|
83
|
+
|
|
84
|
+
Closes #issue-number
|
|
85
|
+
Co-authored-by: Name <email@example.com>
|
|
86
|
+
```
|
|
87
|
+
|
|
88
|
+
## 优点
|
|
89
|
+
|
|
90
|
+
| 优点 | 说明 |
|
|
91
|
+
|------|------|
|
|
92
|
+
| 干净的历史 | 主分支每个功能一个 commit |
|
|
93
|
+
| 容易还原 | 单一 commit 还原整个功能 |
|
|
94
|
+
| 简化 bisect | 较少 commit 需要搜寻 |
|
|
95
|
+
| 自由提交 | 开发者可频繁提交不会杂乱 |
|
|
96
|
+
|
|
97
|
+
## 缺点
|
|
98
|
+
|
|
99
|
+
| 缺点 | 说明 |
|
|
100
|
+
|------|------|
|
|
101
|
+
| 失去细节 | 个别 commit 历史遗失 |
|
|
102
|
+
| 难以追踪 | 无法追溯特定行到原始 commit |
|
|
103
|
+
| 大型 diff | 单一 commit 可能有大量变更 |
|
|
104
|
+
| 失去脉络 | 开发过程不被保留 |
|
|
105
|
+
|
|
106
|
+
## 相关选项
|
|
107
|
+
|
|
108
|
+
- [Merge Commit](./merge-commit.md) - 保留所有 commit 历史
|
|
109
|
+
- [Rebase and Fast-Forward](./rebase-ff.md) - 线性历史保留所有 commit
|
|
110
|
+
|
|
111
|
+
---
|
|
112
|
+
|
|
113
|
+
## 授权条款
|
|
114
|
+
|
|
115
|
+
本文件采用 [CC BY 4.0](https://creativecommons.org/licenses/by/4.0/) 授权条款。
|
|
116
|
+
|
|
117
|
+
**来源**:[universal-dev-standards](https://github.com/AsiaOstrich/universal-dev-standards)
|
|
@@ -0,0 +1,125 @@
|
|
|
1
|
+
---
|
|
2
|
+
source: ../../../../options/git-workflow/trunk-based.md
|
|
3
|
+
source_version: 1.0.0
|
|
4
|
+
translation_version: 1.0.0
|
|
5
|
+
last_synced: 2025-12-30
|
|
6
|
+
status: current
|
|
7
|
+
---
|
|
8
|
+
|
|
9
|
+
# Trunk-Based 开发
|
|
10
|
+
|
|
11
|
+
> **语言**: [English](../../../../options/git-workflow/trunk-based.md) | 繁体中文
|
|
12
|
+
|
|
13
|
+
**上层标准**: [Git 工作流程](../../core/git-workflow.md)
|
|
14
|
+
|
|
15
|
+
---
|
|
16
|
+
|
|
17
|
+
## 概述
|
|
18
|
+
|
|
19
|
+
Trunk-Based 开发是一种版本控制管理实践,所有开发者在单一分支(称为「trunk」或「main」)上进行小型、频繁的更新。它最大化持续整合,减少合并问题。
|
|
20
|
+
|
|
21
|
+
## 适用情境
|
|
22
|
+
|
|
23
|
+
- 经验丰富的团队
|
|
24
|
+
- 强大的 CI/CD 基础设施
|
|
25
|
+
- 需要快速发布周期
|
|
26
|
+
- 高度自动化测试环境
|
|
27
|
+
|
|
28
|
+
## 核心原则
|
|
29
|
+
|
|
30
|
+
| 原则 | 说明 |
|
|
31
|
+
|------|------|
|
|
32
|
+
| 单一主分支 | 所有开发在 main/trunk 进行 |
|
|
33
|
+
| 小型提交 | 频繁提交小变更 |
|
|
34
|
+
| 功能标志 | 使用 feature flags 控制功能 |
|
|
35
|
+
| 持续整合 | 频繁合并到主分支 |
|
|
36
|
+
|
|
37
|
+
## 工作流程
|
|
38
|
+
|
|
39
|
+
### 直接在 trunk 工作
|
|
40
|
+
|
|
41
|
+
```bash
|
|
42
|
+
# 更新本地 main
|
|
43
|
+
git checkout main
|
|
44
|
+
git pull origin main
|
|
45
|
+
|
|
46
|
+
# 进行小型变更
|
|
47
|
+
git add .
|
|
48
|
+
git commit -m "feat: add user avatar display"
|
|
49
|
+
git push origin main
|
|
50
|
+
```
|
|
51
|
+
|
|
52
|
+
### 短期功能分支(可选)
|
|
53
|
+
|
|
54
|
+
```bash
|
|
55
|
+
# 建立短期分支(最长 1-2 天)
|
|
56
|
+
git checkout -b feat/quick-change
|
|
57
|
+
# 进行变更
|
|
58
|
+
git checkout main
|
|
59
|
+
git merge feat/quick-change
|
|
60
|
+
git push origin main
|
|
61
|
+
git branch -d feat/quick-change
|
|
62
|
+
```
|
|
63
|
+
|
|
64
|
+
## 功能标志
|
|
65
|
+
|
|
66
|
+
使用功能标志在生产环境控制未完成功能:
|
|
67
|
+
|
|
68
|
+
```javascript
|
|
69
|
+
// 功能标志范例
|
|
70
|
+
if (featureFlags.isEnabled('new-checkout-flow')) {
|
|
71
|
+
return <NewCheckoutFlow />;
|
|
72
|
+
} else {
|
|
73
|
+
return <LegacyCheckoutFlow />;
|
|
74
|
+
}
|
|
75
|
+
```
|
|
76
|
+
|
|
77
|
+
### 功能标志类型
|
|
78
|
+
|
|
79
|
+
| 类型 | 用途 | 生命周期 |
|
|
80
|
+
|------|------|----------|
|
|
81
|
+
| 发布标志 | 隐藏未完成功能 | 短期 |
|
|
82
|
+
| 实验标志 | A/B 测试 | 中期 |
|
|
83
|
+
| 权限标志 | 功能存取控制 | 长期 |
|
|
84
|
+
| 营运标志 | 系统行为控制 | 长期 |
|
|
85
|
+
|
|
86
|
+
## 前提条件
|
|
87
|
+
|
|
88
|
+
使用 Trunk-Based 开发需要:
|
|
89
|
+
|
|
90
|
+
1. **全面的自动化测试**
|
|
91
|
+
2. **快速的 CI/CD 管线**
|
|
92
|
+
3. **程式码审查文化**
|
|
93
|
+
4. **功能标志系统**
|
|
94
|
+
5. **即时监控能力**
|
|
95
|
+
|
|
96
|
+
## 优点
|
|
97
|
+
|
|
98
|
+
| 优点 | 说明 |
|
|
99
|
+
|------|------|
|
|
100
|
+
| 最少合并冲突 | 频繁整合减少冲突 |
|
|
101
|
+
| 持续整合 | 真正的 CI 实践 |
|
|
102
|
+
| 快速反馈 | 问题快速浮现 |
|
|
103
|
+
| 简化分支管理 | 无复杂分支策略 |
|
|
104
|
+
|
|
105
|
+
## 缺点
|
|
106
|
+
|
|
107
|
+
| 缺点 | 说明 |
|
|
108
|
+
|------|------|
|
|
109
|
+
| 需要高度纪律 | 团队必须遵守规则 |
|
|
110
|
+
| 需要强大的 CI | 测试和建置必须快速 |
|
|
111
|
+
| 功能标志复杂性 | 需要管理标志生命周期 |
|
|
112
|
+
| 不适合新手团队 | 需要经验和信任 |
|
|
113
|
+
|
|
114
|
+
## 相关选项
|
|
115
|
+
|
|
116
|
+
- [GitHub Flow](./github-flow.md) - 带有 PR 的简化流程
|
|
117
|
+
- [GitFlow](./gitflow.md) - 适合有排程发布的专案
|
|
118
|
+
|
|
119
|
+
---
|
|
120
|
+
|
|
121
|
+
## 授权条款
|
|
122
|
+
|
|
123
|
+
本文件采用 [CC BY 4.0](https://creativecommons.org/licenses/by/4.0/) 授权条款。
|
|
124
|
+
|
|
125
|
+
**来源**:[universal-dev-standards](https://github.com/AsiaOstrich/universal-dev-standards)
|
|
@@ -0,0 +1,183 @@
|
|
|
1
|
+
---
|
|
2
|
+
source: ../../../../options/project-structure/dotnet.md
|
|
3
|
+
source_version: 1.0.0
|
|
4
|
+
translation_version: 1.0.0
|
|
5
|
+
last_synced: 2025-12-30
|
|
6
|
+
status: current
|
|
7
|
+
---
|
|
8
|
+
|
|
9
|
+
# .NET 专案结构
|
|
10
|
+
|
|
11
|
+
> **语言**: [English](../../../../options/project-structure/dotnet.md) | 繁体中文
|
|
12
|
+
|
|
13
|
+
**上层标准**: [专案结构](../../core/project-structure.md)
|
|
14
|
+
|
|
15
|
+
---
|
|
16
|
+
|
|
17
|
+
## 概述
|
|
18
|
+
|
|
19
|
+
本文件定义遵循 Clean Architecture 原则的 .NET/C# 专案标准目录结构。它促进关注点分离,相依性指向核心领域。
|
|
20
|
+
|
|
21
|
+
## 适用情境
|
|
22
|
+
|
|
23
|
+
- ASP.NET Core Web API
|
|
24
|
+
- 企业级应用程式
|
|
25
|
+
- 微服务
|
|
26
|
+
- 领域驱动设计专案
|
|
27
|
+
- 大型应用程式
|
|
28
|
+
|
|
29
|
+
## 目录结构
|
|
30
|
+
|
|
31
|
+
```
|
|
32
|
+
SolutionName/
|
|
33
|
+
├── src/
|
|
34
|
+
│ ├── SolutionName.Api/ # Web API 专案
|
|
35
|
+
│ │ ├── Controllers/
|
|
36
|
+
│ │ ├── Middleware/
|
|
37
|
+
│ │ ├── Filters/
|
|
38
|
+
│ │ ├── Program.cs
|
|
39
|
+
│ │ └── appsettings.json
|
|
40
|
+
│ ├── SolutionName.Core/ # 核心业务逻辑
|
|
41
|
+
│ │ ├── Entities/
|
|
42
|
+
│ │ ├── Interfaces/
|
|
43
|
+
│ │ ├── Services/
|
|
44
|
+
│ │ └── Exceptions/
|
|
45
|
+
│ ├── SolutionName.Infrastructure/ # 外部服务实作
|
|
46
|
+
│ │ ├── Data/
|
|
47
|
+
│ │ │ ├── ApplicationDbContext.cs
|
|
48
|
+
│ │ │ └── Migrations/
|
|
49
|
+
│ │ ├── Repositories/
|
|
50
|
+
│ │ └── ExternalServices/
|
|
51
|
+
│ └── SolutionName.Shared/ # 共用程式码
|
|
52
|
+
│ ├── DTOs/
|
|
53
|
+
│ ├── Extensions/
|
|
54
|
+
│ └── Utils/
|
|
55
|
+
├── tests/
|
|
56
|
+
│ ├── SolutionName.UnitTests/
|
|
57
|
+
│ ├── SolutionName.IntegrationTests/
|
|
58
|
+
│ └── SolutionName.FunctionalTests/
|
|
59
|
+
├── docs/
|
|
60
|
+
├── SolutionName.sln
|
|
61
|
+
└── README.md
|
|
62
|
+
```
|
|
63
|
+
|
|
64
|
+
## Clean Architecture 层次
|
|
65
|
+
|
|
66
|
+
```
|
|
67
|
+
┌─────────────────────────────────────────┐
|
|
68
|
+
│ API 层 │
|
|
69
|
+
│ Controllers, Middleware, Filters │
|
|
70
|
+
├─────────────────────────────────────────┤
|
|
71
|
+
│ Infrastructure 层 │
|
|
72
|
+
│ DbContext, Repositories, External APIs │
|
|
73
|
+
├─────────────────────────────────────────┤
|
|
74
|
+
│ Core 层 │
|
|
75
|
+
│ Entities, Services, Interfaces │
|
|
76
|
+
└─────────────────────────────────────────┘
|
|
77
|
+
相依性指向内部 ↓
|
|
78
|
+
```
|
|
79
|
+
|
|
80
|
+
## 命名惯例
|
|
81
|
+
|
|
82
|
+
| 类型 | 惯例 | 范例 |
|
|
83
|
+
|------|------|------|
|
|
84
|
+
| 档案 | PascalCase.cs | `UserService.cs` |
|
|
85
|
+
| 目录 | PascalCase | `Controllers/` |
|
|
86
|
+
| 类别 | PascalCase | `UserService` |
|
|
87
|
+
| 介面 | IPascalCase | `IUserService` |
|
|
88
|
+
| 方法 | PascalCase | `CreateUser()` |
|
|
89
|
+
| 私有栏位 | _camelCase | `_userRepository` |
|
|
90
|
+
|
|
91
|
+
## 层次结构
|
|
92
|
+
|
|
93
|
+
### Core 层(领域)
|
|
94
|
+
|
|
95
|
+
```csharp
|
|
96
|
+
// src/SolutionName.Core/Entities/User.cs
|
|
97
|
+
namespace SolutionName.Core.Entities;
|
|
98
|
+
|
|
99
|
+
public class User
|
|
100
|
+
{
|
|
101
|
+
public Guid Id { get; private set; }
|
|
102
|
+
public string Email { get; private set; } = string.Empty;
|
|
103
|
+
public string Name { get; private set; } = string.Empty;
|
|
104
|
+
|
|
105
|
+
public static User Create(string email, string name)
|
|
106
|
+
{
|
|
107
|
+
return new User
|
|
108
|
+
{
|
|
109
|
+
Id = Guid.NewGuid(),
|
|
110
|
+
Email = email,
|
|
111
|
+
Name = name
|
|
112
|
+
};
|
|
113
|
+
}
|
|
114
|
+
}
|
|
115
|
+
```
|
|
116
|
+
|
|
117
|
+
```csharp
|
|
118
|
+
// src/SolutionName.Core/Interfaces/IUserRepository.cs
|
|
119
|
+
public interface IUserRepository
|
|
120
|
+
{
|
|
121
|
+
Task<User?> GetByIdAsync(Guid id, CancellationToken ct = default);
|
|
122
|
+
Task<User> AddAsync(User user, CancellationToken ct = default);
|
|
123
|
+
}
|
|
124
|
+
```
|
|
125
|
+
|
|
126
|
+
### API 层
|
|
127
|
+
|
|
128
|
+
```csharp
|
|
129
|
+
// src/SolutionName.Api/Controllers/UsersController.cs
|
|
130
|
+
[ApiController]
|
|
131
|
+
[Route("api/[controller]")]
|
|
132
|
+
public class UsersController : ControllerBase
|
|
133
|
+
{
|
|
134
|
+
private readonly IUserService _userService;
|
|
135
|
+
|
|
136
|
+
public UsersController(IUserService userService)
|
|
137
|
+
{
|
|
138
|
+
_userService = userService;
|
|
139
|
+
}
|
|
140
|
+
|
|
141
|
+
[HttpPost]
|
|
142
|
+
[ProducesResponseType(typeof(UserDto), StatusCodes.Status201Created)]
|
|
143
|
+
public async Task<IActionResult> CreateUser(
|
|
144
|
+
[FromBody] CreateUserRequest request,
|
|
145
|
+
CancellationToken ct)
|
|
146
|
+
{
|
|
147
|
+
var user = await _userService.CreateUserAsync(request, ct);
|
|
148
|
+
return CreatedAtAction(nameof(GetUser), new { id = user.Id }, user.ToDto());
|
|
149
|
+
}
|
|
150
|
+
}
|
|
151
|
+
```
|
|
152
|
+
|
|
153
|
+
## 专案参考
|
|
154
|
+
|
|
155
|
+
| 专案 | 可参考 |
|
|
156
|
+
|------|--------|
|
|
157
|
+
| Api | Infrastructure, Core, Shared |
|
|
158
|
+
| Infrastructure | Core, Shared |
|
|
159
|
+
| Core | 仅 Shared(无外部相依)|
|
|
160
|
+
| Shared | 无 |
|
|
161
|
+
|
|
162
|
+
## 最佳实践
|
|
163
|
+
|
|
164
|
+
1. **相依性指向内部** - Core 无外部相依
|
|
165
|
+
2. **使用介面** - 在 Core 定义,在 Infrastructure 实作
|
|
166
|
+
3. **建构子注入** - 永远使用 DI
|
|
167
|
+
4. **可为空参考类型** - 启用并强制执行
|
|
168
|
+
5. **全程非同步** - 使用 CancellationToken
|
|
169
|
+
|
|
170
|
+
## 相关选项
|
|
171
|
+
|
|
172
|
+
- [Node.js](./nodejs.md) - Node.js 专案结构
|
|
173
|
+
- [Python](./python.md) - Python 专案结构
|
|
174
|
+
- [Java](./java.md) - Java/Spring 专案结构
|
|
175
|
+
- [Go](./go.md) - Go 专案结构
|
|
176
|
+
|
|
177
|
+
---
|
|
178
|
+
|
|
179
|
+
## 授权条款
|
|
180
|
+
|
|
181
|
+
本文件采用 [CC BY 4.0](https://creativecommons.org/licenses/by/4.0/) 授权条款。
|
|
182
|
+
|
|
183
|
+
**来源**:[universal-dev-standards](https://github.com/AsiaOstrich/universal-dev-standards)
|
|
@@ -0,0 +1,226 @@
|
|
|
1
|
+
---
|
|
2
|
+
source: ../../../../options/project-structure/go.md
|
|
3
|
+
source_version: 1.0.0
|
|
4
|
+
translation_version: 1.0.0
|
|
5
|
+
last_synced: 2025-12-30
|
|
6
|
+
status: current
|
|
7
|
+
---
|
|
8
|
+
|
|
9
|
+
# Go 专案结构
|
|
10
|
+
|
|
11
|
+
> **语言**: [English](../../../../options/project-structure/go.md) | 繁体中文
|
|
12
|
+
|
|
13
|
+
**上层标准**: [专案结构](../../core/project-structure.md)
|
|
14
|
+
|
|
15
|
+
---
|
|
16
|
+
|
|
17
|
+
## 概述
|
|
18
|
+
|
|
19
|
+
本文件定义遵循社群最佳实践的 Go 专案标准目录结构。它在简单性和可扩展性之间取得平衡,适用于小型服务和大型应用程式。
|
|
20
|
+
|
|
21
|
+
## 适用情境
|
|
22
|
+
|
|
23
|
+
- HTTP 服务和 API
|
|
24
|
+
- CLI 应用程式
|
|
25
|
+
- 微服务
|
|
26
|
+
- 系统工具
|
|
27
|
+
- 函式库和套件
|
|
28
|
+
|
|
29
|
+
## 目录结构
|
|
30
|
+
|
|
31
|
+
```
|
|
32
|
+
project-root/
|
|
33
|
+
├── cmd/ # 应用程式进入点
|
|
34
|
+
│ ├── api/
|
|
35
|
+
│ │ └── main.go
|
|
36
|
+
│ └── cli/
|
|
37
|
+
│ └── main.go
|
|
38
|
+
├── internal/ # 私有应用程式码
|
|
39
|
+
│ ├── config/
|
|
40
|
+
│ │ └── config.go
|
|
41
|
+
│ ├── domain/ # 业务逻辑
|
|
42
|
+
│ │ ├── user/
|
|
43
|
+
│ │ │ ├── user.go
|
|
44
|
+
│ │ │ ├── service.go
|
|
45
|
+
│ │ │ ├── repository.go
|
|
46
|
+
│ │ │ └── service_test.go
|
|
47
|
+
│ │ └── product/
|
|
48
|
+
│ ├── handler/ # HTTP 处理器
|
|
49
|
+
│ │ ├── user_handler.go
|
|
50
|
+
│ │ └── middleware/
|
|
51
|
+
│ ├── repository/ # 资料存取实作
|
|
52
|
+
│ │ ├── postgres/
|
|
53
|
+
│ │ └── redis/
|
|
54
|
+
│ └── server/
|
|
55
|
+
│ └── server.go
|
|
56
|
+
├── pkg/ # 公开可重用套件
|
|
57
|
+
│ └── validator/
|
|
58
|
+
│ └── validator.go
|
|
59
|
+
├── api/ # API 规格
|
|
60
|
+
│ └── openapi.yaml
|
|
61
|
+
├── scripts/ # 建置/部署脚本
|
|
62
|
+
├── docs/ # 文件
|
|
63
|
+
├── go.mod
|
|
64
|
+
├── go.sum
|
|
65
|
+
├── Makefile
|
|
66
|
+
└── README.md
|
|
67
|
+
```
|
|
68
|
+
|
|
69
|
+
## 命名惯例
|
|
70
|
+
|
|
71
|
+
| 类型 | 惯例 | 范例 |
|
|
72
|
+
|------|------|------|
|
|
73
|
+
| 档案 | snake_case.go | `user_service.go` |
|
|
74
|
+
| 套件 | lowercase | `user`, `httphandler` |
|
|
75
|
+
| 汇出 | PascalCase | `UserService`, `CreateUser` |
|
|
76
|
+
| 未汇出 | camelCase | `userRepository`, `validateEmail` |
|
|
77
|
+
| 常数 | PascalCase 或 ALL_CAPS | `MaxRetries`, `DB_TIMEOUT` |
|
|
78
|
+
| 介面 | PascalCase + "er" 后缀 | `Reader`, `UserRepository` |
|
|
79
|
+
|
|
80
|
+
## 关键目录
|
|
81
|
+
|
|
82
|
+
### cmd/
|
|
83
|
+
|
|
84
|
+
应用程式进入点。每个子目录是一个独立的二进位档案:
|
|
85
|
+
|
|
86
|
+
```go
|
|
87
|
+
// cmd/api/main.go
|
|
88
|
+
package main
|
|
89
|
+
|
|
90
|
+
import (
|
|
91
|
+
"log"
|
|
92
|
+
"myproject/internal/config"
|
|
93
|
+
"myproject/internal/server"
|
|
94
|
+
)
|
|
95
|
+
|
|
96
|
+
func main() {
|
|
97
|
+
cfg, err := config.Load()
|
|
98
|
+
if err != nil {
|
|
99
|
+
log.Fatal(err)
|
|
100
|
+
}
|
|
101
|
+
|
|
102
|
+
srv := server.New(cfg)
|
|
103
|
+
if err := srv.Run(); err != nil {
|
|
104
|
+
log.Fatal(err)
|
|
105
|
+
}
|
|
106
|
+
}
|
|
107
|
+
```
|
|
108
|
+
|
|
109
|
+
### internal/
|
|
110
|
+
|
|
111
|
+
无法被其他专案汇入的私有程式码。
|
|
112
|
+
|
|
113
|
+
### pkg/
|
|
114
|
+
|
|
115
|
+
可被其他专案汇入的公开套件。
|
|
116
|
+
|
|
117
|
+
## 领域层
|
|
118
|
+
|
|
119
|
+
### 实体
|
|
120
|
+
|
|
121
|
+
```go
|
|
122
|
+
// internal/domain/user/user.go
|
|
123
|
+
package user
|
|
124
|
+
|
|
125
|
+
import (
|
|
126
|
+
"errors"
|
|
127
|
+
"time"
|
|
128
|
+
)
|
|
129
|
+
|
|
130
|
+
var (
|
|
131
|
+
ErrInvalidEmail = errors.New("invalid email format")
|
|
132
|
+
ErrUserNotFound = errors.New("user not found")
|
|
133
|
+
ErrEmailExists = errors.New("email already exists")
|
|
134
|
+
)
|
|
135
|
+
|
|
136
|
+
type User struct {
|
|
137
|
+
ID string
|
|
138
|
+
Email string
|
|
139
|
+
Name string
|
|
140
|
+
CreatedAt time.Time
|
|
141
|
+
}
|
|
142
|
+
|
|
143
|
+
func NewUser(email, name string) (*User, error) {
|
|
144
|
+
if !isValidEmail(email) {
|
|
145
|
+
return nil, ErrInvalidEmail
|
|
146
|
+
}
|
|
147
|
+
return &User{
|
|
148
|
+
Email: email,
|
|
149
|
+
Name: name,
|
|
150
|
+
CreatedAt: time.Now(),
|
|
151
|
+
}, nil
|
|
152
|
+
}
|
|
153
|
+
```
|
|
154
|
+
|
|
155
|
+
### Repository 介面
|
|
156
|
+
|
|
157
|
+
```go
|
|
158
|
+
// internal/domain/user/repository.go
|
|
159
|
+
package user
|
|
160
|
+
|
|
161
|
+
import "context"
|
|
162
|
+
|
|
163
|
+
type Repository interface {
|
|
164
|
+
Create(ctx context.Context, user *User) error
|
|
165
|
+
GetByID(ctx context.Context, id string) (*User, error)
|
|
166
|
+
GetByEmail(ctx context.Context, email string) (*User, error)
|
|
167
|
+
}
|
|
168
|
+
```
|
|
169
|
+
|
|
170
|
+
### 服务
|
|
171
|
+
|
|
172
|
+
```go
|
|
173
|
+
// internal/domain/user/service.go
|
|
174
|
+
package user
|
|
175
|
+
|
|
176
|
+
import "context"
|
|
177
|
+
|
|
178
|
+
type Service struct {
|
|
179
|
+
repo Repository
|
|
180
|
+
}
|
|
181
|
+
|
|
182
|
+
func NewService(repo Repository) *Service {
|
|
183
|
+
return &Service{repo: repo}
|
|
184
|
+
}
|
|
185
|
+
|
|
186
|
+
func (s *Service) CreateUser(ctx context.Context, input CreateUserInput) (*User, error) {
|
|
187
|
+
existing, _ := s.repo.GetByEmail(ctx, input.Email)
|
|
188
|
+
if existing != nil {
|
|
189
|
+
return nil, ErrEmailExists
|
|
190
|
+
}
|
|
191
|
+
|
|
192
|
+
user, err := NewUser(input.Email, input.Name)
|
|
193
|
+
if err != nil {
|
|
194
|
+
return nil, err
|
|
195
|
+
}
|
|
196
|
+
|
|
197
|
+
if err := s.repo.Create(ctx, user); err != nil {
|
|
198
|
+
return nil, err
|
|
199
|
+
}
|
|
200
|
+
return user, nil
|
|
201
|
+
}
|
|
202
|
+
```
|
|
203
|
+
|
|
204
|
+
## 最佳实践
|
|
205
|
+
|
|
206
|
+
1. **接受介面,回传结构**
|
|
207
|
+
2. **保持 `main.go` 最小化** - 连接相依性,呼叫 `Run()`
|
|
208
|
+
3. **使用 `internal/` 存放私有程式码**
|
|
209
|
+
4. **在使用处定义介面** - 而非实作处
|
|
210
|
+
5. **错误包装** - 使用 `fmt.Errorf("context: %w", err)`
|
|
211
|
+
6. **Context 传播** - 所有层都传递 context
|
|
212
|
+
|
|
213
|
+
## 相关选项
|
|
214
|
+
|
|
215
|
+
- [Node.js](./nodejs.md) - Node.js 专案结构
|
|
216
|
+
- [Python](./python.md) - Python 专案结构
|
|
217
|
+
- [.NET](./dotnet.md) - .NET/C# 专案结构
|
|
218
|
+
- [Java](./java.md) - Java/Spring 专案结构
|
|
219
|
+
|
|
220
|
+
---
|
|
221
|
+
|
|
222
|
+
## 授权条款
|
|
223
|
+
|
|
224
|
+
本文件采用 [CC BY 4.0](https://creativecommons.org/licenses/by/4.0/) 授权条款。
|
|
225
|
+
|
|
226
|
+
**来源**:[universal-dev-standards](https://github.com/AsiaOstrich/universal-dev-standards)
|