245 lines
10 KiB
ReStructuredText
245 lines
10 KiB
ReStructuredText
***************
|
||
Troubleshooting
|
||
***************
|
||
|
||
System-specific issues
|
||
======================
|
||
|
||
.. toctree::
|
||
|
||
Linux <troubleshooting/linux>
|
||
OS X <troubleshooting/osx>
|
||
|
||
Common 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.
|
||
|
||
|
||
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
|
||
tracker <https://github.com/Lokaltog/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
|
||
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.
|
||
#) 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.
|
||
|
||
#) 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
|
||
|
||
Shell issues
|
||
============
|
||
|
||
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.
|
||
|
||
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.
|
||
|
||
Vim issues
|
||
==========
|
||
|
||
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
|
||
fillchars (see ``:h fillchars`` for details). Add this to your
|
||
:file:`vimrc` to solve this issue:
|
||
|
||
.. 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).
|
||
|
||
Powerline loses color after editing vimrc
|
||
-----------------------------------------
|
||
|
||
If your vimrc has something like
|
||
|
||
.. code-block:: vim
|
||
|
||
autocmd! BufWritePost vimrc :source ~/.vimrc
|
||
|
||
to automatically source vimrc after saving it you must then add ``nested`` after
|
||
pattern (``vimrc`` in this case):
|
||
|
||
.. code-block:: vim
|
||
|
||
autocmd! BufWritePost vimrc nested :source ~/.vimrc
|
||
|
||
. Alternatively move ``:colorscheme`` command out of the vimrc to the file which
|
||
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`` event,
|
||
but without ``nested`` this event is not launched. See also `autocmd-nested
|
||
<http://vimpluginloader.sourceforge.net/doc/autocmd.txt.html#autocmd-nested>`_
|
||
Vim documentation.
|
||
|
||
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.
|