--- name: style-cleanup description: "Clean up formatting and code style with the repo’s existing toolchain (clang-format/black/isort/flake8/pre-commit/etc). Triggers: 整理代码风格, 格式化, format, fmt, lint fix, clang-format, black, isort." --- # Style Cleanup Workflow(整理代码风格 / 格式化) ## When to Use - “整理代码风格 / 格式化 / format / fmt / lint fix” - 合并前做一次风格对齐(不做语义级重构) - 批量改动后,希望把格式化与机械性风格问题收敛到可控 diff ## Inputs(required) - Scope:仅本次改动文件(默认)|全仓库|指定目录/文件类型 - Languages:自动识别;如为多语言仓库请确认优先级 - Verification:至少一个可执行的验证命令(如未知,先问/再推断) ## Procedure(default) 1. **Baseline** - 记录当前状态:`git status --porcelain` - 明确范围(默认只处理变更文件): - staged:`git diff --name-only --cached` - unstaged:`git diff --name-only` - untracked:`git ls-files -o --exclude-standard` 2. **Detect Toolchain(prefer repo truth)** - 优先用仓库既有入口脚本 / 配置: - JS/TS:`package.json` scripts(`format`/`lint`/`lint:fix`)、prettier/biome/eslint 配置 - Python:`pyproject.toml` / `.flake8` / `.pylintrc` / `.pre-commit-config.yaml` - C/C++:`.clang-format`(唯一真相),可选 `.clang-tidy` - Shell:`shfmt`/`shellcheck`(若仓库已使用) - Markdown:prettier/markdownlint(仅在仓库已固定时使用) - 禁止默认“引入新 formatter/linter 配置”;缺配置时只做最小手工调整,并先确认是否允许落地配置文件。 3. **Apply(format first, then lint)** - 先 formatter(会改文件),再 lint(检查),再 lint --fix(如有),最后再跑一次 check 确认干净。 - 默认只处理目标文件集合;避免全仓库 reformat(除非用户明确要求)。 - 典型命令(按仓库实际替换): - C++:`clang-format -i `;CI 校验:`clang-format --dry-run --Werror ` - Python:`black ` + `isort `;或 `pre-commit run --files ` - JS/TS:`npm run format -- ` / `pnpm ...` / `npx prettier -w `(以项目脚本为准) 4. **Guardrails** - 只做风格与格式:不改变行为、不改 public API、不做重构。 - 如格式化导致 diff 暴涨(文件数/行数过大):先停下,给出原因与两种方案让用户选: 1. 仅格式化本次改动文件(推荐默认) 2. 全仓库统一格式(通常需要单独 PR/提交) 5. **Verify** - 跑最小验证命令(仓库已有命令优先)。 - 若无法运行(缺环境/缺权限/缺依赖):说明原因,并给出替代验证(例如 formatter 二次运行无 diff、lint 输出为 0)。 ## Playbook as Authority(如果项目 vendoring 了本 Playbook) 当目标仓库包含 `docs/standards/playbook/docs/`(或直接包含 `docs/tsl|cpp|python/...`),风格决策参考: - TSL:`docs/tsl/code_style.md`、`docs/tsl/naming.md`、`docs/tsl/toolchain.md` - C++:`docs/cpp/code_style.md`、`docs/cpp/naming.md`、`docs/cpp/toolchain.md` - Python:`docs/python/style_guide.md`、`docs/python/tooling.md`、`docs/python/configuration.md` ## Output Contract(stable) - Scope:实际处理范围(文件/目录/语言) - Toolchain:使用了哪些工具与配置依据 - Commands:实际执行命令(按顺序) - Changes:修改文件列表 + 改动规模概览 - Remaining:仍未修复的问题(分类:formatter / lint / style)+ 下一步建议 ## Success Criteria - formatter 二次运行无新增 diff - lint/检查命令通过(或仅剩已确认的例外) - 未引入语义变更(仅格式/风格) ## Failure Handling - 工具缺失:优先提示安装方式或替代命令;无法解决则退回“最小手工风格修复 + 明确未覆盖项” - 规则冲突(如 black vs flake8):以仓库配置为准;必要时调整例外配置但需先确认