2作者: debba大约 1 个月前原帖
项目网址:https://github.com/debba/rewindtty 我一直在开发 rewindtty,这是一个用 C 语言编写的轻量级终端会话录制和回放工具。它的工作方式类似于 script/scriptreplay,但输出结构化的 JSON,并包含一个基于浏览器的播放器,用于回放终端会话,支持时间控制、快进、书签等功能。 到目前为止,我一直是逐条命令地录制会话,分别捕获每个 shell 命令及其输出。这使得分析会话和按命令索引变得简单。 然而,我刚刚引入了一种新的交互模式,它的行为更像传统的 script:它通过 PTY 实时录制原始终端输入输出,捕获每个输入或显示的字符,包括控制序列。 这对于实现真实感和完整的会话保真度(例如,像 htop、vim、REPL 等交互式工具)非常有帮助,但这也使得命令检测变得更加困难——我不再在 shell 层面拦截输入。 我的问题是:如何从这个原始的 PTY 流中提取实际的命令? 我知道这很棘手,但我想知道: - 有没有人尝试解析 ANSI 流以重建命令边界? - 是否可以实时挂钩到 shell(bash、zsh 等)以拦截命令? - 是否有 shell 选项或审计功能可以与原始捕获并行利用? - 有没有我应该关注的相关文献或库? 我很想听听其他人在录制、分析或回放 shell 会话方面的做法。任何见解或建议都将非常有帮助。