nWave/skills/nw-update/SKILL.md
Queues a deferred self-update of nwave-ai. Writes a PendingUpdateFlag that the SessionStart hook replays on the next Claude Code launch, so the current session is not interrupted. Falls back to manual instructions when the package manager cannot be detected.
npx skillsauth add nwave-ai/nwave nw-updateInstall this skill globally with one command. Works with Claude Code, Cursor, and Windsurf.
3 of 9 scanners reported clean
Some scanners were skipped, did not run, or reported a non-clean status. Review each row below.
Wave: CROSS_WAVE | Agent: Main Instance (self) | Command: /nw-update
/nw-update records a PendingUpdateFlag on disk. The actual upgrade is performed
by the SessionStart hook on the next Claude Code launch, so the user can keep
working in the current session and apply the new version whenever they restart.
You (the main Claude instance) run this command directly — no subagent delegation. Do NOT attempt to upgrade nwave-ai in the current session.
$ARGUMENTS), treat it as the target version
after stripping a leading v.update_check.latest_available from DESConfig
(.nwave/des-state.json).Invoke the detector and resolve the PM binary absolute path in a single Bash call:
python3 -c "
import sys, os
sys.path.insert(0, os.path.expanduser('~/.claude/lib/python'))
import shutil
from pathlib import Path
from des.adapters.driven.package_managers.package_manager_detector import detect_pm
pm = detect_pm(Path(sys.executable))
binary = shutil.which(pm) if pm in ('pipx', 'uv') else ''
print(f'{pm}|{binary or \"\"}')"
Parse the output as pm|binary_abspath.
If pm == "unknown" OR binary_abspath is empty:
PendingUpdateService.request_update.nwave-ai was not installed via a supported package manager (pipx or uv).
Please upgrade manually:
pipx upgrade nwave-ai && nwave-ai install
— or —
uv tool install nwave-ai@latest && nwave-ai install
Then restart Claude Code.
Call the driving port PendingUpdateService.request_update:
python3 -c "
import sys, os
sys.path.insert(0, os.path.expanduser('~/.claude/lib/python'))
from des.application.pending_update_service import PendingUpdateService
from des.adapters.driven.config.des_config import DESConfig
from des.adapters.driven.package_managers.package_manager_detector import detect_pm
from des.ports.driven_ports.package_manager_port import PackageManagerPort
from pathlib import Path
import shutil
pm = detect_pm(Path(sys.executable))
binary = shutil.which(pm)
target = '${TARGET_VERSION}'
config = DESConfig.load()
# PM adapter is only used by apply(), request_update() does not invoke it.
svc = PendingUpdateService(config=config, pm=None) # type: ignore[arg-type]
svc.request_update(pm=pm, pm_binary_abspath=binary, target_version=target)
print(f'queued:{pm}:{target}')"
Substitute ${TARGET_VERSION} with the value resolved in Step 1 (no leading v).
On success, print:
Update to vX.Y.Z queued. It will be applied the next time you restart Claude Code.
Package manager: <pipx|uv> (<binary_abspath>)
| Condition | Response |
|-----------|----------|
| No target version provided and none discovered | Ask the user for an explicit version |
| PM detection returns unknown | Print manual fallback (Step 3), do not write flag |
| shutil.which(pm) returns empty | Same as unknown — print fallback |
| request_update raises | Surface the exception, do not claim success |
This command is synchronous and fast (< 1s). Do not create a task list; print progress inline.
/nw-update
Reads update_check.latest_available = "1.4.2", detects pipx at
/home/alex/.local/bin/pipx, queues flag, prints:
Update to v1.4.2 queued. It will be applied the next time you restart Claude Code.
/nw-update 1.5.0
Detects uv at /home/alex/.cargo/bin/uv, queues flag for 1.5.0.
/nw-update 1.4.2
Detector returns unknown (e.g. pip venv install). Prints manual fallback
instructions and exits without writing the flag.
testing
Acceptance test creation methodology for the DISTILL wave. Domain knowledge for the acceptance designer agent: port-to-port principle, prior wave reading, wave-decision reconciliation, graceful degradation, and document back-propagation.
testing
Methodology for minimizing test count while maximizing behavioral coverage - behavior definition, anti-pattern catalog, consolidation patterns, stopping criterion, coverage-preserving validation
testing
Methodology for minimizing test count while maximizing behavioral coverage - behavior definition, anti-pattern catalog, consolidation patterns, stopping criterion, coverage-preserving validation
development
Design mandates for acceptance tests - hexagonal boundary, business language abstraction, user journey completeness, pure function extraction, 3 Pillars (domain language / chained narrative / production composition), and the layered ATD discipline (Universe-bound assertion, layer-dependent PBT mode, two-tier acceptance, example-based sad paths)