tidy-project-structure
À propos
Cette compétence organise les structures de projet désordonnées en déplaçant les fichiers dans des répertoires conventionnels, en mettant à jour les README obsolètes, en nettoyant la dérive de configuration et en archivant les éléments obsolètes sans altérer la logique du code central. Utilisez-la lorsque les fichiers sont dispersés sans organisation claire, que les README sont périmés ou que les fichiers de configuration se sont multipliés à travers les environnements. Elle aide à maintenir des conventions de nommage cohérentes et supprime les fichiers obsolètes de la racine du projet.
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
Projektstruktur aufraumen
Wann verwenden
Diesen Skill verwenden wenn die Projektorganisation von Konventionen abgewichen ist:
- Dateien ohne klare Organisation ueber Verzeichnisse verstreut
- READMEs veraltet oder mit defekten Beispielen
- Konfigurationsdateien haben sich vermehrt (Dev-, Staging-, Prod-Drift)
- Veraltete Dateien verbleiben im Projektstamm
- Namenskonventionen inkonsistent ueber Verzeichnisse hinweg
NICHT verwenden fuer Code-Refactoring oder Abhaengigkeits-Umstrukturierung. Dieser Skill konzentriert sich auf Dateiorganisation und Dokumentationshygiene.
Eingaben
| Parameter | Typ | Erforderlich | Beschreibung |
|---|---|---|---|
project_path | string | Ja | Absoluter Pfad zum Projektstamm |
conventions | string | Nein | Pfad zum Stilhandbuch (z.B. docs/conventions.md) |
archive_mode | enum | Nein | move (Standard) oder delete fuer veraltete Dateien |
readme_update | boolean | Nein | Veraltete READMEs aktualisieren (Standard: true) |
Vorgehensweise
Schritt 1: Verzeichnisstruktur pruefen
Aktuelle Struktur mit Projektkonventionen oder sprachspezifischen Best Practices vergleichen.
Gaengige Konventionen nach Sprache:
JavaScript/TypeScript:
src/ # Quellcode
tests/ # Testdateien
dist/ # Build-Ausgabe (gitignored)
docs/ # Dokumentation
.github/ # CI/CD-Workflows
Python:
package_name/ # Paketcode
tests/ # Testsuite
docs/ # Sphinx-Dokumentation
scripts/ # Hilfsskripte
R:
R/ # R-Quellcode
tests/testthat/ # Testsuite
man/ # Dokumentation (generiert)
vignettes/ # Ausfuehrliche Anleitungen
inst/ # Installierte Dateien
data/ # Paketdaten
Rust:
src/ # Quellcode
tests/ # Integrationstests
benches/ # Benchmarks
examples/ # Verwendungsbeispiele
Erwartet: Liste der gegen Konventionen verstossenden Dateien/Verzeichnisse in structure_audit.txt gespeichert
Bei Fehler: Wenn keine Konventionen dokumentiert sind, sprachspezifische Standards verwenden
Schritt 2: Fehlplatzierte Dateien verschieben
Dateien in ihre konventionellen Verzeichnisse umlagern.
Haeufige Verschiebungen:
- Testdateien ausserhalb von
tests/nachtests/verschieben - Dokumentation ausserhalb von
docs/nachdocs/verschieben - Build-Artefakte in
src/loeschen (sollten gitignored sein) - Konfigurationsdateien im Stammverzeichnis nach
config/oder.config/verschieben
Fuer jede Verschiebung:
# Pruefen ob Datei irgendwo referenziert wird
grep -r "filename" .
# Wenn keine Referenzen oder nur relative Pfadreferenzen:
mkdir -p target_directory/
git mv source/file target_directory/file
# Alle Imports/Requires aktualisieren
# (sprachspezifisch — siehe repair-broken-references Skill)
Erwartet: Alle Dateien an konventionellen Positionen; Git-Historie ueber git mv erhalten
Bei Fehler: Wenn Verschieben Imports bricht, Importpfade aktualisieren oder eskalieren
Schritt 3: README-Aktualitaet pruefen
Veraltete Informationen in allen README-Dateien identifizieren.
Veralterungsindikatoren:
- Letzte Aenderung vor >6 Monaten
- Referenzen auf alte Versionsnummern
- Defekte Links oder Code-Beispiele
- Fehlende Abschnitte (Installation, Verwendung, Mitwirkung)
- Kein Lizenz-Badge oder defekte Badge-Links
# Alle READMEs finden
find . -name "README.md" -o -name "readme.md"
# Fuer jede README:
# - Letztes Aenderungsdatum pruefen
git log -1 --format="%ci" README.md
# - Auf defekte Links pruefen
markdown-link-check README.md
# - Beispielcode auf Funktionsfaehigkeit pruefen (erstes Beispiel testen)
Erwartet: Liste veralteter READMEs in readme_freshness.txt mit konkreten Problemen
Bei Fehler: Wenn markdown-link-check nicht verfuegbar, externe Links manuell pruefen
Schritt 4: Veraltete READMEs aktualisieren
Defekte Links reparieren, Beispiele aktualisieren, fehlende Abschnitte ergaenzen.
Standard-Korrekturen:
- Defekte Badge-URLs ersetzen
- Versionsnummern in Installationsanweisungen aktualisieren
- Defekten Beispielcode reparieren (zur Verifizierung ausfuehren)
- Fehlende Abschnitte ergaenzen (Vorlage aus Projektkonventionen verwenden)
- Copyright-Jahr aktualisieren
README-Vorlagenstruktur:
# Projektname
Kurzbeschreibung (1-2 Saetze).
## Installation
```bash
# Sprachspezifischer Installationsbefehl
Verwendung
# Grundlegendes Beispiel
Dokumentation
Link zur vollstaendigen Dokumentation.
Mitwirkung
Link zu CONTRIBUTING.md oder eingebettete Richtlinien.
Lizenz
LIZENZ-Badge und Link.
**Erwartet:** Alle READMEs aktualisiert; Beispiele auf Funktionsfaehigkeit verifiziert
**Bei Fehler:** Wenn Beispielcode nicht verifizierbar, mit Warnkommentar markieren
### Schritt 5: Konfigurationsdateien ueberpruefen
Konfigurationsdrift identifizieren und doppelte Einstellungen konsolidieren.
**Haeufige Konfigurationsprobleme**:
1. Mehrere `.env`-Dateien (`.env`, `.env.local`, `.env.dev`, `.env.prod`)
2. Doppelte Einstellungen ueber Konfigurationsdateien hinweg
3. Hartcodierte Geheimnisse (sollten Umgebungsvariablen verwenden)
4. Veraltete API-Endpunkte oder Feature-Flags
```bash
# Alle Konfigurationsdateien finden
find . -name "*.config.*" -o -name ".env*" -o -name "*.yml" -o -name "*.yaml"
# Fuer jede Konfiguration:
# - Auf doppelte Schluessel pruefen
# - Nach hartcodierten Geheimnissen suchen (API-Schluessel, Token, Passwoerter)
grep -E "(api[_-]?key|token|password|secret)" config_file
# - Dev- vs Prod-Einstellungen vergleichen
diff .env.dev .env.prod
Erwartet: Konfigurationsdrift in config_review.txt dokumentiert; Geheimnisse zur Eskalation markiert
Bei Fehler: Wenn Diff grosse Abweichungen zeigt, an devops-engineer eskalieren
Schritt 6: Veraltete Dateien archivieren
Nicht mehr benoetigte Dateien verschieben oder loeschen.
Kandidaten fuer Archivierung:
- Auskommentierte Konfigurationsdateien (z.B.
nginx.conf.old) - Altskripte die seit >1 Jahr nicht ausgefuehrt wurden
- Sicherungsdateien (z.B.
file.bak,file~) - Versehentlich committete Build-Artefakte
Archivierungsprozess:
# Archivverzeichnis erstellen (wenn archive_mode=move)
mkdir -p archive/YYYY-MM-DD/
# Fuer jede veraltete Datei:
# 1. Pruefen ob nirgends referenziert
grep -r "filename" .
# 2. Git-Historie auf letzte Aenderung pruefen
git log -1 --format="%ci" filename
# 3. Wenn seit >1 Jahr nicht geaendert und keine Referenzen:
if [ "$archive_mode" = "move" ]; then
git mv filename archive/YYYY-MM-DD/
else
git rm filename
fi
# 4. In ARCHIVE_LOG.md dokumentieren
echo "- filename (Grund, letzte Aenderung: DATUM)" >> ARCHIVE_LOG.md
Erwartet: Veraltete Dateien archiviert; ARCHIVE_LOG.md aktualisiert
Bei Fehler: Wenn unsicher ob Datei veraltet ist, belassen und im Bericht dokumentieren
Schritt 7: Namenskonventionen ueberpruefen
Auf inkonsistente Dateibenennung im Projekt pruefen.
Gaengige Konventionen:
- kebab-case:
my-file.js(ueblich in JS/Web-Projekten) - snake_case:
my_file.py(Python-Standard) - PascalCase:
MyComponent.tsx(React-Komponenten) - camelCase:
myUtility.js(JavaScript-Funktionen)
# Dateien finden die gegen Konventionen verstossen
# Beispiel: Python-Projekt mit erwarteter snake_case
find . -name "*.py" | grep -v "__pycache__" | grep -E "[A-Z-]"
# Fuer jeden Verstoss entweder:
# 1. Umbenennen um Konventionen einzuhalten
# 2. Ausnahme dokumentieren (z.B. Django settings.py Konvention)
Erwartet: Alle Dateien folgen Namenskonventionen oder Ausnahmen dokumentiert
Bei Fehler: Wenn Umbenennung Imports bricht, Referenzen aktualisieren oder eskalieren
Schritt 8: Bereinigungsbericht erstellen
Alle strukturellen Aenderungen dokumentieren.
# Projektstruktur-Bereinigungsbericht
**Datum**: JJJJ-MM-TT
**Projekt**: <projektname>
## Verzeichnisaenderungen
- X Dateien in konventionelle Verzeichnisse verschoben
- Y neue Verzeichnisse erstellt
- Z veraltete Dateien archiviert
## README-Aktualisierungen
- W veraltete READMEs aktualisiert
- X defekte Links repariert
- Y Code-Beispiele verifiziert
## Konfigurationsbereinigung
- X doppelte Einstellungen konsolidiert
- Y hartcodierte Geheimnisse zur Entfernung markiert
- Z Konfigurationsdrift-Probleme dokumentiert
## Archivierte Dateien
Siehe ARCHIVE_LOG.md fuer vollstaendige Liste (Z Dateien).
## Namenskonventionskorrekturen
- X Dateien entsprechend Konventionen umbenannt
- Y Ausnahmen dokumentiert
## Eskalierungen
- [Konfigurationsdrift erfordert DevOps-Pruefung]
- [Hartcodierte Geheimnisse erfordern Sicherheitsaudit]
Erwartet: Bericht in TIDYING_REPORT.md gespeichert
Bei Fehler: (Entfaellt — Bericht unabhaengig generieren)
Validierung
Nach der Bereinigung:
- Alle Dateien in konventionellen Verzeichnissen
- Keine defekten Links in READMEs
- README-Beispiele auf Funktionsfaehigkeit verifiziert
- Konfigurationsdateien auf Geheimnisse geprueft
- Veraltete Dateien mit Dokumentation archiviert
- Namenskonventionen konsistent
- Git-Historie erhalten (verwendet
git mv, nichtmv) - Tests bestehen nach Verschiebungen weiterhin
Haeufige Stolperfallen
-
Relative Imports brechen: Verschieben von Dateien bricht relative Importpfade. Alle Referenzen aktualisieren oder absolute Imports verwenden.
-
Git-Historie verlieren: Verwendung von
mvstattgit mvverliert Dateihistorie. Immer Git-Befehle fuer Verschiebungen verwenden. -
Ueberorganisation: Zu viele verschachtelte Verzeichnisse erschweren die Navigation. Flach halten bis Komplexitaet Struktur erfordert.
-
Loeschen statt Archivieren: Direktes Loeschen verliert Wiederherstellungsmoeglichkeit. Immer zuerst archivieren wenn nicht sicher.
-
Sprachkonventionen ignorieren: Persoenliche Vorlieben ueber Sprachstandards stellen. Etablierte Konventionen befolgen.
-
Dokumentation nicht aktualisieren: Dateien verschieben ohne README-Pfade anzupassen hinterlaesst defekte Dokumentation.
Verwandte Skills
- clean-codebase — Toten Code entfernen, Lint-Warnungen beheben
- repair-broken-references — Links und Imports nach Verschiebungen reparieren
- escalate-issues — Komplexe Konfigurationsprobleme an Spezialisten weiterleiten
- devops/config-management — Erweiterte Konfigurationskonsolidierung
- compliance/documentation-audit — Umfassende Dokumentationspruefung
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.
