Se os caracteres na linha de comando às vezes são exibidos em um deslocamento, isso geralmente ocorre porque o zsh calculou a largura incorreta para o prompt. Os sintomas são que a exibição parece boa, desde que você adicione caracteres ou mova caracteres por caractere, mas fique distorcida (com alguns caracteres aparecendo mais à direita do que deveria) quando você usa outros comandos que movem o cursor ( Homeconclusão, etc.) ) ou quando o comando se sobrepõe a uma segunda linha.
O Zsh precisa saber a largura do prompt para saber onde os caracteres do comando são colocados. Ele assume que cada personagem ocupa uma posição, a menos que seja dito o contrário.
Uma possibilidade é que seu prompt contenha seqüências de escape que não sejam adequadamente delimitadas. Seqüências de escape que alteram a cor ou outros aspectos de formatação do texto, ou que alteram o título da janela ou outros efeitos, têm largura zero. Eles precisam ser incluídos em uma construção de chaves de porcentagem%{…%}
. De maneira mais geral, uma sequência de escape %42{…%}
diz ao zsh para assumir que o que está dentro do aparelho tem 42 caracteres de largura.
Portanto, verifique suas configurações rápidas ( PS1
, PROMPT
ou as variáveis que eles fazem referência) e certifique-se de que todas as sequências de escape (como \e[…m
para alterar atributos de texto - nota que pode estar presente através de algumas variáveis como $fg[red]
) estão no interior %{…%}
. Como você está usando o oh-my-zsh, verifique suas próprias configurações e as definições que você está usando no oh-my-zsh.
O mesmo problema surge no bash. É necessário incluir seqüências de largura zero em um prompt\[…\]
.
Outra possibilidade é que o seu prompt contenha caracteres não ASCII e que o zsh (ou qualquer outro aplicativo) e o seu terminal tenham uma idéia diferente da largura deles. Isso pode acontecer se houver uma incompatibilidade entre a codificação do seu terminal e a codificada declarada no shell, e as duas codificações resultam em larguras diferentes para determinadas seqüências de bytes. Normalmente, você pode encontrar esse problema ao usar um terminal não-Unicode, mas declarando um código de idioma Unicode ou vice-versa.
Os aplicativos contam com variáveis de ambiente para conhecer o código do idioma; a configuração relevante é LC_CTYPE
, que é determinada a partir das variáveis de ambiente LANGUAGE
, LC_ALL
, LC_CTYPE
e LANG
(a primeira delas que está definido é aplicável). O comando locale | grep LC_CTYPE
informa sua configuração atual. Geralmente, a melhor maneira de evitar problemas de localidade é deixar o emulador de terminal definido LC_CTYPE
, pois ele sabe qual codificação espera; mas se isso não funcionar para você, defina LC_CTYPE
.
Os mesmos sintomas podem ocorrer quando o comando anterior exibiu alguma saída que não terminou em uma nova linha, para que o prompt seja exibido no meio da linha, mas o shell não percebe isso. Nesse caso, isso só aconteceria após a execução de um comando desse tipo, não persistentemente.
Se uma linha não for exibida corretamente, o comando redisplay
ou clear-screen
(vinculado a Ctrl+ Lpor padrão) a corrigirá.