【问题标题】:Issues with newline character while using ansi-term in emacs在 emacs 中使用 ansi-term 时出现换行符问题
【发布时间】:2016-08-19 11:55:31
【问题描述】:

我正在尝试在 emacs 中使用 ansi-term(配置为 tcsh shell)。我看到显示换行符的一些问题。如果我从终端(ansi-term)尝试以下操作,我会得到正确的输出:

myterm > echo "Line1"; echo "Line2"; echo "Line3";    
Line1
Line2
Line3
myterm >

但如果我尝试将相同的行放入 shell 脚本并尝试从 ansi-term 执行脚本,我会得到错误的输出

脚本:(测试)

#!/usr/bin/env tcsh
echo "Line1"; echo "Line2"; echo "Line3";

运行脚本(测试):

myterm > ./test
Line1
     Line2
          Line3
               myterm >

注意:/usr/bin/env tcsh 确实指向正确的 shell(它与我在调用 ansi-term 时使用的 shell 相同)。同样从 gnome-terminal 执行脚本也会显示正确的输出。 我也尝试设置以下变量,但没有解决我的问题:

(set-terminal-coding-system 'utf-8-unix)
(setq default-process-coding-system '((utf-8-unix . utf-8-unix)))

【问题讨论】:

  • 最有可能的 \r 和 \r\n 差异。无法在此处重现,因此无法提供更多帮助。
  • infocmp 的输出可能有助于在这里生成一些答案
  • 尝试使用printf 而不是echo 并在每个字符串的末尾明确指定\r\n
  • @Ivan :在这种情况下,将 printf 与 \r\n 一起使用将为我提供所需的输出。但问题是我无法控制我使用的工具的输出。这些工具的打印件也有同样的问题。上面的代码是复制问题的最简单示例。
  • @user6170930:我不确定如何使用 infocmp。你能告诉我更多细节吗?

标签: shell emacs terminal tcsh ansi-term


【解决方案1】:

如果您在脚本中设置stty onlcr,您将获得所需的行为。
将命令翻译成英文可能会说:
set the tty o 输出 nline 作为 carriage-r回车换行。

这当然是一种解决方法,因为默认情况下应设置此选项。我可以从stty -a 的输出中看到,您在 cmets 中提供了它 设置在您的 ansi-term 中运行的 tcsh 中。我怀疑 ansi-term 和您的 shell 脚本行为不同的一个可能原因是由于 term.el 中的以下几行

    (apply 'start-process name buffer
       "/bin/sh" "-c"
       (format "stty -nl echo rows %d columns %d sane 2>/dev/null; 
                if [ $1 = .. ]; then shift; fi; exec \"$@\""
               term-height term-width)
       ".."
       command switches)))

上面的stty 命令实际上设置了两次onlcr,因为
复合选项-nl 转换为icrnl -inlcr -igncr onlcr -ocrnl -onlret
sane 选项转换为
cread -ignbrk brkint -inlcr -igncr icrnl -iutf8 -ixoff -iuclc -ixany imaxbel 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

另一个可能的原因:对于非登录 shell,tcsh 将在启动时读取 /etc/csh.cshrc~/.tcshrc~/.cshrc,但对于登录 shell,它会读取许多其他包括/etc/csh.login ~/.history$histfile 的值的文件 - 您应该咨询man page 以获取完整的详细信息,包括它读取内容的确切顺序。

【讨论】:

  • @pulimon 我对答案进行了重大重写,因为我的第一次尝试有点简洁。 meta 上有关于它的讨论
猜你喜欢
  • 1970-01-01
  • 2012-12-31
  • 1970-01-01
  • 1970-01-01
  • 2011-03-18
  • 2011-02-22
  • 1970-01-01
  • 2015-01-27
  • 1970-01-01
相关资源
最近更新 更多