X-Git-Url: https://git.librecmc.org/?a=blobdiff_plain;f=id.c;h=85b288c0c2dc53d1717c2c9615450eac1099c694;hb=51ded05b3bf4df6f126420d39a40d27ea0728aa9;hp=3a8e77a1f0be0cfbdd9f5e746ad07e68812fa54f;hpb=bd193a42a5624f0a72b5f99d554e9a8d2afc64cc;p=oweals%2Fbusybox.git diff --git a/id.c b/id.c index 3a8e77a1f..85b288c0c 100644 --- a/id.c +++ b/id.c @@ -23,14 +23,14 @@ #include "busybox.h" #include #include -#include -#include #include +#include #include extern int id_main(int argc, char **argv) { int no_user = 0, no_group = 0, print_real = 0; + int name_not_number = 0; char user[9], group[9]; long gid; long pwnam, grnam; @@ -38,7 +38,7 @@ extern int id_main(int argc, char **argv) gid = 0; - while ((opt = getopt(argc, argv, "ugr")) > 0) { + while ((opt = getopt(argc, argv, "ugrn")) > 0) { switch (opt) { case 'u': no_group++; @@ -49,12 +49,15 @@ extern int id_main(int argc, char **argv) case 'r': print_real++; break; + case 'n': + name_not_number++; + break; default: - usage(id_usage); + show_usage(); } } - if (no_user && no_group) usage(id_usage); + if (no_user && no_group) show_usage(); if (argv[optind] == NULL) { if (print_real) { @@ -73,15 +76,20 @@ extern int id_main(int argc, char **argv) pwnam=my_getpwnam(user); grnam=my_getgrnam(group); - if (gid == -1 || pwnam==-1 || grnam==-1) { - error_msg_and_die("%s: No such user\n", user); - } - if (no_group) - printf("%ld\n", pwnam); - else if (no_user) - printf("%ld\n", grnam); - else + + if (no_group) { + if(name_not_number && user) + puts(user); + else + printf("%ld\n", pwnam); + } else if (no_user) { + if(name_not_number && group) + puts(group); + else + printf("%ld\n", grnam); + } else { printf("uid=%ld(%s) gid=%ld(%s)\n", pwnam, user, grnam, group); + } return(0); }