mirror of
https://sourceware.org/git/glibc.git
synced 2024-11-28 04:03:35 +08:00
0a55a28475
2000-04-27 Ulrich Drepper <drepper@redhat.com> * hesiod/nss_hesiod/hesiod-grp.c (_nss_hesiod_initgroups): Handle overflows in conversion from ASCII. 2000-04-26 Jakub Jelinek <jakub@redhat.com> * Makeconfig (full_config_sysdirs): Renamed from full-config-sysdirs. * Makerules (full_config_sysdirs): Likewise. * MakeTAGS (full_config_sysdirs): Likewise. 2000-04-26 Jakub Jelinek <jakub@redhat.com> * .cvsignore: Remove linuxthreads. * po/.cvsignore: Remove *.pot. * posix/glob/.cvsignore: Removed. * sysdeps/unix/bsd/osf/.cvsignore: Removed. 2000-04-25 Andreas Jaeger <aj@suse.de> * conform/Makefile (distribute): Also distribute contents of subdirectories. * Makerules (no_deps): Remove abi-versions.h. * nis/nis_print_group_entry.c: Include alloca.h for alloca prototype. 2000-04-25 Jakub Jelinek <jakub@redhat.com> * sysdeps/sparc/sparc64/elf/Dist: Remove. * sysdeps/sparc/sparc64/elf/crtbegin.S: Remove. * sysdeps/sparc/sparc64/elf/crtbeginS.S: Remove. * sysdeps/sparc/sparc64/elf/crtend.S: Remove. * sysdeps/sparc/sparc64/elf/crtendS.S: Remove. * sysdeps/sparc/sparc64/elf/Makefile: Don't build crtbegin/crtend objects. 2000-04-25 Thorsten Kukuk <kukuk@suse.de> * nscd/grpcache.c: Fix gr_name pointer [PR/1702]. 2000-04-23 Bruno Haible <clisp.cons.org> * intl/dcigettext.c: Define _GNU_SOURCE as early as possible. * intl/l10nflist.c: Likewise. 2000-04-23 Bruno Haible <clisp.cons.org> * intl/bindtextdom.c [!_LIBC]: Define __libc_rwlock_define, __libc_rwlock_wrlock, __libc_rwlock_unlock as empty. * intl/textdomain.c [!_LIBC]: Likewise. * intl/dcigettext.c [!_LIBC]: Define __libc_rwlock_define_initialized, __libc_rwlock_rdlock, __libc_rwlock_unlock as empty. * intl/loadmsgcat.c (_nl_load_domain) [!_LIBC, !HAVE_ICONV]: Avoid syntax error. 2000-04-23 Bruno Haible <clisp.cons.org> * intl/dcigettext.c (_nl_find_msg): Do the plural treatment and character set conversion also in the case the translation was found after a hash collision or through binary search. Store the maximum index together with the converted message. Use iconv() when available. In case of out of memory during conversion, return the unconverted translated string, not NULL.
173 lines
4.8 KiB
C
173 lines
4.8 KiB
C
/* Copyright (c) 1997, 1998, 2000 Free Software Foundation, Inc.
|
|
This file is part of the GNU C Library.
|
|
Contributed by Thorsten Kukuk <kukuk@vt.uni-paderborn.de>, 1997.
|
|
|
|
The GNU C Library is free software; you can redistribute it and/or
|
|
modify it under the terms of the GNU Library General Public License as
|
|
published by the Free Software Foundation; either version 2 of the
|
|
License, or (at your option) any later version.
|
|
|
|
The GNU C Library is distributed in the hope that it will be useful,
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
Library General Public License for more details.
|
|
|
|
You should have received a copy of the GNU Library General Public
|
|
License along with the GNU C Library; see the file COPYING.LIB. If not,
|
|
write to the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
|
|
Boston, MA 02111-1307, USA. */
|
|
|
|
#include <alloca.h>
|
|
#include <string.h>
|
|
#include <libintl.h>
|
|
#include <rpcsvc/nis.h>
|
|
|
|
void
|
|
nis_print_group_entry (const_nis_name group)
|
|
{
|
|
if (group != NULL && group[0] != '\0')
|
|
{
|
|
size_t grouplen = strlen (group);
|
|
char buf[grouplen + 50];
|
|
char leafbuf[grouplen + 3];
|
|
char domainbuf[grouplen + 3];
|
|
unsigned long mem_exp_cnt = 0, mem_imp_cnt = 0, mem_rec_cnt = 0;
|
|
unsigned long nomem_exp_cnt = 0, nomem_imp_cnt = 0, nomem_rec_cnt = 0;
|
|
char **mem_exp, **mem_imp, **mem_rec;
|
|
char **nomem_exp, **nomem_imp, **nomem_rec;
|
|
nis_result *res;
|
|
char *cp, *cp2;
|
|
u_int i;
|
|
|
|
cp = stpcpy (buf, nis_leaf_of_r (group, leafbuf, sizeof (leafbuf) - 1));
|
|
cp = stpcpy (cp, ".groups_dir");
|
|
cp2 = nis_domain_of_r (group, domainbuf, sizeof (domainbuf) - 1);
|
|
if (cp2 != NULL && cp2[0] != '\0')
|
|
{
|
|
*cp++ = '.';
|
|
stpcpy (cp, cp2);
|
|
}
|
|
res = nis_lookup (buf, FOLLOW_LINKS | EXPAND_NAME);
|
|
|
|
if (NIS_RES_STATUS(res) != NIS_SUCCESS)
|
|
return;
|
|
|
|
if ((NIS_RES_NUMOBJ (res) != 1) ||
|
|
(__type_of (NIS_RES_OBJECT (res)) != NIS_GROUP_OBJ))
|
|
return;
|
|
|
|
mem_exp = alloca (sizeof (char *) * NIS_RES_NUMOBJ (res));
|
|
mem_imp = alloca (sizeof (char *) * NIS_RES_NUMOBJ (res));
|
|
mem_rec = alloca (sizeof (char *) * NIS_RES_NUMOBJ (res));
|
|
nomem_exp = alloca (sizeof (char *) * NIS_RES_NUMOBJ (res));
|
|
nomem_imp = alloca (sizeof (char *) * NIS_RES_NUMOBJ (res));
|
|
nomem_rec = alloca (sizeof (char *) * NIS_RES_NUMOBJ (res));
|
|
|
|
for (i = 0;
|
|
i < NIS_RES_OBJECT (res)->GR_data.gr_members.gr_members_len; ++i)
|
|
{
|
|
char *grmem =
|
|
NIS_RES_OBJECT (res)->GR_data.gr_members.gr_members_val[i];
|
|
int neg = grmem[0] == '-';
|
|
|
|
switch (grmem[neg])
|
|
{
|
|
case '*':
|
|
if (neg)
|
|
{
|
|
nomem_imp[nomem_imp_cnt] = grmem;
|
|
++nomem_imp_cnt;
|
|
}
|
|
else
|
|
{
|
|
mem_imp[mem_imp_cnt] = grmem;
|
|
++mem_imp_cnt;
|
|
}
|
|
break;
|
|
case '@':
|
|
if (neg)
|
|
{
|
|
nomem_rec[nomem_rec_cnt] = grmem;
|
|
++nomem_rec_cnt;
|
|
}
|
|
else
|
|
{
|
|
mem_rec[mem_rec_cnt] = grmem;
|
|
++mem_rec_cnt;
|
|
}
|
|
break;
|
|
default:
|
|
if (neg)
|
|
{
|
|
nomem_exp[nomem_exp_cnt] = grmem;
|
|
++nomem_exp_cnt;
|
|
}
|
|
else
|
|
{
|
|
mem_exp[mem_exp_cnt] = grmem;
|
|
++mem_exp_cnt;
|
|
}
|
|
break;
|
|
}
|
|
}
|
|
{
|
|
char buf[strlen (NIS_RES_OBJECT (res)->zo_domain) + 10];
|
|
printf (_("Group entry for \"%s.%s\" group:\n"),
|
|
NIS_RES_OBJECT (res)->zo_name,
|
|
nis_domain_of_r (NIS_RES_OBJECT (res)->zo_domain,
|
|
buf, strlen (NIS_RES_OBJECT (res)->zo_domain)
|
|
+ 10));
|
|
}
|
|
if (mem_exp_cnt)
|
|
{
|
|
fputs (_(" Explicit members:\n"), stdout);
|
|
for (i = 0; i < mem_exp_cnt; ++i)
|
|
printf ("\t%s\n", mem_exp[i]);
|
|
}
|
|
else
|
|
fputs (_(" No explicit members\n"), stdout);
|
|
if (mem_imp_cnt)
|
|
{
|
|
fputs (_(" Implicit members:\n"), stdout);
|
|
for (i = 0; i < mem_imp_cnt; ++i)
|
|
printf ("\t%s\n", &mem_imp[i][2]);
|
|
}
|
|
else
|
|
fputs (_(" No implicit members\n"), stdout);
|
|
if (mem_rec_cnt)
|
|
{
|
|
fputs (_(" Recursive members:\n"), stdout);
|
|
for (i = 0; i < mem_rec_cnt; ++i)
|
|
printf ("\t%s\n", &mem_rec[i][1]);
|
|
}
|
|
else
|
|
fputs (_(" No recursive members\n"), stdout);
|
|
if (nomem_exp_cnt)
|
|
{
|
|
fputs (_(" Explicit nonmembers:\n"), stdout);
|
|
for (i = 0; i < nomem_exp_cnt; ++i)
|
|
printf ("\t%s\n", &nomem_exp[i][1]);
|
|
}
|
|
else
|
|
fputs (_(" No explicit nonmembers\n"), stdout);
|
|
if (nomem_imp_cnt)
|
|
{
|
|
fputs (_(" Implicit nonmembers:\n"), stdout);
|
|
for (i = 0; i < nomem_imp_cnt; ++i)
|
|
printf ("\t%s\n", &mem_imp[i][3]);
|
|
}
|
|
else
|
|
fputs (_(" No implicit nonmembers\n"), stdout);
|
|
if (nomem_rec_cnt)
|
|
{
|
|
fputs (_(" Explicit nonmembers:\n"), stdout);
|
|
for (i = 0; i < nomem_rec_cnt; ++i)
|
|
printf ("\t%s=n", &nomem_rec[i][2]);
|
|
}
|
|
else
|
|
fputs (_(" No recursive nonmembers\n"), stdout);
|
|
|
|
nis_freeresult (res);
|
|
}
|
|
}
|