summaryrefslogtreecommitdiffstats
path: root/docs/source/troubleshooting.rst
blob: 2b9174742c109b7c4180a5497903ab877a0ec16e (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
***************
Troubleshooting
***************

System-specific issues
======================

.. toctree::

   Linux <troubleshooting/linux>
   OS X <troubleshooting/osx>

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 
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 
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 absence 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

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.*

Shell issues
============

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.

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).

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.
  See installation instructions for more details.
* Compile and install ``libzpython`` module that lives in 
  https://bitbucket.org/ZyX_I/zpython. This variant is zsh-specific.
* If you are a python package manager, be sure to set ``POWERLINE_COMMAND``
  to your Powerline command.  See installation instructions for details.
  

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.

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).

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

used to automatically source vimrc after saving it then you must 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`` (or any other) event, but without ``nested`` 
this event is not launched. See also `autocmd-nested 
<http://vimcommunity.bitbucket.org/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.