*************** Troubleshooting *************** System-specific issues ====================== .. toctree:: Linux OS X 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 `_. 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 `_ 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 `. * Alternative: set :ref:`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 ````. 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 ============ 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. * 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 `_ 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 `_ 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 ` 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 `_ 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 `_ and removed in version 6.5.0 of its successor `minibufexplorer `_. It is highly advised to use the latter because `minibufexpl`_ was last updated late in 2004.