homebrew-formula-maintenance
30
总安装量
30
周安装量
#6895
全站排名
安装命令
npx skills add https://github.com/bobmatnyc/claude-mpm-skills --skill homebrew-formula-maintenance
Agent 安装分布
claude-code
24
gemini-cli
17
opencode
17
github-copilot
16
codex
16
Skill 文档
Homebrew Formula Maintenance
Overview
Use this workflow to keep Homebrew formulas in sync with PyPI releases for Python CLIs. The pattern in your taps is: update version + sha, refresh resource blocks when needed, run brew install/test/audit, then push the tap update (manually or via CI).
Quick Start (manual bump)
- Verify the PyPI release exists and grab the sdist URL + SHA256.
- Update the
urlandsha256in the formula. - Refresh
resourcestanzas if the formula usesvirtualenv_install_with_resources. - Test:
brew install --build-from-source+brew test+brew audit --strict. - Update changelog/tag and push the tap repo.
Local Scripts You Already Use
homebrew-claude-mpm/scripts/update_formula.sh <version>- Verifies PyPI, updates url/sha, regenerates resources, optional brew test/audit.
homebrew-claude-mpm/scripts/generate_resources.py- Emits Python dependency
resourceblocks from PyPI.
- Emits Python dependency
homebrew-claude-mpm/scripts/test_formula.sh- End-to-end brew install/test/audit/style.
mcp-vector-search/scripts/update_homebrew_formula.py- End-to-end tap update with
--dry-run,--version,--tap-repo-pathandHOMEBREW_TAP_TOKEN.
- End-to-end tap update with
Standard Workflow
1. Confirm PyPI Release
- Check the sdist is available and capture URL/SHA.
- Typical command:
curl -s https://pypi.org/pypi/<package>/<version>/json.
2. Update Formula URL + SHA
- Replace
urlandsha256inFormula/<name>.rb. - Keep the formula version implicit via the sdist URL (your taps do this).
3. Refresh Resources (Python Virtualenv Formula)
If the formula uses Language::Python::Virtualenv and virtualenv_install_with_resources:
- Regenerate
resourcestanzas after dependency changes. - Use
generate_resources.pyor equivalent; review output before pasting.
4. Test and Audit
Run these in the tap repo:
brew install --build-from-source ./Formula/<name>.rb
brew test <name>
brew audit --strict ./Formula/<name>.rb
brew style ./Formula/<name>.rb
5. Commit and Push
- Update
CHANGELOG.mdif the tap repo tracks releases. - Commit, tag, and push as required by the tap workflow.
Formula Patterns (From Your Taps)
Full Virtualenv Formula (claude-mpm)
include Language::Python::Virtualenvvirtualenv_install_with_resources- Large
resourceblocks to pin dependencies test douses CLI commands like--versionand subcommands
Minimal Venv Formula (mcp-vector-search)
- Create venv explicitly and
pip install -v buildpath bin.install_symlinkfor CLI entrypoint- Minimal
test douses--versionand--help
CI Automation Pattern
Your GitHub Actions workflow for Homebrew updates follows this flow:
- Trigger on tag or
workflow_runafter CI succeeds. - Run
scripts/update_homebrew_formula.py. - Require
HOMEBREW_TAP_TOKEN(and optionalHOMEBREW_TAP_REPO). - On failure, open an issue with manual update steps.
Troubleshooting
- PyPI release missing: verify tag push and publish step completed.
- SHA mismatch: re-fetch sdist SHA from PyPI JSON.
- brew audit failures: confirm dependency resource blocks match the sdist and
python@x.ydependency is present. - Install failures: verify
python@x.ydependency andvirtualenv_install_with_resourcesusage.
Related Skills
toolchains/universal/infrastructure/github-actionstoolchains/universal/infrastructure/docker