xref: /titanic_51/usr/src/lib/libbc/libc/stdio/sys5/fprintf.c (revision 7c8de9202c10c8c49a901bff2e373864b545bd57)
1  /*
2   * CDDL HEADER START
3   *
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
7   * with the License.
8   *
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.
13   *
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]
19   *
20   * CDDL HEADER END
21   */
22  /*
23   * Copyright 2005 Sun Microsystems, Inc.  All rights reserved.
24   * Use is subject to license terms.
25   */
26  
27  /*      Copyright (c) 1984 AT&T */
28  /*        All Rights Reserved   */
29  
30  #pragma ident	"%Z%%M%	%I%	%E% SMI"
31  
32  /*LINTLIBRARY*/
33  #include <stdio.h>
34  #include <stdarg.h>
35  
36  extern int _doprnt();
37  
38  int
39  fprintf(FILE *iop, char *format, ...)
40  {
41  	unsigned char localbuf[BUFSIZ];
42  	int count;
43  	va_list ap;
44  
45  	if (!(iop->_flag & _IOWRT)) {
46  		/* if no write flag */
47  		if (iop->_flag & _IORW) {
48  			/* if ok, cause read-write */
49  			iop->_flag |= _IOWRT;
50  		} else {
51  			/* else error */
52  			return (EOF);
53  		}
54  	}
55  	va_start(ap, format);
56  	if (iop->_flag & _IONBF) {
57  		iop->_flag &= ~_IONBF;
58  		iop->_ptr = iop->_base = localbuf;
59  		iop->_bufsiz = BUFSIZ;
60  		count = _doprnt(format, ap, iop);
61  		fflush(iop);
62  		iop->_flag |= _IONBF;
63  		iop->_base = NULL;
64  		iop->_bufsiz = 0;
65  		iop->_cnt = 0;
66  	} else
67  		count = _doprnt(format, ap, iop);
68  	va_end(ap);
69  	return (ferror(iop)? EOF: count);
70  }
71