Joelclaw skill-review
Audit and maintain the joelclaw skill inventory. Use when checking skill health, fixing broken symlinks, finding stale skills, or running the skill garden. Triggers: 'skill audit', 'check skills', 'stale skills', 'skill health', 'skill garden', 'broken skill', 'skill review', 'fix skills', 'garden skills', or any task involving skill inventory maintenance.
git clone https://github.com/joelhooks/joelclaw
T=$(mktemp -d) && git clone --depth=1 https://github.com/joelhooks/joelclaw "$T" && mkdir -p ~/.claude/skills && cp -r "$T/skills/skill-review" ~/.claude/skills/joelhooks-joelclaw-skill-review && rm -rf "$T"
skills/skill-review/SKILL.mdSkill Review & Gardening
Automated and manual processes for keeping the 51+ joelclaw skills accurate and healthy. ADR-0179.
Canonical Contract
- Source of truth:
(repo, fully git-tracked)~/Code/joelhooks/joelclaw/skills/ - Home dir consumers (symlink IN to repo):
→~/.agents/skills/<name>~/Code/joelhooks/joelclaw/skills/<name>
→~/.pi/agent/skills/<name>~/Code/joelhooks/joelclaw/skills/<name>
- Never put skill content in dot directories (
,.agents/
,.pi/
). Those are symlink consumers..claude/ - Third-party skill packs (axiom-*, marketing, etc.) live in
as external installs — NOT in the repo.~/.agents/skills/
Automated Garden (Inngest)
The
skill-garden function runs daily at 6am PT and checks:
Daily (structural + patterns)
- Broken symlinks — dead links in
,~/.agents/skills/~/.pi/agent/skills/ - Non-canonical REAL DIRs — directories in home skill dirs that should be symlinks
- Missing frontmatter — skills without SKILL.md or required frontmatter (name, description)
- Stale patterns — skills referencing known-dead infrastructure:
- legacy lightweight-k8s distro terms → replaced by Talos on Colima
- retired vector DB terms → replaced by Typesense vector search
- launchctl commands targeting worker labels → worker runs in k8s
- old standalone worker clone paths → monorepo
packages/system-bus/ - old standalone CLI repo paths/aliases → CLI is
+packages/cli/joelclaw
- Orphans — skills in repo with no symlink from any home dir
Monthly (1st of month, LLM deep review)
- Reads current
as ground truthAGENTS.md - Compares each skill's content against system reality via
inferencepi - Flags outdated workflows, wrong versions, missing capabilities
- Produces structured report
Triggers
# On-demand via event joelclaw send "skill-garden/check" joelclaw send "skill-garden/check" --data '{"deep": true}' # force LLM review # Daily cron: 0 6 * * * (automatic)
Output
- OTEL event:
skill-garden.findings - Gateway notification when issues found (zero noise on clean days)
- Structured JSON report with findings by type
Manual Review Process
When the automated garden flags issues, or for periodic deep review:
1. Run the audit
joelclaw send "skill-garden/check" --data '{"deep": true}'
2. Check for structural issues
# Broken symlinks find ~/.agents/skills/ ~/.pi/agent/skills/ -maxdepth 1 -type l ! -exec test -e {} \; -print # REAL DIRs that should be symlinks for dir in ~/.agents/skills ~/.pi/agent/skills; do find "$dir" -maxdepth 1 -type d ! -type l | while read d; do name=$(basename "$d") [ -d ~/Code/joelhooks/joelclaw/skills/"$name" ] && echo "NON-CANONICAL: $d" done done # Orphan skills (in repo, no home dir symlink) for skill in ~/Code/joelhooks/joelclaw/skills/*/; do name=$(basename "$skill") [ ! -L ~/.agents/skills/"$name" ] && [ ! -L ~/.pi/agent/skills/"$name" ] && echo "ORPHAN: $name" done
3. Fix structural issues
# Canonical repair path for repo-local skills joelclaw skills ensure <name> # Or explicitly from another repo root joelclaw skills ensure <name> --source-root /abs/repo
If
joelclaw skills ensure fails because a consumer target is a real file/dir instead of a symlink, fix that conflict manually, then rerun the command.
4. Fix stale content
When a skill references outdated architecture:
- Read the skill:
read skills/<name>/SKILL.md - Cross-reference with
and current system stateAGENTS.md - Update the skill with current facts
- Commit:
git add skills/<name> && git commit -m "skill(<name>): update for current architecture"
5. Adding a new skill
mkdir -p skills/<name> # Write SKILL.md with frontmatter: name, description, version, author, tags # Symlink from home dirs: ln -s ~/Code/joelhooks/joelclaw/skills/<name> ~/.agents/skills/<name> ln -s ~/Code/joelhooks/joelclaw/skills/<name> ~/.pi/agent/skills/<name> git add skills/<name> git commit -m "skill(<name>): add new skill"
See the add-skill skill for the full idiomatic process.
Stale Pattern Registry
Keep this list updated as infrastructure changes. The Inngest function reads these patterns.
| Pattern | What it means | Current reality |
|---|---|---|
| legacy k8s distro token | Old k8s distribution reference | Talos v1.12.4 on Colima |
| legacy vector DB token | Old vector store reference | Typesense with vector search |
| launchctl worker command token | Old worker deploy mode | k8s Deployment |
| standalone worker clone path token | Old worker path | in monorepo |
| standalone CLI path token | Old CLI path | in monorepo |
| short CLI alias token | Old CLI name | CLI |
When infrastructure changes, update this table AND the exact regex list in
inside STALE_PATTERNS
.skill-garden.ts
Required Frontmatter
Every skill MUST have:
--- name: skill-name description: "What this skill does and when to use it" ---
Recommended additional fields:
version: 1.0.0 author: Joel Hooks tags: [relevant, tags] displayName: Human Readable Name
Key Paths
| What | Path |
|---|---|
| Repo skills (canonical) | |
| Inngest function | |
| ADR | |
| Home dir: agents | |
| Home dir: pi | |
| Stale patterns | in |