2014-01-25 16:19:47 +01:00
|
|
|
|
***************
|
|
|
|
|
Troubleshooting
|
|
|
|
|
***************
|
|
|
|
|
|
2014-08-02 21:51:20 +02:00
|
|
|
|
System-specific issues
|
|
|
|
|
======================
|
|
|
|
|
|
2014-01-25 16:19:47 +01:00
|
|
|
|
.. toctree::
|
|
|
|
|
|
|
|
|
|
Linux <troubleshooting/linux>
|
|
|
|
|
OS X <troubleshooting/osx>
|
2014-08-02 21:51:20 +02:00
|
|
|
|
|
|
|
|
|
Common issues
|
|
|
|
|
=============
|
|
|
|
|
|
|
|
|
|
After an update something stopped working
|
|
|
|
|
-----------------------------------------
|
|
|
|
|
|
|
|
|
|
Assuming powerline was working before update and stopped only after there are
|
|
|
|
|
two possible explanations:
|
|
|
|
|
|
|
|
|
|
* You have more then one powerline installation (e.g. ``pip`` and ``Vundle``
|
|
|
|
|
installations) and you have updated only one.
|
|
|
|
|
* Update brought some bug to powerline.
|
|
|
|
|
|
|
|
|
|
In the second case you, of course, should report the bug to `powerline bug
|
2014-12-07 14:08:24 +01:00
|
|
|
|
tracker <https://github.com/powerline/powerline>`_. In the first you should
|
|
|
|
|
make sure you either have only one powerline installation or you update all of
|
|
|
|
|
them simultaneously (beware that in the second case you are not supported). To
|
2014-08-02 21:51:20 +02:00
|
|
|
|
diagnose this problem you may do the following:
|
|
|
|
|
|
|
|
|
|
#) If this problem is observed within the shell make sure that
|
|
|
|
|
|
|
|
|
|
.. code-block:: sh
|
|
|
|
|
|
|
|
|
|
python -c 'import powerline; print (powerline.__file__)'
|
|
|
|
|
|
|
|
|
|
which should report something like
|
|
|
|
|
:file:`/usr/lib64/python2.7/site-packages/powerline/__init__.pyc` (if
|
|
|
|
|
powerline is installed system-wide) or
|
|
|
|
|
:file:`/home/USER/.../powerline/__init__.pyc` (if powerline was cloned
|
|
|
|
|
somewhere, e.g. in :file:`/home/USER/.vim/bundle/powerline`) reports the same
|
|
|
|
|
location you use to source in your shell configuration: in first case it
|
|
|
|
|
should be some location in :file:`/usr` (e.g.
|
|
|
|
|
:file:`/usr/share/zsh/site-contrib/powerline.zsh`), in the second it should
|
|
|
|
|
be something like
|
|
|
|
|
:file:`/home/USER/.../powerline/bindings/zsh/powerline.zsh`. If this is true
|
|
|
|
|
it may be a powerline bug, but if locations do not match you should not
|
|
|
|
|
report the bug until you observe it on configuration where locations do
|
|
|
|
|
match.
|
2014-08-03 16:56:14 +02:00
|
|
|
|
#) If this problem is observed specifically within bash make sure that you clean
|
|
|
|
|
``$POWERLINE_COMMAND`` and ``$PROMPT_COMMAND`` environment variables on
|
|
|
|
|
startup or, at least, that it was cleaned after update. While different
|
|
|
|
|
``$POWERLINE_COMMAND`` variable should not cause any troubles most of time
|
|
|
|
|
(and when it will cause troubles are rather trivial) spoiled
|
|
|
|
|
``$PROMPT_COMMAND`` may lead to strange error messages or absense of exit
|
|
|
|
|
code reporting.
|
|
|
|
|
|
|
|
|
|
These are the sources which may keep outdated environment variables:
|
|
|
|
|
|
|
|
|
|
* Any command launched from any application inherits its environment unless
|
|
|
|
|
callee explicitly requests to use specific environment. So if you did
|
|
|
|
|
``exec bash`` after update it is rather unlikely to fix the problem.
|
|
|
|
|
* More interesting: `tmux` is a client-server application, it keeps one
|
|
|
|
|
server instance per one user. You probably already knew that, but there is
|
|
|
|
|
an interesting consequence: once `tmux` server was started it inherits its
|
|
|
|
|
environment from the callee and keeps it *forever* (i.e. until server is
|
|
|
|
|
killed). This environment is then inherited by applications you start with
|
|
|
|
|
``tmux new-session``. Easiest solution is to kill tmux with ``tmux
|
|
|
|
|
kill-server``, but you may also use ``tmux set-environment -u`` to unset
|
|
|
|
|
offending variables.
|
|
|
|
|
* Also check `When using z powerline shows wrong number of jobs`_: though
|
|
|
|
|
this problem should not be seen after update only, it contains another
|
|
|
|
|
example of ``$PROMPT_COMMAND`` spoiling results.
|
|
|
|
|
|
2014-08-02 21:51:20 +02:00
|
|
|
|
#) If this problem is observed within the vim instance you should check out the
|
|
|
|
|
output of the following Ex mode commands
|
|
|
|
|
|
|
|
|
|
.. code-block:: vim
|
|
|
|
|
|
|
|
|
|
python import powerline as pl ; print (pl.__file__)
|
|
|
|
|
python3 import powerline as pl ; print (pl.__file__)
|
|
|
|
|
|
|
|
|
|
One (but not both) of them will most likely error out, this is OK. The same
|
|
|
|
|
rules apply as in the 1), but in place of sourcing you should seek for the
|
|
|
|
|
place where you modify `runtimepath` vim option. If you install powerline
|
|
|
|
|
using `VAM <https://github.com/MarcWeber/vim-addon-manager>`_ then no
|
|
|
|
|
explicit modifications of runtimpath were performed in your vimrc
|
|
|
|
|
(runtimepath is modified by VAM in this case), but powerline will be placed
|
|
|
|
|
in :file:`{plugin_root_dir}/powerline` where `{plugin_root_dir}` is stored in
|
|
|
|
|
VAM settings dictionary: do `echo g:vim_addon_manager.plugin_root_dir`.
|
|
|
|
|
|
|
|
|
|
There is a hint if you want to place powerline repository somewhere, but still
|
|
|
|
|
make powerline package importable anywhere: use
|
|
|
|
|
|
|
|
|
|
.. code-block:: sh
|
|
|
|
|
|
|
|
|
|
pip install --user --editable path/to/powerline
|
|
|
|
|
|
2014-11-28 18:31:24 +01:00
|
|
|
|
Tmux/screen-related issues
|
|
|
|
|
==========================
|
|
|
|
|
|
|
|
|
|
I’m using tmux and Powerline looks like crap, what’s wrong?
|
|
|
|
|
-----------------------------------------------------------
|
|
|
|
|
|
|
|
|
|
* You need to tell tmux that it has 256-color capabilities. Add this to your
|
|
|
|
|
:file:`.tmux.conf` to solve this issue::
|
|
|
|
|
|
|
|
|
|
set -g default-terminal "screen-256color"
|
|
|
|
|
* If you’re using iTerm2, make sure that you have enabled the setting
|
|
|
|
|
:guilabel:`Set locale variables automatically` in :menuselection:`Profiles -->
|
|
|
|
|
Terminal --> Environment`.
|
|
|
|
|
* Make sure tmux knows that terminal it is running in support 256 colors. You
|
|
|
|
|
may tell it tmux by using ``-2`` option when launching it.
|
|
|
|
|
|
|
|
|
|
I’m using tmux/screen and Powerline is colorless
|
|
|
|
|
------------------------------------------------
|
|
|
|
|
|
|
|
|
|
* If the above advices do not help, then you need to disable
|
|
|
|
|
:ref:`term_truecolor <config-common-term_truecolor>`.
|
|
|
|
|
* Alternative: set :ref:`additional_escapes <config-common-additional_escapes>`
|
|
|
|
|
to ``"tmux"`` or ``"screen"``. Note that it is known to work perfectly in
|
|
|
|
|
screen, but in tmux it may produce ugly spaces.
|
|
|
|
|
|
|
|
|
|
.. warning::
|
|
|
|
|
Both tmux and screen are not resending sequences escaped in such a way. Thus
|
|
|
|
|
even though additional escaping will work for the last shown prompt,
|
|
|
|
|
highlighting will eventually go away when tmux or screen will redraw screen
|
|
|
|
|
for some reason.
|
|
|
|
|
|
|
|
|
|
E.g. in screen it will go away when you used copy mode and prompt got out of
|
|
|
|
|
screen and in tmux it will go away immediately after you press ``<Enter>``.
|
|
|
|
|
|
|
|
|
|
In tmux there is a green bar in place of powerline
|
|
|
|
|
--------------------------------------------------
|
|
|
|
|
|
|
|
|
|
In order for tmux bindings to work ``powerline-config`` script is required to be
|
|
|
|
|
present in ``$PATH``. Alternatively one may define ``$POWERLINE_CONFIG_COMMAND``
|
|
|
|
|
environment variable pointing to the location of the script. *This variable must
|
|
|
|
|
be defined prior to launching tmux server and in the environment where server is
|
|
|
|
|
started from.*
|
|
|
|
|
|
2014-08-27 20:28:44 +02:00
|
|
|
|
Shell issues
|
|
|
|
|
============
|
|
|
|
|
|
2017-05-16 17:49:28 +02:00
|
|
|
|
Pipe status segment displays only last value in bash
|
|
|
|
|
----------------------------------------------------
|
|
|
|
|
|
|
|
|
|
Make sure that powerline command that sets prompt appears the very first in
|
|
|
|
|
``$PROMPT_COMMAND``. To do this ``powerline.sh`` needs to be sourced the very
|
|
|
|
|
last, after all other users of ``$PROMPT_COMMAND``.
|
|
|
|
|
|
|
|
|
|
Bash prompt stopped updating
|
|
|
|
|
----------------------------
|
|
|
|
|
|
|
|
|
|
Make sure that powerline commands appear in ``$PROMPT_COMMAND``: some users of
|
|
|
|
|
``$PROMPT_COMMAND`` have a habit of overwriting the value instead of
|
|
|
|
|
prepending/appending to it. All powerline commands start with ``_powerline`` or
|
|
|
|
|
``powerline``, e.g. ``_powerline_set_prompt``.
|
|
|
|
|
|
|
|
|
|
Bash prompt does not show last exit code
|
|
|
|
|
----------------------------------------
|
|
|
|
|
|
|
|
|
|
There are two possibilities here:
|
|
|
|
|
|
|
|
|
|
* You are using ``default`` theme in place of ``default_leftonly``. Unlike
|
|
|
|
|
``default_leftonly`` ``default`` theme was designed for shells with right
|
|
|
|
|
prompt support (e.g. zsh, tcsh, fish) and status in question is supposed to be
|
|
|
|
|
shown on the right side which bash cannot display.
|
|
|
|
|
|
|
|
|
|
* There is some other user of ``$PROMPT_COMMAND`` which prepended to this
|
|
|
|
|
variable, but did not bother keeping the exit code. For the best experience
|
|
|
|
|
powerline must appear first in ``$PROMPT_COMMAND`` which may be achieved by
|
|
|
|
|
sourcing powerline bindings the last.
|
|
|
|
|
|
|
|
|
|
.. note::
|
|
|
|
|
Resourcing bash bindings will not resolve the problem unless you clear
|
|
|
|
|
powerline commands from ``$PROMPT_COMMAND`` first.
|
|
|
|
|
|
2014-11-28 18:37:53 +01:00
|
|
|
|
When sourcing shell bindings it complains about missing command or file
|
|
|
|
|
-----------------------------------------------------------------------
|
|
|
|
|
|
|
|
|
|
If you are using ``pip`` based installation do not forget to add pip-specific
|
|
|
|
|
executable path to ``$PATH`` environment variable. This path usually looks
|
|
|
|
|
something like ``$HOME/.local/bin`` (linux) or
|
|
|
|
|
``$HOME/Library/Python/{python_version}/bin`` (OS X). One may check out where
|
|
|
|
|
``powerline-config`` script was installed by using ``pip show -f
|
|
|
|
|
powerline-status | grep powerline-config`` (does not always work).
|
|
|
|
|
|
2014-08-27 20:28:07 +02:00
|
|
|
|
I am suffering bad lags before displaying shell prompt
|
|
|
|
|
------------------------------------------------------
|
|
|
|
|
|
|
|
|
|
To get rid of these lags there currently are two options:
|
|
|
|
|
|
|
|
|
|
* Run ``powerline-daemon``. Powerline does not automatically start it for you.
|
|
|
|
|
* Compile and install ``libzpython`` module that lives in
|
|
|
|
|
https://bitbucket.org/ZyX_I/zpython. This variant is zsh-specific.
|
|
|
|
|
|
|
|
|
|
Prompt is spoiled after completing files in ksh
|
|
|
|
|
-----------------------------------------------
|
|
|
|
|
|
|
|
|
|
This is exactly why powerline has official mksh support, but not official ksh
|
|
|
|
|
support. If you know the solution feel free to share it in `powerline bug
|
|
|
|
|
tracker`_.
|
|
|
|
|
|
|
|
|
|
When using z powerline shows wrong number of jobs
|
|
|
|
|
-------------------------------------------------
|
|
|
|
|
|
|
|
|
|
This happens because `z <https://github.com/rupa/z>`_ is launching some jobs in
|
|
|
|
|
the background from ``$POWERLINE_COMMAND`` and these jobs fail to finish before
|
|
|
|
|
powerline prompt is run.
|
|
|
|
|
|
|
|
|
|
Solution to this problem is simple: be sure that :file:`z.sh` is sourced
|
|
|
|
|
strictly after :file:`powerline/bindings/bash/powerline.sh`. This way background
|
|
|
|
|
jobs are spawned by `z <https://github.com/rupa/z>`_ after powerline has done
|
|
|
|
|
its job.
|
|
|
|
|
|
2014-08-27 20:33:14 +02:00
|
|
|
|
When using shell I do not see powerline fancy characters
|
|
|
|
|
--------------------------------------------------------
|
|
|
|
|
|
|
|
|
|
If your locale encoding is not unicode (any encoding that starts with “utf” or
|
|
|
|
|
“ucs” will work, case is ignored) powerline falls back to ascii-only theme. You
|
|
|
|
|
should set up your system to use unicode locale or forget about powerline fancy
|
|
|
|
|
characters.
|
|
|
|
|
|
2015-07-10 11:15:03 +02:00
|
|
|
|
Urxvt unicode3 and frills
|
|
|
|
|
-------------------------
|
|
|
|
|
|
|
|
|
|
Make sure that, whatever urxvt package you're installing, both the `unicode3`
|
|
|
|
|
and `frills` features are enabled at compile time. Run
|
|
|
|
|
``urxvt --help 2>&1 | grep options:`` to get a list of enabled options.
|
|
|
|
|
This should contain at least `frills`, `unicode3` and optionally `iso14755`
|
|
|
|
|
if you want to input Unicode characters as well.
|
|
|
|
|
|
|
|
|
|
Compiler flags example:
|
|
|
|
|
|
|
|
|
|
--enable-frills \
|
|
|
|
|
--enable-unicode3
|
|
|
|
|
|
|
|
|
|
As long as your terminal emulator is compiled without unicode rendering,
|
|
|
|
|
no amount of configuration will make it display unicode characters.
|
|
|
|
|
They're being considered 'unnecessary features', but they add negligible
|
|
|
|
|
overhead to the size of the installed package (~100KB).
|
|
|
|
|
|
2014-08-27 20:28:07 +02:00
|
|
|
|
Vim issues
|
|
|
|
|
==========
|
|
|
|
|
|
2014-08-02 21:51:20 +02:00
|
|
|
|
My vim statusline has strange characters like ``^B`` in it!
|
|
|
|
|
-----------------------------------------------------------
|
|
|
|
|
|
|
|
|
|
* Please add ``set encoding=utf-8`` to your :file:`vimrc`.
|
|
|
|
|
|
|
|
|
|
My vim statusline has a lot of ``^`` or underline characters in it!
|
|
|
|
|
-------------------------------------------------------------------
|
|
|
|
|
|
|
|
|
|
* You need to configure the ``fillchars`` setting to disable statusline
|
2014-11-28 18:31:24 +01:00
|
|
|
|
fillchars (see ``:h 'fillchars'`` for details). Add this to your :file:`vimrc`
|
|
|
|
|
to solve this issue:
|
2014-08-02 21:51:20 +02:00
|
|
|
|
|
|
|
|
|
.. code-block:: vim
|
|
|
|
|
|
|
|
|
|
set fillchars+=stl:\ ,stlnc:\
|
|
|
|
|
|
|
|
|
|
My vim statusline is hidden/only appears in split windows!
|
|
|
|
|
----------------------------------------------------------
|
|
|
|
|
|
|
|
|
|
* Make sure that you have ``set laststatus=2`` in your :file:`vimrc`.
|
|
|
|
|
|
|
|
|
|
My vim statusline is not displayed completely and has too much spaces
|
|
|
|
|
---------------------------------------------------------------------
|
|
|
|
|
|
|
|
|
|
* Be sure you have ``ambiwidth`` option set to ``single``.
|
|
|
|
|
* Alternative: set :ref:`ambiwidth <config-common-ambiwidth>` to 2, remove fancy
|
|
|
|
|
dividers (they suck when ``ambiwidth`` is set to double).
|
|
|
|
|
|
2014-08-03 01:04:47 +02:00
|
|
|
|
Powerline loses color after editing vimrc
|
|
|
|
|
-----------------------------------------
|
|
|
|
|
|
|
|
|
|
If your vimrc has something like
|
|
|
|
|
|
|
|
|
|
.. code-block:: vim
|
|
|
|
|
|
2015-04-03 21:42:23 +02:00
|
|
|
|
autocmd! BufWritePost ~/.vimrc :source ~/.vimrc
|
2014-08-03 01:04:47 +02:00
|
|
|
|
|
2015-04-03 21:42:23 +02:00
|
|
|
|
used to automatically source vimrc after saving it then you must add ``nested``
|
|
|
|
|
after pattern (``vimrc`` in this case):
|
2014-08-03 01:04:47 +02:00
|
|
|
|
|
|
|
|
|
.. code-block:: vim
|
|
|
|
|
|
2015-04-03 21:42:23 +02:00
|
|
|
|
autocmd! BufWritePost ~/.vimrc nested :source ~/.vimrc
|
2014-08-03 01:04:47 +02:00
|
|
|
|
|
|
|
|
|
. Alternatively move ``:colorscheme`` command out of the vimrc to the file which
|
2015-04-03 21:42:23 +02:00
|
|
|
|
will not be automatically resourced.
|
|
|
|
|
|
|
|
|
|
Observed problem is that when you use ``:colorscheme`` command existing
|
|
|
|
|
highlighting groups are usually cleared, including those defined by powerline.
|
|
|
|
|
To workaround this issue powerline hooks ``Colorscheme`` event, but when you
|
|
|
|
|
source vimrc with ``BufWritePost`` (or any other) event, but without ``nested``
|
|
|
|
|
this event is not launched. See also `autocmd-nested
|
2015-07-19 14:03:28 +02:00
|
|
|
|
<http://vimcommunity.bitbucket.org/doc/autocmd.txt.html#autocmd-nested>`_ Vim
|
|
|
|
|
documentation.
|
2014-08-03 01:21:39 +02:00
|
|
|
|
|
|
|
|
|
Powerline loses color after saving any file
|
|
|
|
|
-------------------------------------------
|
|
|
|
|
|
|
|
|
|
It may be one of the incarnations of the above issue: specifically minibufexpl
|
|
|
|
|
is known to trigger it. If you are using minibufexplorer you should set
|
|
|
|
|
|
|
|
|
|
.. code-block:: vim
|
|
|
|
|
|
|
|
|
|
let g:miniBufExplForceSyntaxEnable = 1
|
|
|
|
|
|
|
|
|
|
variable so that this issue is not triggered. Complete explanation:
|
|
|
|
|
|
|
|
|
|
#. When MBE autocommand is executed it launches ``:syntax enable`` Vim command…
|
|
|
|
|
#. … which makes Vim source :file:`syntax/syntax.vim` file …
|
|
|
|
|
#. … which in turn sources :file:`syntax/synload.vim` …
|
|
|
|
|
#. … which executes ``:colorscheme`` command. Normally this command triggers
|
|
|
|
|
``Colorscheme`` event, but in the first point minibufexplorer did set up
|
|
|
|
|
autocommands that miss ``nested`` attribute meaning that no events will be
|
|
|
|
|
triggered when processing MBE events.
|
|
|
|
|
|
|
|
|
|
.. note::
|
|
|
|
|
This setting was introduced in version 6.3.1 of `minibufexpl
|
|
|
|
|
<http://www.vim.org/scripts/script.php?script_id=159>`_ and removed in
|
|
|
|
|
version 6.5.0 of its successor `minibufexplorer
|
|
|
|
|
<http://www.vim.org/scripts/script.php?script_id=3239>`_. It is highly
|
|
|
|
|
advised to use the latter because `minibufexpl`_ was last updated late in
|
|
|
|
|
2004.
|