X-Git-Url: http://erislabs.net/gitweb/?a=blobdiff_plain;f=lib%2Fgetugroups.c;h=6fad8b7b530989aafafe4b695895c60879889375;hb=310f220f3dc11206e8c8374c2350d8e5f74c8427;hp=d76517cfc6ab8eec1faa1f27c2f97cff4a188ad6;hpb=b7b9b901fe19fc9817675762ee1318b9fe78484e;p=gnulib.git diff --git a/lib/getugroups.c b/lib/getugroups.c index d76517cfc..6fad8b7b5 100644 --- a/lib/getugroups.c +++ b/lib/getugroups.c @@ -41,8 +41,12 @@ struct group *getgrent (); # include #endif -/* Like `getgroups', but for user USERNAME instead of for - the current process. */ +/* 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 + group ID (pw_gid) obtained from getpwuid, in case USERNAME is not + listed in /etc/groups. + Always return the number of groups of which USERNAME is a member. */ int getugroups (int maxcount, GETGROUPS_T *grouplist, char *username, gid_t gid) @@ -51,8 +55,12 @@ getugroups (int maxcount, GETGROUPS_T *grouplist, char *username, gid_t gid) register char **cp; register int count = 0; - if (maxcount != 0) - grouplist[count++] = gid; + if (gid != -1) + { + if (maxcount != 0) + grouplist[count] = gid; + ++count; + } setgrent (); while ((grp = getgrent ()) != 0)