release

star 1.2k

Run the claude-code-viewer release flow end-to-end. Use when the user asks to release patch, minor, major, beta, or an explicit semver; includes non-interactive release execution, GitHub Actions monitoring with gh, release note cleanup, and publishing the GitHub Release.

d-kimuson By d-kimuson schedule Updated 5/9/2026

name: release description: Run the claude-code-viewer release flow end-to-end. Use when the user asks to release patch, minor, major, beta, or an explicit semver; includes non-interactive release execution, GitHub Actions monitoring with gh, release note cleanup, and publishing the GitHub Release.

claude-code-viewer Release

Use this skill to perform an end-to-end release for this repository.

Inputs

Interpret the user's argument as the release version spec:

  • patch, minor, major, beta
  • or an explicit semver such as 0.8.0 / 0.8.0-beta.0

If no version spec is present, ask the user which one to use.

Preconditions

  1. Work from the repository root.
  2. Inspect the current branch and working tree:
git branch --show-current
git status --short
  1. If there are unrelated uncommitted changes, stop and ask the user how to handle them.
  2. If release-related changes were just made, commit them before running release because scripts/release.ts requires a clean working tree.
  3. The release script requires SSH signing config:
git config --get gpg.format
git config --get commit.gpgsign
git config --get tag.gpgsign

Expected values are ssh, true, true.

Release command

Run the non-interactive release:

VERSION_SPEC="patch" # replace with the user's requested spec
pnpm release -y --version "$VERSION_SPEC"

The script runs gatecheck, Lingui validation, tests, and build checks. It then updates package.json, creates a signed release commit, creates a signed tag, and pushes commits and tags.

If push fails because the branch has no upstream

The release commit and tag may already exist locally. Push the current branch with upstream, then push tags:

BRANCH="$(git branch --show-current)"
git push --set-upstream origin "$BRANCH"
git push --tags

Do not rerun pnpm release unless the local release commit/tag were removed or the previous run failed before creating them.

Monitor GitHub Actions

After tags are pushed, find and watch the Release workflow run:

gh run list --workflow Release --limit 5
RUN_ID="<id from the vX.Y.Z row>"
gh run watch "$RUN_ID" --exit-status

A reusable one-liner variant:

TAG="v0.0.0"; RUN_ID="$(gh run list --workflow Release --limit 20 --json databaseId,headBranch,event --jq ".[] | select(.headBranch == \"$TAG\" and .event == \"push\") | .databaseId" | head -n 1)"; test -n "$RUN_ID" && gh run watch "$RUN_ID" --exit-status

If the workflow fails, inspect logs before taking corrective action:

gh run view "$RUN_ID" --log-failed

Verify publish

After the workflow succeeds:

TAG="v0.0.0" # replace
npm view @kimuson/claude-code-viewer version
gh release view "$TAG" --json tagName,name,isDraft,isPrerelease,url

Fix and publish GitHub Release

The workflow creates a draft release with generated notes. Inspect the generated notes:

TAG="v0.0.0" # replace
gh release view "$TAG" --json body --jq .body

Rewrite the notes for claude-code-viewer users:

  • Use concise, user-focused English.
  • Prefer these sections when relevant: Features, Bug Fixes, Breaking Changes, Internal.
  • Describe the user-visible impact, not implementation details.
  • Remove trivial items such as formatting, typo-only, dependency-only, and purely internal refactors unless they affect users.
  • Merge intermediate same-release fixes into their related feature or fix.
  • Keep each item short and clear.

For a second-pass review before publishing, delegate a focused review to another agent:

RELEASE_URL="https://github.com/d-kimuson/claude-code-viewer/releases/tag/v0.0.0" # replace
pi -p "Review the GitHub Release note at $RELEASE_URL for claude-code-viewer. Check that it is concise, user-focused, correctly categorized, and excludes internal-only noise. Do not edit files or GitHub releases; only report concrete findings."

Apply review findings when they are consistent with the rules above. Publish the draft with the rewritten notes:

TAG="v0.0.0" # replace
NOTES_FILE="/tmp/claude-code-viewer-$TAG-release-notes.md"
$EDITOR "$NOTES_FILE" # or write the file with the agent's file tool
gh release edit "$TAG" --notes-file "$NOTES_FILE" --draft=false

Confirm it is public:

gh release view "$TAG" --json tagName,name,isDraft,isPrerelease,url

Final report

Report:

  • released tag/version
  • local release command used
  • GitHub Actions run ID and result
  • npm version verification result
  • GitHub Release URL and draft/public state
  • any follow-up commits created for release automation or skill updates
Install via CLI
npx skills add https://github.com/d-kimuson/claude-code-viewer --skill release
Repository Details
star Stars 1,217
call_split Forks 149
navigation Branch main
article Path SKILL.md
More from Creator