4 * The contents of this file are subject to the terms of the
5 * Common Development and Distribution License (the "License").
6 * You may not use this file except in compliance with the License.
8 * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
9 * or http://www.opensolaris.org/os/licensing.
10 * See the License for the specific language governing permissions
11 * and limitations under the License.
13 * When distributing Covered Code, include this CDDL HEADER in each
14 * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
15 * If applicable, add the following below this CDDL HEADER, with the
16 * fields enclosed by brackets "[]" replaced with your own identifying
17 * information: Portions Copyright [yyyy] [name of copyright owner]
23 * Copyright 2006 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 #pragma ident "%Z%%M% %I% %E% SMI"
32 /* EMACS_MODES: !fill, lnumb, !overwrite, !nodelete, !picture */
37 #include "sys/types.h"
44 ** getclass() - READ CLASS FROM TO DISK
50 static long lastdir
= -1;
59 syslog(LOG_DEBUG
, "getclass(%s)", name
? name
: "");
61 if (!name
|| !*name
) {
67 * Getting ``all''? If so, jump into the directory
68 * wherever we left off.
70 if (STREQU(NAME_ALL
, name
)) {
71 if (!(name
= next_file(Lp_A_Classes
, &lastdir
)))
80 if (!(file
= getclassfile(name
)))
83 if ((fd
= open_locked(file
, "r", 0)) < 0) {
89 clsp
= (CLASS
*)calloc(sizeof (*clsp
), 1);
91 if (!(clsp
->name
= Strdup(name
))) {
100 while (fdgets(buf
, BUFSIZ
, fd
)) {
101 buf
[strlen(buf
) - 1] = 0;
102 addlist (&clsp
->members
, buf
);
105 int save_errno
= errno
;
107 freelist (clsp
->members
);
116 if (!clsp
->members
) {