我在使用 Mac OS X 的终端 (TERM=xterm) 时遇到了一个问题:有时它会进入一种状态,即从顶部滚动的行不会添加到回滚缓冲区。我没有使用screen
或类似的;这是终端选项卡内的普通 bash shell。
打开新标签后,它不会立即执行此操作。我相信这是我在问题选项卡中运行的东西的副作用。我的猜测是它与 xterm 仿真有关,可能与滚动区域有关。
什么没有奏效:
- 通过 Shell 菜单进行软复位和硬复位
reset
在选项卡中运行
是否有可靠的方法来重置终端和/或 xterm 状态?
任何人都可以解释发生了什么,即使唯一的解决方法是关闭选项卡并打开一个新选项卡?
这意味着终端正在使用备用屏幕缓冲区。有一个主屏幕可以滚动到回滚日志,而另一个屏幕则不能。“全屏”或“面向屏幕”的程序,如 top、less、emacs、vim 和 screen 默认情况下会将终端切换到备用屏幕。
每个屏幕都有自己的内容和状态。拥有一个备用屏幕使程序能够接管整个显示,然后在退出时通过切换回主屏幕来恢复以前的内容。
从 Mac OS X Lion 10.7 开始,终端有一个菜单项可用于手动切换屏幕:
这主要是为了让您可以在“全屏”程序退出后从备用屏幕查看或复制文本。Xterm 也有类似的命令。
例如,您还可以使用它来手动强制程序使用特定屏幕,以控制输出是否进入回滚日志。但是,如果您当前正在使用显式切换到备用屏幕的程序,如果在程序运行时将其强制切换到主屏幕,您可能会混淆它或得到意想不到的结果,因此请谨慎使用。
根据程序的不同,它可能有一个命令行参数或其他方式来配置它以使用主屏幕。例如,
less -X
。某些 terminfo 条目专门设计用于禁止使用备用屏幕,例如
xterm1
.TERM=xterm1 emacs
将在主屏幕上运行 Emacs。我不建议永久使用,因为与Lionxterm1
上的默认设置相比,它禁用了许多其他有用的功能。xterm-256color
您还可以使用
tput
命令切换屏幕以从外壳或脚本内部发出转义序列。tput smcup
切换到备用屏幕,然后tput rmcup
切换回主屏幕。要查看当前正在运行的程序,请查看终端窗口或选项卡标题中显示的程序名称,或查看检查器窗口(Shell > Show Inspector)。Inspector 列表中的最后一个进程(通常)是当前使用屏幕的程序。那是您需要配置为使用主屏幕的那个。