スキル一覧に戻る

clean-codebase

pjt222
更新日 5 days ago
34 閲覧
17
2
17
GitHubで表示
ドキュメントapi

について

このスキルは、ビジネスロジックを変更することなく、デッドコードや未使用のインポートを削除し、リント警告を修正し、フォーマットを正規化することで、自動化されたコードベースのクリーンアップを実行します。静的解析ツールが修正可能な保守上の問題を報告する際、急速な開発の過程で蓄積された技術的負債に対処するのに理想的です。散らかりや不整合を排除するような保守タスクに使用しますが、アーキテクチャのリファクタリングやバグ修正には使用しません。

クイックインストール

Claude Code

推奨
メイン
npx skills add pjt222/agent-almanac -a claude-code
プラグインコマンド代替
/plugin add https://github.com/pjt222/agent-almanac
Git クローン代替
git clone https://github.com/pjt222/agent-almanac.git ~/.claude/skills/clean-codebase

このコマンドをClaude Codeにコピー&ペーストしてスキルをインストールします

ドキュメント

clean-codebase

用時

用此技於庫積污者:

  • 速開發中 lint 警已累
  • 未用之引與變雜亂諸檔
  • 死碼徑存而未除
  • 諸檔之式不一
  • 靜析具報可補之問

勿用於構重構、修訛、或業理之變。此技專於潔與自動之清。

ParameterTypeRequiredDescription
codebase_pathstringYesAbsolute path to codebase root
languagestringYesPrimary language (js, python, r, rust, etc.)
cleanup_modeenumNosafe (default) or aggressive
run_testsbooleanNoRun test suite after cleanup (default: true)
backupbooleanNoCreate 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.jsoncloc_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())"

通法

  1. grep 函之定
  2. grep 函之呼
  3. 報定而未呼之函

得: dead_code.txt 列未用之函、變、檔

敗則: 若靜析具不得,手察近之提交史尋孤碼

第四步:除未用之引

清引區,除永未用之包。

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

得: 諸未用之引句皆除

敗則: 若除引而建敗,間接有用——復而書之

第五步:除死碼(依模)

安模(默):

  • 只除明標為棄之碼
  • 除已注釋之碼塊(若逾十行且逾六月)
  • 除引已畢之 TODO 注

侵模(擇入):

  • 除第三步所識諸未用之函
  • 除零引之私法
  • 除棄功之旗

每候刪:

  1. 驗庫中零引
  2. 察 git 史近之動(若三十日內改則略)
  3. 除碼而加條入 CLEANUP_LOG.md

得: 死碼已除;CLEANUP_LOG.md 書諸除

敗則: 若不確碼真死,移入 archive/ 而非除

第六步:式之一

確諸檔式一(雖 lint 不捕)。

  1. 一行末(LF 抑 CRLF)
  2. 確檔末單新行
  3. 除尾空
  4. 一縮(空抑 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 管已通

  1. 除仍以反射用之碼:靜析漏動呼(如 eval()、元編程)。必察 git 史。

  2. 破隱依:除依所用之引。每除引後行測。

  3. 刪活功之旗:雖當枝未用,或於他境活。察部署之設。

  4. 過侵之式:如 blackprettier 可重式生冗 diff。設具合項目之風。

  5. 忽測覆:無測之庫不可安清。若覆低,先升補測。

  6. 不備:除前必建 backup_YYYYMMDD/,雖用 git。

  7. 混系上之誤 R 二:於 WSL 或 Docker,Rscript 或解為跨臺之包而非原生 R。以 which Rscript && Rscript --version 察。宜用原生 R 二(如 Linux/WSL 上之 /usr/local/bin/Rscript)以信。見 Setting Up Your Environment 以 R 路之設。

GitHub リポジトリ

pjt222/agent-almanac
パス: i18n/wenyan/skills/clean-codebase
0
agentsagentskillsai-assisted-developmentclaude-codeskillsteams

関連スキル

railway-docs

ドキュメント

このスキルは、Railwayの機能や仕様、特定のドキュメントURLに関する質問に答えるために、最新のRailwayドキュメントを取得します。開発者がRailwayの公式情報源から正確かつ最新の情報を直接受け取れるようにします。ユーザーがRailwayの動作方法について尋ねたり、Railwayドキュメントを参照する際にご利用ください。

スキルを見る

n8n-code-python

ドキュメント

このClaudeスキルは、n8nのコードノードでPythonコードを記述するための専門的なガイダンスを提供します。具体的には、Pythonの標準ライブラリの使用方法や、`_input`、`_json`、`_node`といったn8n独自の構文の扱い方を解説します。n8n環境内におけるPythonの制限事項を開発者が理解できるよう支援し、ほとんどのワークフローではJavaScriptの使用を推奨しながらも、特定のデータ変換ニーズに対応するPythonソリューションを提案します。

スキルを見る

archon

ドキュメント

Archonスキルは、RAGを活用したセマンティック検索とプロジェクト管理をREST APIを通じて提供します。ドキュメントの検索、階層的なプロジェクト/タスクの管理、ドキュメントアップロード機能を備えたナレッジ検索の実行にご利用いただけます。外部ドキュメントを検索する際は、他の情報源を利用する前に常にArchonを最優先で使用してください。

スキルを見る

n8n-code-javascript

ドキュメント

このClaudeスキルは、n8nのCodeノードでJavaScriptコードを書くための専門的なガイダンスを提供します。`$input`/`$json`変数、HTTPヘルパー、DateTime処理などの重要なn8n固有の構文を網羅し、一般的なエラーのトラブルシューティングも行います。CodeノードでカスタムJavaScript処理を必要とするn8nワークフローを開発する際にご利用ください。

スキルを見る