Bump Release
Release one package or several packages with version bumps, changelog entries, commits, and tags. Supports single-package repos, workspace monorepos, regular releases, beta releases, and dry runs.
Arguments
packages: Optional monorepo package names or directories, such asevmorevm-safe. Omit in single-package repos.version: Optional explicit semver, such as2.0.0. Only valid for one target package.--beta: Create or advance a-beta.Xprerelease.--dry-run: Preview the release plan without modifying files, committing, or tagging.
Fast Planner
Run the bundled planner before manual inspection. It is read-only and gives one JSON fact base for package discovery, previous tags, scoped changed files, dependency edges, and dirty-tree status. In pnpm workspaces, it uses pnpm list -r --depth -1 --json when available and falls back to local workspace-glob discovery. Bun and npm-style package.json workspaces use the local glob discovery, including negative workspace patterns.
Resolve <skill-dir> from the loaded SKILL.md path:
node "<skill-dir>/scripts/plan-release.mjs" [--cwd <repo>] [--beta] [--dry-run] [--version <semver>] [--package <name-or-dir>]...
Map user arguments directly:
- Pass every package selector as
--package <selector>. - Pass an explicit version as
--version <semver>. - Pass
--betaand--dry-runwhen requested.
If the helper exits 2, stop: the cwd is not a git repo or has no root package.json. If it exits 64, read the JSON errors when present, report the invalid arguments, and stop.
Workflow
- Run the planner - Use the JSON output as the source of truth for
mode,packages,targets,previousTags,changedFiles,includedFiles,excludedFiles,dependencyEdges,needsSelection, andworkingTree. - Require a clean tree - If
workingTree.cleanis false, stop and show the short status. Do not invoke thecommitskill or commit unrelated work unless the user explicitly asks. - Resolve targets - If
needsSelectionis true, ask the user which workspace packages to release. If package selectors are unknown or ambiguous, stop and ask for exact package names or directories. - Reject invalid version scope - If an explicit
versionwas supplied for more than one target package, stop. Explicit versions are single-package only. - Plan versions - Determine a candidate version for each target package:
- Explicit
version: use it as-is for a regular release; with--beta, append-beta.1unless it already has a prerelease suffix. - Beta from stable
1.2.3: use1.2.4-beta.1. - Beta from beta
1.2.3-beta.1: use1.2.3-beta.2. - Regular from beta
1.2.3-beta.5: use1.2.3. - Regular from stable: inspect relevant net changes and choose patch, minor, or major by Semantic Versioning.
- Explicit
- Skip no-op releases - For regular releases, if a target has no
includedFilesand no dependency-range cascade, report that there are no relevant release changes and do not bump it. - Cascade dependents - Use
dependencyEdgesto find workspace packages whosedependenciesorpeerDependenciespoint at bumped packages. Check ranges with a structured semver parser or package manager API when available, not ad hoc string comparison. If the new version is outside the declared range, update the range and add the dependent to the release plan. Treat dependency range widening as patch by default; treat peer dependency major changes as major unless the user confirms otherwise. - Confirm inferred versions - For non-dry-run regular releases without explicit versions, ask the user to confirm inferred versions. For multi-package releases, include requested packages and cascaded dependents in the same release-plan confirmation when the agent UI allows it.
- Preview dry runs - For
--dry-run, print the package order, current versions, planned versions, changelog/tag/commit actions, dependency range updates, and skipped files. Stop before edits. - Write changelogs - For regular releases only, read
references/common-changelog.mdafter the final package set is known. Use each target'sincludedFilesto bound diff inspection against itspreviousTags[package].tag. Include only production-impacting changes; forpackage.json, includedependenciesandpeerDependencieschanges only, notdevDependencies. - Edit release files - Update each target package's
CHANGELOG.mdandpackage.json. For beta releases, skipCHANGELOG.md. Update any cascaded dependent ranges before committing the dependent release. - Format once - After all release edits, run formatting once. If a
justfileexists, inspectjust --listand prefer the narrowest relevant write recipe; use broad recipes such asjust full-writeonly when no narrower established recipe covers the touched files. Without a suitable recipe, use the repo's established formatter commands or leave formatting unchanged. - Commit and tag in dependency order - Process dependencies before dependents. Use one commit and one annotated tag per package:
- Single-package commit:
docs: release <version> - Monorepo commit:
docs: release <package> <version> - Single-package tag:
v<version>unless existing tags use bare semver. - Monorepo tag: follow existing tag patterns from
previousTags; default to<package-dir>@<version>.
- Single-package commit:
Changelog Rules
Regular releases must generate entries in CHANGELOG.md following references/common-changelog.md.
- Use categories in this order:
Changed,Added,Removed,Fixed. - Start every entry with a present-tense imperative verb.
- Reference PRs when available; fall back to commit links.
- Merge related commits into one user-facing entry.
- Exclude tests, CI/CD, dev tooling, style-only churn, and
devDependencies. - If
package.jsonhas afilesfield, include only changes under those package files/directories, plus production dependency changes inpackage.json.
Beta releases do not update changelogs.
Script Reference
| Script | Purpose |
| -------------------------- | ------------------------------------------------- |
| scripts/plan-release.mjs | Read-only release discovery and scoped diff facts |
Planner output fields to use:
packagesandtargets: package identity, directory, name, version,files, dependency names, and peer dependency names.previousTags: per-package previous release tag and tag patterns used.changedFiles,includedFiles,excludedFiles: scoped file lists for changelog and no-op decisions.dependencyEdges: workspace dependency and peer dependency relationships.workingTree: dirty-tree status that must be clean before release edits.needsSelectionanderrors: package-selection or argument problems to resolve before proceeding.
Examples
# Regular release
/bump-release
# Preview without writes
/bump-release --dry-run
# Beta release
/bump-release --beta
# Monorepo package release
/bump-release evm
# Multi-package monorepo release
/bump-release evm evm-safe
# Explicit single-package version
/bump-release 2.0.0
# Explicit beta version
/bump-release 2.0.0-beta.1
Version Examples
| Current Version | Release Type | New Version |
| --------------- | -------------- | --------------- |
| 1.2.3 | Regular | 1.2.4 (patch) |
| 1.2.3 | Beta | 1.2.4-beta.1 |
| 1.2.3-beta.1 | Beta | 1.2.3-beta.2 |
| 1.2.3-beta.5 | Regular | 1.2.3 |
| 1.2.3 | 2.0.0 | 2.0.0 |
| 1.2.3 | 2.0.0 + Beta | 2.0.0-beta.1 |
Resources
references/common-changelog.md- Read only for regular releases after the final stable release package set is known.