Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/buo/homebrew-cask-upgrade
A command line tool for upgrading every outdated app installed by Homebrew Cask
https://github.com/buo/homebrew-cask-upgrade
homebrew-cask
Last synced: 5 days ago
JSON representation
A command line tool for upgrading every outdated app installed by Homebrew Cask
- Host: GitHub
- URL: https://github.com/buo/homebrew-cask-upgrade
- Owner: buo
- License: mit
- Created: 2015-11-06T09:06:30.000Z (about 9 years ago)
- Default Branch: master
- Last Pushed: 2024-10-28T17:19:02.000Z (3 months ago)
- Last Synced: 2025-01-07T06:07:43.688Z (12 days ago)
- Topics: homebrew-cask
- Language: Ruby
- Homepage:
- Size: 238 KB
- Stars: 2,482
- Watchers: 34
- Forks: 91
- Open Issues: 16
-
Metadata Files:
- Readme: README.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
Awesome Lists containing this project
- awesome-starred-test - buo/homebrew-cask-upgrade - A command line tool for upgrading every outdated app installed by Homebrew Cask (Ruby)
- my-awesome-starred - buo/homebrew-cask-upgrade - A command line tool for upgrading every outdated app installed by Homebrew Cask (Ruby)
README
[![CI](https://github.com/buo/homebrew-cask-upgrade/actions/workflows/ci.yml/badge.svg)](https://github.com/buo/homebrew-cask-upgrade/actions/workflows/ci.yml)
# brew-cask-upgrade
`brew-cask-upgrade` is a command-line tool for upgrading every outdated app
installed by [Homebrew Cask](https://github.com/Homebrew/homebrew-cask).Homebrew Cask extends [Homebrew](http://brew.sh) and brings its elegance, simplicity, and speed to the installation and management of GUI macOS applications and large binaries alike.
`brew-cask-upgrade` is an external command to replace the native `upgrade` by offering interactivity, an improved interface, and higher granularity of what to upgrade.
## Installation
```shell
brew tap buo/cask-upgrade
```### Verification of installation
In order to simply verify that `brew cu` is correctly installed, you can simply run `brew tap` command and see if the repo is included:```shell
> brew tap
buo/cask-upgrade
homebrew/bundle
homebrew/cask
homebrew/core
```## Uninstallation
```shell
brew untap buo/cask-upgrade
```## Usage
Upgrade outdated apps:
```shell
brew cu
```Upgrade a specific app:
```bash
brew cu [CASK]
```While running the `brew cu` command without any other further options, the script automatically runs `brew update` to get
latest versions of all the installed casks (this can be disabled, see options below).It is also possible to use `*` to install multiple casks at once, i.e. `brew cu flash-*` to install all casks starting with `flash-` prefix.
[![asciicast](https://asciinema.org/a/DlXUmiFFVnDhIDe2tCGo3ecLW.png)](https://asciinema.org/a/DlXUmiFFVnDhIDe2tCGo3ecLW)
### Apps with auto-update
If the app has the auto update functionality (i.e. they ask you themselves if you want to upgrade them), they are not
upgraded while running `brew cu` and will display a `PASS` result. If you want to upgrade them, pass the `-a` or `--all` option to include also those kind of apps.Please note, that if you update the apps using their auto-update functionality, that change will not reflect in the
`brew cu` script! Tracked version gets only updated, when the app is upgraded through `brew cu --all`.### Options
```text
Usage: brew cu [command=run] [CASK] [options]
Commands:
run Default command, doesn't have to be specified. Executes cask upgrades.
pin Pin the current app version, preventing it from being
upgraded when issuing the `brew cu` command. See also `unpin`.
unpin Unpin the current app version, allowing them to be
upgraded by `brew cu` command. See also `pin`.
pinned Print all pinned apps and its version. See also `pin`.Options:
-a, --all Include apps that auto-update in the upgrade.
--cleanup Cleans up cached downloads and tracker symlinks after
updating.
-f --force Include apps that are marked as latest
(i.e. force-reinstall them).
--no-brew-update Prevent auto-update of Homebrew, taps, and formulae
before checking outdated apps.
-y, --yes Update all outdated apps; answer yes to updating packages.
-q, --quiet Do not show information about installed apps or current options.
-v, --verbose Make output more verbose.
--no-quarantine Pass --no-quarantine option to `brew cask install`.
-i, --interactive Running update in interactive mode
--include-mas (Experimental) Include applications from Mac App Store.
```Display usage instructions:
```shell
brew help cu
```### Mac App Store applications (Experimental)
By adding `--include-mas` parameter to the `brew cu` command, we use [mas](https://github.com/mas-cli/mas/) cli tool to manage
upgrades for Mac App Store applications as well.**Note:** This feature is highly experimental and we don't guarantee it's functionality. Use at your own risk.
### Interactive mode
When using interactive mode (by adding `--interactive` argument or confirming app installation with `i`) will trigger per-cask confirmation.
For every cask it is then possible to use following options:
- `y` will install the current cask update
- `N` will skip the installation of current cask
- `p` will pin the current version of the cask (see [version pinning](#version-pinning))### Version pinning
Pinned apps will not be updated by `brew cu` until they are unpinned.
NB: version pinning in `brew cu` will not prevent `brew cask upgrade` from updating pinned apps.### Export / Import pinned apps
In order to export backup of your pinned casks into a file, simply pass `--export` option to the `pinned` command.
```shell
brew cu pinned --export my-backup-filename.txt
```
**Note**: Versions, in which were casks pinned, are not exported as it isn’t possible to install a specific version afterwards.In order to load the configuration back, use `--load` option.
```shell
brew cu pinned --load my-backup-filename.txt
```
**Note**: Loading the configuration will **replace** current values.