summaryrefslogtreecommitdiff
path: root/completions/vpnc
blob: 143798de8612d44a299439c5e42b9906e367de15 (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
# 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)
            return 0
            ;;
        --gateway)
            _known_hosts_real "$cur"
            return 0
            ;;
        --vendor)
            COMPREPLY=( $( compgen -W 'cisco netscreen' -- "$cur" ) )
            return 0
            ;;
        --natt-mode)
            COMPREPLY=( $( compgen -W 'natt none force-natt cisco-udp' \
                -- "$cur" ) )
            return 0
            ;;
        --script|--pid-file|--ca-file)
            _filedir
            return 0
            ;;
        --dh)
            COMPREPLY=( $( compgen -W 'dh1 dh2 dh5' -- "$cur" ) )
            return 0
            ;;
        --pfs)
            COMPREPLY=( $( compgen -W 'nopfs dh1 dh2 dh5 server' -- "$cur" ) )
            return 0
            ;;
        --debug)
            COMPREPLY=( $( compgen -W '0 1 2 3 99' -- "$cur" ) )
            return 0
            ;;
        --auth-mode)
            COMPREPLY=( $( compgen -W 'psk cert hybrid' -- "$cur" ) )
            return 0
            ;;
        --ca-dir)
            _filedir -d
            return 0
            ;;
    esac

    if [[ "$cur" == -* ]]; then
        COMPREPLY=( $( compgen -W '$( _parse_help "$1" --long-help )' \
            -- "$cur" ) )
    else
        COMPREPLY=( $( compgen -W '$( command ls /etc/vpnc )' -- "$cur" ) )
    fi
} &&
complete -F _vpnc vpnc

# ex: ts=4 sw=4 et filetype=sh