列出bash“bind -x”绑定

问题描述 投票:12回答:2

我搜索了man bash,但找不到任何列出所有当前bind -x键绑定的东西。有什么办法可以吗?我尝试了以下方法:

$ bind -x '"\C-`":"echo hello"'
# test binding: press CTRL+`
hello
# Binding works!
$ bind -p | grep 'hello'
# no output
$ bind -S
# no output

那么,有什么方法可以看到所有bind -x目前活跃的列表?

linux bash shell
2个回答
4
投票

好像你可以使用bind -X(Bash 4.3中的新功能):

$ help bind
      ...
      -x  keyseq:shell-command  Cause SHELL-COMMAND to be executed when
                                KEYSEQ is entered.
      -X                        List key sequences bound with -x and
                                associated commands in a form that can be
                                reused as input.
      ...
$

4
投票

上面的答案为bash 4.3.48返回空输出。但资本'P'确实有效:

bind - display all function names (and bindings)

bind -P

说明

          -P     List current readline function names and bindings.
          -p     Display  readline  function  names and bindings in such a
                 way that they can be re-read.

样本输出

set-mark can be found on "\C-@", "\e ".
shell-expand-line can be found on "\e\C-e".
start-kbd-macro can be found on "\C-x(".
tilde-expand can be found on "\e&".
transpose-chars can be found on "\C-t".
transpose-words can be found on "\et".
undo can be found on "\C-x\C-u", "\C-_".
unix-line-discard can be found on "\C-u".
unix-word-rubout can be found on "\C-w".
upcase-word can be found on "\eu".
yank can be found on "\C-y".
yank-last-arg can be found on "\e.", "\e_".
yank-nth-arg can be found on "\e\C-y".
yank-pop can be found on "\ey".

manpage

由于很难找到它的联机帮助页,因此它是:

bind [-m keymap] [-lpsvPSVX]
       bind [-m keymap] [-q function] [-u function] [-r keyseq]
       bind [-m keymap] -f filename
       bind [-m keymap] -x keyseq:shell-command
       bind [-m keymap] keyseq:function-name
       bind readline-command
              Display current readline key and function bindings, bind  a  key
              sequence  to  a  readline  function  or macro, or set a readline
              variable.  Each non-option argument is a  command  as  it  would
              appear  in  .inputrc, but each binding or command must be passed
              as a separate argument; e.g.,  '"\C-x\C-r":  re-read-init-file'.
              Options, if supplied, have the following meanings:
              -m keymap
                     Use keymap as the keymap to be affected by the subsequent
                     bindings.    Acceptable   keymap   names    are    emacs,
                     emacs-standard,   emacs-meta,  emacs-ctlx,  vi,  vi-move,
                     vi-command,  and  vi-insert.    vi   is   equivalent   to
                     vi-command; emacs is equivalent to emacs-standard.
              -l     List the names of all readline functions.
              -p     Display  readline  function  names and bindings in such a
                     way that they can be re-read.
              -P     List current readline function names and bindings.
              -s     Display readline key sequences bound to  macros  and  the
                     strings  they  output  in such a way that they can be re-
                     read.
              -S     Display readline key sequences bound to  macros  and  the
                     strings they output.
              -v     Display  readline variable names and values in such a way
                     that they can be re-read.
              -V     List current readline variable names and values.
              -f filename
                     Read key bindings from filename.
              -q function
                     Query about which keys invoke the named function.
              -u function
                     Unbind all keys bound to the named function.
              -r keyseq
                     Remove any current binding for keyseq.
              -x keyseq:shell-command
                     Cause shell-command to be  executed  whenever  keyseq  is
                     entered.   When shell-command is executed, the shell sets
                     the  READLINE_LINE  variable  to  the  contents  of   the
                     readline  line  buffer and the READLINE_POINT variable to
                     the current location of  the  insertion  point.   If  the
                     executed  command  changes  the value of READLINE_LINE or
                     READLINE_POINT, those new values will be reflected in the
                     editing state.
              -X     List  all  key  sequences bound to shell commands and the
                     associated commands in a format that  can  be  reused  as
                     input.

              The  return value is 0 unless an unrecognized option is given or
              an error occurred.
© www.soinside.com 2019 - 2024. All rights reserved.