@dtt_siye/atool 1.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LICENSE +21 -0
- package/README.md +235 -0
- package/VERSION +1 -0
- package/agents/code-reviewer.md +29 -0
- package/bin/atool.js +235 -0
- package/bin/postinstall.js +23 -0
- package/hooks/doc-sync-reminder +155 -0
- package/hooks/hooks-cursor.json +37 -0
- package/hooks/hooks.json +37 -0
- package/hooks/prompt-guard +135 -0
- package/hooks/session-start +286 -0
- package/install.sh +603 -0
- package/lib/analyze-source.sh +1265 -0
- package/lib/common.sh +1041 -0
- package/lib/compute-importance.sh +598 -0
- package/lib/detect-stack.sh +354 -0
- package/lib/generate-visualization.sh +266 -0
- package/lib/install-claude.sh +43 -0
- package/lib/install-cursor.sh +281 -0
- package/lib/install-hooks.sh +285 -0
- package/lib/install-kiro.sh +543 -0
- package/lib/install-mcp.sh +99 -0
- package/lib/install-skills.sh +129 -0
- package/lib/knowledge-graph.sh +1014 -0
- package/lib/multi-dimensional-analysis.sh +413 -0
- package/lib/pre-scan.sh +1045 -0
- package/lib/project-init.sh +552 -0
- package/lib/visualization-template.html +545 -0
- package/mcp/recommended.json +24 -0
- package/package.json +39 -0
- package/skills/_superpowers/.claude-plugin/marketplace.json +20 -0
- package/skills/_superpowers/.claude-plugin/plugin.json +20 -0
- package/skills/_superpowers/.codex/INSTALL.md +67 -0
- package/skills/_superpowers/.cursor-plugin/plugin.json +25 -0
- package/skills/_superpowers/.gitattributes +18 -0
- package/skills/_superpowers/.github/FUNDING.yml +3 -0
- package/skills/_superpowers/.github/ISSUE_TEMPLATE/bug_report.md +52 -0
- package/skills/_superpowers/.github/ISSUE_TEMPLATE/config.yml +5 -0
- package/skills/_superpowers/.github/ISSUE_TEMPLATE/feature_request.md +34 -0
- package/skills/_superpowers/.github/ISSUE_TEMPLATE/platform_support.md +23 -0
- package/skills/_superpowers/.github/PULL_REQUEST_TEMPLATE.md +87 -0
- package/skills/_superpowers/.opencode/INSTALL.md +83 -0
- package/skills/_superpowers/.opencode/plugins/superpowers.js +107 -0
- package/skills/_superpowers/CHANGELOG.md +13 -0
- package/skills/_superpowers/CODE_OF_CONDUCT.md +128 -0
- package/skills/_superpowers/GEMINI.md +2 -0
- package/skills/_superpowers/LICENSE +21 -0
- package/skills/_superpowers/README.md +187 -0
- package/skills/_superpowers/RELEASE-NOTES.md +1083 -0
- package/skills/_superpowers/agents/code-reviewer.md +48 -0
- package/skills/_superpowers/commands/brainstorm.md +5 -0
- package/skills/_superpowers/commands/execute-plan.md +5 -0
- package/skills/_superpowers/commands/write-plan.md +5 -0
- package/skills/_superpowers/docs/README.codex.md +126 -0
- package/skills/_superpowers/docs/README.opencode.md +130 -0
- package/skills/_superpowers/docs/plans/2025-11-22-opencode-support-design.md +294 -0
- package/skills/_superpowers/docs/plans/2025-11-22-opencode-support-implementation.md +1095 -0
- package/skills/_superpowers/docs/plans/2025-11-28-skills-improvements-from-user-feedback.md +711 -0
- package/skills/_superpowers/docs/plans/2026-01-17-visual-brainstorming.md +571 -0
- package/skills/_superpowers/docs/superpowers/plans/2026-01-22-document-review-system.md +301 -0
- package/skills/_superpowers/docs/superpowers/plans/2026-02-19-visual-brainstorming-refactor.md +523 -0
- package/skills/_superpowers/docs/superpowers/plans/2026-03-11-zero-dep-brainstorm-server.md +479 -0
- package/skills/_superpowers/docs/superpowers/plans/2026-03-23-codex-app-compatibility.md +564 -0
- package/skills/_superpowers/docs/superpowers/specs/2026-01-22-document-review-system-design.md +136 -0
- package/skills/_superpowers/docs/superpowers/specs/2026-02-19-visual-brainstorming-refactor-design.md +162 -0
- package/skills/_superpowers/docs/superpowers/specs/2026-03-11-zero-dep-brainstorm-server-design.md +118 -0
- package/skills/_superpowers/docs/superpowers/specs/2026-03-23-codex-app-compatibility-design.md +244 -0
- package/skills/_superpowers/docs/testing.md +303 -0
- package/skills/_superpowers/docs/windows/polyglot-hooks.md +212 -0
- package/skills/_superpowers/gemini-extension.json +6 -0
- package/skills/_superpowers/hooks/hooks-cursor.json +10 -0
- package/skills/_superpowers/hooks/hooks.json +16 -0
- package/skills/_superpowers/hooks/run-hook.cmd +46 -0
- package/skills/_superpowers/hooks/session-start +57 -0
- package/skills/_superpowers/package.json +6 -0
- package/skills/_superpowers/skills/brainstorming/SKILL.md +164 -0
- package/skills/_superpowers/skills/brainstorming/scripts/frame-template.html +214 -0
- package/skills/_superpowers/skills/brainstorming/scripts/helper.js +88 -0
- package/skills/_superpowers/skills/brainstorming/scripts/server.cjs +354 -0
- package/skills/_superpowers/skills/brainstorming/scripts/start-server.sh +148 -0
- package/skills/_superpowers/skills/brainstorming/scripts/stop-server.sh +56 -0
- package/skills/_superpowers/skills/brainstorming/spec-document-reviewer-prompt.md +49 -0
- package/skills/_superpowers/skills/brainstorming/visual-companion.md +287 -0
- package/skills/_superpowers/skills/dispatching-parallel-agents/SKILL.md +182 -0
- package/skills/_superpowers/skills/executing-plans/SKILL.md +70 -0
- package/skills/_superpowers/skills/finishing-a-development-branch/SKILL.md +200 -0
- package/skills/_superpowers/skills/receiving-code-review/SKILL.md +213 -0
- package/skills/_superpowers/skills/requesting-code-review/SKILL.md +105 -0
- package/skills/_superpowers/skills/requesting-code-review/code-reviewer.md +146 -0
- package/skills/_superpowers/skills/subagent-driven-development/SKILL.md +277 -0
- package/skills/_superpowers/skills/subagent-driven-development/code-quality-reviewer-prompt.md +26 -0
- package/skills/_superpowers/skills/subagent-driven-development/implementer-prompt.md +113 -0
- package/skills/_superpowers/skills/subagent-driven-development/spec-reviewer-prompt.md +61 -0
- package/skills/_superpowers/skills/systematic-debugging/CREATION-LOG.md +119 -0
- package/skills/_superpowers/skills/systematic-debugging/SKILL.md +296 -0
- package/skills/_superpowers/skills/systematic-debugging/condition-based-waiting-example.ts +158 -0
- package/skills/_superpowers/skills/systematic-debugging/condition-based-waiting.md +115 -0
- package/skills/_superpowers/skills/systematic-debugging/defense-in-depth.md +122 -0
- package/skills/_superpowers/skills/systematic-debugging/find-polluter.sh +63 -0
- package/skills/_superpowers/skills/systematic-debugging/root-cause-tracing.md +169 -0
- package/skills/_superpowers/skills/systematic-debugging/test-academic.md +14 -0
- package/skills/_superpowers/skills/systematic-debugging/test-pressure-1.md +58 -0
- package/skills/_superpowers/skills/systematic-debugging/test-pressure-2.md +68 -0
- package/skills/_superpowers/skills/systematic-debugging/test-pressure-3.md +69 -0
- package/skills/_superpowers/skills/test-driven-development/SKILL.md +371 -0
- package/skills/_superpowers/skills/test-driven-development/testing-anti-patterns.md +299 -0
- package/skills/_superpowers/skills/using-git-worktrees/SKILL.md +218 -0
- package/skills/_superpowers/skills/using-superpowers/SKILL.md +115 -0
- package/skills/_superpowers/skills/using-superpowers/references/codex-tools.md +100 -0
- package/skills/_superpowers/skills/using-superpowers/references/gemini-tools.md +33 -0
- package/skills/_superpowers/skills/verification-before-completion/SKILL.md +139 -0
- package/skills/_superpowers/skills/writing-plans/SKILL.md +152 -0
- package/skills/_superpowers/skills/writing-plans/plan-document-reviewer-prompt.md +49 -0
- package/skills/_superpowers/skills/writing-skills/SKILL.md +655 -0
- package/skills/_superpowers/skills/writing-skills/anthropic-best-practices.md +1150 -0
- package/skills/_superpowers/skills/writing-skills/examples/CLAUDE_MD_TESTING.md +189 -0
- package/skills/_superpowers/skills/writing-skills/graphviz-conventions.dot +172 -0
- package/skills/_superpowers/skills/writing-skills/persuasion-principles.md +187 -0
- package/skills/_superpowers/skills/writing-skills/render-graphs.js +168 -0
- package/skills/_superpowers/skills/writing-skills/testing-skills-with-subagents.md +384 -0
- package/skills/_superpowers/tests/brainstorm-server/package-lock.json +36 -0
- package/skills/_superpowers/tests/brainstorm-server/package.json +10 -0
- package/skills/_superpowers/tests/brainstorm-server/server.test.js +427 -0
- package/skills/_superpowers/tests/brainstorm-server/windows-lifecycle.test.sh +351 -0
- package/skills/_superpowers/tests/brainstorm-server/ws-protocol.test.js +392 -0
- package/skills/_superpowers/tests/claude-code/README.md +158 -0
- package/skills/_superpowers/tests/claude-code/analyze-token-usage.py +168 -0
- package/skills/_superpowers/tests/claude-code/run-skill-tests.sh +187 -0
- package/skills/_superpowers/tests/claude-code/test-document-review-system.sh +177 -0
- package/skills/_superpowers/tests/claude-code/test-helpers.sh +202 -0
- package/skills/_superpowers/tests/claude-code/test-subagent-driven-development-integration.sh +314 -0
- package/skills/_superpowers/tests/claude-code/test-subagent-driven-development.sh +165 -0
- package/skills/_superpowers/tests/explicit-skill-requests/prompts/action-oriented.txt +3 -0
- package/skills/_superpowers/tests/explicit-skill-requests/prompts/after-planning-flow.txt +17 -0
- package/skills/_superpowers/tests/explicit-skill-requests/prompts/claude-suggested-it.txt +11 -0
- package/skills/_superpowers/tests/explicit-skill-requests/prompts/i-know-what-sdd-means.txt +8 -0
- package/skills/_superpowers/tests/explicit-skill-requests/prompts/mid-conversation-execute-plan.txt +3 -0
- package/skills/_superpowers/tests/explicit-skill-requests/prompts/please-use-brainstorming.txt +1 -0
- package/skills/_superpowers/tests/explicit-skill-requests/prompts/skip-formalities.txt +3 -0
- package/skills/_superpowers/tests/explicit-skill-requests/prompts/subagent-driven-development-please.txt +1 -0
- package/skills/_superpowers/tests/explicit-skill-requests/prompts/use-systematic-debugging.txt +1 -0
- package/skills/_superpowers/tests/explicit-skill-requests/run-all.sh +70 -0
- package/skills/_superpowers/tests/explicit-skill-requests/run-claude-describes-sdd.sh +100 -0
- package/skills/_superpowers/tests/explicit-skill-requests/run-extended-multiturn-test.sh +113 -0
- package/skills/_superpowers/tests/explicit-skill-requests/run-haiku-test.sh +144 -0
- package/skills/_superpowers/tests/explicit-skill-requests/run-multiturn-test.sh +143 -0
- package/skills/_superpowers/tests/explicit-skill-requests/run-test.sh +136 -0
- package/skills/_superpowers/tests/opencode/run-tests.sh +163 -0
- package/skills/_superpowers/tests/opencode/setup.sh +73 -0
- package/skills/_superpowers/tests/opencode/test-plugin-loading.sh +72 -0
- package/skills/_superpowers/tests/opencode/test-priority.sh +198 -0
- package/skills/_superpowers/tests/opencode/test-tools.sh +104 -0
- package/skills/_superpowers/tests/skill-triggering/prompts/dispatching-parallel-agents.txt +8 -0
- package/skills/_superpowers/tests/skill-triggering/prompts/executing-plans.txt +1 -0
- package/skills/_superpowers/tests/skill-triggering/prompts/requesting-code-review.txt +3 -0
- package/skills/_superpowers/tests/skill-triggering/prompts/systematic-debugging.txt +11 -0
- package/skills/_superpowers/tests/skill-triggering/prompts/test-driven-development.txt +7 -0
- package/skills/_superpowers/tests/skill-triggering/prompts/writing-plans.txt +10 -0
- package/skills/_superpowers/tests/skill-triggering/run-all.sh +60 -0
- package/skills/_superpowers/tests/skill-triggering/run-test.sh +88 -0
- package/skills/_superpowers/tests/subagent-driven-dev/go-fractals/design.md +81 -0
- package/skills/_superpowers/tests/subagent-driven-dev/go-fractals/plan.md +172 -0
- package/skills/_superpowers/tests/subagent-driven-dev/go-fractals/scaffold.sh +45 -0
- package/skills/_superpowers/tests/subagent-driven-dev/run-test.sh +106 -0
- package/skills/_superpowers/tests/subagent-driven-dev/svelte-todo/design.md +70 -0
- package/skills/_superpowers/tests/subagent-driven-dev/svelte-todo/plan.md +222 -0
- package/skills/_superpowers/tests/subagent-driven-dev/svelte-todo/scaffold.sh +46 -0
- package/skills/ai-project-architecture/SKILL.md +632 -0
- package/skills/ai-project-architecture/reference/structure-rules.md +406 -0
- package/skills/ai-project-architecture/templates/compliance-report.md +300 -0
- package/skills/ai-project-architecture/templates/migration-plan.md +433 -0
- package/skills/ai-project-architecture/templates/verification-checklist.md +408 -0
- package/skills/android-conventions/SKILL.md +125 -0
- package/skills/atool-init/SKILL.md +141 -0
- package/skills/clarify-before-build/SKILL.md +107 -0
- package/skills/code-review/SKILL.md +406 -0
- package/skills/code-review/rules/architecture.md +285 -0
- package/skills/code-review/rules/coupling-cohesion.md +309 -0
- package/skills/code-review/rules/dead-code.md +115 -0
- package/skills/code-review/rules/deprecation-debt.md +279 -0
- package/skills/code-review/rules/duplication.md +104 -0
- package/skills/code-review/rules/error-security.md +143 -0
- package/skills/code-review/rules/maintainability.md +203 -0
- package/skills/code-review/rules/quality.md +158 -0
- package/skills/devops-conventions/SKILL.md +205 -0
- package/skills/doc-coauthoring/SKILL.md +392 -0
- package/skills/doc-standards-enforcer/SKILL.md +290 -0
- package/skills/doc-standards-enforcer/examples/valid-document-example.md +67 -0
- package/skills/doc-standards-enforcer/references/101-standards-summary.md +318 -0
- package/skills/doc-standards-enforcer/scripts/check_references.py +175 -0
- package/skills/doc-standards-enforcer/scripts/fix_common_issues.py +303 -0
- package/skills/doc-standards-enforcer/scripts/validate_doc_standards.py +332 -0
- package/skills/docx/LICENSE.txt +30 -0
- package/skills/docx/SKILL.md +200 -0
- package/skills/docx/docx-js.md +350 -0
- package/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/dml-chart.xsd +1499 -0
- package/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/dml-chartDrawing.xsd +146 -0
- package/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/dml-diagram.xsd +1085 -0
- package/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/dml-lockedCanvas.xsd +11 -0
- package/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/dml-main.xsd +3081 -0
- package/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/dml-picture.xsd +23 -0
- package/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/dml-spreadsheetDrawing.xsd +185 -0
- package/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/dml-wordprocessingDrawing.xsd +287 -0
- package/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/pml.xsd +1676 -0
- package/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/shared-additionalCharacteristics.xsd +28 -0
- package/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/shared-bibliography.xsd +144 -0
- package/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/shared-commonSimpleTypes.xsd +174 -0
- package/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/shared-customXmlDataProperties.xsd +25 -0
- package/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/shared-customXmlSchemaProperties.xsd +18 -0
- package/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/shared-documentPropertiesCustom.xsd +59 -0
- package/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/shared-documentPropertiesExtended.xsd +56 -0
- package/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/shared-documentPropertiesVariantTypes.xsd +195 -0
- package/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/shared-math.xsd +582 -0
- package/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/shared-relationshipReference.xsd +25 -0
- package/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/sml.xsd +4439 -0
- package/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/vml-main.xsd +570 -0
- package/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/vml-officeDrawing.xsd +509 -0
- package/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/vml-presentationDrawing.xsd +12 -0
- package/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/vml-spreadsheetDrawing.xsd +108 -0
- package/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/vml-wordprocessingDrawing.xsd +96 -0
- package/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/wml.xsd +3646 -0
- package/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/xml.xsd +116 -0
- package/skills/docx/ooxml/schemas/ecma/fouth-edition/opc-contentTypes.xsd +42 -0
- package/skills/docx/ooxml/schemas/ecma/fouth-edition/opc-coreProperties.xsd +50 -0
- package/skills/docx/ooxml/schemas/ecma/fouth-edition/opc-digSig.xsd +49 -0
- package/skills/docx/ooxml/schemas/ecma/fouth-edition/opc-relationships.xsd +33 -0
- package/skills/docx/ooxml/schemas/mce/mc.xsd +75 -0
- package/skills/docx/ooxml/schemas/microsoft/wml-2010.xsd +560 -0
- package/skills/docx/ooxml/schemas/microsoft/wml-2012.xsd +67 -0
- package/skills/docx/ooxml/schemas/microsoft/wml-2018.xsd +14 -0
- package/skills/docx/ooxml/schemas/microsoft/wml-cex-2018.xsd +20 -0
- package/skills/docx/ooxml/schemas/microsoft/wml-cid-2016.xsd +13 -0
- package/skills/docx/ooxml/schemas/microsoft/wml-sdtdatahash-2020.xsd +4 -0
- package/skills/docx/ooxml/schemas/microsoft/wml-symex-2015.xsd +8 -0
- package/skills/docx/ooxml/scripts/pack.py +159 -0
- package/skills/docx/ooxml/scripts/unpack.py +29 -0
- package/skills/docx/ooxml/scripts/validate.py +69 -0
- package/skills/docx/ooxml/scripts/validation/__init__.py +15 -0
- package/skills/docx/ooxml/scripts/validation/base.py +951 -0
- package/skills/docx/ooxml/scripts/validation/docx.py +274 -0
- package/skills/docx/ooxml/scripts/validation/pptx.py +315 -0
- package/skills/docx/ooxml/scripts/validation/redlining.py +279 -0
- package/skills/docx/ooxml.md +610 -0
- package/skills/docx/scripts/__init__.py +1 -0
- package/skills/docx/scripts/document.py +1276 -0
- package/skills/docx/scripts/templates/comments.xml +3 -0
- package/skills/docx/scripts/templates/commentsExtended.xml +3 -0
- package/skills/docx/scripts/templates/commentsExtensible.xml +3 -0
- package/skills/docx/scripts/templates/commentsIds.xml +3 -0
- package/skills/docx/scripts/templates/people.xml +3 -0
- package/skills/docx/scripts/utilities.py +374 -0
- package/skills/flutter-conventions/SKILL.md +70 -0
- package/skills/go-conventions/SKILL.md +230 -0
- package/skills/harmony-conventions/SKILL.md +156 -0
- package/skills/java-conventions/SKILL.md +277 -0
- package/skills/pdf/LICENSE.txt +30 -0
- package/skills/pdf/SKILL.md +297 -0
- package/skills/pdf/forms.md +205 -0
- package/skills/pdf/reference.md +612 -0
- package/skills/pdf/scripts/check_bounding_boxes.py +70 -0
- package/skills/pdf/scripts/check_bounding_boxes_test.py +226 -0
- package/skills/pdf/scripts/check_fillable_fields.py +12 -0
- package/skills/pdf/scripts/convert_pdf_to_images.py +35 -0
- package/skills/pdf/scripts/create_validation_image.py +41 -0
- package/skills/pdf/scripts/extract_form_field_info.py +152 -0
- package/skills/pdf/scripts/fill_fillable_fields.py +114 -0
- package/skills/pdf/scripts/fill_pdf_form_with_annotations.py +108 -0
- package/skills/pptx/LICENSE.txt +30 -0
- package/skills/pptx/SKILL.md +487 -0
- package/skills/pptx/html2pptx.md +625 -0
- package/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/dml-chart.xsd +1499 -0
- package/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/dml-chartDrawing.xsd +146 -0
- package/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/dml-diagram.xsd +1085 -0
- package/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/dml-lockedCanvas.xsd +11 -0
- package/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/dml-main.xsd +3081 -0
- package/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/dml-picture.xsd +23 -0
- package/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/dml-spreadsheetDrawing.xsd +185 -0
- package/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/dml-wordprocessingDrawing.xsd +287 -0
- package/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/pml.xsd +1676 -0
- package/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/shared-additionalCharacteristics.xsd +28 -0
- package/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/shared-bibliography.xsd +144 -0
- package/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/shared-commonSimpleTypes.xsd +174 -0
- package/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/shared-customXmlDataProperties.xsd +25 -0
- package/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/shared-customXmlSchemaProperties.xsd +18 -0
- package/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/shared-documentPropertiesCustom.xsd +59 -0
- package/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/shared-documentPropertiesExtended.xsd +56 -0
- package/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/shared-documentPropertiesVariantTypes.xsd +195 -0
- package/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/shared-math.xsd +582 -0
- package/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/shared-relationshipReference.xsd +25 -0
- package/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/sml.xsd +4439 -0
- package/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/vml-main.xsd +570 -0
- package/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/vml-officeDrawing.xsd +509 -0
- package/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/vml-presentationDrawing.xsd +12 -0
- package/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/vml-spreadsheetDrawing.xsd +108 -0
- package/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/vml-wordprocessingDrawing.xsd +96 -0
- package/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/wml.xsd +3646 -0
- package/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/xml.xsd +116 -0
- package/skills/pptx/ooxml/schemas/ecma/fouth-edition/opc-contentTypes.xsd +42 -0
- package/skills/pptx/ooxml/schemas/ecma/fouth-edition/opc-coreProperties.xsd +50 -0
- package/skills/pptx/ooxml/schemas/ecma/fouth-edition/opc-digSig.xsd +49 -0
- package/skills/pptx/ooxml/schemas/ecma/fouth-edition/opc-relationships.xsd +33 -0
- package/skills/pptx/ooxml/schemas/mce/mc.xsd +75 -0
- package/skills/pptx/ooxml/schemas/microsoft/wml-2010.xsd +560 -0
- package/skills/pptx/ooxml/schemas/microsoft/wml-2012.xsd +67 -0
- package/skills/pptx/ooxml/schemas/microsoft/wml-2018.xsd +14 -0
- package/skills/pptx/ooxml/schemas/microsoft/wml-cex-2018.xsd +20 -0
- package/skills/pptx/ooxml/schemas/microsoft/wml-cid-2016.xsd +13 -0
- package/skills/pptx/ooxml/schemas/microsoft/wml-sdtdatahash-2020.xsd +4 -0
- package/skills/pptx/ooxml/schemas/microsoft/wml-symex-2015.xsd +8 -0
- package/skills/pptx/ooxml/scripts/pack.py +159 -0
- package/skills/pptx/ooxml/scripts/unpack.py +29 -0
- package/skills/pptx/ooxml/scripts/validate.py +69 -0
- package/skills/pptx/ooxml/scripts/validation/__init__.py +15 -0
- package/skills/pptx/ooxml/scripts/validation/base.py +951 -0
- package/skills/pptx/ooxml/scripts/validation/docx.py +274 -0
- package/skills/pptx/ooxml/scripts/validation/pptx.py +315 -0
- package/skills/pptx/ooxml/scripts/validation/redlining.py +279 -0
- package/skills/pptx/ooxml.md +427 -0
- package/skills/pptx/scripts/html2pptx.js +979 -0
- package/skills/pptx/scripts/inventory.py +1020 -0
- package/skills/pptx/scripts/rearrange.py +231 -0
- package/skills/pptx/scripts/replace.py +385 -0
- package/skills/pptx/scripts/thumbnail.py +450 -0
- package/skills/project-analyze/SKILL.md +270 -0
- package/skills/project-analyze/phases/phase0-discovery.md +278 -0
- package/skills/project-analyze/phases/phase0.5-prescan.md +139 -0
- package/skills/project-analyze/phases/phase1-inventory.md +94 -0
- package/skills/project-analyze/phases/phase2-deep-analysis.md +249 -0
- package/skills/project-analyze/phases/phase2a-l4-analysis.md +94 -0
- package/skills/project-analyze/phases/phase2b-l5-analysis.md +97 -0
- package/skills/project-analyze/phases/phase3-knowledge-graph.md +120 -0
- package/skills/project-analyze/phases/phase3a-multi-dimensional.md +61 -0
- package/skills/project-analyze/phases/phase4-code-quality.md +81 -0
- package/skills/project-analyze/phases/phase5-synthesis.md +284 -0
- package/skills/project-analyze/phases/phase6-validation.md +179 -0
- package/skills/project-analyze/prompts/code-review-agent.md +122 -0
- package/skills/project-analyze/prompts/deep-analysis-agent.md +107 -0
- package/skills/project-analyze/prompts/inventory-agent.md +67 -0
- package/skills/project-analyze/prompts/l4-analysis-agent.md +98 -0
- package/skills/project-analyze/rules/android.md +282 -0
- package/skills/project-analyze/rules/devops.md +443 -0
- package/skills/project-analyze/rules/generic.md +243 -0
- package/skills/project-analyze/rules/go.md +289 -0
- package/skills/project-analyze/rules/harmony.md +257 -0
- package/skills/project-analyze/rules/java.md +507 -0
- package/skills/project-analyze/rules/mobile-flutter.md +315 -0
- package/skills/project-analyze/rules/mobile-react-native.md +283 -0
- package/skills/project-analyze/rules/mobile-swift.md +323 -0
- package/skills/project-analyze/rules/python.md +317 -0
- package/skills/project-analyze/rules/rust-tauri.md +243 -0
- package/skills/project-analyze/rules/rust.md +296 -0
- package/skills/project-analyze/rules/web-nextjs.md +364 -0
- package/skills/project-analyze/rules/web-react.md +298 -0
- package/skills/project-analyze/rules/web-vue.md +378 -0
- package/skills/project-analyze/rules/web.md +390 -0
- package/skills/project-query/SKILL.md +224 -0
- package/skills/project-query/rules/query-templates.md +212 -0
- package/skills/python-conventions/SKILL.md +169 -0
- package/skills/react-native-conventions/SKILL.md +73 -0
- package/skills/requirements-writer/README.md +153 -0
- package/skills/requirements-writer/SKILL.md +341 -0
- package/skills/requirements-writer/examples/prd-outline-example.md +217 -0
- package/skills/requirements-writer/templates/module-prd-template.md +362 -0
- package/skills/requirements-writer/templates/prd-outline-template.md +185 -0
- package/skills/requirements-writer/templates/user-story-template.md +1125 -0
- package/skills/rust-conventions/SKILL.md +361 -0
- package/skills/smart-dispatch/SKILL.md +296 -0
- package/skills/smart-dispatch/implementer-prompt.md +146 -0
- package/skills/smart-dispatch/reviewer-prompt.md +199 -0
- package/skills/software-architecture/SKILL.md +278 -0
- package/skills/swift-conventions/SKILL.md +72 -0
- package/skills/ui-ux-pro/SKILL.md +140 -0
- package/skills/verification-before-completion/SKILL.md +119 -0
- package/skills/web-conventions/SKILL.md +259 -0
- package/skills/webapp-testing/LICENSE.txt +202 -0
- package/skills/webapp-testing/SKILL.md +97 -0
- package/skills/webapp-testing/examples/console_logging.py +35 -0
- package/skills/webapp-testing/examples/element_discovery.py +40 -0
- package/skills/webapp-testing/examples/static_html_automation.py +33 -0
- package/skills/webapp-testing/scripts/with_server.py +106 -0
- package/skills/writing-plans/SKILL.md +144 -0
- package/skills/xlsx/LICENSE.txt +30 -0
- package/skills/xlsx/SKILL.md +292 -0
- package/skills/xlsx/recalc.py +178 -0
- package/templates/CLAUDE.md.android +57 -0
- package/templates/CLAUDE.md.devops +50 -0
- package/templates/CLAUDE.md.generic +34 -0
- package/templates/CLAUDE.md.go +67 -0
- package/templates/CLAUDE.md.harmony +54 -0
- package/templates/CLAUDE.md.java +56 -0
- package/templates/CLAUDE.md.mobile-flutter +38 -0
- package/templates/CLAUDE.md.mobile-react-native +37 -0
- package/templates/CLAUDE.md.mobile-swift +40 -0
- package/templates/CLAUDE.md.python +65 -0
- package/templates/CLAUDE.md.rust +68 -0
- package/templates/CLAUDE.md.rust-tauri +120 -0
- package/templates/CLAUDE.md.web +63 -0
- package/templates/COMPONENT.md.android +58 -0
- package/templates/COMPONENT.md.devops +54 -0
- package/templates/COMPONENT.md.generic +35 -0
- package/templates/COMPONENT.md.go +59 -0
- package/templates/COMPONENT.md.harmony +63 -0
- package/templates/COMPONENT.md.java +69 -0
- package/templates/COMPONENT.md.mobile-flutter +56 -0
- package/templates/COMPONENT.md.mobile-react-native +55 -0
- package/templates/COMPONENT.md.mobile-swift +56 -0
- package/templates/COMPONENT.md.python +67 -0
- package/templates/COMPONENT.md.rust +57 -0
- package/templates/COMPONENT.md.rust-tauri +66 -0
- package/templates/COMPONENT.md.web +39 -0
- package/templates/README.md.android +71 -0
- package/templates/README.md.devops +68 -0
- package/templates/README.md.generic +39 -0
- package/templates/README.md.go +70 -0
- package/templates/README.md.harmony +72 -0
- package/templates/README.md.java +73 -0
- package/templates/README.md.mobile-flutter +69 -0
- package/templates/README.md.mobile-react-native +65 -0
- package/templates/README.md.mobile-swift +69 -0
- package/templates/README.md.monorepo +59 -0
- package/templates/README.md.python +66 -0
- package/templates/README.md.rust +69 -0
- package/templates/README.md.rust-tauri +149 -0
- package/templates/README.md.web +94 -0
- package/templates/UI_STYLE.md.android +74 -0
- package/templates/UI_STYLE.md.devops +50 -0
- package/templates/UI_STYLE.md.generic +31 -0
- package/templates/UI_STYLE.md.go +49 -0
- package/templates/UI_STYLE.md.harmony +71 -0
- package/templates/UI_STYLE.md.java +61 -0
- package/templates/UI_STYLE.md.mobile-flutter +70 -0
- package/templates/UI_STYLE.md.mobile-react-native +71 -0
- package/templates/UI_STYLE.md.mobile-swift +71 -0
- package/templates/UI_STYLE.md.python +58 -0
- package/templates/UI_STYLE.md.rust +52 -0
- package/templates/UI_STYLE.md.rust-tauri +102 -0
- package/templates/UI_STYLE.md.web +92 -0
- package/templates/cursor-rules.android.mdc +33 -0
- package/templates/cursor-rules.devops.mdc +32 -0
- package/templates/cursor-rules.generic.mdc +25 -0
- package/templates/cursor-rules.go.mdc +34 -0
- package/templates/cursor-rules.harmony.mdc +30 -0
- package/templates/cursor-rules.java.mdc +30 -0
- package/templates/cursor-rules.mobile-flutter.mdc +42 -0
- package/templates/cursor-rules.mobile-react-native.mdc +43 -0
- package/templates/cursor-rules.mobile-swift.mdc +42 -0
- package/templates/cursor-rules.python.mdc +33 -0
- package/templates/cursor-rules.rust-tauri.mdc +67 -0
- package/templates/cursor-rules.rust.mdc +30 -0
- package/templates/cursor-rules.web.mdc +30 -0
- package/templates/kiro-steering.android.md +39 -0
- package/templates/kiro-steering.devops.md +32 -0
- package/templates/kiro-steering.generic.md +28 -0
- package/templates/kiro-steering.go.md +41 -0
- package/templates/kiro-steering.harmony.md +36 -0
- package/templates/kiro-steering.java.md +37 -0
- package/templates/kiro-steering.mobile-flutter.md +73 -0
- package/templates/kiro-steering.mobile-react-native.md +71 -0
- package/templates/kiro-steering.mobile-swift.md +62 -0
- package/templates/kiro-steering.python.md +34 -0
- package/templates/kiro-steering.rust-tauri.md +50 -0
- package/templates/kiro-steering.rust.md +36 -0
- package/templates/kiro-steering.web.md +41 -0
|
@@ -0,0 +1,203 @@
|
|
|
1
|
+
---
|
|
2
|
+
name: maintainability
|
|
3
|
+
dimension: maintainability
|
|
4
|
+
weight: 0.10
|
|
5
|
+
---
|
|
6
|
+
|
|
7
|
+
> **栈级规范:** 代码可维护性标准和项目结构约定参考对应 `{stack}-conventions` skill。
|
|
8
|
+
|
|
9
|
+
# 可维护性分析规则(SQALE 启发)
|
|
10
|
+
|
|
11
|
+
本维度基于 SQALE(Software Quality Assessment based on Lifecycle Expectations)方法,评估代码的可维护性技术债务。
|
|
12
|
+
|
|
13
|
+
## 1. 修复工作量估算(Remediation Effort)
|
|
14
|
+
|
|
15
|
+
### 1.1 评估方法
|
|
16
|
+
|
|
17
|
+
对每个代码异味(code smell),估算修复所需的分钟数:
|
|
18
|
+
|
|
19
|
+
| 异味类型 | 修复工作量 | 说明 |
|
|
20
|
+
|----------|-----------|------|
|
|
21
|
+
| 过长函数 (>120行) | 30-60 min | 拆分为多个小函数 |
|
|
22
|
+
| 过深嵌套 (>5层) | 20-45 min | 提取方法 + guard clause |
|
|
23
|
+
| 高圈复杂度 (>15) | 45-90 min | 分解分支逻辑 |
|
|
24
|
+
| 重复代码块 | 15-30 min/块 | 提取公共方法 |
|
|
25
|
+
| 硬编码常量 | 5-10 min | 提取为配置/常量 |
|
|
26
|
+
| 过长参数列表 (>8) | 10-20 min | 封装参数对象 |
|
|
27
|
+
| 上帝类/模块 (>20个方法) | 60-120 min | 按职责拆分 |
|
|
28
|
+
| 过长文件 (>500行) | 30-60 min | 按职责拆分文件 |
|
|
29
|
+
| 紧耦合(直接依赖实现) | 20-40 min | 引入接口/依赖注入 |
|
|
30
|
+
|
|
31
|
+
### 1.2 技术债务比率
|
|
32
|
+
|
|
33
|
+
```
|
|
34
|
+
technical_debt_ratio = total_remediation_time / estimated_development_time
|
|
35
|
+
|
|
36
|
+
# 估算开发时间
|
|
37
|
+
estimated_development_time = total_lines_of_code / 30 # 假设 30 行/人时
|
|
38
|
+
|
|
39
|
+
# 健康评级
|
|
40
|
+
ratio < 0.05 → ✅ 优秀(技术债务可控)
|
|
41
|
+
ratio 0.05-0.10 → ⚠️ 一般(建议关注)
|
|
42
|
+
ratio 0.10-0.20 → ❌ 较差(需计划性重构)
|
|
43
|
+
ratio > 0.20 → 🔴 严重(系统性重构优先级)
|
|
44
|
+
```
|
|
45
|
+
|
|
46
|
+
## 2. 可维护性指数(Maintainability Index)
|
|
47
|
+
|
|
48
|
+
### 2.1 计算公式
|
|
49
|
+
|
|
50
|
+
基于原始 Microsoft MI 公式的简化版本:
|
|
51
|
+
|
|
52
|
+
```
|
|
53
|
+
MI = MAX(0, 171 - 5.2 * ln(HV) - 0.23 * CC - 16.2 * ln(LOC) + 50 * sin(sqrt(2.4 * CM)))
|
|
54
|
+
|
|
55
|
+
其中:
|
|
56
|
+
- HV = Halstead Volume(估算,见 2.2)
|
|
57
|
+
- CC = 平均圈复杂度
|
|
58
|
+
- LOC = 有效代码行数(排除空行和纯注释行)
|
|
59
|
+
- CM = 注释率 (comment_lines / total_lines)
|
|
60
|
+
```
|
|
61
|
+
|
|
62
|
+
### 2.2 Halstead Volume 估算
|
|
63
|
+
|
|
64
|
+
精确计算需要完整的词法分析,此处使用简化估算:
|
|
65
|
+
|
|
66
|
+
```
|
|
67
|
+
# 统计操作符(operators)
|
|
68
|
+
operators = count of: +, -, *, /, =, ==, !=, <, >, <=, >=, &&, ||, !, &, |, ^, ~, <<, >>,
|
|
69
|
+
if, else, for, while, do, switch, case, return, new, delete,
|
|
70
|
+
., ->, ::, [], (), {}, import, class, function, def, fn, let, const, var
|
|
71
|
+
|
|
72
|
+
# 统计操作数(operands)
|
|
73
|
+
operands = count of: 变量名、常量值、字符串字面量、数字字面量
|
|
74
|
+
|
|
75
|
+
# 计算
|
|
76
|
+
N = operators + operands # 程序长度
|
|
77
|
+
n = unique_operators + unique_operands # 词汇量
|
|
78
|
+
HV = N * log2(n) # Halstead Volume
|
|
79
|
+
|
|
80
|
+
# 简化估算(逐文件)
|
|
81
|
+
HV ≈ (total_tokens * 1.2) * log2(unique_symbols)
|
|
82
|
+
其中 total_tokens ≈ LOC * 3(平均每行约 3 个 token)
|
|
83
|
+
unique_symbols ≈ sqrt(LOC) * 5(估算词汇量)
|
|
84
|
+
```
|
|
85
|
+
|
|
86
|
+
### 2.3 MI 健康评级
|
|
87
|
+
|
|
88
|
+
| MI 值 | 等级 | 描述 |
|
|
89
|
+
|--------|------|------|
|
|
90
|
+
| 85-100 | 优秀 | 高度可维护,易于理解和修改 |
|
|
91
|
+
| 65-85 | 良好 | 可维护性良好,局部可改进 |
|
|
92
|
+
| 40-65 | 一般 | 可维护性下降,建议重构 |
|
|
93
|
+
| 20-40 | 较差 | 难以维护,重构优先级高 |
|
|
94
|
+
| 0-20 | 严重 | 几乎不可维护,需系统性重写 |
|
|
95
|
+
|
|
96
|
+
## 3. 代码异味检测(Code Smells)
|
|
97
|
+
|
|
98
|
+
### 3.1 检测项
|
|
99
|
+
|
|
100
|
+
| 异味 | 严重度 | 判定标准 | 修复工作量 |
|
|
101
|
+
|------|--------|----------|-----------|
|
|
102
|
+
| 上帝函数 | Critical | 单个函数 >200 行或 CC >20 | 60-90 min |
|
|
103
|
+
| 过长参数列表 | Warning | 函数参数 >6 个 | 15-20 min |
|
|
104
|
+
| 特性嫉妒 | Warning | 函数频繁访问其他类的数据(>5 次引用其他类字段) | 20-40 min |
|
|
105
|
+
| 拒绝的馈赠 | Warning | 子类未使用父类 >50% 的方法 | 30-60 min |
|
|
106
|
+
| 过度耦合 | Warning | 类的直接依赖 >10 个 | 30-45 min |
|
|
107
|
+
| 中间人 | Info | 类 >80% 的方法仅委托给其他类 | 20-30 min |
|
|
108
|
+
| 惰性类 | Info | 类 <3 个方法且总行数 <30 行 | 10-15 min |
|
|
109
|
+
| 纯数据类 | Info | 类只有字段,无行为方法(贫血模型) | 20-40 min |
|
|
110
|
+
|
|
111
|
+
### 3.2 检测方法
|
|
112
|
+
|
|
113
|
+
逐文件扫描,对每个类/模块执行:
|
|
114
|
+
1. 统计方法数量和总行数(识别上帝类/惰性类)
|
|
115
|
+
2. 检查方法体中对外部类/模块的引用次数(特性嫉妒)
|
|
116
|
+
3. 统计 import/依赖数量(过度耦合)
|
|
117
|
+
4. 检查类是否有业务方法或仅为数据容器(纯数据类)
|
|
118
|
+
|
|
119
|
+
## 4. 模块级可维护性评估
|
|
120
|
+
|
|
121
|
+
### 4.1 模块健康度矩阵
|
|
122
|
+
|
|
123
|
+
对每个模块(3+ 文件的目录),生成:
|
|
124
|
+
|
|
125
|
+
| 指标 | 值 | 评级 |
|
|
126
|
+
|------|-----|------|
|
|
127
|
+
| MI 均值 | {value} | {level} |
|
|
128
|
+
| 技术债务比率 | {ratio} | {level} |
|
|
129
|
+
| 总修复工作量 | {hours} 人时 | — |
|
|
130
|
+
| 高风险文件数 | {count} | — |
|
|
131
|
+
| 代码异味密度 | {count}/KLOC | — |
|
|
132
|
+
|
|
133
|
+
### 4.2 高风险文件识别
|
|
134
|
+
|
|
135
|
+
满足以下任一条件的文件标记为高风险:
|
|
136
|
+
- MI < 40
|
|
137
|
+
- 圈复杂度 > 20
|
|
138
|
+
- 函数长度 > 200 行
|
|
139
|
+
- 重复代码占比 > 30%
|
|
140
|
+
- 硬编码安全敏感信息
|
|
141
|
+
|
|
142
|
+
## 评分算法
|
|
143
|
+
|
|
144
|
+
```
|
|
145
|
+
maintainability_score = 0
|
|
146
|
+
|
|
147
|
+
# 代码异味评分
|
|
148
|
+
for each smell:
|
|
149
|
+
if Critical: maintainability_score += 20
|
|
150
|
+
if Warning: maintainability_score += 8
|
|
151
|
+
if Info: maintainability_score += 2
|
|
152
|
+
|
|
153
|
+
# 技术债务比率惩罚
|
|
154
|
+
debt_penalty = 0
|
|
155
|
+
if debt_ratio > 0.20: debt_penalty += 30
|
|
156
|
+
elif debt_ratio > 0.10: debt_penalty += 15
|
|
157
|
+
elif debt_ratio > 0.05: debt_penalty += 5
|
|
158
|
+
|
|
159
|
+
maintainability_score += debt_penalty
|
|
160
|
+
|
|
161
|
+
# MI 偏差惩罚(MI < 65 的文件越多,惩罚越大)
|
|
162
|
+
low_mi_ratio = count(MI < 65 files) / total_files
|
|
163
|
+
mi_penalty = low_mi_ratio * 30
|
|
164
|
+
|
|
165
|
+
maintainability_score += mi_penalty
|
|
166
|
+
|
|
167
|
+
# 标准化
|
|
168
|
+
normalized = min(maintainability_score / max(total_modules, 1) * 10, 100)
|
|
169
|
+
```
|
|
170
|
+
|
|
171
|
+
## 报告章节模板
|
|
172
|
+
|
|
173
|
+
```markdown
|
|
174
|
+
### 可维护性 (Score: {score}/100)
|
|
175
|
+
|
|
176
|
+
**技术债务比率:** {ratio} — {level}
|
|
177
|
+
**估算修复工作量:** {hours} 人时
|
|
178
|
+
**MI 均值:** {mi_value}
|
|
179
|
+
|
|
180
|
+
发现 {count} 个可维护性问题:
|
|
181
|
+
- 上帝函数:{n} 个
|
|
182
|
+
- 过长参数列表:{n} 个
|
|
183
|
+
- 代码异味:{n} 个
|
|
184
|
+
- 高风险文件:{n} 个
|
|
185
|
+
|
|
186
|
+
#### 技术债务分析
|
|
187
|
+
|
|
188
|
+
| 异味类型 | 数量 | 单项修复时间 | 总修复时间 |
|
|
189
|
+
|----------|------|------------|-----------|
|
|
190
|
+
| 过长函数 | {n} | 30-60 min | {total} |
|
|
191
|
+
| ... | ... | ... | ... |
|
|
192
|
+
| **合计** | **{total}** | — | **{hours} 人时** |
|
|
193
|
+
|
|
194
|
+
#### 高风险文件
|
|
195
|
+
|
|
196
|
+
| 文件 | MI | CC | 最大函数长度 | 风险因素 |
|
|
197
|
+
|------|-----|-----|------------|---------|
|
|
198
|
+
| ... | ... | ... | ... | ... |
|
|
199
|
+
|
|
200
|
+
**重构优先级建议:**
|
|
201
|
+
1. {最高 ROI 的重构项(修复工作量低但改善最大的)}
|
|
202
|
+
2. {第二优先重构项}
|
|
203
|
+
```
|
|
@@ -0,0 +1,158 @@
|
|
|
1
|
+
---
|
|
2
|
+
name: code-quality
|
|
3
|
+
dimension: quality
|
|
4
|
+
weight: 0.15
|
|
5
|
+
---
|
|
6
|
+
|
|
7
|
+
> **栈级规范:** 如需更详细的命名约定、代码风格标准,参考对应 `{stack}-conventions` skill。
|
|
8
|
+
|
|
9
|
+
# 代码质量分析规则
|
|
10
|
+
|
|
11
|
+
## 检测维度
|
|
12
|
+
|
|
13
|
+
### 1. 圈复杂度 (Cyclomatic Complexity)
|
|
14
|
+
|
|
15
|
+
**阈值:**
|
|
16
|
+
- Critical: >15(函数包含过多分支,难以测试和维护)
|
|
17
|
+
- Warning: >10(函数较复杂,建议拆分)
|
|
18
|
+
- Info: >6(可考虑简化)
|
|
19
|
+
|
|
20
|
+
**检测方法:**
|
|
21
|
+
逐函数/方法扫描,统计以下结构数量:
|
|
22
|
+
- `if`/`elif`/`else` 分支
|
|
23
|
+
- `for`/`while`/`do-while` 循环
|
|
24
|
+
- `case`/`switch` 分支(含 `default`)
|
|
25
|
+
- `&&`/`||`/`and`/`or` 逻辑运算符
|
|
26
|
+
- `?.`/`??`/`?.()` 空值链式操作
|
|
27
|
+
- `try`/`catch` 异常路径
|
|
28
|
+
- 嵌套的三元运算符
|
|
29
|
+
|
|
30
|
+
**输出格式:**
|
|
31
|
+
```
|
|
32
|
+
| Severity | File | Line | Function | Complexity | Suggestion |
|
|
33
|
+
|----------|------|------|----------|------------|------------|
|
|
34
|
+
| Critical | src/auth.rs | 89 | process_login | 23 | 拆分为 validate_input() + authenticate() + create_session() |
|
|
35
|
+
```
|
|
36
|
+
|
|
37
|
+
### 2. 函数长度 (Function Length)
|
|
38
|
+
|
|
39
|
+
**阈值:**
|
|
40
|
+
- Critical: >120行(极长函数,几乎不可能正确理解)
|
|
41
|
+
- Warning: >40行(函数做了太多事情)
|
|
42
|
+
- Info: >25行(可考虑精简)
|
|
43
|
+
|
|
44
|
+
**检测方法:**
|
|
45
|
+
统计每个函数/方法从声明到结束的行数。排除空行和纯注释行后计数。
|
|
46
|
+
|
|
47
|
+
**特殊情况处理:**
|
|
48
|
+
- Rust `impl` 块中的方法:按方法边界计数
|
|
49
|
+
- JavaScript/TypeScript 箭头函数:`const fn = () => { ... }` 到闭合 `};`
|
|
50
|
+
- Python 装饰器方法:从 `def` 行到下一个同缩进级别的 `def` 或文件末尾
|
|
51
|
+
- Java 匿名类/lambda:如果超过 20 行,标记为 Warning
|
|
52
|
+
|
|
53
|
+
### 3. 嵌套深度 (Nesting Depth)
|
|
54
|
+
|
|
55
|
+
**阈值:**
|
|
56
|
+
- Critical: >5层(深度嵌套,逻辑极难追踪)
|
|
57
|
+
- Warning: >3层(建议使用 guard clause 或 early return)
|
|
58
|
+
- Info: >2层
|
|
59
|
+
|
|
60
|
+
**检测方法:**
|
|
61
|
+
追踪缩进层级或大括号嵌套。每进入一个 `if`/`for`/`while`/`switch`/`try`/`match` 块深度+1。
|
|
62
|
+
|
|
63
|
+
### 4. 注释率 (Comment Ratio)
|
|
64
|
+
|
|
65
|
+
**阈值(按文件计算):**
|
|
66
|
+
- Critical: <3%(几乎无注释,维护者无法理解设计意图)
|
|
67
|
+
- Warning: <10%(关键逻辑缺少注释)
|
|
68
|
+
- Info: <15%
|
|
69
|
+
|
|
70
|
+
**检测方法:**
|
|
71
|
+
```
|
|
72
|
+
comment_ratio = (注释行数 / 总有效行数) * 100
|
|
73
|
+
```
|
|
74
|
+
|
|
75
|
+
排除空行后计算。以下算作注释:
|
|
76
|
+
- `//` 和 `/* */` (C-style)
|
|
77
|
+
- `#` (Python/Ruby/Shell)
|
|
78
|
+
- `///` 和 `//!` (Rust doc comments)
|
|
79
|
+
- `--` (SQL/Haskell)
|
|
80
|
+
- JSDoc/TSDoc `/** */`
|
|
81
|
+
|
|
82
|
+
以下不算注释:
|
|
83
|
+
- 被注释掉的代码(以 `//` 开头后紧跟变量声明、函数调用等代码特征)
|
|
84
|
+
|
|
85
|
+
### 5. 参数数量 (Parameter Count)
|
|
86
|
+
|
|
87
|
+
**阈值:**
|
|
88
|
+
- Critical: >8个(函数签名过长,应使用配置对象/结构体)
|
|
89
|
+
- Warning: >5个(建议封装为参数对象)
|
|
90
|
+
- Info: >3个
|
|
91
|
+
|
|
92
|
+
**检测方法:**
|
|
93
|
+
统计函数声明的参数数量。排除 `self`/`this`。
|
|
94
|
+
|
|
95
|
+
### 6. Halstead Volume 估算(新增)
|
|
96
|
+
|
|
97
|
+
**说明:**
|
|
98
|
+
v3.0 新增维度。与 `maintainability.md` 的 MI 计算配合使用。此处的估算值会被 `maintainability.md` 引用。
|
|
99
|
+
|
|
100
|
+
**简化估算方法(精确计算需要完整词法分析):**
|
|
101
|
+
|
|
102
|
+
```
|
|
103
|
+
# 操作符(operators)
|
|
104
|
+
operators = count of: +, -, *, /, =, ==, !=, <, >, <=, >=, &&, ||, !, &, |, ^,
|
|
105
|
+
., ->, ::, [], (), {}, if, else, for, while, switch, return, new, class, function
|
|
106
|
+
|
|
107
|
+
# 操作数(operands)
|
|
108
|
+
operands = count of: 变量名、常量值、字符串字面量、数字字面量
|
|
109
|
+
|
|
110
|
+
# Halstead Volume
|
|
111
|
+
HV = (operators + operands) * log2(unique_operators + unique_operands)
|
|
112
|
+
|
|
113
|
+
# 简化估算(逐文件,无需精确词法分析)
|
|
114
|
+
# 假设:平均每行约 3 个 token,词汇量 ≈ sqrt(LOC) * 5
|
|
115
|
+
HV_approx = (LOC * 3) * log2(max(sqrt(LOC) * 5, 2))
|
|
116
|
+
|
|
117
|
+
# 阈值
|
|
118
|
+
HV > 10000 → Critical(文件过于复杂)
|
|
119
|
+
HV > 5000 → Warning(文件较复杂)
|
|
120
|
+
HV > 2000 → Info(可考虑简化)
|
|
121
|
+
```
|
|
122
|
+
|
|
123
|
+
**输出格式:**
|
|
124
|
+
```
|
|
125
|
+
| Severity | File | HV | CC | MI | Suggestion |
|
|
126
|
+
|----------|------|-----|-----|-----|------------|
|
|
127
|
+
| Critical | report-generator.ts | 12500 | 18 | 31 | 拆分为多个模块 |
|
|
128
|
+
```
|
|
129
|
+
|
|
130
|
+
## 评分算法```
|
|
131
|
+
quality_score = 0
|
|
132
|
+
|
|
133
|
+
for each issue:
|
|
134
|
+
if Critical: quality_score += 15
|
|
135
|
+
if Warning: quality_score += 5
|
|
136
|
+
if Info: quality_score += 1
|
|
137
|
+
|
|
138
|
+
normalized = min(quality_score / (total_functions * 2) * 100, 100)
|
|
139
|
+
```
|
|
140
|
+
|
|
141
|
+
## 报告章节模板
|
|
142
|
+
|
|
143
|
+
```markdown
|
|
144
|
+
### 代码质量 (Score: {score}/100)
|
|
145
|
+
|
|
146
|
+
发现 {count} 个代码质量问题:
|
|
147
|
+
- 圈复杂度超标:{n} 个函数
|
|
148
|
+
- 过长函数:{n} 个函数
|
|
149
|
+
- 嵌套过深:{n} 处
|
|
150
|
+
- 注释不足:{n} 个文件
|
|
151
|
+
- 参数过多:{n} 个函数
|
|
152
|
+
|
|
153
|
+
{issue_table}
|
|
154
|
+
|
|
155
|
+
**优先修复建议:**
|
|
156
|
+
1. {top_critical_issue}
|
|
157
|
+
2. {second_critical_issue}
|
|
158
|
+
```
|
|
@@ -0,0 +1,205 @@
|
|
|
1
|
+
---
|
|
2
|
+
name: devops-conventions
|
|
3
|
+
description: Docker/Kubernetes/Terraform/CI-CD DevOps conventions and best practices
|
|
4
|
+
version: 1.0.0
|
|
5
|
+
---
|
|
6
|
+
|
|
7
|
+
# DevOps Conventions
|
|
8
|
+
|
|
9
|
+
Use this skill when working on DevOps, infrastructure, or CI/CD projects.
|
|
10
|
+
|
|
11
|
+
## When to Use
|
|
12
|
+
- Detected DevOps project (Dockerfile, docker-compose.yml, *.tf, Chart.yaml)
|
|
13
|
+
- User asks about Docker, K8s, Terraform, or CI-CD best practices
|
|
14
|
+
- Writing or reviewing infrastructure code
|
|
15
|
+
|
|
16
|
+
## Docker
|
|
17
|
+
|
|
18
|
+
### Dockerfile Best Practices
|
|
19
|
+
```dockerfile
|
|
20
|
+
# Multi-stage build
|
|
21
|
+
FROM golang:1.22-alpine AS builder
|
|
22
|
+
WORKDIR /app
|
|
23
|
+
COPY go.mod go.sum ./
|
|
24
|
+
RUN go mod download
|
|
25
|
+
COPY . .
|
|
26
|
+
RUN CGO_ENABLED=0 go build -o myapp ./cmd/myapp
|
|
27
|
+
|
|
28
|
+
FROM alpine:3.19
|
|
29
|
+
RUN apk --no-cache add ca-certificates
|
|
30
|
+
COPY --from=builder /app/myapp /usr/local/bin/myapp
|
|
31
|
+
ENTRYPOINT ["myapp"]
|
|
32
|
+
```
|
|
33
|
+
|
|
34
|
+
### Rules
|
|
35
|
+
- Pin base image versions (never use `latest`)
|
|
36
|
+
- Use multi-stage builds to minimize image size
|
|
37
|
+
- Use `.dockerignore` to exclude unnecessary files
|
|
38
|
+
- Run as non-root user (`USER appuser`)
|
|
39
|
+
- Combine `RUN` commands to reduce layers
|
|
40
|
+
- Use health checks (`HEALTHCHECK`)
|
|
41
|
+
- Order instructions from least to most frequently changing
|
|
42
|
+
|
|
43
|
+
### Docker Compose
|
|
44
|
+
```yaml
|
|
45
|
+
version: "3.9"
|
|
46
|
+
services:
|
|
47
|
+
app:
|
|
48
|
+
build: .
|
|
49
|
+
ports:
|
|
50
|
+
- "8080:8080"
|
|
51
|
+
environment:
|
|
52
|
+
- DB_HOST=db
|
|
53
|
+
depends_on:
|
|
54
|
+
db:
|
|
55
|
+
condition: service_healthy
|
|
56
|
+
|
|
57
|
+
db:
|
|
58
|
+
image: postgres:16-alpine
|
|
59
|
+
environment:
|
|
60
|
+
POSTGRES_DB: myapp
|
|
61
|
+
POSTGRES_PASSWORD: secret
|
|
62
|
+
healthcheck:
|
|
63
|
+
test: ["CMD-SHELL", "pg_isready -U postgres"]
|
|
64
|
+
```
|
|
65
|
+
|
|
66
|
+
## Kubernetes
|
|
67
|
+
|
|
68
|
+
### Resource Manifest Structure
|
|
69
|
+
```yaml
|
|
70
|
+
apiVersion: apps/v1
|
|
71
|
+
kind: Deployment
|
|
72
|
+
metadata:
|
|
73
|
+
name: myapp
|
|
74
|
+
labels:
|
|
75
|
+
app: myapp
|
|
76
|
+
spec:
|
|
77
|
+
replicas: 3
|
|
78
|
+
selector:
|
|
79
|
+
matchLabels:
|
|
80
|
+
app: myapp
|
|
81
|
+
template:
|
|
82
|
+
metadata:
|
|
83
|
+
labels:
|
|
84
|
+
app: myapp
|
|
85
|
+
spec:
|
|
86
|
+
containers:
|
|
87
|
+
- name: myapp
|
|
88
|
+
image: myapp:1.0.0
|
|
89
|
+
ports:
|
|
90
|
+
- containerPort: 8080
|
|
91
|
+
resources:
|
|
92
|
+
requests:
|
|
93
|
+
memory: "128Mi"
|
|
94
|
+
cpu: "250m"
|
|
95
|
+
limits:
|
|
96
|
+
memory: "256Mi"
|
|
97
|
+
cpu: "500m"
|
|
98
|
+
livenessProbe:
|
|
99
|
+
httpGet:
|
|
100
|
+
path: /health
|
|
101
|
+
port: 8080
|
|
102
|
+
readinessProbe:
|
|
103
|
+
httpGet:
|
|
104
|
+
path: /ready
|
|
105
|
+
port: 8080
|
|
106
|
+
```
|
|
107
|
+
|
|
108
|
+
### Best Practices
|
|
109
|
+
- Always define resource limits and requests
|
|
110
|
+
- Use ConfigMaps for configuration, Secrets for sensitive data
|
|
111
|
+
- Implement liveness and readiness probes
|
|
112
|
+
- Use NetworkPolicies for security
|
|
113
|
+
- Use anti-affinity rules for high availability
|
|
114
|
+
- Horizontal Pod Autoscaler (HPA) for scaling
|
|
115
|
+
|
|
116
|
+
## Terraform
|
|
117
|
+
|
|
118
|
+
### Module Structure
|
|
119
|
+
```
|
|
120
|
+
terraform/
|
|
121
|
+
├── main.tf
|
|
122
|
+
├── variables.tf
|
|
123
|
+
├── outputs.tf
|
|
124
|
+
├── providers.tf
|
|
125
|
+
├── modules/
|
|
126
|
+
│ ├── vpc/
|
|
127
|
+
│ └── ecs/
|
|
128
|
+
└── environments/
|
|
129
|
+
├── dev/
|
|
130
|
+
│ ├── main.tf
|
|
131
|
+
│ └── terraform.tfvars
|
|
132
|
+
├── staging/
|
|
133
|
+
└── prod/
|
|
134
|
+
```
|
|
135
|
+
|
|
136
|
+
### Best Practices
|
|
137
|
+
```hcl
|
|
138
|
+
# Pin provider versions
|
|
139
|
+
terraform {
|
|
140
|
+
required_version = ">= 1.5.0"
|
|
141
|
+
required_providers {
|
|
142
|
+
aws = {
|
|
143
|
+
source = "hashicorp/aws"
|
|
144
|
+
version = "~> 5.0"
|
|
145
|
+
}
|
|
146
|
+
}
|
|
147
|
+
}
|
|
148
|
+
|
|
149
|
+
# Use variables for environment-specific values
|
|
150
|
+
variable "environment" {
|
|
151
|
+
type = string
|
|
152
|
+
description = "Deployment environment"
|
|
153
|
+
}
|
|
154
|
+
|
|
155
|
+
# Use modules for reusability
|
|
156
|
+
module "vpc" {
|
|
157
|
+
source = "./modules/vpc"
|
|
158
|
+
cidr = var.vpc_cidr
|
|
159
|
+
}
|
|
160
|
+
```
|
|
161
|
+
|
|
162
|
+
### Rules
|
|
163
|
+
- Pin provider versions
|
|
164
|
+
- Use remote state with locking (S3 + DynamoDB)
|
|
165
|
+
- Separate environments
|
|
166
|
+
- Run `terraform plan` before `terraform apply`
|
|
167
|
+
- Use `tflint` for linting
|
|
168
|
+
- Name resources consistently
|
|
169
|
+
|
|
170
|
+
## CI/CD
|
|
171
|
+
|
|
172
|
+
### GitHub Actions
|
|
173
|
+
```yaml
|
|
174
|
+
name: CI
|
|
175
|
+
on:
|
|
176
|
+
push:
|
|
177
|
+
branches: [main]
|
|
178
|
+
pull_request:
|
|
179
|
+
branches: [main]
|
|
180
|
+
|
|
181
|
+
jobs:
|
|
182
|
+
test:
|
|
183
|
+
runs-on: ubuntu-latest
|
|
184
|
+
steps:
|
|
185
|
+
- uses: actions/checkout@v4
|
|
186
|
+
- uses: actions/setup-go@v5
|
|
187
|
+
- run: go test ./...
|
|
188
|
+
- run: golangci-lint run
|
|
189
|
+
|
|
190
|
+
build:
|
|
191
|
+
needs: test
|
|
192
|
+
runs-on: ubuntu-latest
|
|
193
|
+
steps:
|
|
194
|
+
- uses: actions/checkout@v4
|
|
195
|
+
- run: docker build -t myapp:${{ github.sha }} .
|
|
196
|
+
```
|
|
197
|
+
|
|
198
|
+
### Best Practices
|
|
199
|
+
- Pipeline as code (never manual)
|
|
200
|
+
- Test before build, build before deploy
|
|
201
|
+
- Use immutable artifacts
|
|
202
|
+
- Implement rollback strategy
|
|
203
|
+
- Separate build and deploy stages
|
|
204
|
+
- Cache dependencies between runs
|
|
205
|
+
- Use secrets management (never hardcode)
|