diff options
author | Jim Meyering <jim@meyering.net> | 1997-11-30 10:24:38 +0000 |
---|---|---|
committer | Jim Meyering <jim@meyering.net> | 1997-11-30 10:24:38 +0000 |
commit | 07783bcdf0fd2f0dc5b4e2707db58e0a62b7e1b6 (patch) | |
tree | 40d492d8ec2ef68d3918c9c1b199ebf6d326dc0a /lib | |
parent | 240cb49efec335cd60eb65e35742ca292400fdc3 (diff) | |
download | coreutils-07783bcdf0fd2f0dc5b4e2707db58e0a62b7e1b6.tar.xz |
(getuidbyname, getgidbyname): Names can now
be NULL in cache. This change merely fixes ifdeffed-out code.
Diffstat (limited to 'lib')
-rw-r--r-- | lib/idcache.c | 17 |
1 files changed, 10 insertions, 7 deletions
diff --git a/lib/idcache.c b/lib/idcache.c index e8809c838..0cfd90348 100644 --- a/lib/idcache.c +++ b/lib/idcache.c @@ -55,10 +55,13 @@ struct userid struct userid *next; }; +/* The members of this list have already been looked up. + If a name is NULL, the corresponding id is not in the password file. */ static struct userid *user_alist; #ifdef NOT_USED -/* The members of this list have names not in the local passwd file. */ +/* The members of this list are names not in the local passwd file; + their names are always not NULL, and their ids are irrelevant. */ static struct userid *nouser_alist; #endif /* NOT_USED */ @@ -82,7 +85,7 @@ getuser (uid) tail->id.u = uid; tail->name = (pwent ? xstrdup (pwent->pw_name) : NULL); - /* Add to the head of the list, so most recently used is first. */ + /* Add to the head of the list, so most recently added is first. */ tail->next = user_alist; user_alist = tail; return tail->name; @@ -104,7 +107,7 @@ getuidbyname (user) for (tail = user_alist; tail; tail = tail->next) /* Avoid a function call for the most common case. */ - if (*tail->name == *user && !strcmp (tail->name, user)) + if (tail->name && *tail->name == *user && !strcmp (tail->name, user)) return &tail->id.u; for (tail = nouser_alist; tail; tail = tail->next) @@ -117,7 +120,7 @@ getuidbyname (user) tail = (struct userid *) xmalloc (sizeof (struct userid)); tail->name = xstrdup (user); - /* Add to the head of the list, so most recently used is first. */ + /* Add to the head of the list, so most recently added is first. */ if (pwent) { tail->id.u = pwent->pw_uid; @@ -139,8 +142,8 @@ static struct userid *group_alist; static struct userid *nogroup_alist; #endif -/* Translate GID to a group name or a stringified number, - with cache. */ +/* Translate GID to a group name, with cache. + Return NULL if the group has no name. */ char * getgroup (gid) @@ -180,7 +183,7 @@ getgidbyname (group) for (tail = group_alist; tail; tail = tail->next) /* Avoid a function call for the most common case. */ - if (*tail->name == *group && !strcmp (tail->name, group)) + if (tail->name && *tail->name == *group && !strcmp (tail->name, group)) return &tail->id.g; for (tail = nogroup_alist; tail; tail = tail->next) |