This project is a fork of the Homebrew.git project. If you have that one already cloned locally, you can use
git clone --reference /path/to/your/Homebrew.git/incarnation mirror_URL
to save bandwidth during cloning.
 
descriptionBundler for non-Ruby dependencies from Homebrew, Homebrew Cask and the Mac App Store.
homepage URLhttps://brew.sh/
repository URLhttps://github.com/Homebrew/homebrew-bundle.git
ownerroot@yurikoles.com
last changeThu, 30 May 2024 23:36:19 +0000 (31 09:36 +1000)
last refreshMon, 3 Jun 2024 05:41:38 +0000 (3 07:41 +0200)
content tags
add:
README.md

Homebrew Bundle

Bundler for non-Ruby dependencies from Homebrew, Homebrew Cask, Mac App Store, Whalebrew and Visual Studio Code.

Requirements

Homebrew (on macOS or Linux) for installing dependencies.

Homebrew Cask is optional and used for installing Mac applications.

mas-cli is optional and used for installing Mac App Store applications.

Whalebrew is optional and used for installing Whalebrew images.

Visual Studio Code is optional and used for installing Visual Studio Code extensions.

Installation

brew bundle is automatically installed when first run.

Usage

See the brew bundle section of the brew generate-man-completions output or brew bundle --help.

An example Brewfile:

# 'brew tap'
tap "homebrew/cask"
# 'brew tap' with custom Git URL
tap "user/tap-repo", "https://user@bitbucket.org/user/homebrew-tap-repo.git"
# 'brew tap' with arguments
tap "user/tap-repo", "https://user@bitbucket.org/user/homebrew-tap-repo.git", force_auto_update: true

# set arguments for all 'brew install --cask' commands
cask_args appdir: "~/Applications", require_sha: true

# 'brew install'
brew "imagemagick"
# 'brew install --with-rmtp', 'brew services restart' on version changes
brew "denji/nginx/nginx-full", args: ["with-rmtp"], restart_service: :changed
# 'brew install', always 'brew services restart', 'brew link', 'brew unlink mysql' (if it is installed)
brew "mysql@5.6", restart_service: true, link: true, conflicts_with: ["mysql"]
# install only on specified OS
brew "gnupg" if OS.mac?
brew "glibc" if OS.linux?

# 'brew install --cask'
cask "google-chrome"
# 'brew install --cask --appdir=~/my-apps/Applications'
cask "firefox", args: { appdir: "~/my-apps/Applications" }
# bypass Gatekeeper protections (NOT RECOMMENDED)
cask "firefox", args: { no_quarantine: true }
# always upgrade auto-updated or unversioned cask to latest version even if already installed
cask "opera", greedy: true
# 'brew install --cask' only if '/usr/libexec/java_home --failfast' fails
cask "java" unless system "/usr/libexec/java_home", "--failfast"

# 'mas install'
mas "1Password", id: 443_987_910

# 'whalebrew install'
whalebrew "whalebrew/wget"

# 'vscode --install-extension'
vscode "GitHub.codespaces"

Versions and lockfiles

Homebrew is a rolling release package manager so it does not support installing arbitrary older versions of software. If your software needs specific pinned versions, consider whalebrew lines in your Brewfile to install Docker containers.

After a successful brew bundle run, it creates a Brewfile.lock.json to record the environment. If a future brew bundle run fails, you can check the differences between Brewfile.lock.json to debug. As it can contain local environment information that varies between systems, it's not worth committing to version control on multi-user repositories.

Disable generation of the Brewfile.lock.json file by setting the environment variable with export HOMEBREW_BUNDLE_NO_LOCK=1 or by using the command-line argument brew bundle --no-lock.

New Installers/Checkers/Dumpers

brew bundle currently supports Homebrew, Homebrew Cask, Mac App Store, Whalebrew and Visual Studio Code.

We are interested in contributions for other installers/checkers/dumpers but they must:

Note: based on these criteria, we would not accept e.g. Whalebrew (but have no plans to remove it.)

Tests

Tests can be run with bundle install && bundle exec rspec. Syntax linting can be run with brew style homebrew/bundle.

Copyright (c) Homebrew maintainers and Andrew Nesbitt. See LICENSE for details.

shortlog
3 days ago Jacob BednarzMerge pull request #1374 from Homebrew/dependabot/githu... master
3 days ago dependabot... build(deps): bump ruby/setup-ruby from 1.177.1 to 1...
4 days ago Jacob BednarzMerge pull request #1373 from Homebrew/dependabot/bundl...
4 days ago dependabot... build(deps-dev): bump concurrent-ruby from 1.2.3 to...
9 days ago Mike McQuaidMerge pull request #1372 from Homebrew/sync-shared...
9 days ago BrewTestBotdependabot.yml: update to match main configuration
9 days ago Mike McQuaidMerge pull request #1371 from Homebrew/sync-shared...
9 days ago BrewTestBot.rubocop.yml: update to match main configuration
9 days ago Mike McQuaidMerge pull request #1370 from Homebrew/sync-shared...
9 days ago BrewTestBotdependabot.yml: update to match main configuration
10 days ago Mike McQuaidMerge pull request #1365 from Homebrew/eval-path
10 days ago Bo AndersonSupport __FILE__ in Brewfiles
10 days ago Mike McQuaidMerge pull request #1369 from Homebrew/ruby-version
10 days ago Mike McQuaidGemfile: use `.ruby-version`.
10 days ago Mike McQuaidMerge pull request #1368 from Homebrew/sync-triage...
10 days ago BrewTestBot.ruby-version: update to match main configuration
...
heads
3 days ago master
2 months ago mas_updates
19 months ago dependabot/bundler/rspec-mocks-3.11.2