4 * The contents of this file are subject to the terms of the
5 * Common Development and Distribution License, Version 1.0 only
6 * (the "License"). You may not use this file except in compliance
9 * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
10 * or http://www.opensolaris.org/os/licensing.
11 * See the License for the specific language governing permissions
12 * and limitations under the License.
14 * When distributing Covered Code, include this CDDL HEADER in each
15 * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
16 * If applicable, add the following below this CDDL HEADER, with the
17 * fields enclosed by brackets "[]" replaced with your own identifying
18 * information: Portions Copyright [yyyy] [name of copyright owner]
23 * Copyright 2005 Sun Microsystems, Inc. All rights reserved.
24 * Use is subject to license terms.
27 /* Copyright (c) 1984, 1986, 1987, 1988, 1989 AT&T */
28 /* All Rights Reserved */
31 * University Copyright- Copyright (c) 1982, 1986, 1988
32 * The Regents of the University of California
35 * University Acknowledgment- Portions of this document are derived from
36 * software developed by the University of California, Berkeley, and its
40 #pragma ident "%Z%%M% %I% %E% SMI"
43 * groups - show group memberships
45 /* LINTLIBRARY PROTOLIB1 */
53 extern struct group
*getgrgid();
54 extern struct passwd
*getpwnam();
55 extern int _getgroupsbymember(const char *, gid_t
[], int, int);
57 static void showgroups();
59 static int ngroups_max
;
62 main(int argc
, char *argv
[])
67 ngroups_max
= sysconf(_SC_NGROUPS_MAX
);
69 if (ngroups_max
< 0) {
70 (void) fprintf(stderr
,
71 "groups: could not get configuration info\n");
80 if ((pw
= getpwuid(getuid())) == NULL
) {
81 (void) fprintf(stderr
, "groups: No passwd entry\n");
86 } else while (*++argv
) {
88 if ((pw
= getpwnam(*argv
)) == NULL
) {
89 (void) fprintf(stderr
,
90 "groups: %s : No such user\n", *argv
);
94 (void) printf("%s : ", *argv
);
104 showgroups(struct passwd
*pw
)
107 static gid_t
*groups
= NULL
;
111 if (groups
== NULL
) {
112 if ((groups
= (gid_t
*)calloc((uint_t
)ngroups_max
,
113 sizeof (gid_t
))) == 0) {
114 (void) fprintf(stderr
,
115 "allocation of %d bytes failed\n",
116 ngroups_max
* sizeof (gid_t
));
120 groups
[0] = pw
->pw_gid
;
122 ngroups
= _getgroupsbymember(pw
->pw_name
, groups
, ngroups_max
, 1);
124 if (gr
= getgrgid(groups
[0]))
125 (void) printf("%s", gr
->gr_name
);
127 (void) printf("%d", (int)pw
->pw_gid
);
129 for (i
= 1; i
< ngroups
; i
++) {
130 if ((gr
= getgrgid(groups
[i
])))
131 (void) printf(" %s", gr
->gr_name
);
133 (void) printf(" %d", (int)groups
[i
]);