aboutsummaryrefslogtreecommitdiff
path: root/loginutils
diff options
context:
space:
mode:
authorDenis Vlasenko <vda.linux@googlemail.com>2008-02-15 15:17:23 +0000
committerDenis Vlasenko <vda.linux@googlemail.com>2008-02-15 15:17:23 +0000
commit753f42ab8d50f92e36d3b06a2a47630bed69f257 (patch)
treef79be7056a4e5ddc0066bffd5daab406d961175e /loginutils
parent0e6f661e23d358cca104c24f8438d0ec64df32f1 (diff)
downloadbusybox-753f42ab8d50f92e36d3b06a2a47630bed69f257.tar.gz
adduser: optional support for long options. +110 bytes.
closes bug 2134.
Diffstat (limited to 'loginutils')
-rw-r--r--loginutils/Config.in7
-rw-r--r--loginutils/adduser.c17
2 files changed, 24 insertions, 0 deletions
diff --git a/loginutils/Config.in b/loginutils/Config.in
index 6f2702e95..6ee154c61 100644
--- a/loginutils/Config.in
+++ b/loginutils/Config.in
@@ -88,6 +88,13 @@ config ADDUSER
help
Utility for creating a new user account.
+config FEATURE_ADDUSER_LONG_OPTIONS
+ bool "Enable long options"
+ default n
+ depends on ADDUSER && GETOPT_LONG
+ help
+ Support long options for the adduser applet.
+
config DELUSER
bool "deluser"
default n
diff --git a/loginutils/adduser.c b/loginutils/adduser.c
index a859f4b0c..7b5283e99 100644
--- a/loginutils/adduser.c
+++ b/loginutils/adduser.c
@@ -66,6 +66,19 @@ static void passwd_wrapper(const char *login)
bb_error_msg_and_die("cannot execute %s, you must set password manually", prog);
}
+#if ENABLE_FEATURE_ADDUSER_LONG_OPTIONS
+static const char adduser_longopts[] ALIGN1 =
+ "home\0" Required_argument "h"
+ "gecos\0" Required_argument "g"
+ "shell\0" Required_argument "s"
+ "ingroup\0" Required_argument "G"
+ "disabled-password\0" No_argument "D"
+ "empty-password\0" No_argument "D"
+ "system\0" No_argument "S"
+ "no-create-home\0" No_argument "H"
+ ;
+#endif
+
/*
* adduser will take a login_name as its first parameter.
* home, shell, gecos:
@@ -78,6 +91,10 @@ int adduser_main(int argc, char **argv)
const char *usegroup = NULL;
FILE *file;
+#if ENABLE_FEATURE_ADDUSER_LONG_OPTIONS
+ applet_long_options = adduser_longopts;
+#endif
+
/* got root? */
if (geteuid()) {
bb_error_msg_and_die(bb_msg_perm_denied_are_you_root);