aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--ChangeLog4
-rw-r--r--grp/initgroups.c16
2 files changed, 18 insertions, 2 deletions
diff --git a/ChangeLog b/ChangeLog
index 4d02e81937..4ab9d7bd48 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,7 @@
+1998-07-07 16:28 Ulrich Drepper <drepper@cygnus.com>
+
+ * grp/initgroups.c: Handle directives from nsswitch.conf file.
+
1998-07-07 Ulrich Drepper <drepper@cygnus.com>
* sysdeps/unix/sysv/linux/sparc/sparc64/bits/types.h: Add
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