summaryrefslogtreecommitdiffstats
path: root/completions/ping
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-28 09:14:42 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-28 09:14:42 +0000
commit0bc58b66a4850cdb8458a86c3d9a2fc81de82aa3 (patch)
treeea0fe36eb5e6f40e0a1f765d44c4b0c0b2bfb089 /completions/ping
parentInitial commit. (diff)
downloadbash-completion-upstream.tar.xz
bash-completion-upstream.zip
Adding upstream version 1:2.11.upstream/1%2.11upstream
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'completions/ping')
-rw-r--r--completions/ping71
1 files changed, 71 insertions, 0 deletions
diff --git a/completions/ping b/completions/ping
new file mode 100644
index 0000000..446f026
--- /dev/null
+++ b/completions/ping
@@ -0,0 +1,71 @@
+# ping(8) completion -*- shell-script -*-
+
+_ping()
+{
+ local cur prev words cword
+ _init_completion -n = || return
+
+ local ipvx
+
+ case $prev in
+ -*[cFGghilmPpstVWwz])
+ return
+ ;;
+ -*I)
+ _available_interfaces -a
+ return
+ ;;
+ -*M)
+ # Path MTU strategy in Linux, mask|time in FreeBSD
+ local opts="do want dont"
+ [[ $OSTYPE == *bsd* ]] && opts="mask time"
+ COMPREPLY=($(compgen -W '$opts' -- "$cur"))
+ return
+ ;;
+ -*N)
+ if [[ $cur != *= ]]; then
+ COMPREPLY=($(compgen -W 'name ipv6 ipv6-global ipv6-sitelocal
+ ipv6-linklocal ipv6-all ipv4 ipv4-all subject-ipv6=
+ subject-ipv4= subject-name= subject-fqdn=' -- "$cur"))
+ [[ ${COMPREPLY-} == *= ]] && compopt -o nospace
+ fi
+ return
+ ;;
+ -*Q)
+ # TOS in Linux, "somewhat quiet" (no args) in FreeBSD
+ if [[ $OSTYPE != *bsd* ]]; then
+ COMPREPLY=($(compgen -W '{0..7}' -- "$cur"))
+ return
+ fi
+ ;;
+ -*S)
+ # Socket sndbuf in Linux, source IP in FreeBSD
+ [[ $OSTYPE == *bsd* ]] && _ip_addresses
+ return
+ ;;
+ -*T)
+ # Timestamp option in Linux, TTL in FreeBSD
+ [[ $OSTYPE == *bsd* ]] ||
+ COMPREPLY=($(compgen -W 'tsonly tsandaddr' -- "$cur"))
+ return
+ ;;
+ -*4*)
+ ipvx=-4
+ ;;
+ -*6*)
+ ipvx=-6
+ ;;
+ esac
+
+ if [[ $cur == -* ]]; then
+ local opts=$(_parse_help "$1")
+ COMPREPLY=($(compgen -W '${opts:-$(_parse_usage "$1")}' -- "$cur"))
+ return
+ fi
+
+ [[ $1 == *6 ]] && ipvx=-6
+ _known_hosts_real ${ipvx-} -- "$cur"
+} &&
+ complete -F _ping ping ping6
+
+# ex: filetype=sh