README.md 3.33 KB
Newer Older
1
2
# Bundler

3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
This plugin adds completion for basic bundler commands, as well as aliases and helper functions for
an easier experience with bundler.

To use it, add `bundler` to the plugins array in your zshrc file:

```zsh
plugins=(... bundler)
```

## Aliases

| Alias  | Command                              | Description                                                                              |
|--------|--------------------------------------|------------------------------------------------------------------------------------------|
| `ba`   | `bundle add`                         | Add gem to the Gemfile and run bundle install                                            |
| `bck`  | `bundle check`                       | Verifies if dependencies are satisfied by installed gems                                 |
| `bcn`  | `bundle clean`                       | Cleans up unused gems in your bundler directory                                          |
| `be`   | `bundle exec`                        | Execute a command in the context of the bundle                                           |
| `bi`   | `bundle install --jobs=<core_count>` | Install the dependencies specified in your Gemfile (using all cores in bundler >= 1.4.0) |
| `bl`   | `bundle list`                        | List all the gems in the bundle                                                          |
| `bo`   | `bundle open`                        | Opens the source directory for a gem in your bundle                                      |
| `bout` | `bundle outdated`                    | List installed gems with newer versions available                                        |
| `bp`   | `bundle package`                     | Package your needed .gem files into your application                                     |
| `bu`   | `bundle update`                      | Update your gems to the latest available versions                                        |

## Gem wrapper

The plugin adds a wrapper for common gems, which:

- Looks for a binstub under `./bin/` and executes it if present.
- Calls `bundle exec <gem>` otherwise.
33

34
Common gems wrapped by default (by name of the executable):
35

David Shaffer's avatar
David Shaffer committed
36
`annotate`, `cap`, `capify`, `cucumber`, `foodcritic`, `guard`, `hanami`, `irb`, `jekyll`, `kitchen`, `knife`, `middleman`, `nanoc`, `pry`, `puma`, `rackup`, `rainbows`, `rake`, `rspec`, `rubocop`, `shotgun`, `sidekiq`, `spec`, `spork`, `spring`, `strainer`, `tailor`, `taps`, `thin`, `thor`, `unicorn` and `unicorn_rails`.
37

38
### Settings
39

40
41
You can add or remove gems from the list of wrapped commands.
Please **use the exact name of the executable** and not the gem name.
42

43
#### Include gems to be wrapped (`BUNDLED_COMMANDS`)
44

45
Add this before the plugin list in your `.zshrc`:
46

47
48
49
50
```sh
BUNDLED_COMMANDS=(rubocop)
plugins=(... bundler ...)
```
51

52
53
This will add the wrapper for the `rubocop` gem (i.e. the executable).

54
#### Exclude gems from being wrapped (`UNBUNDLED_COMMANDS`)
55

56
Add this before the plugin list in your `.zshrc`:
57

58
59
60
61
```sh
UNBUNDLED_COMMANDS=(foreman spin)
plugins=(... bundler ...)
```
62

63
64
This will exclude the `foreman` and `spin` gems (i.e. their executable) from being wrapped.

65
### Excluded gems
66

67
These gems should not be called with `bundle exec`. Please see [issue #2923](https://github.com/ohmyzsh/ohmyzsh/pull/2923) on GitHub for clarification:
68

69
70
71
72
73
74
- `berks`
- `foreman`
- `mailcatcher`
- `rails`
- `ruby`
- `spin`