diff options
| author | Denis Vlasenko <vda.linux@googlemail.com> | 2006-09-26 16:31:01 +0000 |
|---|---|---|
| committer | Denis Vlasenko <vda.linux@googlemail.com> | 2006-09-26 16:31:01 +0000 |
| commit | 22f6dcb47c32909ca0a3d720b11df5ea86b1e76c (patch) | |
| tree | 52fa81231c3fafd4ddfb1eecb9d4a62ad5401908 | |
| parent | 8b8c75e6abc9283cbdbe6a76e0c4db6098f73ed8 (diff) | |
| download | busybox-w32-22f6dcb47c32909ca0a3d720b11df5ea86b1e76c.tar.gz busybox-w32-22f6dcb47c32909ca0a3d720b11df5ea86b1e76c.tar.bz2 busybox-w32-22f6dcb47c32909ca0a3d720b11df5ea86b1e76c.zip | |
login: fix getopt_ulflags fallout (wasn't taking username supplied by getty)
| -rw-r--r-- | loginutils/login.c | 6 |
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) | |||
| 235 | alarm(TIMEOUT); | 235 | alarm(TIMEOUT); |
| 236 | 236 | ||
| 237 | opt = bb_getopt_ulflags(argc, argv, "f:h:p", &opt_user, &opt_host); | 237 | opt = bb_getopt_ulflags(argc, argv, "f:h:p", &opt_user, &opt_host); |
| 238 | |||
| 239 | if (opt & LOGIN_OPT_f) { | 238 | if (opt & LOGIN_OPT_f) { |
| 240 | if (!amroot) | 239 | if (!amroot) |
| 241 | bb_error_msg_and_die("-f is for root only"); | 240 | bb_error_msg_and_die("-f is for root only"); |
| 242 | safe_strncpy(username, opt_user, strlen(opt_user)); | 241 | safe_strncpy(username, opt_user, sizeof(username)); |
| 243 | } | 242 | } |
| 244 | username[USERNAME_SIZE] = 0; | 243 | if (optind < argc) /* user from command line (getty) */ |
| 244 | safe_strncpy(username, argv[optind], sizeof(username)); | ||
| 245 | 245 | ||
| 246 | /* Let's find out and memorize our tty */ | 246 | /* Let's find out and memorize our tty */ |
| 247 | if (!isatty(0) || !isatty(1) || !isatty(2)) | 247 | if (!isatty(0) || !isatty(1) || !isatty(2)) |
