First of all, thank you for contributing to Homebrew/science. The following guidelines are designed to help you write more efficient pull requests and/or issues.
## IssuesFirst, please read the Troubleshooting Checklist.
See also Homebrew's FAQ and README.
- Search open and closed issues before submitting a new issue. Duplicates will be closed.
- Strictly one formula per issue unless your issue is about different formulae interacting negatively.
- Give the full
brew
command that you used and that caused the error to emerge. - If a formula fails to brew, always gist the full logs with
brew gist-logs <formula>
.
Please first read Homebrew's Formula Cookbook and Acceptable Formulae. This section lists additional guidelines that should be followed in Homebrew/science.
We insist that formulae in Homebrew/science always be accompanied by tests. Not all formulae currently in Homebrew/science have meaningful tests but the idea is to improve them over time.
Tests can be in the form of a make test
or make check
, a test
method, or (if possible) both. If your package doesn't provide tests, that should be specified in the pull request. Meaningful tests are preferred over simple commands like system "foo", "-v"
.
Whenever install-time tests in the form of make test
or make check
take more than a few seconds, an option offering to disable tests should be included. Running the tests by default is preferable. Use the option without-check
to disable your build-time tests. See Testing / Checking.
- Patches should be submitted upstream. Describe and link to the issue in your comments.
- Group mandatory, optional, and recommended dependencies together.
- Group other options together.
- Follow the GitHub Ruby Styleguide.
- Use inline
if
andunless
whevener possible and reasonable (e.g.,depends_on "foo" if build.with? "bar"
,system "make", "check" if build.with? "check"
).
- One formula per pull request.
- When modifying an existing formula, avoid cluttering the patch with unnecessary changes.
- Please check open pull requests before submitting a new pull request. Duplicate pull requests will be closed.
- Fix anything reported by
brew audit foo
when you submitfoo.rb
. - Head-only formulae belong in Homebrew/headonly or their own tap.
-
Please give your pull request an informative title. Each pull request title and commit message should start with the name of the formula, followed by a colon and short comment. For example:
foo 1.2.3 (new formula)
bar 0.1.2
baz: add test
qux: make X11 optional
-
Please keep the commit message to a minimum. GitHub lets you describe your pull request at length when you submit it.
-
Be sure to include a
make test
/make check
if available. If the test or check takes more that a few seconds, a--without-check
option should be available to disable it. The test or check must be enabled by default.
In some cases, it may make more sense for you to host a Homebrew tap than to include your formula(e) in Homebrew/science. Here are a few guidelines to keep in mind when making your decision.
Homebrew/science may give your formula wider visibility but a tap may be preferable when:
- Your formula is part of a group of specialized and/or related formulae.
- The source code or releases are very frequent so that the formula(e) must be updated frequently.
- Your formula should be brewable urgently.
It can be a good idea to start with your own tap and submit to Homebrew/science later.
Probably, but please pay attention to the points above. The more careful you are with your code, the smoother the process will be.
If it takes a while for us to get back to you, relax. We work on Homebrew/science on our own time. We're glad you're contributing and we'll do our best to keep you waiting as little as possible. It's fine to ping us to remind us of your request after a few days.
If you'd like your formula(e) to be brewable urgently, the best option may be for you to host your own tap, even if it's temporary.
## Useful Snippets and NotesHomebrew provides the symbols :optional
and :recommended
to allow for inclusion / exclusion of optional dependencies. If the dependency foo
is marked as :optional
, it is excluded by default and may be included using --with-foo
on the command line. If foo
is marked as :recommended
, it is included by default and may be excluded by using --without-foo
on the command line.
Thus, the following
option "with-foo"
depends_on "foo" if build.with? "foo"
is redundant and should be replaced with the simpler and more readable
depends_on "foo" => :optional
There is no good reason to refer to HOMEBREW_PREFIX
in a formula. Please keep in mind that dependencies may be unlinked at build time. Brew will complain if a dependency is unlinked but that is a historical remnant that is probably bound to disappear. If you need to refer to the location of libraries or header files, please use Formula["foo"].opt_lib
, Formula["foo"].opt_include
, Formula["foo"].opt_prefix
, etc.
This should become a classic:
option "without-check", "Disable build-time checking (not recommended)"
...
system "make"
system "make", "check" if build.with? "check"
system "make", "install"
ENV.m64 if MacOS.prefer_64_bit?
The one-liners
arch = MacOS.prefer_64_bit? ? "macosx64" : "macosx"
and
arch = if MacOS.prefer_64_bit? then "macosx64" else "macosx" end
should be preferred to the multi-line if
block, and, with a little habit, are more readable.
The current version of Clang, which is the default C compiler used in Homebrew, doesn't support OpenMP, but GCC does. Here's an example of alerting the user that OpenMP will not be enabled if using Clang:
opoo "Clang does not support OpenMP. Compile with gcc if this is not acceptable." if ENV.compiler == :clang
This snippet will not abort compilation but output a warning message.
Please do not duplicate options for enabling MPI in a formula. For instance
option "with-mpi"
depends_on :mpi => [:f90, :c, :cxx] if build.with? "mpi"
is redundant and should be replaced with
depends_on :mpi => [:f90, :c, :cxx, :optional]
Depending on :mpi
is more flexible than depending directly on mpich2
or open-mpi
. Remember that users could have installed either and that the two conflict_with
each other.
nprocs = Tab.for_formula("foo").without?("mpi") ? 1 : 2
depends_on :x11 => :optional # or :recommended
Improvements to this guide are appreciated via issues or pull requests. If you're willing to add a new section to this documentation or the wiki, we would very much welcome your contribution.