From clinicaltrialsgov-mcp-server
Lands working-tree changes as logical commits grouped by concern, topped by a release commit (version bump, changelog, regenerated artifacts) and an annotated tag. Stops at local commit/tag; no push.
How this skill is triggered — by the user, by Claude, or both
Slash command
/clinicaltrialsgov-mcp-server:git-wrapupThe summary Claude sees in its skill listing — used to decide when to auto-load this skill
Working-tree or staged changes are ready to ship as a new version. This skill lands them as a stack of logical commits — the work grouped by concern, topped by a release commit (version + changelog + tree) — with an annotated tag. It does NOT push or publish — that's a separate step (`release-and-publish`).
Working-tree or staged changes are ready to ship as a new version. This skill lands them as a stack of logical commits — the work grouped by concern, topped by a release commit (version + changelog + tree) — with an annotated tag. It does NOT push or publish — that's a separate step (release-and-publish).
Common triggers:
Every item must be true before starting wrapup. Committing means releasing — a commit only happens when the work is ready to ship, not just "the edits are done." Each item is a goal to verify.
code-simplifier skill has been run across the changesbun run devcheck passes — typecheck + lint cleanbun run rebuild succeeds — full clean build from scratchbun run test:all (or bun run test). New tests and regression tests added as needed for the changes being shipped.bun run rebuild and field-testing. Not just written — confirmed to resolve the described behavior.If any gate is red, fix it before proceeding. This skill re-verifies build + tests in step 6, but starting wrapup on a broken tree wastes the version number and creates a revert-or-amend situation.
Understand what's about to ship before touching version numbers:
git status
git log v<latest-tag>..HEAD --oneline # commits since last release
git diff --stat # uncommitted changes
git diff # review the actual content
If the working tree is clean AND there are no commits since the last tag, halt — nothing to wrap up.
Read the current version from package.json. Apply the intended bump:
| Bump | When |
|---|---|
| patch | Bug fixes, dependency updates, metadata changes, docs |
| minor | New tools, new features, new env vars, behavioral changes |
| major | Breaking changes to tool schemas, removed tools, incompatible config |
Default to patch unless the diff clearly warrants minor or major.
Every file that declares a version must be updated. Skip any file that doesn't exist in the project. For @cyanheads/mcp-ts-core projects:
package.json — versionserver.json — top-level version AND every packages[].version entrymanifest.json (if present) — version. Verify name is the bare package name (e.g. bls-mcp-server, not @cyanheads/bls-mcp-server)README.md — version badgeCLAUDE.md / AGENTS.md — if they pin a version stringDockerfile — OCI labels if they pin the versionCatch stragglers (replace the placeholder with the actual current version string, e.g. 0.9.7):
grep -rn "0.9.7" . --exclude-dir=node_modules --exclude-dir=.git --exclude-dir=changelog
Resolve hits case by case — historical changelog entries are correct as-is; everything else should match the new version.
Create changelog/<major.minor>.x/<version>.md. Use changelog/template.md as the format reference — never edit, rename, or move that file.
Frontmatter (required):
---
summary: "<one-line headline, ≤350 chars, no markdown>"
breaking: false # true if consumers must change code to upgrade
security: false # true if this release contains a security fix
---
Body: Section order follows Keep a Changelog — Added / Changed / Deprecated / Removed / Fixed / Security. Include only sections with entries. Delete empty sections.
Tone: Terse, fact-dense. Lead each bullet with the symbol or concept in bold. One sentence per bullet by default. See the authoring guide in changelog/template.md for full conventions.
bun run changelog:build # rebuilds CHANGELOG.md rollup from per-version files
bun run tree # regenerates docs/tree.md — run when files were added, removed, or moved in src/
Both scripts are idempotent — safe to run even if nothing changed.
The tree being committed must pass verification. Both must succeed:
bun run devcheck
bun run test:all # or `bun run test` if no test:all script exists
If either fails, halt. Do not bypass verification to land the commit. Fix the issue first, then re-run from step 6.
Do NOT git add -A into one commit. Group the working tree into a handful of logical commits — never one blob:
package.json, server.json, README badge, CLAUDE.md/AGENTS.md), the changelog entry, CHANGELOG.md, and docs/tree.md go in a single final commit that sits on top of the work stack — never mixed into a feature commit.Stage each group explicitly, commit it, then move to the next — the release commit goes last:
git add <paths-for-this-concern>
git commit -m "<subject>"
# repeat per concern; version + changelog + tree are the final commit
The file is the atomic boundary: NEVER split a single file's changes across commits. When one file serves two concerns, it ships whole in the commit of its dominant concern.
Subject format: Conventional Commits.
feat: hosted server endpoint, fix: handle empty SPARQL result sets, feat(linter): enrichment contract rules, docs: document the enrichment blockchore(release): 0.2.1 — empty SPARQL result handlingRules:
-m flag only — no heredoc, no command substitutionCo-authored-by or Generated with trailersgit log — no chat context, option numbers, or "as discussed"Right-size it. "Group by concern" is not "always split." A genuinely single-concern change — one fix, a dependency bump, a small doc edit — is one work commit plus the release commit; when the change and its version bump are inseparable for a tiny patch, a single commit whose subject leads with the version is fine. The failure mode to prevent is the inverse: a large, multi-layer feature crammed into one commit alongside the release artifacts.
git tag -a v<version> -m "<tag message with embedded newlines>"
Use -m with embedded newlines in the string (the commit -m-only constraint applies here too — no heredoc). The tag message renders as the GitHub Release body via --notes-from-tag. It must be structured markdown, not a flat string. Format:
<theme — omit version number, GitHub prepends v<VERSION>:>
<1-2 sentence context: what this release does>
<Sections — Keep a Changelog names, only those with entries>
Added:
- <bullet>
Changed:
- <bullet>
<dep arrows if applicable>
Dependency bumps:
- `pkg` ^old → ^new
<N> tests pass; `bun run devcheck` clean.
Rules:
v<VERSION>: to the release title)(#N) references in the relevant bullets — same as the changelog entry. The backlinks render as clickable links in the GitHub Release body.git log --oneline -8 # confirm the commit stack: work commits + release commit on top
git show v<version> --stat | head -20 # confirm tag points at HEAD (the release commit)
git status # must be clean
If the working tree isn't clean or the tag doesn't point at HEAD, something went wrong — investigate before proceeding.
Do NOT push. This skill stops here. Use the release-and-publish skill for the push + publish workflow.
git push, no remote operationsgit reset --hard, git restore ., git clean -f, git checkout -- .v<version> already exists as a tag, halt and report the conflict — include the version string, existing tag SHA, and current HEAD SHA so the caller can resolve it. Do not delete or move tags without explicit authorizationpackage.json, server.json, manifest.json, README badge, CLAUDE.md/AGENTS.md if they pin a version)changelog/<major.minor>.x/<version>.mdCHANGELOG.md rollup regenerated (bun run changelog:build)docs/tree.md regenerated if structure changed (bun run tree)bun run devcheck passesbun run test:all (or test) passesv<version> with structured markdown messagenpx claudepluginhub cyanheads/cyanheads --plugin clinicaltrialsgov-mcp-serverLands working-tree changes as logical commits grouped by concern, topped by a release commit (version bump, changelog, regenerated artifacts) and an annotated tag. Stops at local commit/tag; no push.
Generates SemVer-compliant version bumps and changelog entries from git diffs. Use when cutting releases, tagging, or publishing with precise change summaries.
Plans and executes software releases: inventories git changes, applies semantic versioning, generates changelog and release notes, updates files, creates tags, and publishes to GitHub. Use before new versions.