diff options
author | Eric Andersen | 2000-12-13 01:52:39 +0000 |
---|---|---|
committer | Eric Andersen | 2000-12-13 01:52:39 +0000 |
commit | bd193a42a5624f0a72b5f99d554e9a8d2afc64cc (patch) | |
tree | 7aacebe98730fbfee623943425a100fd158ba48a | |
parent | 77508b29fa63d99136fc09f00c5a2addd6331b4c (diff) | |
download | busybox-bd193a42a5624f0a72b5f99d554e9a8d2afc64cc.zip busybox-bd193a42a5624f0a72b5f99d554e9a8d2afc64cc.tar.gz |
Fix from Matt Kraai -- a better way to NULL terminate strings for the
my_* passwd and group routines. I should have thought of doing it
this way...
-rw-r--r-- | archival/tar.c | 2 | ||||
-rw-r--r-- | coreutils/id.c | 12 | ||||
-rw-r--r-- | coreutils/logname.c | 4 | ||||
-rw-r--r-- | coreutils/ls.c | 2 | ||||
-rw-r--r-- | coreutils/whoami.c | 4 | ||||
-rw-r--r-- | id.c | 12 | ||||
-rw-r--r-- | logname.c | 4 | ||||
-rw-r--r-- | ls.c | 2 | ||||
-rw-r--r-- | procps/ps.c | 13 | ||||
-rw-r--r-- | ps.c | 13 | ||||
-rw-r--r-- | tar.c | 2 | ||||
-rw-r--r-- | utility.c | 2 | ||||
-rw-r--r-- | whoami.c | 4 |
13 files changed, 26 insertions, 50 deletions
diff --git a/archival/tar.c b/archival/tar.c index 8c2650e..3a3b7f1 100644 --- a/archival/tar.c +++ b/archival/tar.c @@ -691,13 +691,11 @@ extern int readTarFile(int tarFd, int extractFlag, int listFlag, struct tm *tm = localtime (&(header.mtime)); len=printf("%s ", mode_string(header.mode)); - memset(buf, 0, 8*sizeof(char)); my_getpwuid(buf, header.uid); if (! *buf) len+=printf("%d", header.uid); else len+=printf("%s", buf); - memset(buf, 0, 8*sizeof(char)); my_getgrgid(buf, header.gid); if (! *buf) len+=printf("/%-d ", header.gid); diff --git a/coreutils/id.c b/coreutils/id.c index 86667f5..3a8e77a 100644 --- a/coreutils/id.c +++ b/coreutils/id.c @@ -31,12 +31,11 @@ extern int id_main(int argc, char **argv) { int no_user = 0, no_group = 0, print_real = 0; - char *cp, *user, *group; + char user[9], group[9]; long gid; long pwnam, grnam; int opt; - cp = user = group = NULL; gid = 0; while ((opt = getopt(argc, argv, "ugr")) > 0) { @@ -57,11 +56,7 @@ extern int id_main(int argc, char **argv) if (no_user && no_group) usage(id_usage); - user = argv[optind]; - - if (user == NULL) { - user = xcalloc(9, sizeof(char)); - group = xcalloc(9, sizeof(char)); + if (argv[optind] == NULL) { if (print_real) { my_getpwuid(user, getuid()); my_getgrgid(group, getgid()); @@ -70,7 +65,8 @@ extern int id_main(int argc, char **argv) my_getgrgid(group, getegid()); } } else { - group = xcalloc(9, sizeof(char)); + strncpy(user, argv[optind], 8); + user[8] = '\0'; gid = my_getpwnamegid(user); my_getgrgid(group, gid); } diff --git a/coreutils/logname.c b/coreutils/logname.c index 1fc518b..d614e85 100644 --- a/coreutils/logname.c +++ b/coreutils/logname.c @@ -25,13 +25,13 @@ extern int logname_main(int argc, char **argv) { - char *user = xmalloc(9); + char user[9]; if (argc > 1) usage(logname_usage); my_getpwuid(user, geteuid()); - if (user) { + if (*user) { puts(user); return EXIT_SUCCESS; } diff --git a/coreutils/ls.c b/coreutils/ls.c index 94c73b3..655dd7f 100644 --- a/coreutils/ls.c +++ b/coreutils/ls.c @@ -600,13 +600,11 @@ int list_single(struct dnode *dn) break; case LIST_ID_NAME: #ifdef BB_FEATURE_LS_USERNAME - memset(scratch, 0, sizeof(scratch)); my_getpwuid(scratch, dn->dstat.st_uid); if (*scratch) fprintf(stdout, "%-8.8s ", scratch); else fprintf(stdout, "%-8d ", dn->dstat.st_uid); - memset(scratch, 0, sizeof(scratch)); my_getgrgid(scratch, dn->dstat.st_gid); if (*scratch) fprintf(stdout, "%-8.8s", scratch); diff --git a/coreutils/whoami.c b/coreutils/whoami.c index 6a5dd2c..38a2b30 100644 --- a/coreutils/whoami.c +++ b/coreutils/whoami.c @@ -26,14 +26,14 @@ extern int whoami_main(int argc, char **argv) { - char *user = xmalloc(9); + char user[9]; uid_t uid = geteuid(); if (argc > 1) usage(whoami_usage); my_getpwuid(user, uid); - if (user) { + if (*user) { puts(user); return EXIT_SUCCESS; } @@ -31,12 +31,11 @@ extern int id_main(int argc, char **argv) { int no_user = 0, no_group = 0, print_real = 0; - char *cp, *user, *group; + char user[9], group[9]; long gid; long pwnam, grnam; int opt; - cp = user = group = NULL; gid = 0; while ((opt = getopt(argc, argv, "ugr")) > 0) { @@ -57,11 +56,7 @@ extern int id_main(int argc, char **argv) if (no_user && no_group) usage(id_usage); - user = argv[optind]; - - if (user == NULL) { - user = xcalloc(9, sizeof(char)); - group = xcalloc(9, sizeof(char)); + if (argv[optind] == NULL) { if (print_real) { my_getpwuid(user, getuid()); my_getgrgid(group, getgid()); @@ -70,7 +65,8 @@ extern int id_main(int argc, char **argv) my_getgrgid(group, getegid()); } } else { - group = xcalloc(9, sizeof(char)); + strncpy(user, argv[optind], 8); + user[8] = '\0'; gid = my_getpwnamegid(user); my_getgrgid(group, gid); } @@ -25,13 +25,13 @@ extern int logname_main(int argc, char **argv) { - char *user = xmalloc(9); + char user[9]; if (argc > 1) usage(logname_usage); my_getpwuid(user, geteuid()); - if (user) { + if (*user) { puts(user); return EXIT_SUCCESS; } @@ -600,13 +600,11 @@ int list_single(struct dnode *dn) break; case LIST_ID_NAME: #ifdef BB_FEATURE_LS_USERNAME - memset(scratch, 0, sizeof(scratch)); my_getpwuid(scratch, dn->dstat.st_uid); if (*scratch) fprintf(stdout, "%-8.8s ", scratch); else fprintf(stdout, "%-8d ", dn->dstat.st_uid); - memset(scratch, 0, sizeof(scratch)); my_getgrgid(scratch, dn->dstat.st_gid); if (*scratch) fprintf(stdout, "%-8.8s", scratch); diff --git a/procps/ps.c b/procps/ps.c index 79910fe..357ece3 100644 --- a/procps/ps.c +++ b/procps/ps.c @@ -121,8 +121,8 @@ extern int ps_main(int argc, char **argv) FILE *file; struct dirent *entry; char path[32], sbuf[512]; - char uidName[10] = ""; - char groupName[10] = ""; + char uidName[9]; + char groupName[9]; int len, i, c; #ifdef BB_FEATURE_AUTOWIDTH struct winsize win = { 0, 0, 0, 0 }; @@ -146,9 +146,6 @@ extern int ps_main(int argc, char **argv) fprintf(stdout, "%5s %-8s %-3s %5s %s\n", "PID", "Uid", "Gid", "State", "Command"); while ((entry = readdir(dir)) != NULL) { - uidName[0] = '\0'; - groupName[0] = '\0'; - if (!isdigit(*entry->d_name)) continue; sprintf(path, "/proc/%s/status", entry->d_name); @@ -204,8 +201,8 @@ extern int ps_main(int argc, char **argv) pid_t num_pids; pid_t* pid_array = NULL; struct pid_info info; - char uidName[10] = ""; - char groupName[10] = ""; + char uidName[9]; + char groupName[9]; #ifdef BB_FEATURE_AUTOWIDTH struct winsize win = { 0, 0, 0, 0 }; int terminal_width = TERMINAL_WIDTH; @@ -247,8 +244,6 @@ extern int ps_main(int argc, char **argv) "State", "Command"); for (i=1; i<pid_array[0] ; i++) { - uidName[0] = '\0'; - groupName[0] = '\0'; info.pid = pid_array[i]; if (ioctl (fd, DEVPS_GET_PID_INFO, &info)<0) @@ -121,8 +121,8 @@ extern int ps_main(int argc, char **argv) FILE *file; struct dirent *entry; char path[32], sbuf[512]; - char uidName[10] = ""; - char groupName[10] = ""; + char uidName[9]; + char groupName[9]; int len, i, c; #ifdef BB_FEATURE_AUTOWIDTH struct winsize win = { 0, 0, 0, 0 }; @@ -146,9 +146,6 @@ extern int ps_main(int argc, char **argv) fprintf(stdout, "%5s %-8s %-3s %5s %s\n", "PID", "Uid", "Gid", "State", "Command"); while ((entry = readdir(dir)) != NULL) { - uidName[0] = '\0'; - groupName[0] = '\0'; - if (!isdigit(*entry->d_name)) continue; sprintf(path, "/proc/%s/status", entry->d_name); @@ -204,8 +201,8 @@ extern int ps_main(int argc, char **argv) pid_t num_pids; pid_t* pid_array = NULL; struct pid_info info; - char uidName[10] = ""; - char groupName[10] = ""; + char uidName[9]; + char groupName[9]; #ifdef BB_FEATURE_AUTOWIDTH struct winsize win = { 0, 0, 0, 0 }; int terminal_width = TERMINAL_WIDTH; @@ -247,8 +244,6 @@ extern int ps_main(int argc, char **argv) "State", "Command"); for (i=1; i<pid_array[0] ; i++) { - uidName[0] = '\0'; - groupName[0] = '\0'; info.pid = pid_array[i]; if (ioctl (fd, DEVPS_GET_PID_INFO, &info)<0) @@ -691,13 +691,11 @@ extern int readTarFile(int tarFd, int extractFlag, int listFlag, struct tm *tm = localtime (&(header.mtime)); len=printf("%s ", mode_string(header.mode)); - memset(buf, 0, 8*sizeof(char)); my_getpwuid(buf, header.uid); if (! *buf) len+=printf("%d", header.uid); else len+=printf("%s", buf); - memset(buf, 0, 8*sizeof(char)); my_getgrgid(buf, header.gid); if (! *buf) len+=printf("/%-d ", header.gid); @@ -957,12 +957,14 @@ long my_getgrnam(char *name) /* gets a username given a uid */ void my_getpwuid(char *name, long uid) { + name[0] = '\0'; my_getid("/etc/passwd", name, uid, NULL); } /* gets a groupname given a gid */ void my_getgrgid(char *group, long gid) { + group[0] = '\0'; my_getid("/etc/group", group, gid, NULL); } @@ -26,14 +26,14 @@ extern int whoami_main(int argc, char **argv) { - char *user = xmalloc(9); + char user[9]; uid_t uid = geteuid(); if (argc > 1) usage(whoami_usage); my_getpwuid(user, uid); - if (user) { + if (*user) { puts(user); return EXIT_SUCCESS; } |