The following commands are used by Homebrew contributors to set up a fork of Homebrew’s Git repository on GitHub, create a new branch and create a GitHub pull request (“PR”) for the changes in that branch.
The type of change you want to make influences which of Homebrew’s main repositories you’ll need to send your pull request to. If you want to submit a change to Homebrew’s core code (the brew
implementation), you should open a pull request on Homebrew/brew. If you want to submit a change for a formula, you should open a pull request on the homebrew/core tap, while for casks you should open the pull request on the homebrew/cask tap or another official tap, depending on the formula type.
brew bump-formula-pr
to do everything (i.e. forking, committing, pushing) with a single command. Run brew bump-formula-pr --help
to learn more.brew bump-cask-pr
to do everything (i.e. forking, committing, pushing) with a single command. Run brew bump-cask-pr --help
to learn more.brew
code pull requestChange to the directory containing your Homebrew installation:
cd "$(brew --repository)"
Add your pushable forked repository as a new remote:
git remote add <YOUR_USERNAME> https://github.com/<YOUR_USERNAME>/brew.git
<YOUR_USERNAME>
is your GitHub username, not your local machine username.Before creating a new formulae, please read Acceptable Formulae.
Tap (download a local clone of) the repository of core Homebrew formulae:
brew tap --force homebrew/core
Change to the directory containing Homebrew formulae:
cd "$(brew --repository homebrew/core)"
Add your pushable forked repository as a new remote:
git remote add <YOUR_USERNAME> https://github.com/<YOUR_USERNAME>/homebrew-core.git
<YOUR_USERNAME>
is your GitHub username, not your local machine username.Before creating a new cask, please read Acceptable Casks.
Tap (download a local clone of) the repository of core Homebrew casks:
brew tap --force homebrew/cask
Change to the directory containing Homebrew casks:
cd "$(brew --repository homebrew/cask)"
Add your pushable forked repository as a new remote:
git remote add <YOUR_USERNAME> https://github.com/<YOUR_USERNAME>/homebrew-cask.git
<YOUR_USERNAME>
is your GitHub username, not your local machine username.To make changes on a new branch and submit it for review, create a GitHub pull request with the following steps:
Check out the master
branch:
git checkout master
Retrieve new changes to the master
branch:
brew update
Create a new branch from the latest master
branch:
git checkout -b <YOUR_BRANCH_NAME> origin/master
brew edit
or your favourite text editor, following all the guidelines in the Formula Cookbook or Cask Cookbook.
bottle do
block in the formula, don’t remove or change it; we’ll update it when we merge your PR.Test your changes by running the following, and ensure they all pass without issue. For changed formulae and casks, make sure you do the brew audit
step after your changed formula/cask has been installed.
brew tests
HOMEBREW_NO_INSTALL_FROM_API=1 brew install --build-from-source <CHANGED_FORMULA|CHANGED_CASK>
brew test <CHANGED_FORMULA|CHANGED_CASK>
brew audit --strict --online <CHANGED_FORMULA|CHANGED_CASK>
git add
and git commit
. Each formula’s commits must be squashed.
<FORMULA_NAME> <NEW_VERSION>
”, e.g. “source-highlight 3.1.8
”.Upload your branch of new commits to your fork:
git push --set-upstream <YOUR_USERNAME> <YOUR_BRANCH_NAME>
Thank you!
To respond well to feedback:
needs response
label on a PR means that the Homebrew maintainers need you to respond to previous comments.To make changes based on feedback:
Check out your branch again:
git checkout <YOUR_BRANCH_NAME>
git add
and git commit
.Squash new commits into one commit per formula:
git rebase --interactive origin/master
git commit --amend
is a convenient way of keeping your commits squashed as you go.Push to your remote fork’s branch and the pull request:
git push --force
Once all feedback has been addressed and if it’s a change we want to include (we include most changes), then we’ll add your changes to Homebrew. Note that the PR status may show up as “Closed” instead of “Merged” because of the way we merge contributions. Don’t worry: you will still get author credit in the actual merged commit.
Well done, you are now a Homebrew contributor!