X-Git-Url: http://erislabs.net/gitweb/?a=blobdiff_plain;f=lib%2Fidcache.c;h=82dec8d90c1e2477c6f69de6e15ddc0fffb6fe8f;hb=794b55ff3dcebba4518b555161f97ef6524a7270;hp=c00ee869ded1696f511d764136f40df1511dbf71;hpb=87735e126a0c79f3f43d0830c5c400c2ff3f4c5a;p=gnulib.git diff --git a/lib/idcache.c b/lib/idcache.c index c00ee869d..82dec8d90 100644 --- a/lib/idcache.c +++ b/lib/idcache.c @@ -1,5 +1,7 @@ /* idcache.c -- map user and group IDs, cached for speed - Copyright (C) 1985, 1988, 1989, 1990, 1997, 1998 Free Software Foundation, Inc. + + Copyright (C) 1985, 1988, 1989, 1990, 1997, 1998, 2003, 2005 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 @@ -13,36 +15,27 @@ 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. */ + Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. */ #if HAVE_CONFIG_H # include #endif #include +#include #include #include #include -#if STDC_HEADERS || HAVE_STRING_H -# include -#else -# include -#endif - #if HAVE_UNISTD_H # include #endif -#ifndef _POSIX_VERSION -struct passwd *getpwuid (); -struct passwd *getpwnam (); -struct group *getgrgid (); -struct group *getgrnam (); -#endif +#include "xalloc.h" -char *xmalloc (); -char *xstrdup (); +#ifdef __DJGPP__ +static char digits[] = "0123456789"; +#endif struct userid { @@ -73,7 +66,7 @@ getuser (uid_t uid) return tail->name; pwent = getpwuid (uid); - tail = (struct userid *) xmalloc (sizeof (struct userid)); + tail = xmalloc (sizeof *tail); tail->id.u = uid; tail->name = pwent ? xstrdup (pwent->pw_name) : NULL; @@ -105,8 +98,17 @@ getuidbyname (const char *user) return 0; pwent = getpwnam (user); +#ifdef __DJGPP__ + /* We need to pretend to be the user USER, to make + pwd functions know about an arbitrary user name. */ + if (!pwent && strspn (user, digits) < strlen (user)) + { + setenv ("USER", user, 1); + pwent = getpwnam (user); /* now it will succeed */ + } +#endif - tail = (struct userid *) xmalloc (sizeof (struct userid)); + tail = xmalloc (sizeof *tail); tail->name = xstrdup (user); /* Add to the head of the list, so most recently used is first. */ @@ -140,7 +142,7 @@ getgroup (gid_t gid) return tail->name; grent = getgrgid (gid); - tail = (struct userid *) xmalloc (sizeof (struct userid)); + tail = xmalloc (sizeof *tail); tail->id.g = gid; tail->name = grent ? xstrdup (grent->gr_name) : NULL; @@ -172,8 +174,17 @@ getgidbyname (const char *group) return 0; grent = getgrnam (group); +#ifdef __DJGPP__ + /* We need to pretend to belong to group GROUP, to make + grp functions know about any arbitrary group name. */ + if (!grent && strspn (group, digits) < strlen (group)) + { + setenv ("GROUP", group, 1); + grent = getgrnam (group); /* now it will succeed */ + } +#endif - tail = (struct userid *) xmalloc (sizeof (struct userid)); + tail = xmalloc (sizeof *tail); tail->name = xstrdup (group); /* Add to the head of the list, so most recently used is first. */