From 6333c255baf8ad9547c282b47fe5c35a40bca77d Mon Sep 17 00:00:00 2001 From: Ulrich Drepper Date: Tue, 7 Jul 1998 16:30:46 +0000 Subject: Update. 1998-07-07 16:28 Ulrich Drepper * grp/initgroups.c: Handle directives from nsswitch.conf file. --- ChangeLog | 4 ++++ grp/initgroups.c | 16 ++++++++++++++-- 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 + + * grp/initgroups.c: Handle directives from nsswitch.conf file. + 1998-07-07 Ulrich Drepper * 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 -- cgit 1.4.1