BASH 完了: 繰り返しを無視しますか?

BASH 完了: 繰り返しを無視しますか?

ターミナルを使用するときに、キーを何度も押すという悪い癖がありますTAB。呼び出された bash 補完ルーチンが特に遅い場合、ターミナルが補完リストを 2 ~ 3 回 (または押された回数) 表示する間、長い待機時間が発生しますTAB

bash 補完で繰り返しキー押下を無視する方法はありますか?

答え1

マニュアル ページでは、サポートされている補完キーを微調整するために ~/.inputrc ファイルで定義できる多数の「変数」が定義されています。

戦略的に割り当てることで右キー適切な関数に割り当てれば、おそらく望みどおりの効果が得られるでしょう。ただし、double がTAB作業を 2 回実行することを完全に防ぐことはできません。

サンプル ~/.inputrc ファイル:

C-TAB: complete
TAB: complete-filename

マニュアルページの懸念事項は次のとおりです。

Completing
   complete (TAB)
          Attempt  to  perform  completion on the text before point.  Bash attempts
          completion treating the text as a variable (if the text begins with $),
          username (if the text begins with ~), hostname (if the text begins with @),
          or command (including aliases and functions) in  turn.   If  none  of
          these produces a match, filename completion is attempted.
   possible-completions (M-?)
          List the possible completions of the text before point.
   insert-completions (M-*)
          Insert all completions of the text before point that would have been
          generated by possible-completions.
   menu-complete
          Similar  to  complete,  but  replaces  the word to be completed with a
          single match from the list of possible completions.  Repeated execution of
          menu-complete steps through the list of possible completions, inserting
          each match in turn.  At the end of the list of completions, the  bell  is
          rung  (subject  to  the  setting  of  bell-style)  and  the original text
          is restored.  An argument of n moves n positions forward in the list of
          matches; a negative argument may be used to move backward through the list.
          This command is intended to be bound  to  TAB,  but  is  unbound  by
          default.
   menu-complete-backward
          Identical  to menu-complete, but moves backward through the list of possible
          completions, as if menu-complete had been given a negative argument.
          This command is unbound by default.
   delete-char-or-list
          Deletes the character under the cursor if not at the beginning or end of
          the line (like delete-char).  If at the end of the line, behaves identi‐
          cally to possible-completions.  This command is unbound by default.
   complete-filename (M-/)
          Attempt filename completion on the text before point.
   possible-filename-completions (C-x /)
          List the possible completions of the text before point, treating it as
          a filename.
   complete-username (M-~)
          Attempt completion on the text before point, treating it as a username.
   possible-username-completions (C-x ~)
          List the possible completions of the text before point, treating it as
          a username.
   complete-variable (M-$)
          Attempt completion on the text before point, treating it as a shell variable.
   possible-variable-completions (C-x $)
          List the possible completions of the text before point, treating it as
          a shell variable.
   complete-hostname (M-@)
          Attempt completion on the text before point, treating it as a hostname.
   possible-hostname-completions (C-x @)
          List the possible completions of the text before point, treating it as
          a hostname.
   complete-command (M-!)
          Attempt  completion  on  the  text  before  point, treating it as a
          command name.  Command completion attempts to match the text against aliases,
          reserved words, shell functions, shell builtins, and finally executable
          filenames, in that order.
   possible-command-completions (C-x !)
          List the possible completions of the text before point, treating it as
          a command name.
   dynamic-complete-history (M-TAB)
          Attempt completion on the text before point, comparing the text against
          lines from the history list for possible completion matches.
   dabbrev-expand
          Attempt menu completion on the text before point, comparing the text
          against lines from the history list for possible completion matches.
   complete-into-braces (M-{)
          Perform filename completion and insert the list of possible completions
          enclosed within braces so the list is available to the shell  (see  Brace
          Expansion above).

関連情報