Premendo invio produce ^ M invece di una nuova riga

65

Ad esempio, se sono tail -f in un file o read in input utente, <Enter> produrrà ^M nel terminale anziché terminare read o aggiungere una nuova riga a stdout. ^J funziona bene.

Sono ssh ing nel sistema ubuntu, se questo è importante. Questo mi succede sia in zsh che in bash. Una soluzione con cui ho giocato è la rimappatura di ^M in ^J in zsh, ma sembra che non risolverebbe il problema di root. Qualcuno sa cosa potrebbe causare questo?

Modifica: per rispondere ad alcune domande, sto ssh ing in Ubuntu da OSX. Sto usando iTerm e zsh. Ho anche dimenticato di menzionare che sto usando tmux sulla macchina Ubuntu.

Modifica 2: mancava una domanda. Quando digito Ctrl-V Enter ottengo ^M (sia su OSX che su Ubuntu).

Modifica 3: su OSX e Ubuntu echo $TERM produce screen-256color .

    
posta benekastah 01.04.2014 - 03:39

2 risposte

135

Nel caso in cui qualcun altro abbia questo problema, è molto probabile che si tratti di un problema con l'impostazione della linea terminale stty piuttosto che con un problema TERM. Se ti capita di nuovo, prova a eseguire stty sane e facci sapere se lo corregge.

    
risposta data hackerb9 22.04.2014 - 07:21
28

Prova a eseguire stty -a per visualizzare le impostazioni del terminale. Il mio sospetto è che l'impostazione icrnl non sia impostata e verrà visualizzata come -icrnl (il segno meno indica che è disattivata) invece di avere la sua normale impostazione di attivazione. Ecco come viene normalmente configurato il mio terminale quando effettuo l'accesso:

$ 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 non ho alcun problema con le terminazioni di riga: o return (^ M) o invio (^ J) terminerà le linee di input. Ma se spengo icrnl off, i codici ^ M appaiono improvvisamente ogni volta che parlo con un programma e premo invio:

$ 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

Il codice icrnl significa "turn carriage return in newlines" e si nasconde dal programma in esecuzione che potresti digitare ^ M quando Unix vuole davvero ^ J. Le vecchie tastiere avevano un tasto Return e Invio separato (in cui Return tipicamente ti precedeva attraverso un modulo e Invio lo inoltrava), ma oggi generalmente abbiamo solo un tasto di fine linea e quindi questa impostazione del terminale aiuta a combinare i due significati. p>

Aggiungi il comando stty icrnl al tuo .profile o .bashrc se trovi che questa è davvero l'impostazione del problema.

    
risposta data Brandon Rhodes 24.04.2014 - 19:48

Leggi altre domande sui tag