Merge pull request #194004 from Homebrew/bump-binance-1.54.4
[Homebrew/homebrew-cask.git] / CONTRIBUTING.md
blobeda5d5fc512ee61432a1eb6e951e84b610f5ddfb
1 # How To Contribute
3 :+1::tada: First off, thanks for taking the time to contribute! :tada::+1:
5 * [Updating a Cask](#updating-a-cask)
6 * [Getting Set Up To Contribute](#getting-set-up-to-contribute)
7 * [Adding a Cask](#adding-a-cask)
8 * [Style Guide](#style-guide)
9 * [Reporting Bugs](README.md#reporting-bugs)
11 ## Updating a Cask
13 Notice an application that's out-of-date in Homebrew Cask? In most cases, it's very simple to update it. We have a command that will take care of updating the cask file and submitting a pull request to us:
15 ```bash
16 brew bump --open-pr <outdated_cask>
17 ```
19 You can also follow the steps in the documentation on [adding a cask](https://docs.brew.sh/Adding-Software-to-Homebrew#casks) for more complicated changes.
21 ## Getting Set Up To Contribute
23 Follow the guide in [How to Open a Homebrew Pull Request](https://docs.brew.sh/How-To-Open-a-Homebrew-Pull-Request#cask-related-pull-request).
25 ## Adding a Cask
27 Notice an application that's not in Homebrew Cask yet? Make sure it's also not in [homebrew/core](https://github.com/Homebrew/homebrew-core) (can be searched with `brew search`). Mac App Store apps can't be installed via Homebrew Cask, but check out [mas](https://github.com/mas-cli/mas) for an alternative.
29 With a bit of work, you can create a cask for it. The documentation on [adding a cask](https://docs.brew.sh/Adding-Software-to-Homebrew#casks) will help you create, test, and submit a new cask to us.
31 ## Style Guide
33 Some style guidelines:
35 * All casks and code should be indented using two spaces (never tabs). When `brew style` contradicts this, `style` must be followed.
36 * There should not be any extraneous comments - the only comments that should be used are the ones explicitly defined in the [Cask Cookbook](https://docs.brew.sh/Cask-Cookbook).
37 * The stanza order and position of newlines is important to make things easier (see [Stanza order](https://docs.brew.sh/Cask-Cookbook#stanza-order)).
38 * Use string manipulations to improve the maintainability of your cask (see [`version` methods](https://docs.brew.sh/Cask-Cookbook#version-methods)).
39 * Test your cask using `brew audit` and `brew style` (see the documentation on [testing and auditing](https://docs.brew.sh/Adding-Software-to-Homebrew#testing-and-auditing-the-cask)).
40 * Make one pull request per cask change.
41 * Do not squash commits after updating a pull request.
42 * Use descriptive commit messages - mention cask name and version/change (ie. `transmission 2.82`, `google-chrome: update zap`).