Нажатие Enter производит ^ M вместо новой строки

94

Например, если я tail -fиспользую файл или readпользовательский ввод, я <Enter>получу ^Mв терминале вместо завершения readили добавление новой строки в stdout. ^Jработает отлично.

Я вхожу sshв систему Ubuntu, если это имеет значение. Это происходит со мной как в zsh, так и в bash. Одно из решений, с которым я играл, это переназначение ^Mto ^Jв zsh, но похоже, что это не решит проблему с корнем. Кто-нибудь знает, что может быть причиной этого?

Изменить: Чтобы ответить на некоторые вопросы, я вхожу sshв Ubuntu из OSX. Я использую iTerm и Zsh. Я также забыл упомянуть, что я использую tmux на машине с Ubuntu.

Изменить 2: пропустил вопрос. Когда я печатаю, Ctrl-V Enterя получаю ^M(как на OSX и Ubuntu).

Редактировать 3: На OSX и Ubuntu echo $TERMпроизводит screen-256color.

benekastah
источник
Что вы используете для SSH в Ubuntu?
Тасос
Да --- а с какой ОС? Кажется, СРОК проблема.
Rmano
Что вы получите, если наберете Ctrl + V, а затем Enter ? Поскольку вы можете выполнять команды очень хорошо, это определенно не является проблемой оболочки.
Adaephon
2
(Непроизвольный) перезапуск моего блока OSX, похоже, решил проблему ... Я думаю, это один из них. Надеюсь, это прошло навсегда.
Benekastah
Также для меня работало только перезапуск, включая очистку NVRAM. Нажмите и удерживайте клавиши Command-Option-PR сразу после того, как вы услышите звук запуска, чтобы также сбросить NVRAM OSx
jonbros

Ответы:

192

В случае, если у кого-то еще есть эта проблема, скорее всего, это проблема с настройкой линии терминала stty, а не проблема TERM. Если это случится с вами снова, попробуйте запустить stty saneи дайте нам знать, если это исправит.

hackerb9
источник
22
Это работает на OS X также.
Патрик Беркли
1
Работал на меня (монетный двор 17.1).
Deleet
1
Работа над Ubuntu Bionic
protoEvangelion
хорошо работает на iTerm2 в Мохаве
Ракиб
работал для меня на котенка на archlinux
Юкашима Хуксей
31

Попробуйте запустить, stty -aчтобы просмотреть настройки терминала. Я подозреваю, что ваши icrnlнастройки не установлены и будут отображаться как -icrnl(знак минус означает, что он выключен) вместо того, чтобы иметь обычную настройку включения. Вот как обычно настраивается мой терминал при входе в систему:

$ 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

И у меня нет проблем с окончаниями строк: либо return (^ M), либо enter (^ J) заканчивают вводные строки. Но если я icrnlвыключаю, коды ^ M внезапно появляются каждый раз, когда я разговариваю с программой, и нажимаю ввод:

$ 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

Код icrnlозначает «превратить перевод каретки в новые строки» и скрывает от запущенной программы, что вы можете вводить ^ M, когда Unix действительно хочет ^ J. В старых клавиатурах использовалась отдельная клавиша Return и Enter (где Return обычно продвигал вас через форму, а Enter отправлял ее), но сегодня у нас, как правило, есть только одна клавиша конца строки, и поэтому этот параметр терминала помогает объединить два значения.

Добавьте stty icrnlкоманду к вашему .profileили, .bashrcесли вы обнаружите, что это действительно проблема установки.

Брэндон Роудс
источник