我想清除特定tmux窗格中的所有滚动历史。


当前回答

如果您希望完全清除窗格,另一种选择是暂时将窗格调整为一行,清除历史记录,然后将其调整回来。这应该可以用一个tmux命令链无闪烁地工作。其优点是无论窗格中运行的是什么程序,它都可以正常工作。当然,这使得shell脚本逻辑更加复杂。

bind-key -n F11 run "
    if [[ #{window_panes} == "1" ]] ; then
        tmux send-keys C-l; sleep 0.1 ; tmux clear-history ;
    else
        restored_height=$((#{pane_height} + #{pane_at_bottom}));
        tmux resize-pane -y 1 \\; clear-history \\; resize-pane -y \${restored_height} ;
    fi
"

其他回答

我使用了上面的一些资料,再加上其他资料,得出了以下结论:

bind k send-keys C-u \; send-keys C-k \; send-keys " clear && tmux clear-history" \; send-keys "Enter" \; run-shell "sleep .3s" \; send-keys "Up" \; send-keys C-u 

" clear && tmux clear-history"中的前导空格防止命令被写入历史文件(前提是你的shell设置以这种方式处理前导空格;谷歌“hist忽略空格”+你的壳的名字,以获取更多信息)。我喜欢让这个命令不显示在我的历史记录中,因为这与终端中的ctrl-k更内联。

第一个发送键C-u和发送键C-k将清除当前在提示符下键入的任何内容,以确保“clear && tmux clear-history”是成功的(例如,如果您在提示符下键入了“ABCDEFG”,并且将光标放在D和E之间,这将确保“ABCD clear && tmux clear- historyefg”不会发送到shell,这将失败)。

发送键“Up”和最后一个发送键C-u清除shell内部历史记录中的最后一项。即使使用上面提到的尾随空格,shell的内部历史记录也将包括“clear…”行。向上发送和Ctrl-u可以去掉这个。

最后,在iTerm中,我将ctrl-k设置为映射到ctrl-a k(我的tmux前缀设置为ctrl-a),所以我可以输入ctrl-k,这是我多年来想做的事情。我这样做,通过到iTerm >首选项>配置文件>键,并添加一个快捷方式发送十六进制代码“0x01 0x6B”。这里有一篇很棒的文章,提供了更多关于在tmux和iTerm中使用十六进制代码的信息:http://tangledhelix.com/blog/2012/04/28/iterm2-keymaps-for-tmux/

这就得到了ctrl-k和tmux。唯一让我感到困扰的是,如果您当前在提示符下输入了一些内容,那么没有tmux的真正ctrl-k没有问题,并且在清除屏幕时将保留您键入的内容。如前所述,这种方法需要清除输入的内容,这样“clear…”命令才不会失败。但它非常接近!

为什么不呢?bind -n C-l send-keys C-l

如果你想结合CTRL-L加上clear-history,添加到你的~/.tmux.conf:

bind u send-keys C-l \; run-shell "sleep .3s" \; clear-history

这甚至适用于MySQL shell。

Ctrl-L在控制台应用程序中用于重绘屏幕。我发现当绑定到send-keys -R时,它会导致方向键在某些应用程序(如vim, mc)中不再正常工作。

为了在控制台应用程序中保留重绘功能,我使用了:

bind-key -n C-l if-shell -F '#{alternate_on}' 'send-keys C-l' 'send-keys -R C-l; clear-history'

这需要打开tmux选项的备用屏幕(默认情况下是这样)。

因此,我已经从上面使用了一段时间的plu方法,但我厌倦了它的局限性(基本上,传递的⌃L是没有意义的,除非通过管道传递给一个能够理解它的程序)。

所以我在这个线程的不同答案中改进了各种方法;虽然很复杂,但这种方法适用于shell和其他命令:

# ⌃K: Clears the current pane (from <https://stackoverflow.com/a/34162098>)
bind-key -n C-k \
   if-shell "test \"$(printf '#{pane_current_command}' | tail -c 2)\" = sh" \
      "send-keys C-l ; run-shell 'sleep .3s' ; clear-history" \
      "split-window -vp 100 ; clear-history -t ! ; kill-pane"

尝试使用tail -f /private/var/log/system.log或其他东西!


警告:

这里有一个重要的注意事项:这是无形地调整正在清除的窗格的大小,如果它不是一个shell的话。这可以在一些命令行应用程序监听SIGWINCHes时触发调整大小行为;但我的理由是,这不是一个大问题,因为这些是你很可能不会试图“清除”的程序。

此外,shell引用的情况已经很混乱,并且在嵌入#{pane_current_command}时很容易变得更加混乱,所以要小心,您可能必须根据默认命令设置修改它。

这同样适用于我对命令末尾匹配“sh”的测试;如果你有一个默认的命令,比如/bin/bash——login或者一些复杂的命令,比如exec,实际的命令可能不会以“sh”结尾;使用⌃B:执行display-message '#{pane_current_command}'如果你想知道测试针对的是什么。