OS X 终端行不会进入回滚状态

Ste*_*sen 13 shell terminal xterm

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

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

什么没有奏效:

  • 通过 Shell 菜单软复位和硬复位
  • reset在选项卡中运行

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

任何人都可以解释发生了什么,即使唯一的解决方法是关闭选项卡并打开一个新选项卡?

Chr*_*age 20

这意味着终端正在使用备用屏幕缓冲区。有一个可滚动到回滚日志的主屏幕和一个不滚动到回滚日志的备用屏幕。“全屏”或“面向屏幕”的程序,如 top、less、emacs、vim 和 screen,默认情况下将终端切换到备用屏幕。

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

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

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

这主要是为了您可以在“全屏”程序退出后从备用屏幕查看或复制文本。Xterm 有一个类似的命令。

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

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

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

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

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

  • 就我而言,似乎发生的事情是,当我在“vi”中时,我与远程机器的“ssh”会话失败(超时?),显然将终端留在备用屏幕中(因为从未给出“vi”清理的机会)。此后,同一终端中的任何新“ssh”会话都会出现 OP 描述的问题,直到我通过选择 **View > Hide Alternate Screen** 菜单项解决了该问题。 (2认同)