Base releases are explicit release ceremonies, not automatic side effects of ordinary pull requests.
Use this checklist when preparing and publishing a new Base release such as
0.3.1 or 0.4.0.
The release spans two repositories:
codeforester/baseowns Base source, release notes,VERSION, Git tags, and GitHub Releases.codeforester/homebrew-baseowns the Homebrew formula that installs published Base releases, plus the Homebrew bottle artifacts for supported macOS hosts.
The Homebrew tap update happens after the Base tag and GitHub Release exist.
The formula points at a versioned tag archive and records that archive's
sha256, so the archive must be available before the formula can be updated and
validated. Supported macOS installs should use Homebrew bottles; source builds
remain a fallback for unsupported hosts or explicit source-build validation.
Base's current supported macOS floor is macOS 14 Sonoma. Keep Homebrew bottle
workflows, formula validation, and Base's macOS CI floor aligned with that
support contract until the Compatibility section in the top-level README is
changed intentionally.
Do not update VERSION on every merged pull request.
VERSION records the latest published Base release. Ordinary feature, fix,
documentation, and maintenance PRs leave it unchanged. A release-prep PR updates
VERSION once the next release number has been chosen.
Keep upcoming changes under the Unreleased section in CHANGELOG.md until a
release-prep PR moves them into a dated release section.
Base-managed repositories can declare a release: section in
base_manifest.yaml with the version file, changelog, tag prefix, GitHub
repository, GitHub Release title, and optional Homebrew handoff metadata.
The inspection commands are read-only:
basectl release check --version X.Y.Z
basectl release plan --version X.Y.Z
basectl release notes --version X.Y.ZUse check before publishing to validate the version file, changelog section,
Git worktree cleanliness, current branch, GitHub CLI authentication, and local
and remote tag availability. Use plan to print the GitHub release target and
downstream handoff requirements. Use notes to print the changelog body
intended for the GitHub Release.
Publishing is guarded:
basectl release publish --version X.Y.Z --dry-run
basectl release publish --version X.Y.Z
basectl release publish --version X.Y.Z --yespublish reuses the release checks, refuses existing tags or GitHub Releases,
creates an annotated tag, pushes the tag, and creates the GitHub Release from
the changelog section. It does not update the Homebrew tap; it prints the tap
handoff checklist when release.homebrew is declared.
Complete these steps in codeforester/base:
-
Choose the release version and create or use a GitHub issue for the release artifact work.
-
Create a release-prep branch and worktree from
origin/master. -
Update release metadata:
VERSION- README version badge
- README
Current Statussection current-release prose .ai-context/STATUS.mdCurrent ReleasesectionCHANGELOG.md, moving relevantUnreleasedentries into the new release section
-
Validate the release-prep PR:
git diff --check bin/base-test
-
Merge the release-prep PR into
master. -
Sync local
master. -
Dry-run the guarded publish command:
basectl release publish --version X.Y.Z --dry-run
-
Publish the GitHub-side release artifacts:
basectl release publish --version X.Y.Z
Use
--yesonly when running from a trusted non-interactive release shell. -
Confirm the release tag and GitHub Release are visible on GitHub.
Complete these steps in codeforester/homebrew-base after the Base tag exists:
-
Create a Homebrew tap update issue or PR for the new Base version.
-
Create a tap release branch. Do not run the bottle workflow from
master; it pushes the generated bottle stanza back to the branch that triggered it. -
Update
Formula/base.rb:urlto the new Base tag archivesha256to the checksum of that archiveversionto the new Base version
-
Compute the archive checksum from the published tag:
curl -fsSL https://github.com/codeforester/base/archive/refs/tags/vX.Y.Z.tar.gz | shasum -a 256 -
Validate the formula source-build path from the tap repository when the host can run Homebrew source builds:
brew install --build-from-source Formula/base.rb brew test codeforester/base brew audit --new --formula Formula/base.rb -
Run the
Build Base BottlesGitHub Actions workflow from the tap release branch. The workflow builds bottles on supported macOS runners, uploads bottle tarballs to the tap GitHub Release namedbase-vX.Y.Z, merges the generated bottle JSON intoFormula/base.rb, and pushes the bottle stanza back to the branch. -
Confirm the tap PR includes a
bottle doblock for supported macOS targets before merging. The bottleroot_urlshould point at the tap release created by the workflow. -
Open or update the tap PR, wait for checks, and merge it.
-
Smoke-test the consumer bottle and upgrade paths:
brew update brew trust codeforester/base brew install --force-bottle codeforester/base/base brew test codeforester/base brew upgrade --no-ask codeforester/base/baseUse
brew reinstall --force-bottle codeforester/base/basewhen Base is already installed on the validation host. -
Before 1.0.0, complete the Homebrew Upgrade Rehearsal against a release candidate or equivalent test formula. Record the exact commands, host facts, pre-upgrade state, post-upgrade checks, and any follow-up issues. Do not close the rehearsal issue until
brew upgrade --no-ask codeforester/base/baseand the post-upgrade Base project checks pass on a qualified host.
After the Base release PR and Homebrew tap PR are merged, clean up their worktrees and branches. Keep the release issue or linked issue comments updated with the Base release URL and Homebrew tap PR URL so the release record has both halves of the ceremony.