clean-codebase
关于
This skill automatically cleans up code hygiene issues like dead code, unused imports, and lint warnings while normalizing formatting across a codebase. It's designed for maintenance phases after rapid development when technical debt accumulates, without altering business logic or architecture. Use it to consistently fix static analysis warnings and enforce formatting standards.
快速安装
Claude Code
推荐npx skills add pjt222/agent-almanac -a claude-code/plugin add https://github.com/pjt222/agent-almanacgit clone https://github.com/pjt222/agent-almanac.git ~/.claude/skills/clean-codebase在 Claude Code 中复制并粘贴此命令以安装该技能
技能文档
clean-codebase
用
庫積衛生債時用:
- lint 警速積於急開發
- 未用入、變混檔
- 死碼路在而未除
- 格式諸檔不一
- 靜析具報可修者
勿用於架構重構、修錯、商邏變。此技純衛生與自動清。
入
| 參 | 類 | 必 | 述 |
|---|---|---|---|
codebase_path | string | Yes | Absolute path to codebase root |
language | string | Yes | Primary language (js, python, r, rust, etc.) |
cleanup_mode | enum | No | safe (default) or aggressive |
run_tests | boolean | No | Run test suite after cleanup (default: true) |
backup | boolean | No | Create backup before deletion (default: true) |
行
一:清前察
量現狀以後比進。
# Count lint warnings by severity
lint_tool --format json > lint_before.json
# Count lines of code
cloc . --json > cloc_before.json
# List unused symbols (language-dependent)
# JavaScript/TypeScript: ts-prune or depcheck
# Python: vulture
# R: lintr unused function checks
得: 基線存於 lint_before.json 與 cloc_before.json
敗: lint 具缺→略自動修、焦手審
二:修自動 lint 警
施安全自動修(間距、引號、分號、末空白)。
JavaScript/TypeScript:
eslint --fix .
prettier --write .
Python:
black .
isort .
ruff check --fix .
R:
Rscript -e "styler::style_dir('.')"
Rust:
cargo fmt
cargo clippy --fix --allow-dirty
得: 諸安全 lint 警皆解;格式一致
敗: 自動修致測敗→復而升
三:識死碼路
用靜析尋未引函、未用變、孤檔。
JavaScript/TypeScript:
ts-prune | tee dead_code.txt
depcheck | tee unused_deps.txt
Python:
vulture . | tee dead_code.txt
R:
Rscript -e "lintr::lint_dir('.', linters = lintr::unused_function_linter())"
通法:
- Grep 函定
- Grep 函呼
- 報定而未呼者
得: dead_code.txt 列未用函、變、檔
敗: 靜析具缺→手審近 commit 史尋孤碼
四:除未用入
清入塊,除未用之包引。
JavaScript:
eslint --fix --rule 'no-unused-vars: error'
Python:
autoflake --remove-all-unused-imports --in-place --recursive .
R:
# Manual review: grep for library() calls, check if package used
grep -r "library(" . | cut -d: -f2 | sort | uniq
得: 未用入語皆除
敗: 除入破建→間接用也,復而記
五:除死碼(依模)
Safe Mode(默):
- 只除明標廢者
- 除註釋塊(>10 行且 >6 月舊)
- 除 TODO 涉已畢之 issue
Aggressive Mode(入選):
- 除步三所識諸未用函
- 除零引之私法
- 除已廢功能之 feature flag
每候刪:
- 驗庫中零引
- 察 git 史近動(30 日內改→略)
- 刪且入
CLEANUP_LOG.md
得: 死碼已除;CLEANUP_LOG.md 記諸刪
敗: 碼死否不確→移至 archive/ 目錄替代
六:歸格式
確諸檔格式一致(即 linter 未捕者)。
- 歸行末(LF vs CRLF)
- 檔末單換行
- 除末空白
- 歸縮進(空格 vs tab、寬)
# Example: Fix line endings and trailing whitespace
find . -type f -name "*.js" -exec sed -i 's/\r$//' {} +
find . -type f -name "*.js" -exec sed -i 's/[[:space:]]*$//' {} +
得: 諸檔守一致格式
敗: sed 破二進檔→略而記
七:行測
驗清未破功能。
# Language-specific test command
npm test # JavaScript
pytest # Python
R CMD check # R
cargo test # Rust
得: 諸測皆過(或清前同之敗)
敗: 漸復以識破因,升報
八:生清報
記諸變以審。
# Codebase Cleanup Report
**Date**: YYYY-MM-DD
**Mode**: safe | aggressive
**Language**: <language>
## Metrics
| Metric | Before | After | Change |
|--------|--------|-------|--------|
| Lint warnings | X | Y | -Z |
| Lines of code | A | B | -C |
| Unused imports | D | 0 | -D |
| Dead functions | E | F | -G |
## Changes Applied
1. Fixed X lint warnings (automated)
2. Removed Y unused imports
3. Deleted Z lines of dead code (see CLEANUP_LOG.md)
4. Normalized formatting across W files
## Escalations
- [Issue description requiring human review]
- [Uncertain deletion moved to archive/]
## Validation
- [x] All tests pass
- [x] Backup created: backup_YYYYMMDD/
- [x] CLEANUP_LOG.md updated
得: 報存於 CLEANUP_REPORT.md 於項目根
敗: (無——無論結果皆生報)
驗
清後:
- 諸測皆過(或清前同敗)
- 無新 lint 警
- 刪前備已立
-
CLEANUP_LOG.md記諸除碼 - 清報含量度已生
- Git diff 審察意外變
- CI 管道過
忌
-
除反射尚用之碼:靜析漏動呼(如
eval()、元編程)。必察 git 史。 -
破隱依:除依賴所用之入。每除後行測。
-
刪在用功能之 feature flag:雖當前分支未用,或他境在行。察部署配。
-
過激格式化:如
black、prettier或重排致無謂 diff。配具守項目風。 -
忽測覆:無測之庫不可安清。覆低→先升補測。
-
不備:刪前必建
backup_YYYYMMDD/,即 git 在亦然。 -
混系統之誤 R bin:WSL 或 Docker 中,
Rscript或解至跨平臺封裝非原生 R。驗which Rscript && Rscript --version。取原生 R bin(如 Linux/WSL 之/usr/local/bin/Rscript)為靠。見Setting Up Your Environment之 R 路徑配。
參
- tidy-project-structure — 整目錄佈、更 README
- repair-broken-references — 修死鏈與入
- escalate-issues — 複難至專
- r-packages/run-r-cmd-check — 行 R 包全察
- devops/dependency-audit — 察過時依
GitHub 仓库
相关推荐技能
railway-docs
文档Railway Docs Skill可实时获取最新的Railway官方文档,确保回答的准确性。当开发者询问Railway功能特性、工作原理或分享docs.railway.com链接时,应优先使用此技能。它通过专门的LLM优化文档源提供最新信息,避免依赖过时记忆来回答技术问题。
n8n-code-python
文档该Skill为在n8n平台的Python代码节点中编写代码提供专家指导,特别适用于需要使用_input/_json/_node语法、Python标准库或了解n8n中Python限制的场景。它强调JavaScript应作为首选方案,仅当需要特定Python功能或对Python语法更熟悉时才使用Python。Skill提供了快速入门模板和关键注意事项,帮助开发者在n8n中高效编写Python代码。
archon
文档Archon Skill为开发者提供了基于RAG的语义搜索和项目任务管理功能,可通过REST API访问知识库。它支持文档搜索、网站爬取、文件上传和版本控制,适用于技术文档查询和项目管理场景。首次使用时需要配置Archon主机地址,建议在处理外部文档时优先使用该Skill。
n8n-code-javascript
文档这个Skill为n8n工作流中的JavaScript代码节点提供专业指导,涵盖数据处理、HTTP请求和日期操作等核心场景。它详细解释了如何正确使用n8n特有的`$input`/`$json`语法、`$helpers`工具以及DateTime对象,并包含关键的错误排查和模式选择建议。开发者通过该Skill能快速掌握Code节点的正确返回格式、数据访问方法和常见陷阱解决方案。
