Pressionar enter produz ^ M em vez de uma nova linha

62

Por exemplo, se eu for tail -f em um arquivo ou read ing entrada do usuário, <Enter> produzirá ^M no terminal em vez de terminar o read ou adicionar uma nova linha ao stdout. ^J funciona bem.

Estou ssh ing no sistema do Ubuntu, se isso for importante. Isso acontece comigo tanto em zsh quanto em bash. Uma solução com a qual eu brinquei é remapear o ^M para ^J no zsh, mas parece que isso não resolveria o problema da raiz. Alguém sabe o que pode estar causando isso?

Edit: Para responder a algumas perguntas, estou ssh into Ubuntu from OSX. Estou usando o iTerm e o zsh. Eu também esqueci de mencionar que estou usando o tmux na máquina Ubuntu.

Editar 2: perdeu uma pergunta. Quando digito Ctrl-V Enter , recebo ^M (tanto no OSX quanto no Ubuntu).

Editar 3: no OSX e no Ubuntu echo $TERM produz screen-256color .

    
por benekastah 01.04.2014 / 03:39

2 respostas

128

No caso de qualquer outra pessoa ter esse problema, é mais provável que seja um problema com a configuração da linha do terminal stty em vez de um problema TERM. Se isso acontecer novamente, tente executar stty sane e informe-nos se isso for corrigido.

    
por hackerb9 22.04.2014 / 07:21
27

Tente executar stty -a para ver as configurações do seu terminal. Minha suspeita é que sua configuração icrnl não está definida e será mostrada como -icrnl (o sinal de menos significa que está desativado) em vez de ter sua configuração usual de ativação. Aqui está como o meu terminal é normalmente configurado quando eu logar:

$ stty -a
speed 38400 baud; rows 45; columns 80; line = 0;
intr = ^C; quit = ^\; erase = ^?; kill = ^U; eof = ^D; eol = <undef>;
eol2 = <undef>; swtch = <undef>; start = ^Q; stop = ^S; susp = ^Z; rprnt = ^R;
werase = ^W; lnext = ^V; flush = ^O; min = 1; time = 0;
-parenb -parodd cs8 -hupcl -cstopb cread -clocal -crtscts
-ignbrk -brkint -ignpar -parmrk -inpck -istrip -inlcr -igncr icrnl -ixon -ixoff
-iuclc -ixany -imaxbel iutf8
opost -olcuc -ocrnl onlcr -onocr -onlret -ofill -ofdel nl0 cr0 tab0 bs0 vt0 ff0
isig icanon iexten echo echoe echok -echonl -noflsh -xcase -tostop -echoprt
echoctl echoke

E eu não tenho nenhum problema com os finais de linha: retornando (^ M) ou enter (^ J) terminará as linhas de entrada. Mas se eu desativar icrnl , então os códigos M aparecerão de repente cada vez que eu estiver falando com um programa e apertar enter:

$ stty -icrnl
$ read line
Line of text^M^M^M^M
$ stty -a
speed 38400 baud; rows 45; columns 80; line = 0;
intr = ^C; quit = ^\; erase = ^?; kill = ^U; eof = ^D; eol = <undef>;
eol2 = <undef>; swtch = <undef>; start = ^Q; stop = ^S; susp = ^Z; rprnt = ^R;
werase = ^W; lnext = ^V; flush = ^O; min = 1; time = 0;
-parenb -parodd cs8 -hupcl -cstopb cread -clocal -crtscts
-ignbrk -brkint -ignpar -parmrk -inpck -istrip -inlcr -igncr -icrnl -ixon -ixoff
-iuclc -ixany -imaxbel iutf8
opost -olcuc -ocrnl onlcr -onocr -onlret -ofill -ofdel nl0 cr0 tab0 bs0 vt0 ff0
isig icanon iexten echo echoe echok -echonl -noflsh -xcase -tostop -echoprt
echoctl echoke

O código icrnl significa "transformar retornos de carro em novas linhas" e oculta do programa em execução que você pode estar digitando ^ M quando o Unix realmente deseja ^ J. Teclados antigos costumavam ter uma tecla Return e Enter separada (onde Return normalmente avançava através de um formulário e Enter a submete), mas hoje geralmente temos apenas uma chave de fim de linha e essa configuração de terminal ajuda a combinar os dois significados. p>

Adicione o comando stty icrnl ao seu .profile ou .bashrc se achar que essa é realmente a configuração do problema.

    
por Brandon Rhodes 24.04.2014 / 19:48