summaryrefslogtreecommitdiff
path: root/grp/initgroups.c
diff options
context:
space:
mode:
authorUlrich Drepper <drepper@redhat.com>1998-07-07 16:30:46 +0000
committerUlrich Drepper <drepper@redhat.com>1998-07-07 16:30:46 +0000
commit6333c255baf8ad9547c282b47fe5c35a40bca77d (patch)
treebbc8e29100fe7311de954f6b4f11c4e010f55b60 /grp/initgroups.c
parent0302fece014004a2df366dacc2b8e9416264a978 (diff)
downloadglibc-6333c255baf8ad9547c282b47fe5c35a40bca77d.tar.gz
Update.
1998-07-07 16:28 Ulrich Drepper <drepper@cygnus.com> * grp/initgroups.c: Handle directives from nsswitch.conf file.
Diffstat (limited to 'grp/initgroups.c')
-rw-r--r--grp/initgroups.c16
1 files changed, 14 insertions, 2 deletions
diff --git a/grp/initgroups.c b/grp/initgroups.c
index 454882e0af..d74d08ddd0 100644
--- a/grp/initgroups.c
+++ b/grp/initgroups.c
@@ -182,12 +182,24 @@ initgroups (user, group)
fct = __nss_lookup_function (nip, "initgroups");
if (fct == NULL)
- status = compat_call (nip, user, group, &start, &size, groups,
- limit, &errno);
+ {
+ status = compat_call (nip, user, group, &start, &size, groups,
+ limit, &errno);
+
+ if (nss_next_action (nip, NSS_STATUS_UNAVAIL) != NSS_ACTION_CONTINUE)
+ break;
+ }
else
status = _CALL_DL_FCT (fct, (user, group, &start, &size, groups, limit,
&errno));
+ /* This is really only for debugging. */
+ if (NSS_STATUS_TRYAGAIN > status || status > NSS_STATUS_RETURN)
+ __libc_fatal ("illegal status in " __FUNCTION__);
+
+ if (nss_next_action (nip, status) == NSS_ACTION_RETURN)
+ break;
+
if (nip->next == NULL)
no_more = -1;
else