Files
claude-engineering-plugin/plugins/compound-engineering/skills/ce-update/SKILL.md
Trevin Chow b9ae6b758d
Some checks failed
CI / pr-title (push) Has been cancelled
CI / test (push) Has been cancelled
Release PR / release-pr (push) Has been cancelled
Release PR / publish-cli (push) Has been cancelled
fix(ce-update): replace cache sweep with claude plugin update (#656)
2026-04-22 18:23:15 -07:00

91 lines
4.0 KiB
Markdown

---
name: ce-update
description: |
Check if the compound-engineering plugin is up to date and recommend the
update command if not. Use when the user says "update compound engineering",
"check compound engineering version", "ce update", "is compound engineering
up to date", "update ce plugin", or reports issues that might stem from a
stale compound-engineering plugin version. This skill only works in Claude
Code — it relies on the plugin harness cache layout.
disable-model-invocation: true
ce_platforms: [claude]
---
# Check Plugin Version
Verify the installed compound-engineering plugin version matches the latest
release, and recommend the update command if it doesn't. Claude Code only.
## Pre-resolved context
Only the **Skill directory** determines whether this session is Claude Code —
if empty or unresolved, the skill requires Claude Code. The other sections may
contain error sentinels even in valid Claude Code sessions; the decision logic
below handles those cases.
`${CLAUDE_SKILL_DIR}` is a Claude Code-documented substitution that resolves
at skill-load time. For a marketplace-cached install it looks like
`~/.claude/plugins/cache/<marketplace>/compound-engineering/<version>/skills/ce-update`,
so the currently-loaded version is the basename two `dirname` levels up.
**Skill directory:**
!`echo "${CLAUDE_SKILL_DIR}"`
**Latest released version:**
!`gh release list --repo EveryInc/compound-engineering-plugin --limit 30 --json tagName --jq '[.[] | select(.tagName | startswith("compound-engineering-v"))][0].tagName | sub("compound-engineering-v";"")' 2>/dev/null || echo '__CE_UPDATE_VERSION_FAILED__'`
**Currently loaded version:**
!`case "${CLAUDE_SKILL_DIR}" in */plugins/cache/*/compound-engineering/*/skills/ce-update) basename "$(dirname "$(dirname "${CLAUDE_SKILL_DIR}")")" ;; *) echo '__CE_UPDATE_NOT_MARKETPLACE__' ;; esac`
**Marketplace name:**
!`case "${CLAUDE_SKILL_DIR}" in */plugins/cache/*/compound-engineering/*/skills/ce-update) basename "$(dirname "$(dirname "$(dirname "$(dirname "${CLAUDE_SKILL_DIR}")")")")" ;; *) echo '__CE_UPDATE_NOT_MARKETPLACE__' ;; esac`
## Decision logic
### 1. Platform gate
If **Skill directory** is empty or unresolved: tell the user this skill
requires Claude Code and stop. No further action.
### 2. Handle failure cases
If **Latest released version** contains `__CE_UPDATE_VERSION_FAILED__`: tell
the user the latest release could not be fetched (gh may be unavailable or
rate-limited) and stop.
If **Currently loaded version** contains `__CE_UPDATE_NOT_MARKETPLACE__`: this
session loaded the skill from outside the standard marketplace cache (typical
when using `claude --plugin-dir` for local development, or for a non-standard
install). Tell the user (substituting the actual path):
> "Skill is loaded from `{skill-directory}` — not the standard marketplace
> cache at `~/.claude/plugins/cache/`. This is normal when using
> `claude --plugin-dir` for local development. No action for this session.
> Your marketplace install (if any) is unaffected — run `/ce-update` in a
> regular Claude Code session (no `--plugin-dir`) to check that cache."
Then stop.
### 3. Compare versions
**Up to date**`{currently loaded} == {latest}`:
> "compound-engineering **v{version}** is installed and up to date."
**Out of date**`{currently loaded} != {latest}`:
> "compound-engineering is on **v{currently loaded}** but **v{latest}** is available.
>
> Update with:
> ```
> claude plugin update compound-engineering@{marketplace-name}
> ```
> Then restart Claude Code to apply."
The `claude plugin update` command ships with Claude Code itself and updates
installed plugins to their latest version; it replaces earlier manual cache
sweep / marketplace-refresh workarounds. The marketplace name is derived from
the skill path rather than hardcoded because this plugin is distributed under
multiple marketplace names (for example, `compound-engineering-plugin` for
public installs per the README, or other names for internal/team marketplaces).