跳转至内容

Readline

来自 ArchWiki

Readline 是由 GNU 项目开发的一个库,被 Bash 和其他命令行界面 (CLI) 程序用于编辑和与命令行进行交互。更多信息请参阅 readline(3)

安装

readline 软件包很可能已经作为 Bash 的依赖项被安装了。

编辑模式

默认情况下,Readline 使用 Emacs 风格的快捷键与命令行交互。不过,通过在 ~/.inputrc 中添加以下内容,也可以支持 vi 风格的编辑界面

~/.inputrc
set editing-mode vi

或者,若只想为 Bash 设置,请在 ~/.bashrc 中添加以下行

~/.bashrc
set -o vi

提示符中的模式指示器

Vi 风格的编辑有两种模式:命令模式和插入模式。您可以通过添加以下选项来显示当前激活的是哪种模式

~/.inputrc
set show-mode-in-prompt on

这将在您的提示符中打印一个字符串(默认值为 (cmd)/(ins)),可以通过 vi-ins-mode-stringvi-cmd-mode-string 变量进行自定义。

每种模式使用不同的光标形状

您可以使用 "\1 .. \2" 转义序列 为每种模式设置不同的光标形状

~/.inputrc
set vi-ins-mode-string \1\e[6 q\2
set vi-cmd-mode-string \1\e[2 q\2

这将设置在命令模式时使用块状光标,在插入模式时使用竖线光标。请注意,必须启用模式指示器才能使其生效(见 #提示符中的模式指示器)。

虚拟控制台 (Virtual Console) 使用不同的转义码,因此您应该首先检查正在使用哪个 term

~/.inputrc
$if term=linux
	set vi-ins-mode-string \1\e[?0c\2
	set vi-cmd-mode-string \1\e[?8c\2
$else
	set vi-ins-mode-string \1\e[6 q\2
	set vi-cmd-mode-string \1\e[2 q\2
$endif

更多详情请参阅 VGA 软件光标

快速单词移动

Xterm 默认支持使用 Ctrl+LeftCtrl+Right 在单词之间移动。要在其他终端模拟器中实现此效果,请找到正确的 终端代码,并在 ~/.inputrc 中将其绑定到 backward-wordforward-word

例如,对于 urxvt

~/.inputrc
"\e[1;5D": backward-word
"\e[1;5C": forward-word

另一个例子是 macOS 风格(Alt+LeftAlt+Right)的单词移动

~/.inputrc or /etc/inputrc
"\e[1;9D": backward-word
"\e[1;9C": forward-word

历史

历史记录 (history) 的配置分为两部分:

  • 控制其运行方式,这是针对特定 shell 配置的,例如参阅 Bash#History customization;以及
  • 影响交互方式,这可以通过特定 shell 的配置或适用于所有 shell 的原生 inputrc 配置来设置,如下例所示。

通常,按下上箭头键将显示最后一条命令,无论目前已输入了什么。然而,用户可能会发现仅列出与当前输入匹配的过去命令更为实用。

例如,如果用户输入了以下命令

  • ls /usr/src/linux-2.6.15-ARCH/kernel/power/Kconfig
  • who
  • mount
  • man mount

在这种情况下,当输入 ls 并按下上箭头键时,当前输入将被替换为 man mount(最后执行的命令)。如果启用了历史搜索,则仅显示以 ls(当前输入)开头的过去命令,在这种情况下为 ls /usr/src/linux-2.6.15-ARCH/kernel/power/Kconfig

您可以通过在 /etc/inputrc~/.inputrc 中添加以下行来启用历史搜索模式

"\e[A": history-search-backward
"\e[B": history-search-forward

如果您使用的是 vi 模式,可以将以下行添加到 readline 配置文件中(来自 BBS#54972

~/.inputrc
set editing-mode vi
$if mode=vi
set keymap vi-command
# these are for vi-command mode
"\e[A": history-search-backward
"\e[B": history-search-forward
j: history-search-forward
k: history-search-backward
set keymap vi-insert
# these are for vi-insert mode
"\e[A": history-search-backward
"\e[B": history-search-forward
$endif

如果您选择将这些行添加到 ~/.inputrc,建议您在该文件的开头也添加以下行,以避免出现像 BBS#112537 这样奇怪的问题

$include /etc/inputrc

或者,可以使用 Ctrl+r 触发 reverse-search-history(增量搜索),它不是基于之前的输入进行搜索,而是在输入搜索词时在历史缓冲区中向后跳转。在此模式下再次按下 Ctrl+r 将显示缓冲区中匹配当前搜索词的前一行,而按下 Ctrl+g(中止)将取消搜索并恢复当前的输入行。因此,为了搜索所有之前的 mount 命令,请按 Ctrl+r,输入 'mount' 并持续按下 Ctrl+r 直到找到所需的行。

该模式的正向等效操作称为 forward-search-history,默认绑定到 Ctrl+s。请注意,大多数终端将 Ctrl+s 重写为暂停(看起来像冻结)输出,直到输入 Ctrl+q 为止(这被称为 XON/XOFF 流控制)。要激活 forward-search-history,可以通过执行以下命令禁用流控制:

$ stty -ixon

或者在 inputrc 中使用不同的按键。例如,使用默认未绑定的 Alt+s

"\es": forward-search-history

更快速的补全

在执行 Tab 补全时,单击 Tab 尝试部分补全当前单词。如果没有可能的局部补全,双击 Tab 将显示所有可能的补全选项。

可以通过以下设置将双击 Tab 改为单击 Tab

~/.inputrc
set show-all-if-unmodified on

或者您可以将其设置为单击 Tab 即可执行这两个步骤:部分补全单词 在仍然不明确时显示所有可能的补全

~/.inputrc
set show-all-if-ambiguous on

彩色补全

您可以使用 colored-stats 选项启用文件名称补全的着色。您还可以使用 colored-completion-prefix 为补全列表的相同前缀着色。例如

~/.inputrc
# Color files by types
# Note that this may cause completion text blink in some terminals (e.g. xterm).
set colored-stats On
# Append char to indicate type
set visible-stats On
# Mark symlinked directories
set mark-symlinked-directories On
# Color the common prefix
set colored-completion-prefix On
# Color the common prefix in menu-complete
set menu-complete-display-prefix On

Readline 还支持将按键绑定到键盘宏,例如

$ bind '"\ew": "\C-e # macro"'

若要永久保存,请将单引号内的部分添加到 readline 的配置文件中

~/.inputrc
"\ew": "\C-e # macro"

现在输入一行并按下 Alt+w。Readline 将表现得就像按下了 Ctrl+e(行尾),并追加了 ' # macro'。

在 readline 宏中使用任何现有的按键绑定,这对于自动化经常使用的惯用法非常有用。例如,这个宏使 Ctrl+Alt+l 在行尾追加 | less 并运行(Ctrl+m 等同于 Enter

"\e\C-l": "\C-e | less\C-m"

下一个宏在按下 Ctrl+Alt+y 时在行首添加 yes |,从而确认命令可能会询问的任何是/否问题

"\e\C-y": "\C-ayes | \C-m"

这个例子在按下 Alt+s 时,将该行包裹在 su -c '' 中并运行

"\es": "\C-a su -c '\C-e'\C-m"

这个例子在按下 Alt+s 时,在行首添加 sudo 。它允许您检查结果,且不会自动输入 Enter 键。

"\es": "\C-asudo \C-e"

最后一个例子,使用 Ctrl+Alt+b 将命令快速发送到后台,并丢弃其所有输出

"\e\C-b": "\C-e > /dev/null 2>&1 &\C-m"

与历史记录类似,也可以为 vi-command 引入 vi 命令宏,用于没有对应命令的值或其他宏目的。

$if mode=vi
#vi mode settings
   set keymap vi-command
   # char search has a vi command so f could be defined
   "f": vi-char-search

   # char forward(next) and back(prev) does not have a vi-* command
   # so it can be accessed with a macro
   "zn": ";"
   "zp": ","

# end vi mode settingss
$endif

禁用控制字符回显

Readline 会导致终端在按下 Ctrl+c 后回显 ^C。对于希望禁用此功能的用户,只需将以下内容添加到 ~/.inputrc

set echo-control-characters off

括号粘贴 (Bracketed paste)

默认情况下,括号粘贴模式是开启的。可以在 ~/.inputrc 中手动设置

set enable-bracketed-paste on

这确保了粘贴到 Readline 时,剪贴板内容被作为单个字符串插入,而不是像从键盘输入一样逐个插入字符。这是一种安全措施,防止 Readline 自动修改并运行粘贴的命令。

参见

© . This site is unofficial and not affiliated with Arch Linux.

Content is available under GNU Free Documentation License 1.3 or later unless otherwise noted.