我最近从 WSL(Linux 的 Windows 子系统)版本 1 升级到版本 2。我在使用编辑器时遇到问题;有时,当我退出 Nano 或 Vim 时,它会抹去我的历史记录。我仍然安装了 WSL V1 进行比较。
我使用 ConEmu 终端在 Windows 10 上运行。我的 WSL V1 安装是 Ubuntu 18.04,我的 WSL V2 安装在 Ubuntu 20.04。两种 WSL 设置都使用 xterm-256color。
以下是症状:
- 清除历史记录后,Nano/Vim 的最后一个可见屏幕将保留在终端历史记录中,但没有任何颜色(变为白色)并且其下方有足够的空白行以使其不在屏幕顶部。我所看到的只是一个空白屏幕底部的单个提示。除了我在编辑器中打开的最终屏幕、空白行和单个终端提示之外,没有终端历史记录。
- 只有当我拥有超过全屏的终端历史记录时,历史记录才会清除。当我的终端历史记录少于全屏时(即没有滚动条),Nano/Vim 正常退出(它们保留终端历史记录)。
- 仅在 WSL V2 (Ubuntu 20.04) 上清除历史记录;WSL V1 (Ubuntu 18.04) 工作正常。
- 只有当我在 ConEmu 中运行时,才会清除历史记录。当我通过 powershell 运行 WSL V2 时,它工作正常。
- 即使我通过 SSH 连接到服务器,所有历史清除行为都完全按照上述方式工作!(即历史清除仅在 WSL V2 上通过 ConEmu 发生,并且仅当我至少有一个完整的终端历史屏幕时)。
- 所有上述行为在杀死和产生新的终端选项卡时都是可重复的。
- 当我尝试将字符串粘贴
xterm
到 Nano 中时,Nano 给了我错误“[未知序列]”,然后对用户输入完全没有响应(我必须关闭终端窗口才能退出)。粘贴其他文本(包括非常相似的字符串)可以正常工作。
我不认为 ConEmu 有问题,因为 WSL V1 仍然有效。我不认为我的 bash 配置有问题,因为当我通过 SSH 连接到另一台服务器时它仍然会发生。
第 7 点似乎指责 xterm 是罪魁祸首,但修复它的设置是什么?
更新: 对于您的“#7”项目(将“xterm”一词粘贴到 nano),我建议针对 ConEmu 打开一个问题,或者对此发表评论。该问题似乎与括号粘贴有关。在 ConEmu 中,我看到在 WSL2 会话中启用了括号粘贴(设置 -> 信息 -> 控制台状态),但在 WSL1 会话中没有。
似乎没有任何方法可以禁用它,但也许有。根据 ConEmu 问题,它应该在应用程序级别关闭,但鉴于以下研究,这对我来说听起来不太正确。
不确定您看到的任何其他问题是否与它有关,但这似乎是问题 #7 发生与不发生之间的巨大差异。
也不确定为什么文本“xterm”会触发这个,但没有别的。也许 ConEmu 团队也可以在这方面提供帮助。
背景调查:
那里肯定有一些超级时髦的交互(这就是它的技术术语)。我下载了 ConEmu(来自 Github 发布页面的最新版本)。
我现在只关注你问题中的#7:
不过,这里有一些新信息:
fish
,我得到两件事之一。(1)在粘贴文本之前短暂的“闪烁”(这不会发生在我尝试粘贴的任何其他内容),或(2)“^[[201xterm”,通常在第二次和随后的粘贴尝试中. 从好的方面来说,fish
不会锁定。^[[201 似乎是“括号粘贴模式”(参见此处,“CSI ? 2004 h”代码)。当然,这是一个源自 xterm 的转义序列,但这并不能解释为什么粘贴文本“xterm”会触发它。不过,它可能确实解释了为什么 Nano 会窒息它。