aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorDenis Vlasenko <vda.linux@googlemail.com>2006-09-26 16:31:01 +0000
committerDenis Vlasenko <vda.linux@googlemail.com>2006-09-26 16:31:01 +0000
commit22f6dcb47c32909ca0a3d720b11df5ea86b1e76c (patch)
tree52fa81231c3fafd4ddfb1eecb9d4a62ad5401908
parent8b8c75e6abc9283cbdbe6a76e0c4db6098f73ed8 (diff)
downloadbusybox-22f6dcb47c32909ca0a3d720b11df5ea86b1e76c.tar.gz
login: fix getopt_ulflags fallout (wasn't taking username supplied by getty)
-rw-r--r--loginutils/login.c6
1 files changed, 3 insertions, 3 deletions
diff --git a/loginutils/login.c b/loginutils/login.c
index 0157bace8..1b13fa0cc 100644
--- a/loginutils/login.c
+++ b/loginutils/login.c
@@ -235,13 +235,13 @@ int login_main(int argc, char **argv)
alarm(TIMEOUT);
opt = bb_getopt_ulflags(argc, argv, "f:h:p", &opt_user, &opt_host);
-
if (opt & LOGIN_OPT_f) {
if (!amroot)
bb_error_msg_and_die("-f is for root only");
- safe_strncpy(username, opt_user, strlen(opt_user));
+ safe_strncpy(username, opt_user, sizeof(username));
}
- username[USERNAME_SIZE] = 0;
+ if (optind < argc) /* user from command line (getty) */
+ safe_strncpy(username, argv[optind], sizeof(username));
/* Let's find out and memorize our tty */
if (!isatty(0) || !isatty(1) || !isatty(2))