summaryrefslogtreecommitdiff
path: root/Completion/Unix/Command/_user_admin
diff options
context:
space:
mode:
authorOliver Kiddle <opk@users.sourceforge.net>2001-08-06 14:42:02 +0000
committerOliver Kiddle <opk@users.sourceforge.net>2001-08-06 14:42:02 +0000
commit68a8685146f824bea4698cfb9110c26a771ac3e8 (patch)
tree8402978e6ca9f514e75cd73bde862512c8f99125 /Completion/Unix/Command/_user_admin
parent0c3f0b47bff6279c8601f3313144db6d2d1ee980 (diff)
downloadzsh-68a8685146f824bea4698cfb9110c26a771ac3e8.tar.gz
zsh-68a8685146f824bea4698cfb9110c26a771ac3e8.zip
share descriptions for long/short opts in more completions and other changes
Diffstat (limited to 'Completion/Unix/Command/_user_admin')
-rw-r--r--Completion/Unix/Command/_user_admin67
1 files changed, 67 insertions, 0 deletions
diff --git a/Completion/Unix/Command/_user_admin b/Completion/Unix/Command/_user_admin
new file mode 100644
index 000000000..831f365b8
--- /dev/null
+++ b/Completion/Unix/Command/_user_admin
@@ -0,0 +1,67 @@
+#compdef useradd usermod groupadd groupmod
+
+local args shells home=${${words[(r)-D]:+b}:-d} sun=" -s"
+
+if [[ $service = user* ]]; then
+ if [[ -r /etc/shells ]]; then
+ shells=( $(</etc/shells) )
+ else
+ shells=( ${(M)commands:#*/(|[abckz]|tc|ba)sh} )
+ fi
+
+ args=(
+ '(-D)-c+[comment]:comment'
+ "(-D)-${home}+[home directory]:home directory:_directories -W /"
+ '(-D)-e+[specify expriration date]:expiration date (YYYY-MM-DD)'
+ '(-D)-f+[specify inactive days]:inactive days'
+ '(-D)-g+[initial group]:initial group:_groups'
+ '(-D)-G+[supplementary groups]:supplementary groups:_groups -S,'
+ "(-D)-s+[shell]:shell:( $shells /dev/null )"
+ '(-D)-m[create home directory]'
+ '(-D)-u[uid]:uid'
+ '(-D)-o[allow non unique uid]'
+ )
+ [[ $OSTYPE = linux* ]] && args=( $args[@]
+ '(-D)-p+[specify encrypted password]:encrypted password' )
+
+ if [[ $service = useradd ]]; then
+ if [[ $OSTYPE = linux* ]]; then
+ args=( $args[@]
+ "(-D -k)-M[don't create home]"
+ '(-D)-r[create system account]'
+ "(-D)-n[don't create mirrored user]"
+ )
+ unset sun
+ fi
+ args=( $args[@]
+ "(-c -G -m -k -M -p -u -o -n -r$sun)-D[modify or display defaults]"
+ '(-D -M)-k[skeleton home directory]:skeleton directory:_directories -W /'
+ ':username'
+ )
+ else
+ [[ $OSTYPE = linux* ]] && args=( $args[@]
+ "(-U)-L[lock user's password]"
+ "(-L)-U[unlock user's password]"
+ )
+ args=( $args[@]
+ '-l[specify new user name]:new username'
+ ':username:_users'
+ )
+ fi
+else
+ args=( '-g+[gid]:gid' '-o[allow non unique gid]' )
+ if [[ $service = groupadd ]]; then
+ args=( $args[@] ':group name' )
+ [[ $OSTYPE = linux* ]] && args=( $args[@]
+ '-r[create system group]'
+ '-f[force]'
+ )
+ else
+ args=( $args[@]
+ '-n[specify new group name]:new group name'
+ ':group name:_groups'
+ )
+ fi
+fi
+
+_arguments -A "-*" -s $args[@]