X-Git-Url: http://erislabs.net/gitweb/?a=blobdiff_plain;f=lib%2Fgetgroups.c;h=0f951b73baa61fcdfa6c71dcd5b398d838898a13;hb=9db47123ce74651bda88707c3f67441622aae399;hp=0ffe711f583ab1ee0243cf3aed9ff146ec11d7e8;hpb=d349992d82f97d614404565ff66e3f8a47b4a568;p=gnulib.git diff --git a/lib/getgroups.c b/lib/getgroups.c index 0ffe711f5..0f951b73b 100644 --- a/lib/getgroups.c +++ b/lib/getgroups.c @@ -1,5 +1,5 @@ /* provide consistent interface to getgroups for systems that don't allow N==0 - Copyright (C) 1996, 1999, 2000 Free Software Foundation, Inc. + Copyright (C) 1996, 1999, 2003 Free Software Foundation, Inc. This program is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by @@ -20,8 +20,10 @@ #include #include #include +#include +#include -char *xmalloc (); +#include "xalloc.h" /* 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 @@ -29,10 +31,11 @@ char *xmalloc (); provided function handle all others. */ int -getgroups (size_t n, GETGROUPS_T *group) +getgroups (int n, GETGROUPS_T *group) { int n_groups; GETGROUPS_T *gbuf; + int saved_errno; #undef getgroups @@ -40,17 +43,22 @@ getgroups (size_t n, GETGROUPS_T *group) return getgroups (n, group); n = 20; - gbuf = NULL; while (1) { - gbuf = (GETGROUPS_T *) xrealloc (gbuf, n * sizeof (GETGROUPS_T)); + /* No need to worry about address arithmetic overflow here, + since the ancient systems that we're running on have low + limits on the number of secondary groups. */ + gbuf = xmalloc (n * sizeof *gbuf); n_groups = getgroups (n, gbuf); if (n_groups < n) break; + free (gbuf); n += 10; } + saved_errno = errno; free (gbuf); + errno = saved_errno; return n_groups; }