2

我正在创建一个由 VT100 转义序列控制的 Telnet CLI 应用程序。例如,要向左导航光标,<ESC>[D 转义序列从 Telnet 服务器发送到客户端,客户端可能是 Putty 或 Gnome 终端。不幸的是,对于长于 Putty 行长度的行,上面的转义序列将不允许将光标导航到当前行上方的行。

一个例子。光标是“|”。评论用'//'标记

----------------
>potato| // Now I press left arrow which sends esc sequence to application
----------------
>potat|o // Works as expected. The cursor moved left
----------------

另一个例子

----------------
>potatopotatopot // This is a long command which goes over two lines
|ato             // Now I press left arrow which sends esc sequence to application
----------------
>potatopotatopot // The cursor didn't move, since the escape sequence 
|ato             // does nothing if the cursor is at the edge
----------------

我一直在寻找在边缘时会环绕的任何其他转义序列,但没有找到。我还没有找到任何将终端模式更改为允许换行的转义序列。

那么这种终端导航一般是怎么处理的呢?

4

2 回答 2

1

如前所述,该bw功能可以解决部分问题,但很少见。特别是,它不是 vt100 兼容程序(例如 xterm)的功能。OP 提到了 PuTTY 和 gnome-terminal。后者不使用bw,因此首选不同的解决方案。

另一方面,PuTTY 确实实现了 vt100光标位置报告,当它无法使用系统调用获取屏幕尺寸时,它会被resize用作后备。引用 xterm 的控制序列文档:

CSI Ps n  Device Status Report (DSR).
            Ps = 5  -> Status Report.
          Result (``OK'') is CSI 0 n
            Ps = 6  -> Report Cursor Position (CPR) [row;column].
          Result is CSI r ; c R

resize程序通过

  • 将光标发送到“巨大”(999 x 999)窗口的右下角
  • 发送 CPR 序列
  • 读取实际光标位置的报告

知道屏幕大小后,服务器可以将光标发送到更有用的位置。

于 2015-03-11T21:00:17.217 回答
0

termcap 终端描述中的bw功能表示在屏幕边缘向左移动是否换行到上一行。它出现在我检查的 PuTTy 描述中(infocmp putty在 ncurses 下),但在许多其他描述中没有出现(例如,不在 中infocmp gnome)。

您可以尝试跟踪光标所在的列,并在您想绕到上一行时使用移动控制序列。您必须知道用户屏幕的宽度,这可以通过他们设置LINESCOLS环境变量来完成。

于 2014-09-09T11:25:09.500 回答