OS X 终端行不会进入回滚

OS X 终端行不会进入回滚

我在使用 Mac OS X 的终端 (TERM=xterm) 时遇到了一个问题:有时它会进入一种状态,即从顶部滚动的行不会添加到回滚缓冲区。我没有使用screen或类似的东西;这是终端选项卡内的普通 bash shell。

打开新选项卡后不会立即执行此操作。我相信这是我在问题选项卡中运行的某些操作的副作用。我猜想这与 xterm 仿真有关,可能是滚动区域。

无效的做法:

  • 通过 Shell 菜单进行软复位和硬复位
  • reset在标签中运行

有没有可靠的方法来重置终端和/或 xterm 状态?

有人可以解释一下发生了什么吗,即使唯一的解决方法是关闭该标签并打开一个新标签?

答案1

这意味着终端正在使用备用屏幕缓冲区。有一个主屏幕,它会滚动到回滚日志中,还有一个备用屏幕不会滚动到回滚日志中。“全屏”或“屏幕导向”程序(如 top、less、emacs、vim 和 screen)默认将终端切换到备用屏幕。

每个屏幕都有自己的内容和状态。使用备用屏幕可以让程序接管整个显示屏,然后在退出时通过切换回主屏幕来恢复之前的内容。

从 Mac OS X Lion 10.7 开始,终端有一个菜单项可用于手动切换屏幕:

视图 > 显示/隐藏备用屏幕

提供此功能的主要目的是让您在“全屏”程序退出后可以从备用屏幕查看或复制文本。Xterm 有一个类似的命令。

您还可以使用它手动强制程序使用特定屏幕,例如控制输出是否进入回滚日志。但是,如果您当前正在使用明确切换到备用屏幕的程序,则在程序运行时强制其进入主屏幕可能会造成混淆或产生意外结果,因此请谨慎使用。

根据程序的不同,它可能有一个命令行参数或其他方法来配置它以使用主屏幕。例如less -X

一些 terminfo 条目专门设计用于禁止使用备用屏幕,例如,xterm1.TERM=xterm1 emacs将在主屏幕上运行 Emacs。我不建议xterm1永久使用,因为与 Lion 上的默认设置相比,它会禁用许多其他有用的功能xterm-256color

您还可以使用tput命令从 shell 或脚本内部发出转义序列来切换屏幕。tput smcup切换到备用屏幕,然后tput rmcup切换回主屏幕。

要查看当前正在运行的程序,请查看“终端”窗口或选项卡标题中显示的程序名称,或查看“检查器”窗口 (Shell > 显示检查器)。检查器列表中的最后一个进程(通常)是当前正在使用屏幕的程序。您需要将其配置为使用主屏幕。

相关内容