summaryrefslogtreecommitdiffstats
path: root/completions/nslookup
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2024-05-04 01:03:18 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2024-05-04 01:03:18 +0000
commitf2621414ee5f2f601424c22f00e207903e3b6104 (patch)
tree56a856dafd1ca684bb23263cacaa723ee4f404fc /completions/nslookup
parentAdding debian version 1:2.11-8. (diff)
downloadbash-completion-f2621414ee5f2f601424c22f00e207903e3b6104.tar.xz
bash-completion-f2621414ee5f2f601424c22f00e207903e3b6104.zip
Merging upstream version 1:2.12.0.
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'completions/nslookup')
-rw-r--r--completions/nslookup77
1 files changed, 48 insertions, 29 deletions
diff --git a/completions/nslookup b/completions/nslookup
index 3341b1f..b04b03a 100644
--- a/completions/nslookup
+++ b/completions/nslookup
@@ -1,32 +1,42 @@
# bash completion for nslookup -*- shell-script -*-
-_bind_queryclass()
+_comp_cmd_nslookup__queryclass()
{
- COMPREPLY+=($(compgen -W 'IN CH HS ANY' -- "$cur"))
+ _comp_compgen -a -- -W 'IN CH HS ANY'
}
-_bind_querytype()
+_comp_cmd_nslookup__querytype()
{
# https://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"))
+ # Resource records
+ local -a types=(
+ A AAAA AFSDB APL CAA CDNSKEY CDS CERT CNAME CSYNC DHCID DLV DNAME
+ DNSKEY DS EUI48 EUI64 HINFO HIP IPSECKEY KEY KX LOC MX NAPTR NS NSEC
+ NSEC3 NSEC3PARAM OPENPGPKEY PTR RRSIG RP SIG SMIMEA SOA SRV SSHFP TA
+ TKEY TLSA TSIG TXT URI ZONEMD SVCB HTTPS
+ )
+ # Other types/pseudo record types
+ types+=(AXFR IXFR OPT)
+ # Selected obsolete record types
+ types+=(SPF)
+
+ _comp_compgen -a -- -W '"${types[@]}"'
}
-_nslookup()
+_comp_cmd_nslookup()
{
- local cur prev words cword
- _init_completion -n = || return
+ local cur prev words cword comp_args
+ _comp_initialize -n = -- "$@" || return
case $cur in
-class=* | -cl=*)
cur=${cur#*=}
- _bind_queryclass
+ _comp_cmd_nslookup__queryclass
return
;;
-querytype=* | -type=* | -q=* | -ty=*)
cur=${cur#*=}
- _bind_querytype
+ _comp_cmd_nslookup__querytype
return
;;
-?*=*)
@@ -35,38 +45,38 @@ _nslookup()
esac
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"))
+ _comp_compgen -- -W '-all -class= -debug -nodebug -d2 -nod2 -domain=
+ -search -nosearch -port= -querytype= -recurse -norecurse -retry=
+ -timeout= -vc -novc -fail -nofail'
[[ ${COMPREPLY-} == *= ]] && compopt -o nospace
return
fi
- local args
- _count_args =
- if ((args <= 2)); then
- _known_hosts_real -- "$cur"
- [[ $args -eq 1 && $cur == @(|-) ]] && COMPREPLY+=(-)
+ local REPLY
+ _comp_count_args
+ if ((REPLY <= 2)); then
+ _comp_compgen_known_hosts -- "$cur"
+ [[ $REPLY -eq 1 && $cur == @(|-) ]] && COMPREPLY+=(-)
fi
} &&
- complete -F _nslookup nslookup
+ complete -F _comp_cmd_nslookup nslookup
-_host()
+_comp_cmd_host()
{
- local cur prev words cword
- _init_completion || return
+ local cur prev words cword comp_args
+ _comp_initialize -- "$@" || return
case $prev in
-c)
- _bind_queryclass
+ _comp_cmd_nslookup__queryclass
return
;;
-t)
- _bind_querytype
+ _comp_cmd_nslookup__querytype
return
;;
-m)
- COMPREPLY=($(compgen -W 'trace record usage' -- "$cur"))
+ _comp_compgen -- -W 'trace record usage'
return
;;
-N | -R | -W)
@@ -75,12 +85,21 @@ _host()
esac
if [[ $cur == -* ]]; then
- COMPREPLY=($(compgen -W '$(_parse_usage "$1")' -- "$cur"))
+ _comp_compgen_usage
return
fi
- _known_hosts_real -- "$cur"
+ local REPLY
+ _comp_count_args -a "-*[ctmNRW]"
+ if ((REPLY == 1)); then
+ _comp_compgen_known_hosts -- "$cur"
+ elif ((REPLY == 2)); then
+ local ipvx
+ [[ ${words[*]} =~ \ -[^\ ]*([46]) ]] && ipvx=-${BASH_REMATCH[1]}
+ # shellcheck disable=SC2086
+ _comp_compgen_known_hosts ${ipvx-} -- "$cur"
+ fi
} &&
- complete -F _host host
+ complete -F _comp_cmd_host host
# ex: filetype=sh