在shell中自定义选项卡完成

时间:2012-06-08 04:02:50

标签: linux bash shell tab-completion bash-completion

这可能比“自定义标签完成”有更好的名称,但这是方案:

通常当我在命令行并输入命令,然后输入{TAB}两次时,我会得到当前目录中所有文件和子目录的列表。例如:

[user@host tmp]$ cat <TAB><TAB>
chromatron2.exe                  Fedora-16-i686-Live-Desktop.iso  isolate.py
favicon.ico                      foo.exe                          James_Gosling_Interview.mp3

但是,我注意到至少有一个程序以某种方式过滤了这个列表:wine。考虑:

[user@host tmp]$ wine <TAB><TAB>
chromatron2.exe  foo.exe

它有效地将结果过滤到*.exe

认为它可能是负责过滤的某种包装脚本,而whichfile结果wine不是脚本而是可执行文件。

现在,我不知道这个“过滤器”是否以某种方式编码在程序本身中,或者在默认的wine安装过程中以其他方式指定,所以我不确定这个问题是否更适合stackoverflow或超级用户,所以我穿过我的手指把它扔到这里。如果我猜错了,我道歉。 (另外,我检查了一些类似的问题,但大多数都是无关紧要的,或者涉及编辑shell配置。)

所以我的问题是,这个“过滤”是如何完成的?提前谢谢。

3 个答案:

答案 0 :(得分:12)

您可能会在系统上找到一个名为/etc/bash_completion的文件,其中包含设置此行为的函数和complete命令。该文件将由您的一个shell启动文件(例如~/.bashrc

)提供

可能还有一个名为/etc/bash_completion.d的目录,其中包含具有更多完成功能的单个文件。这些文件来自/etc/bash_completion

这是wine完成命令从我系统上的/etc/bash_completion看起来的样子:

complete -f -X '!*.@(exe|EXE|com|COM|scr|SCR|exe.so)' wine

这组文件在很大程度上由Bash Completion Project维护。

答案 1 :(得分:6)

您可以在bash手册中查看Programmable Completion,了解其工作原理。

答案 2 :(得分:5)

我知道这已经过时了,但我正在寻找与我自己的剧本类似的东西。

你可以玩我在这里做的一个例子: http://runnable.com/Uug-FAUPXc4hAADF/autocomplete-for-bash

粘贴上面的代码:

# Create function that will run when a certain phrase is typed in terminal
# and tab key is pressed twice
_math_complete()
{
    # fill local variable with a list of completions
    local COMPLETES="add sub mult div"
    # you can fill this variable however you want. example:
    # ./genMathArgs.sh > ./mathArgsList
    # local COMPLETES=`cat ./mathArgsList`

    # we put the completions into $COMPREPLY using compgen
    COMPREPLY=( $(compgen -W "$COMPLETES" -- ${COMP_WORDS[COMP_CWORD]}) )
    return 0
}

# get completions for command 'math' from function '_math_complete()'
complete -F _math_complete math 

# print instructions
echo ""
echo "To test auto complete do the following:"
echo "Type math then press tab twice." 
echo "You will see the list we created in COMPLETES"
echo ""