1
2
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
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
|
+++
date = 2022-07-31
title = "Upgrade Bash with Bash-It & Ble.sh"
description = "In this post, I walk through the Bash-It and Ble.sh projects, their features, and how they help users power-up their bash shell."
+++
## Bash
For those who are not familiar,
[Bash](https://en.wikipedia.org/wiki/Bash_(Unix_shell)) is a Unix shell that is
used as the default login shell for most Linux distributions. This shell and
command processor should be familiar if you've used Linux (or older version of
macOS) before.
However, bash is not the only option.
There are numerous other shells that exist.
Here are some popular examples:
- [zsh](https://en.wikipedia.org/wiki/Z_shell)
- [fish](https://en.wikipedia.org/wiki/Fish_(Unix_shell))
- [oksh](https://github.com/ibara/oksh)
- [mksh](https://wiki.gentoo.org/wiki/Mksh)
- [dash](https://en.wikipedia.org/wiki/Debian_Almquist_shell)
While each shell has its differences, bash is POSIX compliant and the default
for many Linux users. Because of this, I am going to explore a program called
`bash-it` below that helps bash users increase the utility of their shell
without installing a completely new shell.
### Installation
First, if bash is not already installed on your system, you can [download bash
from GNU](https://www.gnu.org/software/bash/) or use your package manager to
install it.
For example, this is how you can install bash on Fedora Linux:
```sh
sudo dnf install bash
```
If you are not using bash as your default shell, use the `chsh` command to
change your shell:
```sh
chsh
```
You should see a prompt like the one below. If the brackets (`[]`) contain
`bash` already, you're done, and you can simply continue by hitting the Enter
key.
If the brackets contain another shell path (e.g. `/usr/bin/zsh`), enter the path
to the bash program on your system (it's most likely located at
`/usr/bin/bash`).
```sh
Changing shell for <user>.
New shell [/usr/bin/bash]:
```
You must log out or restart the machine in order for the login shell to be
refreshed. You can do it now or wait until you're finished customizing the
shell.
```sh
sudo reboot now
```
## Bash-it
As noted on the [Bash-it](https://github.com/Bash-it/bash-it) repository:
> Bash-it is a collection of community Bash commands and scripts for Bash 3.2+.
> (And a shameless ripoff of oh-my-zsh 😃)
Bash-it makes it easy to install plugins, set up aliases for common commands,
and easily change the visual theme of your shell.
### Installation
To install the framework, simply copy the repository files and use the
`install.sh` script provided. If you want, you can (and should!) inspect the
contents of the installation script before you run it.
```sh
git clone --depth=1 https://github.com/Bash-it/bash-it.git ~/.bash_it
~/.bash_it/install.sh
```
If you didn't restart your session after making bash the default, and are
currently working within another shell, be sure to enter a bash session before
using `bash-it`:
```sh
bash
```
### Aliases
Bash-it contains a number of aliases for common commands to help improve
efficiency in the terminal. To list all available options, use the following
command:
```sh
bash-it show aliases
```
This will provide you a list that looks like the following text block.
Within this screen, you will be able to see all available options and which
ones are currently enabled.
```txt
Alias Enabled? Description
ag [ ] the silver searcher (ag) aliases
ansible [ ] ansible abbreviations
apt [ ] Apt and dpkg aliases for Ubuntu and Debian distros.
atom [ ] Atom.io editor abbreviations
bash-it [ ] Aliases for the bash-it command (these aliases are automatically included with the "general" aliases)
bolt [ ] puppet bolt aliases
bundler [ ] ruby bundler
clipboard [ ] xclip shortcuts
composer [ ] common composer abbreviations
curl [x] Curl aliases for convenience.
...
```
To enable an alias, do:
```sh
bash-it enable alias <alias name> [alias name]... -or- $ bash-it enable alias all
```
To disable an alias, do:
```sh
bash-it disable alias <alias name> [alias name]... -or- $ bash-it disable alias all
```
### Plugins
Similar to aliases, plugins are available with bash-it. You can find a complete
list of plugins in the same way as aliases. Simply execute the following:
```sh
bash-it show plugins
```
You will see the following output showing enabled and disabled plugins:
```txt
Plugin Enabled? Description
alias-completion [ ]
autojump [ ] Autojump configuration, see https://github.com/wting/autojump for more details
aws [ ] AWS helper functions
base [x] miscellaneous tools
basher [ ] initializes basher, the shell package manager
battery [x] display info about your battery charge level
blesh [ ] load ble.sh, the Bash line editor!
boot2docker [ ] Helpers to get Docker setup correctly for boot2docker
browser [ ] render commandline output in your browser
```
To enable a plugin, do:
```sh
bash-it enable plugin <plugin name> [plugin name]... -or- $ bash-it enable plugin all
```
To disable a plugin, do:
```sh
bash-it disable plugin <plugin name> [plugin name]... -or- $ bash-it disable plugin all
```
### Themes
There are quite a few pre-defined
[themes](https://bash-it.readthedocs.io/en/latest/themes-list/#list-of-themes)
available with bash-it.
To list all themes:
```sh
ls ~/.bash_it/themes/
```
To use a new theme, you'll need to edit `.bashrc` and alter the `BASH_IT_THEME`
variable to your desired theme. For example, I am using the `zork` theme.
```sh
nano ~/.bashrc
```
```sh
export BASH_IT_THEME='zork'
```
Once you save your changes, you just need to exit your terminal and create a new
one in order to see your changes to the `.bashrc` file. You can also `source`
the file to see changes, but I recommend starting a completely new shell
instead.
## ble.sh
One big feature I was missing in Bash that both `zsh` and `fish` have is an
autosuggestion feature. To explain: as you type, an autosuggestion feature in
the shell will offer suggestions in a lighter font color beyond the characters
already typed. Once you see the command you want, you can click the right arrow
and have the shell auto-complete that line for you.
Luckily, the [Bash Line Editor](https://github.com/akinomyoga/ble.sh) (ble.sh)
exists! This program provides a wonderful autosuggestions feature perfectly,
among other features that I haven't tested yet.
In order to install ble.sh, execute the following:
```sh
git clone --recursive https://github.com/akinomyoga/ble.sh.git
make -C ble.sh install PREFIX=~/.local
echo 'source ~/.local/share/blesh/ble.sh' >> ~/.bashrc
```
Again, exit the terminal and open a new one in order to see the newly-configured
shell.
## Restart the Session
Finally, as mentioned above, you'll need to restart the session to ensure that
your user is using bash by default.
You will also need to exit and re-open a shell (e.g., terminal or terminal tab)
any time you make changes to the `.bashrc` file.
```sh
sudo reboot now
```
|