X-Git-Url: http://erislabs.net/gitweb/?a=blobdiff_plain;f=lib%2Fgetugroups.c;h=afa425b6e53c43c5ad3946dc9f5ff9801648152d;hb=refs%2Ftags%2FFILEUTILS-3_16x;hp=98e752609bfb93a4a7d5d6f36acd983e9bbdbd41;hpb=7ab769f3a7d85d18d17d4e779430fa56b6e17a18;p=gnulib.git diff --git a/lib/getugroups.c b/lib/getugroups.c index 98e752609..afa425b6e 100644 --- a/lib/getugroups.c +++ b/lib/getugroups.c @@ -1,5 +1,5 @@ /* getugroups.c -- return a list of the groups a user is in - Copyright (C) 1990, 1991 Free Software Foundation. + Copyright (C) 1990, 1991, 1998 Free Software Foundation. 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 @@ -12,13 +12,13 @@ GNU General Public License for more details. You should have received a copy of the GNU General Public License - along with this program; if not, write to the Free Software - Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. */ + along with this program; if not, write to the Free Software Foundation, + Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. */ /* Written by David MacKenzie. */ #ifdef HAVE_CONFIG_H -#include +# include #endif #include @@ -26,7 +26,7 @@ #include #ifdef HAVE_UNISTD_H -#include +# include #endif /* setgrent, getgrent, and endgrent are not specified by POSIX.1, @@ -36,19 +36,16 @@ struct group *getgrent (); #if defined(STDC_HEADERS) || defined(HAVE_STRING_H) -#include +# include #else -#include +# include #endif /* Like `getgroups', but for user USERNAME instead of for the current process. */ int -getugroups (maxcount, grouplist, username) - int maxcount; - GETGROUPS_T *grouplist; - char *username; +getugroups (int maxcount, GETGROUPS_T *grouplist, char *username) { struct group *grp; register char **cp; @@ -59,16 +56,27 @@ getugroups (maxcount, grouplist, username) for (cp = grp->gr_mem; *cp; ++cp) if (!strcmp (username, *cp)) { - if (maxcount != 0) + int n; + + /* See if this group number is already on the list. */ + for (n = 0; n < count; ++n) + if (grouplist[n] == grp->gr_gid) + break; + + /* If it's a new group number, then try to add it to the list. */ + if (n == count) { - if (count >= maxcount) + if (maxcount != 0) { - endgrent (); - return count; + if (count >= maxcount) + { + endgrent (); + return count; + } + grouplist[count] = grp->gr_gid; } - grouplist[count] = grp->gr_gid; + count++; } - count++; } endgrent (); return count;