上下文
4.4.12(1)-release2.5.2-1电力线是从arch linux包安装的,而不是从pip安装的。
PS1脚本
update-ps() {
export PS1="$(powerline shell aboveleft)"
export PS2="$(powerline shell left)"
}
export PROMPT_COMMAND="update-ps;$PROMPT_COMMAND"电力线配置
问题
我和他有同样的问题,当我写几个字符时,行包装,我开始用同一行书写,覆盖我已经写过的内容(包括ps1)。
我知道这可能是一个不可打印的字符问题,但这不意味着它是一个电力线错误吗?还会有什么问题呢?
发布于 2019-10-22 07:02:28
在~.bashrc中更改: from:
. /usr/local/lib/python2.7/dist-packages/powerline/bindings/shell/powerline.sh至
. /usr/local/lib/python2.7/dist-packages/powerline/bindings/bash/powerline.sh解决了这个问题
发布于 2019-04-19 18:12:20
当区域设置不正确时,或者当glibc使用"C“区域设置生成时,就会发生这种情况,因为”C“区域设置不支持unicode字符。电力线使用非中断空间(2字节),也使用2字节unicode字符的三角形.对于这些字符中的每一个,shell (而不是电力线)认为已经打印了一个额外的字符。如果提示符中有5个空格和3个三角形,则提示符将在到达行尾之前包装8个字符。从此以后,一切行为都不正确。这仅与Powerline有关,因为Powerline在提示符中使用unicode字符。
修复方法是更正区域设置,以便shell理解2字节unicode。您可以运行"locale“来查看shell是否使用"C",在这种情况下,它需要修复。对于我的应用程序,我们在Docker映像中运行Powerline,运行Centos。我们必须在/etc/yum.conf中修复区域设置,以便使用小写形式的utf8,如下所示:
sed -i 's/UTF-8/utf8/' /etc/yum.conf然后重新构建glibc--与修复程序相同:
yum reinstall glibc-common之后,新的终端正常运行,提示包装正确。然后,我们修改了我们的Docker映像,以便在安装glibc之前修复yum.conf。但是,我们发现我们的一个模块将区域设置更改为C (LANG="C"),因此我们使用LC_ALL env覆盖它:
LC_ALL=en_US.UTF_8在此之后,所有新的终端运行正常。
https://stackoverflow.com/questions/43267978
复制相似问题