blob: 5eb5be71714bb289411413f27f6a5fc7fc5606f0 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
|
# bash completion for vpnc -*- shell-script -*-
_vpnc()
{
local cur prev words cword
_init_completion || return
case $prev in
--help|--long-help|--version|--id|--username|--domain|--ifname|\
--application-version|--local-addr|--local-port|--udp-port|--dpd-idle|\
--target-network|--ifmtu)
return
;;
--gateway)
_known_hosts_real -- "$cur"
return
;;
--vendor)
COMPREPLY=( $(compgen -W 'cisco netscreen' -- "$cur") )
return
;;
--natt-mode)
COMPREPLY=( $(compgen -W 'natt none force-natt cisco-udp' \
-- "$cur") )
return
;;
--script|--pid-file|--ca-file)
_filedir
return
;;
--dh)
COMPREPLY=( $(compgen -W 'dh1 dh2 dh5' -- "$cur") )
return
;;
--pfs)
COMPREPLY=( $(compgen -W 'nopfs dh1 dh2 dh5 server' -- "$cur") )
return
;;
--ifmode)
COMPREPLY=( $(compgen -W 'tun tap' -- "$cur") )
return
;;
--debug)
COMPREPLY=( $(compgen -W '0 1 2 3 99' -- "$cur") )
return
;;
--auth-mode)
COMPREPLY=( $(compgen -W 'psk cert hybrid' -- "$cur") )
return
;;
--ca-dir)
_filedir -d
return
;;
--password-helper)
compopt -o filenames
COMPREPLY=( $(compgen -c -- "$cur") )
return
;;
esac
if [[ "$cur" == -* ]]; then
COMPREPLY=( $(compgen -W '$(_parse_help "$1" --long-help)' -- "$cur") )
elif [[ "$cur" == */* ]]; then
# explicit filename
_filedir conf
else
# config name, /etc/vpnc/<name>.conf
local IFS=$' \t\n' reset=$(shopt -p nullglob); shopt -s nullglob
local -a configs=( /etc/vpnc/*.conf )
configs=( "${configs[@]##*/}" )
configs=( "${configs[@]%.conf}" )
$reset
IFS=$'\n'
compopt -o filenames
COMPREPLY=( $(compgen -W '${configs[@]}' -- "$cur") )
fi
} &&
complete -F _vpnc vpnc
# ex: filetype=sh
|