diff options
author | Roland McGrath <roland@gnu.org> | 1999-06-23 06:29:18 +0000 |
---|---|---|
committer | Roland McGrath <roland@gnu.org> | 1999-06-23 06:29:18 +0000 |
commit | e650f3b18d86b0787a66e199cd6a91e28f494c6a (patch) | |
tree | adace169163d12938b8df3c3207a95fa69c06f17 /utils/login.c | |
parent | 1482909b6348a6eb3ca70de5be6530b31be519be (diff) |
1999-06-21 Roland McGrath <roland@baalperazim.frob.com>
* login.c (main): For no-uids shell, default SH_ARG0 to informative
value. Use asprintf to construct it.
Diffstat (limited to 'utils/login.c')
-rw-r--r-- | utils/login.c | 25 |
1 files changed, 12 insertions, 13 deletions
diff --git a/utils/login.c b/utils/login.c index 096aaeeb..ddcbadf9 100644 --- a/utils/login.c +++ b/utils/login.c @@ -585,8 +585,8 @@ main(int argc, char *argv[]) /* Check passwords where necessary. If no_passwd is set, then our parent guarantees identity itself (where it is allowed), but otherwise we want every UID fully checked. */ - err = ugids_verify_make_auth (&ugids, - no_passwd ? &parent_uids : 0, + err = ugids_verify_make_auth (&ugids, + no_passwd ? &parent_uids : 0, no_passwd ? &parent_gids : 0, 0, 0, 0, 0, &auth); if (err == EACCES) @@ -818,18 +818,17 @@ main(int argc, char *argv[]) if (no_login) sh_arg0 = shell_base; + else if (ugids.eff_uids.num + ugids.avail_uids.num == 0) + /* Use a special format for the argv[0] of a login prompt shell, + so that `ps' shows something informative in the COMMAND field. + This string must begin with a `-', the convention to tell the + shell to be a login shell (i.e. run .profile and the like). */ + err = (asprintf (&sh_arg0, "-login prompt (%s)", shell_base) == -1 + ? ENOMEM : 0); else - { - sh_arg0 = malloc (strlen (shell_base) + 2); - if (! sh_arg0) - err = ENOMEM; - else - /* Prepend the name with a `-', as is the odd custom. */ - { - sh_arg0[0] = '-'; - strcpy (sh_arg0 + 1, shell_base); - } - } + /* Prepend a `-' to the name, which is the ancient canonical + way to tell the shell that it's a login shell. */ + err = asprintf (&sh_arg0, "-%s", shell_base) == -1 ? ENOMEM : 0; } if (! err) err = argz_insert (&sh_args, &sh_args_len, sh_args, sh_arg0); |