[Bash-completion-commits] [SCM] bash-completion branch, master, updated. 1.3-393-gbd07926
Ville Skyttä
ville.skytta at iki.fi
Fri Jul 1 17:24:43 UTC 2011
The following commit has been merged in the master branch:
commit c328b9135213c989189249b5f2ce41569e328570
Author: Ville Skyttä <ville.skytta at iki.fi>
Date: Fri Jul 1 20:22:55 2011 +0300
nslookup: Fix option completion, add some option argument completions.
diff --git a/completions/bind-utils b/completions/bind-utils
index 79c02c7..3131119 100644
--- a/completions/bind-utils
+++ b/completions/bind-utils
@@ -2,14 +2,46 @@
have nslookup || return
+_bind_queryclass()
+{
+ COMPREPLY+=( $( compgen -W 'IN CH HS ANY' -- "$cur" ) )
+}
+
+_bind_querytype()
+{
+ # http://en.wikipedia.org/wiki/List_of_DNS_record_types
+ COMPREPLY+=( $( compgen -W 'A AAAA AFSDB APL CERT CNAME DHCID DLV DNAME
+ DNSKEY DS HIP IPSECKEY KEY KX LOC MX NAPTR NS NSEC NSEC3 NSEC3PARAM PTR
+ RRSIG RP SIG SOA SPF SRV SSHFP TXT' -- "$cur" ) )
+}
+
_nslookup()
{
local cur prev words cword
- _init_completion || return
+ _init_completion -n = || return
+
+ case $cur in
+ -class=*|-cl=*)
+ cur=${cur#*=}
+ _bind_queryclass
+ return
+ ;;
+ -querytype=*|-type=*|-q=*|-ty=*)
+ cur=${cur#*=}
+ _bind_querytype
+ return
+ ;;
+ -?*=*)
+ return
+ ;;
+ esac
- COMPREPLY=( $( compgen -P '-' -W 'all class= debug d2 domain= srchlist= \
- defname search port= querytype= type= recurse retry root timeout vc \
- ignoretc' -- "$cur" ) )
+ if [[ $cur == -* ]]; then
+ COMPREPLY=( $( compgen -W '-all -class= -debug -nodebug -d2 -nod2
+ -domain= -search -nosearch -port= -querytype= -recurse -norecurse
+ -retry= -timeout= -vc -novc -fail -nofail' -- "$cur" ) )
+ [[ $COMPREPLY == *= ]] && compopt -o nospace
+ fi
} &&
complete -F _nslookup nslookup
--
bash-completion
More information about the Bash-completion-commits
mailing list