X-Git-Url: http://erislabs.net/gitweb/?a=blobdiff_plain;f=lib%2Fgetgroups.c;h=a72bddb5c9c76b215e9fec37275e735bc18b00a5;hb=f755ca1568887fb854b2362855096cb9ff3f3e00;hp=717f90e4acc6049623302d84fc5c01b81efb4b13;hpb=4dc7e74d299f19bce7337f1c7dfda7d455a77c19;p=gnulib.git diff --git a/lib/getgroups.c b/lib/getgroups.c index 717f90e4a..a72bddb5c 100644 --- a/lib/getgroups.c +++ b/lib/getgroups.c @@ -23,7 +23,9 @@ char *xmalloc (); -/* On Ultrix 4.3, getgroups (0, 0) always fails. +/* On at least Ultrix 4.3 and NextStep 3.2, getgroups (0, 0) always fails. + On other systems, it returns the number of supplemental groups for the + process is returned. This function handles that special case and lets the system- provided function handle all others. */ @@ -32,7 +34,7 @@ getgroups (n, group) size_t n; GETGROUPS_T *group; { - int ng; + int n_groups; GETGROUPS_T *gbuf; #undef getgroups @@ -45,13 +47,13 @@ getgroups (n, group) while (1) { gbuf = (GETGROUPS_T *) xrealloc (gbuf, n * sizeof (GETGROUPS_T)); - ng = getgroups (n, gbuf); - if (ng < n) + n_groups = getgroups (n, gbuf); + if (n_groups < n) break; n += 10; } free (gbuf); - return ng; + return n_groups; }