Set up your terminal to boost the productivity, increase the speed and make the user interface beautiful
Configure your shell to boost the productivity, increase the speed and make stunning user interface that you will love working with.
Yogesh 23 Sep, 2020 2403
In this article, we will configure the shell/terminal and upgrade the settings, install the packages to increase the productivity and speed, and change the look and feel of the terminal.
First of all, check the activated shell
echo $SHELL
or
echo $0
The above command will display your currently activated shell.
cat /etc/shells
The above command will display all the available shells.
Follow the below steps to setup & configure the Terminal
- Install ZSH
- Install & Configure Oh-my-zsh
- Install Themes
- Install Plugins
- Fonts & Colors
- Setup Starship
In this article, we consider the Bash terminal that will available in Linux and macOS.
The default terminal that comes with Linux(Ubuntu OS) is Bash(Bourne Shell). In this tutorial, we will first change the shell and then configure it and then update the plugins & color preferences.
Install Zsh Shell
First, check whether zsh is installed or not using below command:
< /etc/shells grep zsh
outout:
/bin/zsh
/usr/bin/zsh
Installation
- For Debian(ubuntu like distros)
sudo apt update sudo apt install zsh
For Redhat
sudo yum install zsh
For OpenSuse
zypper install zsh
For Arc Linux or Manjaro
pacman -S zsh
For Fedora
dnf install zsh
For free bsd
pkg install zsh
For macOS
brew install zsh
or you can download it from source http://zsh.sourceforge.net/Arc/source.html
Official Installation Doc: https://github.com/ohmyzsh/ohmyzsh/wiki/Installing-ZSH
Check zsh version: zsh --version
Zsh has been installed successfully.
Now, make zsh as default terminal:
chsh -s $(which zsh)
If you want to switch back to the default bash or any other terminal, then run the below command.
chsh -s /bin/bash or exec bash
or
chsh -s /bin/zsh or exec zsh
then restart the terminal.
Install oh my zsh
Oh my zsh is an open-source framework for managing Zsh configuration.
Install via Curl
sh -c "$(curl -fsSL https://raw.github.com/ohmyzsh/ohmyzsh/master/tools/install.sh)"
Install via wget
sh -c "$(wget https://raw.github.com/ohmyzsh/ohmyzsh/master/tools/install.sh -O -)"
Manual Installation
curl -Lo install.sh https://raw.githubusercontent.com/ohmyzsh/ohmyzsh/master/tools/install.sh
Check the variable of .zshrc file to confirm that zsh is activated.To check whether oh my zsh is active or not, check the variable inside .zshrc file.
Open zshrc file: > sudo nano ~/.zshrc
export ZSH="$HOME/.oh-my-zsh"
Make sure the above variable is set inside the zshrc file. If it's not there then edit the file and add the above line.
To apply all the edited changes in the bashrc/zshrc file you must have to run
source ~/.bashrc
orsource ~/.zshrc
command.
Next, we will install omz plugins and themes.
To apply the themes and plugins, we've to update the variable of .zshrc config file.
Themes
The Theme(ZSH_THEME) is a variable of zshrc(omz) file. To add or update the theme, you've to first install(if not pre-installed) the theme and then update the theme(ZSH_THEME) variable.
The oh-my-zsh comes with predefined themes. You can set them by setting the ZSH_THEME variable.
The default and popular themes of omz are robbyrussell and agnoster that comes with omz installation.
Set the robbyrussell theme
ZSH_THEME="robbyrussell"
Agnoster theme
ZSH_THEME="agnoster"
There are many more pre-installed theme options available with Oh-my-zsh. For example Pure, Avit, Apple, Bira, etc...
Checkout the full list of Oh-My-Zsh Themes: https://github.com/ohmyzsh/ohmyzsh/wiki/Themes
Apart from that, you can install externally developed themes as well. Some of the popular external themes are Powerlevel10k, Powerlevel9k, Spaceship, Bullet-Train, etc...
Powerlevel10k
Powerlvel10k is a fully customizable and more advanced theme of zsh.
Installation
For Oh my zsh
git clone --depth=1 https://github.com/romkatv/powerlevel10k.git ${ZSH_CUSTOM:-$HOME/.oh-my-zsh/custom}/themes/powerlevel10k
then, add set the theme in ZSH_THME variable in .zshrc file.
ZSH_THEME="powerlevel10k/powerlevel10k"
Configure Powerlevel10k
Type command: p10 configure
to start Powerlevel10k configuration.
Or also you can edit the configuration file: ~/.p10k.zsh
For more details: https://github.com/romkatv/powerlevel10k
Spaceship
Another powerful theme is Spaceship. It comes with many features and an extremely customizable zsh prompt theme.
Installation
For Oh My Zsh
git clone https://github.com/denysdovhan/spaceship-prompt.git "$ZSH_CUSTOM/themes/spaceship-prompt" --depth=1
Symlink spaceship.zsh-theme to your oh-my-zsh custom themes directory:
ln -s "$ZSH_CUSTOM/themes/spaceship-prompt/spaceship.zsh-theme" "$ZSH_CUSTOM/themes/spaceship.zsh-theme"
Then set the ZSH_THEME variable in .zshrc
ZSH_THEME="spaceship"
For more details: https://denysdovhan.com/spaceship-prompt/
Plugins
The Plugins is an array variable that contains a list of activated plugin values in zshrc(omz) file. To add or update the plugins, you've to first install(if not pre-installed) the plugin and then update the plugin variable.
plugins=(git node autojump ... )
The values of the plugins var should be separated by space, not by a comma. Now, install some of the very useful plugins. Git Just add the word git in plugins var.
plugins=(git ...)
zsh-autosuggestions
For Oh-My-Zsh
First, clone the directory using git
git clone https://github.com/zsh-users/zsh-autosuggestions ${ZSH_CUSTOM:-~/.oh-my-zsh/custom}/plugins/zsh-autosuggestions
and activate the plugin
plugins=(... zsh-autosuggestions)
Or Manual Installation
git clone https://github.com/zsh-users/zsh-autosuggestions ~/.zsh/zsh-autosuggestions
and add the following line to ~/.zshrc
source ~/.zsh/zsh-autosuggestions/zsh-autosuggestions.zsh
and restart the terminal.
zsh-syntax-highlighting Installation
For Zsh
Clone the git repo
git clone https://github.com/zsh-users/zsh-syntax-highlighting.git
echo "source ${(q-)PWD}/zsh-syntax-highlighting/zsh-syntax-highlighting.zsh" >> ${ZDOTDIR:-$HOME}/.zshrc
Then enable the plugin
source ./zsh-syntax-highlighting/zsh-syntax-highlighting.zsh
For Oh-My-Zsh
Clone the repo
git clone https://github.com/zsh-users/zsh-syntax-highlighting.git ${ZSH_CUSTOM:-~/.oh-my-zsh/custom}/plugins/zsh-syntax-highlighting
And add the zsh-syntax-highlighting value in plugins variable
plugins=(... zsh-syntax-highlighting)
And restart the terminal.
Before
After
z or Zsh-z
Z allows you to jump quickly to the directory that you visited most in the past. Z will remember the path you've entered frequently and helped you to jump around them with few keystrokes.
Z uses regular expression.
To enable z plugin, assing z to your plugin variable.
plugins=(... z )
For more oh-my-zsh plugins: https://github.com/ohmyzsh/ohmyzsh/wiki/Plugins
Terminal Preferences
Install the Patched Fonts for the terminal. The patched font will be used to display characters, glyphs, icons, arrow effects, emoji.
Install Powerline fonts
sudo apt-get install fonts-powerline
For more options: https://github.com/powerline/fonts#quick-installation
Download and Install the Powerline/Nerd font
Then select the preferable front in custom font inside the text tab in Preferences.
Change the colors(color scheme) of the Terminal Open the preferences and select the second tab=> Colors.
Available Buil-in Schemes are: Tango & Solarized are recommended.
You can also customize the colors according to your need in the custom tab.
Next, make the terminal faster more customizable with Starship
Starship
Install and configure Starship The Starship is "The minimal, blazing-fast, and infinitely customizable prompt for any shell!"
Installation Using curl
curl -fsSL https://starship.rs/install.sh | bash
With Brew
brew install starship
With Scoop
scoop install starship
After installation, add the below line to init the Starship
For Bash(~/.bashrc)
eval "$(starship init bash)"
For Zsh(~/.zshrc)
eval "$(starship init zsh)"
For Fish(~/.config/fish/config.fish)
starship init fish | source
Configuration Starship uses Ta OML file for configuration.
TOML Doc: https://github.com/toml-lang/toml
To get started configuring starship, create the config file starship.toml inside .config direcotry.
starship.toml
add_newline = false
symbol = "➜"
[language]
symbol='*'
.
.
.
For prompt configuration visit: https://starship.rs/config/#prompt
Tmux/Tilix
tmux is a program which runs in a terminal and allows multiple other terminal programs to be run inside it.
Tilix is similar to Tmux. It is tiling terminal emulator. Tmux/Tilix can split your emulator window in multiple terminal panes.
I hope you guys liked the article.