From: Jim Meyering Date: Tue, 10 Mar 1998 22:55:20 +0000 (+0000) Subject: (getuidbyname) [__DJGPP__]: Make function know about X-Git-Url: https://pintos-os.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=a19e601b42a86b59b4af13aa9f960397f5306c38;p=pspp (getuidbyname) [__DJGPP__]: Make function know about any arbitrary user name. (getgidbyname) [__DJGPP__]: Make function know about any arbitrary group name. From Eli. --- diff --git a/lib/idcache.c b/lib/idcache.c index c00ee869de..b8104f1790 100644 --- a/lib/idcache.c +++ b/lib/idcache.c @@ -44,6 +44,10 @@ struct group *getgrnam (); char *xmalloc (); char *xstrdup (); +#ifdef __DJGPP__ +static char digits[] = "0123456789"; +#endif + struct userid { union @@ -105,6 +109,15 @@ 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->name = xstrdup (user); @@ -172,6 +185,15 @@ 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->name = xstrdup (group);