Enterキーを押すと、改行ではなく^ Mが生成されます


94

たとえばtail -f、ファイルをread入力している場合、またはユーザー入力を入力している場合、stdout を終了したり改行を追加したりする代わりに、ターミナルで<Enter>生成^Mreadます。^J正常に動作します。

私はよsshそれが重要な場合は、Ubuntuのシステムにする。これは、zshとbashの両方で起こります。私が試した解決策の1つは、zshで^Mto ^Jを再マッピングすることですが、それでも根本的な問題は解決しないようです。誰がこれを引き起こしているのか知っていますか?

編集:いくつかの質問に答えるためにssh、OSXからUbuntuに参加しています。iTermとzshを使用しています。また、Ubuntuマシンでtmuxを使用していることを忘れていました。

編集2:質問を見逃しました。入力すると、OSXとUbuntuの両方でCtrl-V Enter取得でき^Mます。

編集3:OSXおよびUbuntuでecho $TERM生成されscreen-256colorます。


Ubuntuにsshするために何を使用していますか?
タソス14

はい---そしてどのOSから?TERMの問題のようです。
Rmano

Ctrl + Vに続けてEnterを入力すると、何が得られますか?コマンドをうまく実行できるので、これは間違いなくシェルの問題ではありません。
アダエフォン14

2
私のOSXボックスの(不本意な)再起動は問題を解決したようです...私はそれの1つだと思います。うまくいけば、それはうまくいっていない。
ベネカスタ14

また、私にとっては、NVRAMのクリアリングを含む再起動しか機能しませんでした。押して、あなたはまた、OSXのNVRAMをリセットするために起動音が聞こえた直後にコマンドオプション-PRの鍵を保持
jonbros

回答:


192

他の誰かがこの問題を抱えている場合、それはおそらくTERMの問題ではなく、stty端末回線設定の問題です。この問題が再度発生する場合は、実行stty saneしてみて、修正されるかどうかをお知らせください。


22
これはOS Xでも機能します。
パトリックバークレー

1
私のために働いた(ミント17.1)。
Deleet

1
Ubuntu Bionicでの作業
-protoEvangelion

Mojaveの
iTerm2

archlinuxのキティで働いていました
湯島h介

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

また、行末に問題はありません。リターン(^ M)またはエンター(^ J)のどちらでも入力行が終了します。しかし、icrnlオフにすると、プログラムに話しかけるたびに^ Mコードが突然表示され、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

このコードicrnlは「キャリッジリターンを改行に戻す」ことを意味し、Unixが実際に^ Jを必要としているときに^ Mを入力している可能性がある実行中のプログラムから隠します。以前のキーボードには個別のReturnキーとEnterキーがありました(通常、Returnはフォームを進めてEnterキーを送信していました)が、今日では一般的に行末キーが1つしかないため、このターミナル設定は2つの意味を組み合わせるのに役立ちます。

stty icrnlコマンドを追加する.profile.bashrc、これが実際に問題の設定であることがわかった場合。

弊社のサイトを使用することにより、あなたは弊社のクッキーポリシーおよびプライバシーポリシーを読み、理解したものとみなされます。
Licensed under cc by-sa 3.0 with attribution required.