tidy-project-structure
À propos
Cette Compétence Claude organise et nettoie la structure de projet en déplaçant les fichiers dans des répertoires conventionnels, en mettant à jour les README obsolètes et en consolidant les fichiers de configuration. Elle est utile lorsque les projets ont des fichiers dispersés, une documentation périmée ou une divergence de configuration entre les environnements. L'outil se concentre sur les améliorations structurelles sans altérer la logique du code principal.
Installation rapide
Claude Code
Recommandé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/tidy-project-structureCopiez et collez cette commande dans Claude Code pour installer cette compétence
Documentation
tidy-project-structure
Use When
Project org drifted from conventions:
- Files scattered, no clear org
- READMEs outdated | broken examples
- Config files multiplied (dev, staging, prod drift)
- Deprecated in project root
- Naming inconsistent across dirs
Do NOT use for code refactoring | dep restructuring. Focus = file org + doc hygiene.
In
| Parameter | Type | Required | Description |
|---|---|---|---|
project_path | string | Yes | Absolute path to project root |
conventions | string | No | Path to style guide (e.g., docs/conventions.md) |
archive_mode | enum | No | move (default) or delete for deprecated files |
readme_update | boolean | No | Update stale READMEs (default: true) |
Do
Step 1: Audit Layout
Cmp current structure vs conventions | language best practices.
Common conventions by lang:
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
Got: List of files/dirs violating saved to structure_audit.txt.
If err: No conventions doc'd → use language-std defaults.
Step 2: Move Misplaced Files
Relocate to conventional dirs.
Common moves:
- Test files outside
tests/→tests/ - Docs outside
docs/→docs/ - Build artifacts in
src/→ delete (gitignored) - Config in root →
config/|.config/
Per move:
# 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)
Got: All files in conventional locations; git history preserved via git mv.
If err: Moving breaks imports → update import paths | escalate.
Step 3: README Freshness
ID stale info in all READMEs.
Staleness indicators:
- Last mod >6 mo ago
- Old ver # references
- Broken links | code examples
- Missing sections (Install, Usage, Contributing)
- No license badge | broken badge links
# 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)
Got: List of stale READMEs in readme_freshness.txt w/ specific issues.
If err: markdown-link-check unavail → manually review external links.
Step 4: Update Stale READMEs
Fix broken links, update examples, add missing sections.
Std fixes:
- Replace broken badge URLs
- Update vers in install instructions
- Fix broken example code (run to verify)
- Add missing sections (template from conventions)
- Update copyright year
README template:
# 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.
**Got:** All READMEs updated; examples verified to run.
**If err:** Example code can't be verified → mark w/ warning comment.
### Step 5: Review Config Files
ID drift + consolidate duplicate settings.
**Common config issues**:
1. Multiple `.env` (`.env`, `.env.local`, `.env.dev`, `.env.prod`)
2. Duplicate settings across configs
3. Hardcoded secrets (use env vars)
4. Outdated API endpoints | feature flags
```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
Got: Config drift doc'd in config_review.txt; secrets flagged for escalation.
If err: Diff shows major divergence → escalate to devops-engineer.
Step 6: Archive Deprecated Files
Move | delete files no longer needed.
Candidates:
- Commented-out configs (
nginx.conf.old) - Legacy scripts not run in >1y
- Backup files (
file.bak,file~) - Build artifacts accidentally committed
Archive process:
# 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
Got: Deprecated archived; ARCHIVE_LOG.md updated.
If err: Uncertain if deprecated → leave + doc in report.
Step 7: Verify Naming Conventions
Check inconsistent file naming across project.
Common conventions:
- kebab-case:
my-file.js(JS/web) - snake_case:
my_file.py(Python) - PascalCase:
MyComponent.tsx(React) - camelCase:
myUtility.js(JS fns)
# 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)
Got: All files follow conventions | exceptions doc'd.
If err: Renaming breaks imports → update references | escalate.
Step 8: Generate Tidying Report
Doc all structural changes.
# 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]
Got: Report saved to TIDYING_REPORT.md.
If err: (N/A — generate regardless)
Check
Post-tidy:
- All files in conventional dirs
- No broken links any README
- README examples verified
- Config files reviewed for secrets
- Deprecated archived w/ docs
- Naming conventions consistent
- Git history preserved (
git mvnotmv) - Tests still pass after moves
Traps
- Break Relative Imports: Moving breaks relative paths. Update refs | use absolute.
- Lose Git History:
mvnotgit mv→ loses history. Always git cmds for moves. - Over-Organize: Too many nested dirs → harder navigation. Flat until complexity demands.
- Delete vs Archive: Direct delete → no recovery. Always archive first unless certain.
- Ignore Language Conventions: Personal pref over language std. Follow established.
- Not Updating Docs: Moving w/o updating README paths → broken docs.
→
- clean-codebase — remove dead code, fix lint warns
- repair-broken-references — fix links + imports after moves
- escalate-issues — route complex config to specialists
- devops/config-management — advanced config consolidation
- compliance/documentation-audit — comprehensive doc review
Dépôt GitHub
Compétences associées
qmd
Développementqmd est un outil CLI de recherche et d'indexation locale qui permet aux développeurs d'indexer et de rechercher dans des fichiers locaux en utilisant une recherche hybride combinant BM25, des embeddings vectoriels et du reranking. Il prend en charge à la fois une utilisation en ligne de commande et un mode MCP (Model Context Protocol) pour l'intégration avec Claude. L'outil utilise Ollama pour les embeddings et stocke les index localement, ce qui le rend idéal pour rechercher dans de la documentation ou des bases de code directement depuis le terminal.
subagent-driven-development
DéveloppementCette compétence exécute des plans de mise en œuvre en déployant un nouveau sous-agent pour chaque tâche indépendante, avec une revue de code entre les tâches. Elle permet une itération rapide tout en maintenant des contrôles de qualité grâce à ce processus de revue. Utilisez-la lorsque vous travaillez sur des tâches principalement indépendantes au sein d'une même session pour assurer une progression continue avec des vérifications de qualité intégrées.
mcporter
DéveloppementLa compétence mcporter permet aux développeurs de gérer et d'appeler des serveurs Model Context Protocol (MCP) directement depuis Claude. Elle fournit des commandes pour lister les serveurs disponibles, appeler leurs outils avec des arguments, et gérer l'authentification ainsi que le cycle de vie du démon. Utilisez cette compétence pour intégrer et tester les fonctionnalités des serveurs MCP dans votre flux de travail de développement.
adk-deployment-specialist
DéveloppementCette compétence déploie et orchestre des agents Vertex AI ADK en utilisant le protocole A2A, gérant la découverte d'AgentCard, la soumission de tâches, et prenant en charge des outils tels que le bac à sable d'exécution de code et la banque de mémoire. Elle permet de construire des systèmes multi-agents avec des modèles d'orchestration séquentiels, parallèles ou en boucle en Python, Java ou Go. Utilisez-la lorsqu'on vous demande de déployer des agents ADK ou d'orchestrer des flux de travail d'agents sur Google Cloud.
