6、使用前缀和后缀补全命令
补全命令可以通过被前缀(在后面添加)和后缀(添加在后面)来定义。在下面的例子中,前缀和后缀在list_job_attrib.sh中被定义。
$ jobs
[1]+ Stopped cat
$ complete -P '">' -S '<"' ./list_job_attrib.sh
$ ./list_job_attrib.sh [TAB][TAB]
$ ./list_job_attrib.sh ">cat<"
7、具有排除功能的文件名和目录补全
看看下面的脚本,输出output 目录下面的文件:
$ cd output/
$ ls
all_calls.txt incoming_calls.txt outgoing_calls.txt missed_calls.txt
parser_mod.tmp extract.o
在上面的例子中,如果你想要排除以.tmp和.o为后缀的文件,实现ls命令的自动补全功能,可以这样:
$ export FIGNORE='.tmp:.o'
$ complete -f -d ls
$ cd output
$ ls [TAB][TAB]
all_calls.txt incoming_calls.txt outgoing_calls.txt missed_calls.txt
FIGNORE 是一个shell变量,它包含了排除在自动补全队列中的文件的文件名的后缀。
8、通过IFS变量分割String字符串,得到被分割后的值。
单词表可以通过使用w参数被IFS 变量中定义的字符串分割成多个单词。最终每个单词都会被分开,被显示出来。
$ export IFS=" "
$ complete -W "bubble quick" ./sort_numbers.sh
$ ./sort_numbers.sh [TAB][TAB]
bubble quick
如上所述,被IFS分割之后,单词就会被扩展开,所以也可能有下面展示的这些变量。
$ echo $SORT_TYPE1
bubble
$ echo $SORT_TYPE2
quick
$ complete -W "$SORT_TYPE1 $SORT_TYPE2" ./sort_numbers.sh
$ ./sort_numbers.sh [TAB][TAB]
bubble quick
9、编写你自己的函数以实现自动补全功能
你可以声明一个函数来定义补全功能。使用 -F 参数,被传入到补全命令的函数名,可以执行并。例如,函数可以写成下面的样式。
_parser_options()
{
local curr_arg;
curr_arg=${COMP_WORDS[COMP_CWORD]}
COMPREPLY=( $(compgen -W '-i --incoming -o --outgoing -m --missed' -- $curr_arg ) );
}
在上面的函数中,
1.COMPREPLY :存储在按下[TAB][TAB]之后打印信息的数组。
2.COMP_WORDS :在命令行输入的单词数组
3.COMP_CWORD :COMP_WORDS 数组的索引,可以访问命令行中不用位置的单词。
4.compgen :使用-W参数,持有current_arg变量中尽可能完整的、分开的内容。
文件中parser_option 函数通过source执行如下:
$ source parser_option
这个函数链接到脚本解析器如下:
$ complete -F _parser_options ./parser.pl
$ ./parser.pl [TAB][TAB]
-i --incoming -o --outgoing -m --missed
就像上面所看到的,解析器的参数可以通过_parser_options函数生成。
注意:查看/etc/bash_completion文件,了解更多的可编程的命令行补全功能函数。
10、当第一规范没有进行匹配时,就需要执行第二规范
通过定义的补全规范,没有进行匹配,那么通过-o参数定义的completion 就会执行。
$ complete -F _count_files -o dirnames ./countfiles.sh
同上,通过使用_count_files 文件中定义的_count_files 函数定义的completion ,如果_count_files函数没有进行匹配,那么就会执行目录补全。
$ ls
countfiles.sh dir1/ dir2/ dir3/
$./countfiles.sh [TAB][TAB]
dir1 dir2 dir3