blob: 797e536808545b11f9e056ace8b98367a39ec5c5 (
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
|
# usermod(8) completion -*- shell-script -*-
_comp_cmd_usermod()
{
local cur prev words cword was_split comp_args
_comp_initialize -s -- "$@" || return
# TODO: if -o/--non-unique is given, could complete on existing uids
# with -u/--uid
local word chroot="" has_chroot=""
for word in "${words[@]}"; do
if [[ $has_chroot ]]; then
chroot=$word
break
fi
[[ $word != -@(R|-root) ]] || has_chroot=set
done
local noargopts='!(-*|*[cdeflpugGRZs]*)'
# shellcheck disable=SC2254
case $prev in
--comment | --home | --expiredate | --inactive | --help | --login | \
--password | --uid | -${noargopts}[cdefhlpu])
return
;;
--gid | -${noargopts}g)
_comp_compgen_gids
_comp_compgen -a -- -g
return
;;
--groups | -${noargopts}G)
_comp_delimited , -g
return
;;
--root | -${noargopts}R)
_comp_compgen_filedir -d
return
;;
--selinux-user | -${noargopts}Z)
_comp_compgen_selinux_users
return
;;
--shell | -${noargopts}s)
_comp_compgen_shells "${chroot-}"
return
;;
esac
[[ $was_split ]] && return
if [[ $cur == -* ]]; then
# TODO: -U/--unlock, -p/--password, -L/--lock mutually exclusive
_comp_compgen_help
return
fi
_comp_compgen -- -u
} &&
complete -F _comp_cmd_usermod usermod
# ex: filetype=sh
|