MCP HubMCP Hub
스킬 목록으로 돌아가기

tidy-project-structure

pjt222
업데이트됨 5 days ago
10 조회
17
2
17
GitHub에서 보기
개발ai

정보

이 스킬은 파일을 표준 디렉토리로 이동시키고, 오래된 README를 업데이트하며, 코드 로직을 변경하지 않고 설정 변동을 정리하여 지저분한 프로젝트를 정리합니다. 파일이 흩어져 있거나, 문서가 최신 상태가 아니거나, 여러 환경 설정이 누적된 경우에 사용하세요. 또한 이 스킬은 더 이상 사용되지 않는 항목을 보관하고 프로젝트 전체의 명명 규칙을 표준화합니다.

빠른 설치

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/tidy-project-structure

Claude Code에서 이 명령을 복사하여 붙여넣어 스킬을 설치하세요

문서

tidy-project-structure

適用時機

當專案組織自慣例漂移時用此技能:

  • 檔散於目錄而無清晰組織
  • README 過時或含損壞範例
  • 配置檔已增多(dev、staging、prod 漂移)
  • 廢棄檔留於專案根
  • 跨目錄之命名慣例不一致

勿用於代碼重構或依賴重組。此技能聚焦於檔案組織與文件衛生。

輸入

ParameterTypeRequiredDescription
project_pathstringYesAbsolute path to project root
conventionsstringNoPath to style guide (e.g., docs/conventions.md)
archive_modeenumNomove (default) or delete for deprecated files
readme_updatebooleanNoUpdate stale READMEs (default: true)

步驟

步驟一:稽核目錄佈局

將當前結構與專案慣例或語言最佳實踐相比。

依語言之常見慣例

JavaScript/TypeScript

src/          # Source code
tests/        # Test files
dist/         # Build output (gitignored)
docs/         # Documentation
.github/      # CI/CD workflows

Python

package_name/      # Package code
tests/             # Test suite
docs/              # Sphinx docs
scripts/           # Utility scripts

R

R/                 # R source
tests/testthat/    # Test suite
man/               # Documentation (generated)
vignettes/         # Long-form guides
inst/              # Installed files
data/              # Package data

Rust

src/          # Source code
tests/        # Integration tests
benches/      # Benchmarks
examples/     # Usage examples

預期: 違反慣例之檔/目錄清單存於 structure_audit.txt

失敗時: 若無記錄之慣例,用語言標準預設

步驟二:移動錯置之檔

將檔重置於其慣例目錄。

常見移動

  1. tests/ 外之測試檔 → 移至 tests/
  2. docs/ 外之文件 → 移至 docs/
  3. src/ 中之建置產物 → 刪(應 gitignored)
  4. 根之配置檔 → 移至 config/.config/

對每移動:

# Check if file is referenced anywhere
grep -r "filename" .

# If no references or only relative path references:
mkdir -p target_directory/
git mv source/file target_directory/file

# Update any imports/requires
# (language-specific — see repair-broken-references skill)

預期: 所有檔於慣例位置;git 歷史經 git mv 保留

失敗時: 若移動破壞引入,更新引入路徑或上報

步驟三:檢查 README 新鮮度

識別所有 README 檔中之過時資訊。

過時指標

  1. 上次修改超過 6 個月前
  2. 參考舊版本號
  3. 損壞之連結或代碼範例
  4. 缺節(Installation、Usage、Contributing)
  5. 無授權標章或損壞標章連結
# Find all READMEs
find . -name "README.md" -o -name "readme.md"

# For each README:
# - Check last modified date
git log -1 --format="%ci" README.md

# - Check for broken links
markdown-link-check README.md

# - Verify example code still runs (sample first example)

預期: 過時 README 之清單於 readme_freshness.txt 含具體問題

失敗時: 若 markdown-link-check 不可用,手動審外部連結

步驟四:更新過時 README

修損壞連結、更新範例、加缺節。

標準修復

  1. 替損壞標章 URL
  2. 更新安裝指引中之版本號
  3. 修損壞範例代碼(執以驗)
  4. 加缺節(用專案慣例之模板)
  5. 更新版權年

README 模板結構

# Project Name

Brief description (1-2 sentences).

## Installation

```bash
# Language-specific install command

Usage

# Basic example

Documentation

Link to full docs.

Contributing

Link to CONTRIBUTING.md or inline guidelines.

License

LICENSE badge and link.


**預期:** 所有 README 已更新;範例已驗可執

**失敗時:** 若範例代碼無法驗,以警告註標記

### 步驟五:審配置檔

識別配置漂移並合併重複設定。

**常見配置問題**:
1. 多個 `.env` 檔(`.env`、`.env.local`、`.env.dev`、`.env.prod`)
2. 跨配置檔之重複設定
3. 硬編密(應用環境變數)
4. 過時 API 端點或功能旗標

```bash
# Find all config files
find . -name "*.config.*" -o -name ".env*" -o -name "*.yml" -o -name "*.yaml"

# For each config:
# - Check for duplicate keys
# - Grep for hardcoded secrets (API keys, tokens, passwords)
grep -E "(api[_-]?key|token|password|secret)" config_file

# - Compare dev vs prod settings
diff .env.dev .env.prod

預期: 配置漂移記於 config_review.txt;密標出供上報

失敗時: 若 diff 顯示主要分歧,上報至 devops-engineer

步驟六:歸檔廢棄檔

將不再需之檔移或刪。

