Release Skill
A thin, repo-aware release assistant. On first run it inspects the project and CI to derive release rules, stores them in .omc/RELEASE_RULE.md for future use, then walks you through a release using those rules.
Usage
/oh-my-claudecode:release [version]
versionis optional. If omitted the skill will ask. Acceptspatch,minor,major, or an explicit semver like2.4.0.- Add
--refreshto force re-analysis of the repo even when a cached rule file exists.
Execution Flow
Step 0 — Load or Build Release Rules
Check whether .omc/RELEASE_RULE.md exists.
If it does NOT exist (or --refresh was passed): Run the full repo analysis below and write the file.
If it DOES exist: Read the file. Then do a quick delta check — scan .github/workflows/ (or equivalent CI dirs: .circleci/, .travis.yml, Jenkinsfile, bitbucket-pipelines.yml, gitlab-ci.yml) for any modifications newer than the last-analyzed timestamp in the rule file. If relevant workflow files changed, re-run the analysis for those sections and update the file. Report what changed.
Step 1 — Repo Analysis (first run or --refresh)
Inspect the repo and answer the following. Write answers into .omc/RELEASE_RULE.md.
1a. Version Sources
- Locate all files that contain a version string matching the current version in
package.json/pyproject.toml/Cargo.toml/build.gradle/VERSIONfile / etc. - List each file and the field or regex pattern used to find the version.
- Detect whether there is a release automation script (e.g.
scripts/release.*,Makefile releasetarget,bump2version,release-it,semantic-release,changesets,goreleaser).
1b. Registry / Distribution
- npm (
package.jsonwithpublishConfigornpm publishin CI), PyPI (pyproject.toml+twine/flit), Cargo (Cargo.toml), Docker (Dockerfile+ push step), GitHub Packages, other. - Is there a CI step that publishes automatically on tag push? Which workflow file and job?
1c. Release Trigger
- Identify what starts the release: tag push (
v*), manual dispatch (workflow_dispatch), merge to main/master, a release branch merge, a commit message pattern.
1d. Test Gate
- Identify the test command and where it runs in CI.
- Are tests required to pass before publish? Note any bypass flags.
1e. Release Notes / Changelog
- Does a
CHANGELOG.mdorCHANGELOG.rstexist? - What convention is used: Keep a Changelog, Conventional Commits, GitHub auto-generated, none?
- Is there a release body file (e.g.
.github/release-body.md) committed pre-tag?
1f. First-Time User Check
- Does a release workflow exist in
.github/workflows/(or equivalent)? If not, flag this and offer to scaffold one. - Is there a
.gitignoreentry preventing build artifacts from being committed? If not, flag it. - Are git tags being used? Run
git tag --listto check. If no tags exist, flag and explain best practice.
Step 2 — Write .omc/RELEASE_RULE.md
Create or overwrite the file with this structure:
# Release Rules
<!-- last-analyzed: YYYY-MM-DDTHH:MM:SSZ -->
## Version Sources
<!-- list of files + patterns -->
## Release Trigger
<!-- what kicks off the release -->
## Test Gate
<!-- command + CI job name -->
## Registry / Distribution
<!-- npm, PyPI, Docker, etc. + CI job that publishes -->
## Release Notes Strategy
<!-- convention + files -->
## CI Workflow Files
<!-- paths to relevant workflow files -->
## First-Time Setup Gaps
<!-- any missing pieces found during analysis, or "none" -->
Step 3 — Determine Version
If the user provided a version argument, use it. Otherwise:
- Show the current version (from the primary version file).
- Show what
patch,minor, andmajorwould produce. - Ask the user which to use.
Validate the chosen version is a valid semver string.
Step 4 — Pre-Release Checklist
Present a checklist derived from the release rules. At minimum:
- All changes intended for this release are committed and pushed
- CI is green on the target branch
- Tests pass locally (run the test gate command)
- Version bump applied to all version source files
- Release notes / changelog prepared (see Step 5)
Ask the user to confirm before proceeding, or run each step if they say "go ahead".
Step 5 — Release Notes Guidance
Help the user write good release notes. Apply whichever convention the repo uses. Default guidance when no convention is detected:
What makes a good release note:
- Lead with what changed for users, not internal implementation details.
- Group by type:
New Features,Bug Fixes,Breaking Changes,Deprecations,Internal / Chores. - For each item: one sentence, link to the PR or issue, credit the author if external.
- Breaking changes go first and must include a migration path.
- Omit changes users never see (refactors, CI tweaks, test-only changes) unless they affect build reproducibility.
Example entry format:
### Bug Fixes
- Fix session drop on token expiry (#123) — @contributor
If the repo uses Conventional Commits, generate a draft changelog from git log <prev-tag>..HEAD --no-merges --format="%s" grouped by commit type. Show it to the user and let them edit.
Step 6 — Execute Release
Using the rules discovered, walk through:
- Bump version — apply to each version source file.
- Run tests — execute the test gate command.
- Commit —
git add <version files> CHANGELOG.mdand commit withchore(release): bump version to vX.Y.Z. - Tag —
git tag -a vX.Y.Z -m "vX.Y.Z"(annotated tags are preferred over lightweight). - Push —
git push origin <branch> && git push origin vX.Y.Z. - CI takes over — if the release trigger is a tag push, remind the user that CI will handle the rest (publish, GitHub release creation). Show the expected CI workflow file.
- Manual publish — if no CI automation exists, list the manual publish command (e.g.
npm publish --access public,twine upload dist/*).
Step 7 — First-Time Setup Suggestions
If gaps were found in Step 1f, offer concrete help:
No release workflow:
Your repo doesn't have a release CI workflow. A GitHub Actions workflow triggered on
v*tag push is the most common best practice. It can:
- Run tests
- Publish to npm/PyPI/etc.
- Create a GitHub Release with your release notes
Want me to scaffold a
.github/workflows/release.ymlfor your stack?
No git tags:
This appears to be the first release. Git tags let GitHub, npm, and other tools understand your version history. We'll create your first tag in Step 6.
Build artifacts not gitignored:
Build artifacts are present in git history or not gitignored. This inflates repo size and creates merge conflicts. Want me to add them to
.gitignore?
Step 8 — Verify
After the push:
- Check CI status:
gh run list --workflow=<release workflow> --limit=3(ifghis available). - Check the registry (npm, PyPI) for the new version after a few minutes.
- Confirm a GitHub Release was created:
gh release view vX.Y.Z.
Report success or flag any failures.
Notes
- This skill does not hardcode any project-specific version files or commands. Everything is derived from repo inspection.
.omc/RELEASE_RULE.mdis a local cache. Commit it to your repo if you want to share the derived rules with your team, or add it to.gitignoreif you prefer it stays local.- For complex monorepos or multi-package workspaces, the skill will detect workspace patterns (npm workspaces, pnpm workspaces, Cargo workspace) and adapt accordingly.