web-dev-qa-db-ja.com

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

たとえば、ファイルをtail -fingまたはreadingユーザー入力すると、<Enter>は、readを終了したり改行を追加する代わりに、端末で^Mを生成します標準出力に。 ^Jは正常に動作します。

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

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

編集2:質問を見逃しました。 Ctrl-V Enterと入力すると、^Mが表示されます(OSXとUbuntuの両方で)。

編集3:OSXおよびUbuntuではecho $TERMscreen-256colorを生成します。

91
benekastah

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

184
hackerb9

端末設定を表示するには、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をオフにすると、プログラムと会話してEnterキーを押すたびに^ 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は、「キャリッジリターンを改行に戻す」ことを意味し、Unixが実際に^ Jを必要としているときに^ Mを入力している可能性がある実行中のプログラムから隠します。以前のキーボードには、個別のReturnキーとEnterキーがありました(通常、Returnはフォームを進めてEnterキーを送信しました)が、今日では通常、行末キーが1つしかないため、この端末設定は2つの意味を組み合わせるのに役立ちます。

stty icrnlコマンドを.profileまたは.bashrcに追加して、これが本当に問題の設定であることがわかった場合。

30
Brandon Rhodes