summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJim Meyering <jim@meyering.net>1999-05-15 04:50:26 +0000
committerJim Meyering <jim@meyering.net>1999-05-15 04:50:26 +0000
commit634a39aad5803aced2559829b7f3dd24482f91a9 (patch)
tree23b5a168a5728d2a6e80c7c1451e12e1e63b22ae
parent7af9c3c085e1391b02fdca3f0e3a72001ec8f9ce (diff)
downloadcoreutils-634a39aad5803aced2559829b7f3dd24482f91a9.tar.xz
(getugroups): Don't dereference a null pointer when
running `id USER' for some USER that is listed on the RHS in /etc/group. From Sander van Malssen. Add some curly braces, use STREQ, reverse the sense of a test and use `continue' to save a level of nesting.
-rw-r--r--lib/getugroups.c13
1 files changed, 10 insertions, 3 deletions
diff --git a/lib/getugroups.c b/lib/getugroups.c
index 6fad8b7b5..44aeb809c 100644
--- a/lib/getugroups.c
+++ b/lib/getugroups.c
@@ -41,6 +41,8 @@ struct group *getgrent ();
# include <strings.h>
#endif
+#define STREQ(s1, s2) ((strcmp (s1, s2) == 0))
+
/* Like `getgroups', but for user USERNAME instead of for the current
process. Store at most MAXCOUNT group IDs in the GROUPLIST array.
If GID is not -1, store it first (if possible). GID should be the
@@ -64,14 +66,17 @@ getugroups (int maxcount, GETGROUPS_T *grouplist, char *username, gid_t gid)
setgrent ();
while ((grp = getgrent ()) != 0)
- for (cp = grp->gr_mem; *cp; ++cp)
- if (!strcmp (username, *cp))
+ {
+ for (cp = grp->gr_mem; *cp; ++cp)
{
int n;
+ if ( ! STREQ (username, *cp))
+ continue;
+
/* See if this group number is already on the list. */
for (n = 0; n < count; ++n)
- if (grouplist[n] == grp->gr_gid)
+ if (grouplist && grouplist[n] == grp->gr_gid)
break;
/* If it's a new group number, then try to add it to the list. */
@@ -89,6 +94,8 @@ getugroups (int maxcount, GETGROUPS_T *grouplist, char *username, gid_t gid)
count++;
}
}
+ }
endgrent ();
+
return count;
}