tidy-project-structure
О программе
Этот навык упорядочивает хаотичные структуры проектов, перемещая файлы в стандартные директории, обновляя устаревшие README-файлы, устраняя расхождения в конфигурациях и архивируя устаревшие элементы без изменения основной логики кода. Используйте его, когда файлы разбросаны без чёткой организации, README-файлы устарели или конфигурационные файлы размножились в разных средах. Он помогает поддерживать единые соглашения по именованию и удаляет устаревшие файлы из корневой директории проекта.
Быстрая установка
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/tidy-project-structureСкопируйте и вставьте эту команду в Claude Code для установки этого навыка
Документация
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
GitHub репозиторий
Похожие навыки
qmd
Разработкаqmd — это локальный инструмент командной строки для поиска и индексирования, который позволяет разработчикам индексировать и осуществлять поиск по локальным файлам с использованием гибридного поиска, сочетающего BM25, векторные эмбеддинги и реранкинг. Он поддерживает как использование через командную строку, так и режим MCP (Model Context Protocol) для интеграции с Claude. Инструмент использует Ollama для создания эмбеддингов и хранит индексы локально, что делает его идеальным для поиска по документации или кодовой базе прямо из терминала.
subagent-driven-development
РазработкаЭтот навык выполняет планы реализации, создавая нового суб-агента для каждой независимой задачи, проводя проверку кода между задачами. Он позволяет быстро итерировать, сохраняя контроль качества через этот процесс ревью. Используйте его при работе в основном с независимыми задачами в рамках одной сессии, чтобы обеспечить непрерывный прогресс со встроенными проверками качества.
mcporter
РазработкаНавык mcporter позволяет разработчикам управлять и вызывать серверы Model Context Protocol (MCP) напрямую из Claude. Он предоставляет команды для вывода списка доступных серверов, вызова их инструментов с аргументами, а также для обработки аутентификации и управления жизненным циклом демона. Используйте этот навык для интеграции и тестирования функциональности серверов MCP в вашем рабочем процессе разработки.
adk-deployment-specialist
РазработкаЭтот навык развертывает и оркестрирует агентов Vertex AI ADK с использованием протокола A2A, управляя обнаружением AgentCard, отправкой задач и поддерживая инструменты, такие как песочница для выполнения кода и Memory Bank. Он позволяет создавать мультиагентные системы с последовательными, параллельными или циклическими схемами оркестрации на Python, Java или Go. Используйте его, когда требуется развернуть агентов ADK или оркестрировать рабочие процессы агентов в Google Cloud.
