Pimp My Terminal
By Gonçalo Marantes / Wednesday, September 8, 2021 / 15 minutes
#Technical #Miscellaneous
data:image/s3,"s3://crabby-images/f8145/f8145ea514e7ead12692b1418256d4f8a23833a8" alt="Image"
For us developers, our terminal is our one stop shop for pretty much anything. We rely on it for installing packages, perform system analysis and spring up whole software projects. For those reasons, we should show it some love and affection.
Just yesterday, I performed a fresh install on my personal computer as I strongly needed to do so. I decided to install the latest version of Solus OS with Budgie desktop environment and give it a go. (Who doesn't like to try out a new flavor of Linux from time to time?).
The problem was that the default terminal looks kind of sad, so I decided to spruce things up a bit to make it easier for me to look at it. Budgie uses gnome-terminal, so if you are rocking the reliable Ubuntu LTS version with Gnome, setup will be very similar to this.
Our starting point is the following:
data:image/s3,"s3://crabby-images/fe81e/fe81e9cf7a5ba95e0dca9db32c8022a384832b54" alt="Image"
Fonts
We need to get rid of the default old-looking font that comes with bash. And we need to replace it with a modern font that supports glyphs or icons. Who doesn't like icons?
You've probably already heard of the Nerd Fonts project, it basically aggregates your favorite fonts with icons from Font Awesome and other sources, in order for you to have everything in one place. There are many projects similar to Nerd Fonts, just pick one and go for it. I'm going with Meslo.
Color your terminal
Now that we have a cool font, we need some colors on our terminal. Luckily, there's a project called Gogh where we can choose our favorite color palette in less that 5 seconds. Unfortunely, this project is only compatible with Gnome Terminal, XFCE4 and some others, this means that if you're using KDE with Konsole, it won't work. You can visit the KDE store instead!
To run Gogh, simply run:
bash -c "$(wget -qO- https://git.io/vQgMr)"
and pick the profiles you want to install. I'm going with DeHydration.
data:image/s3,"s3://crabby-images/d26f0/d26f016426622aeea20e465f00a33cd2b38074ff" alt="Image"
Zsh and Oh My Zsh
Out of the box, your Linux distro is probably using Bash
, plain boring bash... I prefer to use Zsh
due to easier configuration, community developed plugins and much much more.
Zsh is a shell designed for interactive use, and with a powerful community you can easily find anything you need. Oh my Zsh
is basically a framework that helps you install plugins, themes and other helpful stuff.
Zsh
Installing # SolusOS
sudo eopkg install zsh # zsh
# Ubuntu/Debian
sudo apt install zsh
# ...
# other distros can be found here
# https://github.com/ohmyzsh/ohmyzsh/wiki/Installing-ZSH
Oh My Zsh
Installing sh -c "$(curl -fsSL https://raw.githubusercontent.com/ohmyzsh/ohmyzsh/master/tools/install.sh)"
PowerLevel10k
Powerlevel10k
is a Zsh theme than can be easily installed with Oh My Zsh.
# Clone the repository
git clone --depth=1 https://github.com/romkatv/powerlevel10k.git ${ZSH_CUSTOM:-$HOME/.oh-my-zsh/custom}/themes/powerlevel10k
And then set ZSH_THEME="powerlevel10k/powerlevel10k" in ~/.zshrc.
You will then be prompted with the theme setup options:
data:image/s3,"s3://crabby-images/d9656/d96568290ce80b5684f4cffb8e479d356ef716df" alt="Image"
Feel free to customize your terminal however you want.
Mine ended up looking like this:
data:image/s3,"s3://crabby-images/6a184/6a184d2751f2a208eb9b714ee07dfc7731ab24e8" alt="Image"
Troubleshooting Visual Studio Code Terminal
It is possible that visual studio code's terminal will look something like this:
data:image/s3,"s3://crabby-images/e17eb/e17eb26b1f28c9c5b250ee8fb8d4741ef9804b3b" alt="Image"
This is happening because we haven't set VSCode's terminal font to the one we've just configured. To do this, just press ctrl + shift + p and write down terminal settings. Then search for the Font Family option and replace it with your new font.
data:image/s3,"s3://crabby-images/b2c5c/b2c5c6347e323c78ad60007072df389108c853f0" alt="Image"
Useful commands
Now that we have Zsh
installed, we can install some commands that can help us.
ls
, lsd
and tree
lsd
is a replacement for ls that can mainly makes the output prettier, adding icons and colors.
data:image/s3,"s3://crabby-images/e8e0e/e8e0e3561c8bb616059f6ef852743cbc06435614" alt="Image"
Firstly you need to install lsd
# Solus
sudo eopkg install lsd
# Ubuntu/Debian
sudo apt install lsd
You can easily replace the traditional commands with new one by simply editing your zshrc file, just add the following lines:
# replace ls with lsd
command -v lsd > /dev/null && alias ls='lsd --group-dirs first'
# replace tree with lsd --tree
command -v lsd > /dev/null && alias ='lsd --tree'
Now everything should work like a charm.
Zsh Plugins
There are a lot of plugins available out there, and some might be more useful than others depending on your use cases. Nonetheless I suggest you take a look at the plugins that zsh comes bundled with.
Below, you can find some other plugins that don't come out of the box with zsh, but are extremely useful.
Autosuggestions
data:image/s3,"s3://crabby-images/fc2a8/fc2a8cf8c364f5bfee1d21391703904a3606582d" alt="Image"
This plugin helps you navigate your command options, making it easier for you to run whatever you need. To install with Oh My Zsh, you only need to clone the repo and add the plugin to .zshrc.
# clone the repo
git clone https://github.com/zsh-users/zsh-autosuggestions ${ZSH_CUSTOM:-~/.oh-my-zsh/custom}/plugins/zsh-autosuggestions
# in .zshrc
plugins = ( <some other plugins> zsh-autosuggestions)
Syntax Highlighting
data:image/s3,"s3://crabby-images/2b2da/2b2da520a458e3c228bb355f94514ef241822bc9" alt="Image"
Who doesn't enjoy seeing color coded stuff while we write some commands? This plugin does just that. Just like the previous one, installation is as simple as can be.
# clone the repo
git clone https://github.com/zsh-users/zsh-syntax-highlighting.git ${ZSH_CUSTOM:-~/.oh-my-zsh/custom}/plugins/zsh-syntax-highlighting
# in .zshrc
plugins = ( <some other plugins> zsh-syntax-highlighting)
Conclusion
I hope you've found this article helpful and that you've found a way to boost your productivity. You can take a look at my dotfiles if there's something left unclear.
Feel free to show me your terminal setup on Twitter.
Happy scripting đŸ¦„