Powerline is a great statusline plugin for Vim editor, which is developed in Python and provides status lines and prompts for many other applications such as bash, zsh, tmux, and many more.
It enhances the appearance and functionality of the Vim editor by providing a customizable and informative status line at the bottom of the editor window, which includes current mode (e.g., normal, insert, visual), file name, path, line and column numbers, Git branch, virtual environment, and more.
Features
- It is written in Python, which makes it extensible and feature-rich.
- Stable and testable code base, which works well with Python 2.6+ and Python 3.
- It also supports prompts and statuslines in several Linux utilities and tools.
- It has configurations and decorator colors developed using JSON.
- Fast and lightweight, with daemon support, which provides, even more, better performance.
In this article, I will show you how to install Powerline and Powerline fonts and how to use Bash and Vim under RHEL-based and Debian-based distributions.
How to Install Powerline in Linux
Due to a naming conflict with some other unrelated projects, the powerline program is available on PyPI (Python Package Index) under the package name as powerline-status.
To install packages from PyPI, we need a pip package management tool for installing Python packages. So, let’s first install the pip tool under our Linux systems.
$ sudo apt install python3-pip [On Debian, Ubuntu and Mint] $ sudo yum install python3-pip [On RHEL/CentOS/Fedora and Rocky Linux/AlmaLinux] $ sudo emerge -a dev-lang/pip [On Gentoo Linux] $ sudo apk add py3-pip [On Alpine Linux] $ sudo pacman -S python-pip [On Arch Linux] $ sudo zypper install python3-pip [On OpenSUSE]
Now it’s’ time to install Powerline latest development version from the Git repository. For this, your system must have a Git package installed in order to fetch the packages from the Git repository.
$ sudo apt install git [On Debian, Ubuntu and Mint] $ sudo yum install git [On RHEL/CentOS/Fedora and Rocky Linux/AlmaLinux] $ sudo emerge -a git [On Gentoo Linux] $ sudo apk add git [On Alpine Linux] $ sudo pacman -S git [On Arch Linux] $ sudo zypper install git [On OpenSUSE]
Next, you can install Powerline with the help of the pip command as shown.
$ pip install powerline-status
If you get the error message “externally-managed-environment“, which typically occurs in the context of Python virtual environments when using Powerline or related tools.
To fix this error, just delete the following file and run the pip install command again.
$ sudo rm -rf /usr/lib/python3.x/EXTERNALLY-MANAGED
Alternatively, you can install Powerline by executing a command specific to your package manager as shown.
$ sudo apt install powerline [On Debian, Ubuntu and Mint] $ sudo yum install powerline [On RHEL/CentOS/Fedora and Rocky/AlmaLinux] $ sudo emerge -a sys-apps/powerline [On Gentoo Linux] $ sudo apk add powerline [On Alpine Linux] $ sudo pacman -S powerline [On Arch Linux] $ sudo zypper install powerline [On OpenSUSE]
How to Install Powerline Fonts in Linux
Powerline uses special glyphs to show special arrow effects and symbols for developers. For this, you must have a symbol font or a patched font installed on your systems.
If you have installed Powerline through PIP, you can install the latest version of the symbol font and fontconfig file as shown.
$ wget https://github.com/powerline/powerline/raw/develop/font/PowerlineSymbols.otf $ wget https://github.com/powerline/powerline/raw/develop/font/10-powerline-symbols.conf $ sudo mv PowerlineSymbols.otf ~/.local/share/fonts/ $ sudo fc-cache -vf ~/.local/share/fonts/ $ sudo mv 10-powerline-symbols.conf ~/.config/fontconfig/conf.d/
If you have installed Powerline through the package manager, you can install the latest fonts by running:
$ sudo apt install fonts-powerline [On Debian, Ubuntu and Mint] $ sudo yum install powerline-fonts [On RHEL/CentOS/Fedora and Rocky/AlmaLinux] $ sudo emerge -a sys-apps/powerline-fonts [On Gentoo Linux] $ sudo apk add powerline-fonts [On Alpine Linux] $ sudo pacman -S powerline-fonts [On Arch Linux] $ sudo zypper install powerline-fonts [On OpenSUSE]
Enable Bash Color Prompts Using Powerline
If you have installed Powerline through PIP, you can enable it by bash shell and vim editor by adding the following line to the ~/.bashrc file as follows.
export TERM=”screen-256color”
To enable Powerline in the bash shell by default, you need to add the following snippet to your ~/.bashrc file.
First, get the location of the installed powerline using the following command.
$ pip show powerline-status Name: powerline-status Version: 2.7 Summary: The ultimate statusline/prompt utility. Home-page: https://github.com/powerline/powerline Author: Kim Silkebaekken Author-email: [email protected] License: MIT Location: /home/tecmint/.local/lib/python3.11/site-packages
Once you know the actual location of the powerline, make sure to replace the location in the below line as per your system suggested.
powerline-daemon -q POWERLINE_BASH_CONTINUATION=1 POWERLINE_BASH_SELECT=1 . /home/tecmint/.local/lib/python3.11/site-packages/powerline/bindings/bash/powerline.sh
If you have installed Powerline through the package manager, you can enable it by running:
$ source /usr/share/powerline/bindings/bash/powerline.sh
Now try to log out and log in back again, you will see the powerline statusline as shown below.
Try changing or switching to different directories and keep an eye on “breadcrumb” prompt changes to show your current location.
You will also be able to watch pending background jobs and if powerline is installed on a remote Linux machine, you can notice that the prompt adds the hostname when you connect via SSH.
Enable Vim Color Prompts with Powerline
If Vim is your favorite editor, luckily there is a powerful plugin for Vim, too. To enable this plugin, add these lines to ~/.vimrc
file.
python3 from powerline.vim import setup as powerline_setup python3 powerline_setup() python3 del powerline_setup set laststatus=2
Now you can launch Vim and see a spiffy new status line:
Summary
Powerline helps to set colorful and beautiful statuslines and prompts in several applications, good for coding environments. I hope you find this guide helpful and remember to post a comment if you need any help or have additional ideas.
Hello Ravi
Thank you for sharing this knowledge. I successfully have powerline running on Linux Mint (Debian edition) LMDE 6, though I must admit the vim portion was a bit of an uphill climb.
Vim must have built-in python3 support. One must check first using
vim --version
. The result should show+python3
instead of –python3
. I looked further then I had to installvim-gtk3
using apt-get install. Powerline statusline in vim now works!Happy holidays 2024!
andy
@andy,
Thank you for sharing your experience! I’m glad you got Powerline working on LMDE 6. Yes, having Vim with Python3 support is crucial, and installing `vim-gtk3` is a great tip for enabling it.
Happy holidays to you too!
Ravi
Hey, thanks for the guide, it worked very well. I had 2 issues and would like to get cleared:
1. for terminal, how do i put arrows at end of path instead of rectangular box?
2. I use yakuake as terminal. powerline worked on it but for vim instead of arrows, weird symbols were shown. can you tell me how to fix that?
@Chinmany,
I suggest you to go through the powerline documentation for implementing arrows in Vim editor at: https://powerline.readthedocs.io/en/latest/overview.html
Please refer to this youtube video for update content for this article
https://www.youtube.com/watch?v=_D6RkmgShvU
Ravi will you need help updating this. We are using python3.5 now.
That works great !! Only one things thats annoying is , if the path to the directory is very long, it displays a very long path on the shell prompt, sometimes it appears on the next line too. Can it be restricted to the Just the Current folder as of that like in Bash. ?
Hi, I am having a problem, when I complete all the steps, it works great. However, as soon as I close and reopen terminal, it gets back to the default look. Can you guys please help me?
@Ken,
You need to add the powerline configuration to your user
~/.bashrc
file to keep it permanent..Indeed, it works now! Thanks a lot for the help :D
I had same problem, can you send me the powerline config to my email : [email protected]
You forgot to mention to install setuptools using
sudo apt-get install python-setuptools
sudo yum install python-setuptools
sudo dnf install python-setuptools
Without setuptools, you wont be able to install powerline
@Anudeep,
Thanks for sharing, yes you correct python-setuptools package needs to install Powerline…
happy to help.. btw how can i get the arrows as seen on fedora magazine..
https://fedoramagazine.org/add-power-terminal-powerline/
@Anydeep,
No idea, how the arrows appear, I think we should tweak some settings in powerline configuration files.
Ok.. It looks nice as it is.. It fulfills it’s purpose.. The arrows were an added plus
@Anudeep,
Yes, those arrows were additional features to powerline, you can get them, but you need to play with configuration..
Ok, fixed it. The problem is I don’t have .vimrc. So, I created .vimrc and added those lines. And then, my vim editor color scheme is lost. Delete .vimrc and it’s back again. So, I add the lines for .vimrc to “/etc/vim/vimrc”. And everything is fine. :)
@Hein,
Thanks for sharing the tip, hope it will help others…
After installing powerline, my vim color scheme is lost. How can I get back to original color scheme?
I had a problem with vim displaying UTF-8 placeholder characters in odd places, and the HOME and END keys misbehaving (printing ‘H’, ‘F’, and making newlines). This was fixed by specifying “set term=xterm-256color” in .vimrc to override “screen-256color”. Using Ubuntu / Terminator & Guake / bash.
I also played with setting xterm-256color in .bashrc, and didn’t see any issues.
@Lenny,
Thanks for sharing the tip with us, hope it will help other users..
hi Ravi,
Possible to provide guide to uninstall Powerline too? Its giving issue.
@Victor,
To uninstall packages installed using pip, just type following command to remove powerline from the system.
i have a probleme……when a finish the tutorial and i exit and start the terminal
i see this message : bash: ./usr/local/lib/python3.4/dist-packages/powerline/bindings/bash/powerline.sh: No such file or directory
@Omar,
If you’ve installed powerline using pip you must add the path variable to .bashrc file where pip puts scripts to $PATH.
First make sure to find out your powerline location using:
You will see something like:
Now add the following line to your .bashrc file as shown:
No problems. But why you deleted powerline? It’s so nice with vim! Did you found something better? Anyway, i just want change the color highlight red that is too heavy. I can’t see the pieces of code with red color. Thanks.
@Paulo,
I just installed the powerline for testing purpose only, yes it is good, but I prefer vim with plain text…:)
Ravi can you show me how as was your complete vimrc.? I am Elementary OS user.
@Paulo,
Sorry, you’re too late actually I removed powerline from my laptop, but could you tell me what exactly you looking for?
Hello!! nice post, always work for me.
How can I set the maxlength of the pwd to 1, eg:
I want this:
diego>..>Dir5
instead of:
diego>-…>Dir3>Dir4>Dir5>
Hey,
I’ve got this to work, even with the fonts but the bash line doesn’t word wrap properly. it just starts over at the beginning of the line.
after going through this, I kept getting errors when running “vim”, “git status”, “screen” saying that terminal is not full functional and that screen-256color not defined.
figured out mistake was in ~/.bashrc:
while this tutorial had quotations around screen-256 like so:
export TERM=”screen-256color”
it should have been without quotations, like so:
export TERM=screen-256color
hope this saves someones time.
@Hasan,
Thanks for the tip, let me check and update the article as per your advise….
Followed every instructions step it doesn’t work. I get this output when opening a terminal:
No command ‘powerline-deamon’ found, did you mean:
Command ‘powerline-daemon’ from package ‘powerline’ (universe)
powerline-deamon: command not found
bash: /home/mcx/.local/lib/python2.7/site-packages/powerline/bindings/bash/../../../scripts/powerline-config: No such file or directory
bash: /home/mcx/.local/lib/python2.7/site-packages/powerline/bindings/bash/../../../scripts/powerline-config: No such file or directory
mcx@mcx:~$
@Sebas,
May I know on which Linux distributions you’ve tried?
I noticed little vertical lines on the right side of the statusline that seem misplaced. Any one agree? If so does anyone know how to fix it?
I f you like a lightweight alternative only for vim you can install vim airline: https://github.com/bling/vim-airline
The documentation is off for EL7. The proper instructions are as follows:
As root do:
(coreutils is for printf for down below, should already be there, but thats why I am adding it explicitly here)
1)yum install python-pip git coreutils
2)pip install git+git://github.com/Lokaltog/powerline
3)wget -o /usr/share/fonts https://github.com/powerline/powerline/raw/develop/font/PowerlineSymbols.otf
4)wget -o /etc/fonts/conf.d/ https://github.com/powerline/powerline/raw/develop/font/10-powerline-symbols.conf
5)fc-cache -vf /usr/share/fonts/
On each user do the following:
Do up bash
6)printf “powerline-daemon -q%s\nPOWERLINE_BASH_CONTINUATION=1%s\nPOWERLINE_BASH_SELECT=1%s\n. /usr/lib/python2.7/site-packages/powerline/bindings/bash/powerline.sh” >> ~/.bashrc
Do up vim
7)printf “set rtp+=/usr/local/lib/python2.7/dist-packages/powerline/bindings/vim/%s\nset laststatus=2%s\nset t_Co=256” >> ~/.vimrc
Is it possible to force some kind of compatibility mode with SSH apps like putty? I’m getting squares where symbols should be.
@Jason,
No, there isn’t any support for SSH over putty..
I got it working in bash but when I open up vim, i get this message –
E558: Terminal entry not found in terminfo
‘”screen-256color”’ not known. Available builtin terminals are:
builtin_amiga
builtin_beos-ansi
builtin_ansi
builtin_pcansi
builtin_win32
builtin_vt320
builtin_vt52
builtin_xterm
builtin_iris-ansi
builtin_debug
builtin_dumb
defaulting to ‘ansi’
1
@jj72,
May I know On which Linux distro you’re getting such error?
i have problem in this commad:
pip show powerline-status
Error command not found you have tu install show, when install show, now say you use –upgrade to upgrade, help
@Guillermo,
Have you installed Python-pip package?
Yes, this package is installed, i have debian 7