歸檔候選

  • 已註解之配置檔(如 nginx.conf.old
  • 超過 1 年未執行之遺留腳本
  • 備份檔(如 file.bakfile~
  • 意外提交之建置產物

歸檔流程

# Create archive directory (if archive_mode=move)
mkdir -p archive/YYYY-MM-DD/

# For each deprecated file:
# 1. Verify not referenced anywhere
grep -r "filename" .

# 2. Check git history for last modification
git log -1 --format="%ci" filename

# 3. If not modified in >1 year and no references:
if [ "$archive_mode" = "move" ]; then
  git mv filename archive/YYYY-MM-DD/
else
  git rm filename
fi

# 4. Document in ARCHIVE_LOG.md
echo "- filename (reason, last modified: DATE)" >> ARCHIVE_LOG.md

預期: 廢棄檔已歸檔;ARCHIVE_LOG.md 已更新

失敗時: 若不確檔是否廢棄,留於原位並於報告中記錄

步驟七:驗命名慣例

跨專案檢檔命名不一致。

常見慣例

  • kebab-casemy-file.js(JS/web 專案常見)
  • snake_casemy_file.py(Python 標準)
  • PascalCaseMyComponent.tsx(React 組件)
  • camelCasemyUtility.js(JavaScript 函式)
# Find files violating conventions
# Example: Python project expecting snake_case
find . -name "*.py" | grep -v "__pycache__" | grep -E "[A-Z-]"

# For each violation, either:
# 1. Rename to match conventions
# 2. Document exception (e.g., Django settings.py convention)

預期: 所有檔皆從命名慣例或例外已記錄

失敗時: 若改名破壞引入,更新引用或上報

步驟八:產生整理報告

記錄所有結構變更。

# Project Structure Tidying Report

**Date**: YYYY-MM-DD
**Project**: <project_name>

## Directory Changes

- Moved X files to conventional directories
- Created Y new directories
- Archived Z deprecated files

## README Updates

- Updated W stale READMEs
- Fixed X broken links
- Verified Y code examples

## Config Cleanup

- Consolidated X duplicate settings
- Flagged Y hardcoded secrets for removal
- Documented Z config drift issues

## Files Archived

See ARCHIVE_LOG.md for full list (Z files).

## Naming Convention Fixes

- Renamed X files to match conventions
- Documented Y exceptions

## Escalations

- [Config drift requiring devops review]
- [Hardcoded secrets requiring security audit]

預期: 報告存至 TIDYING_REPORT.md

失敗時:(不適用——無論如何皆產生報告)

驗證清單

整理後:

  • 所有檔於慣例目錄
  • 任何 README 中無損壞連結
  • README 範例已驗可執
  • 配置檔已審密
  • 廢棄檔已歸檔附記錄
  • 命名慣例一致
  • Git 歷史已保留(用 git mv,非 mv
  • 移動後測試仍通過

常見陷阱

  1. 破壞相對引入:移動檔破壞相對引入路徑。更新所有引用或用絕對引入。

  2. 失 Git 歷史:用 mv 而非 git mv 失檔之歷史。永遠用 git 命令以移動。

  3. 過度組織:建過多巢狀目錄使導航更難。保持平直至複雜需結構。

  4. 刪而非歸檔:直接刪失復原能力。除非確定否則永遠先歸檔。

  5. 忽略語言慣例:將個人偏好凌駕語言標準。從既建慣例。

  6. 未更新文件:移動檔而不更新 README 路徑留損壞文件。

相關技能

GitHub 저장소

pjt222/agent-almanac
경로: i18n/wenyan-lite/skills/tidy-project-structure
0
agentsagentskillsai-assisted-developmentclaude-codeskillsteams

연관 스킬

qmd

개발

qmd는 BM25, 벡터 임베딩, 재순위화를 결합한 하이브리드 검색을 통해 로컬 파일을 색인화하고 검색할 수 있는 로컬 검색 및 색인화 CLI 도구입니다. 명령줄 사용과 Claude 통합을 위한 MCP(Model Context Protocol) 모드를 모두 지원합니다. 이 도구는 임베딩에 Ollama를 사용하고 색인을 로컬에 저장하여 터미널에서 직접 문서나 코드베이스를 검색하는 데 이상적입니다.

스킬 보기

subagent-driven-development

개발

이 스킬은 각 독립적인 작업마다 새로운 하위 에이전트를 배치하고 작업 사이에 코드 리뷰를 진행하여 구현 계획을 실행합니다. 이 리뷰 프로세스를 통해 품질 게이트를 유지하면서 빠른 반복 작업을 가능하게 합니다. 동일한 세션 내에서 대부분 독립적인 작업을 진행할 때 내장된 품질 검증과 함께 지속적인 진행을 보장하기 위해 사용하세요.

스킬 보기

mcporter

개발

mcporter 스킬은 개발자가 Claude에서 직접 Model Context Protocol(MCP) 서버를 관리하고 호출할 수 있도록 합니다. 이 스킬은 사용 가능한 서버를 나열하고, 인수를 사용해 해당 서버의 도구를 호출하며, 인증 및 데몬 생명주기를 처리하는 명령어를 제공합니다. 개발 워크플로우에서 MCP 서버 기능을 통합하고 테스트할 때 이 스킬을 사용하세요.

스킬 보기

adk-deployment-specialist

개발

이 스킬은 A2A 프로토콜을 사용하여 Vertex AI ADK 에이전트를 배포하고 오케스트레이션하며, AgentCard 검색, 작업 제출, 코드 실행 샌드박스 및 메모리 뱅크와 같은 지원 도구를 관리합니다. Python, Java 또는 Go 언어로 순차, 병렬 또는 루프 오케스트레이션 패턴을 갖춘 다중 에이전트 시스템 구축을 가능하게 합니다. Google Cloud에서 ADK 에이전트 배포 또는 에이전트 워크플로우 오케스트레이션을 요청받았을 때 사용하세요.

스킬 보기