1*7c478bd9Sstevel@tonic-gate /*
2*7c478bd9Sstevel@tonic-gate  * CDDL HEADER START
3*7c478bd9Sstevel@tonic-gate  *
4*7c478bd9Sstevel@tonic-gate  * The contents of this file are subject to the terms of the
5*7c478bd9Sstevel@tonic-gate  * Common Development and Distribution License, Version 1.0 only
6*7c478bd9Sstevel@tonic-gate  * (the "License").  You may not use this file except in compliance
7*7c478bd9Sstevel@tonic-gate  * with the License.
8*7c478bd9Sstevel@tonic-gate  *
9*7c478bd9Sstevel@tonic-gate  * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
10*7c478bd9Sstevel@tonic-gate  * or http://www.opensolaris.org/os/licensing.
11*7c478bd9Sstevel@tonic-gate  * See the License for the specific language governing permissions
12*7c478bd9Sstevel@tonic-gate  * and limitations under the License.
13*7c478bd9Sstevel@tonic-gate  *
14*7c478bd9Sstevel@tonic-gate  * When distributing Covered Code, include this CDDL HEADER in each
15*7c478bd9Sstevel@tonic-gate  * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
16*7c478bd9Sstevel@tonic-gate  * If applicable, add the following below this CDDL HEADER, with the
17*7c478bd9Sstevel@tonic-gate  * fields enclosed by brackets "[]" replaced with your own identifying
18*7c478bd9Sstevel@tonic-gate  * information: Portions Copyright [yyyy] [name of copyright owner]
19*7c478bd9Sstevel@tonic-gate  *
20*7c478bd9Sstevel@tonic-gate  * CDDL HEADER END
21*7c478bd9Sstevel@tonic-gate  */
22*7c478bd9Sstevel@tonic-gate /*
23*7c478bd9Sstevel@tonic-gate  * Copyright 1997 Sun Microsystems, Inc.  All rights reserved.
24*7c478bd9Sstevel@tonic-gate  * Use is subject to license terms.
25*7c478bd9Sstevel@tonic-gate  */
26*7c478bd9Sstevel@tonic-gate 
27*7c478bd9Sstevel@tonic-gate /*	Copyright (c) 1988 AT&T	*/
28*7c478bd9Sstevel@tonic-gate /*	  All Rights Reserved	*/
29*7c478bd9Sstevel@tonic-gate 
30*7c478bd9Sstevel@tonic-gate /*
31*7c478bd9Sstevel@tonic-gate  * University Copyright- Copyright (c) 1982, 1986, 1988
32*7c478bd9Sstevel@tonic-gate  * The Regents of the University of California
33*7c478bd9Sstevel@tonic-gate  * All Rights Reserved
34*7c478bd9Sstevel@tonic-gate  *
35*7c478bd9Sstevel@tonic-gate  * University Acknowledgment- Portions of this document are derived from
36*7c478bd9Sstevel@tonic-gate  * software developed by the University of California, Berkeley, and its
37*7c478bd9Sstevel@tonic-gate  * contributors.
38*7c478bd9Sstevel@tonic-gate  */
39*7c478bd9Sstevel@tonic-gate 
40*7c478bd9Sstevel@tonic-gate /*LINTLIBRARY*/
41*7c478bd9Sstevel@tonic-gate 
42*7c478bd9Sstevel@tonic-gate #include	<unistd.h>
43*7c478bd9Sstevel@tonic-gate #include	<sys/types.h>
44*7c478bd9Sstevel@tonic-gate #include	"curses_inc.h"
45*7c478bd9Sstevel@tonic-gate 
46*7c478bd9Sstevel@tonic-gate /*
47*7c478bd9Sstevel@tonic-gate  * Code for various kinds of delays.  Most of this is nonportable and
48*7c478bd9Sstevel@tonic-gate  * requires various enhancements to the operating system, so it won't
49*7c478bd9Sstevel@tonic-gate  * work on all systems.  It is included in curses to provide a portable
50*7c478bd9Sstevel@tonic-gate  * interface, and so curses itself can use it for function keys.
51*7c478bd9Sstevel@tonic-gate  */
52*7c478bd9Sstevel@tonic-gate 
53*7c478bd9Sstevel@tonic-gate #define	NAPINTERVAL	100
54*7c478bd9Sstevel@tonic-gate /*
55*7c478bd9Sstevel@tonic-gate  * Wait until the output has drained enough that it will only take
56*7c478bd9Sstevel@tonic-gate  * ms more milliseconds to drain completely.
57*7c478bd9Sstevel@tonic-gate  * Needs Berkeley TIOCOUTQ ioctl.  Returns ERR if impossible.
58*7c478bd9Sstevel@tonic-gate  */
59*7c478bd9Sstevel@tonic-gate 
60*7c478bd9Sstevel@tonic-gate int
draino(int ms)61*7c478bd9Sstevel@tonic-gate draino(int ms)
62*7c478bd9Sstevel@tonic-gate {
63*7c478bd9Sstevel@tonic-gate #ifdef	TIOCOUTQ
64*7c478bd9Sstevel@tonic-gate #define	_DRAINO
65*7c478bd9Sstevel@tonic-gate 	/* number of chars = that many ms */
66*7c478bd9Sstevel@tonic-gate 	long	ncneeded;
67*7c478bd9Sstevel@tonic-gate 
68*7c478bd9Sstevel@tonic-gate 	/* 10 bits/char, 1000 ms/sec, baudrate in bits/sec */
69*7c478bd9Sstevel@tonic-gate 	ncneeded = SP->baud * ms / (10 * 1000);
70*7c478bd9Sstevel@tonic-gate 	/*CONSTCOND*/
71*7c478bd9Sstevel@tonic-gate 	while (TRUE) {
72*7c478bd9Sstevel@tonic-gate 		int	rv;		/* ioctl return value */
73*7c478bd9Sstevel@tonic-gate 		int	ncthere = 0;	/* number of chars actually in */
74*7c478bd9Sstevel@tonic-gate 					/* output queue */
75*7c478bd9Sstevel@tonic-gate 
76*7c478bd9Sstevel@tonic-gate 		rv = ioctl(cur_term->Filedes, TIOCOUTQ, &ncthere);
77*7c478bd9Sstevel@tonic-gate #ifdef	DEBUG
78*7c478bd9Sstevel@tonic-gate 		if (outf)
79*7c478bd9Sstevel@tonic-gate 			fprintf(outf, "draino: rv %d, ncneeded %d, "
80*7c478bd9Sstevel@tonic-gate 			    "ncthere %d\n", rv, ncneeded, ncthere);
81*7c478bd9Sstevel@tonic-gate #endif	/* DEBUG */
82*7c478bd9Sstevel@tonic-gate 		if (rv < 0)
83*7c478bd9Sstevel@tonic-gate 			return (ERR);	/* ioctl didn't work */
84*7c478bd9Sstevel@tonic-gate 		if (ncthere <= ncneeded)
85*7c478bd9Sstevel@tonic-gate 			return (OK);
86*7c478bd9Sstevel@tonic-gate 		(void) napms(NAPINTERVAL);
87*7c478bd9Sstevel@tonic-gate 	}
88*7c478bd9Sstevel@tonic-gate #else	/* TIOCOUTQ */
89*7c478bd9Sstevel@tonic-gate 
90*7c478bd9Sstevel@tonic-gate #ifdef	TCSETAW
91*7c478bd9Sstevel@tonic-gate #define	_DRAINO
92*7c478bd9Sstevel@tonic-gate 	/*
93*7c478bd9Sstevel@tonic-gate 	 * SYSV simulation - waits until the entire queue is empty,
94*7c478bd9Sstevel@tonic-gate 	 * then sets the state to what it already is (e.g. no-op).
95*7c478bd9Sstevel@tonic-gate 	 * Unfortunately this only works if ms is zero.
96*7c478bd9Sstevel@tonic-gate 	 */
97*7c478bd9Sstevel@tonic-gate 	if (ms <= 0) {
98*7c478bd9Sstevel@tonic-gate #ifdef SYSV
99*7c478bd9Sstevel@tonic-gate 		if (prog_istermios < 0) {
100*7c478bd9Sstevel@tonic-gate 			int i;
101*7c478bd9Sstevel@tonic-gate 
102*7c478bd9Sstevel@tonic-gate 			PROGTTY.c_lflag = PROGTTYS.c_lflag;
103*7c478bd9Sstevel@tonic-gate 			PROGTTY.c_oflag = PROGTTYS.c_oflag;
104*7c478bd9Sstevel@tonic-gate 			PROGTTY.c_iflag = PROGTTYS.c_iflag;
105*7c478bd9Sstevel@tonic-gate 			PROGTTY.c_cflag = PROGTTYS.c_cflag;
106*7c478bd9Sstevel@tonic-gate 			for (i = 0; i < NCC; i++)
107*7c478bd9Sstevel@tonic-gate 				PROGTTY.c_cc[i] = PROGTTYS.c_cc[i];
108*7c478bd9Sstevel@tonic-gate 			(void) ioctl(cur_term->Filedes, TCSETAW, &PROGTTY);
109*7c478bd9Sstevel@tonic-gate 		} else
110*7c478bd9Sstevel@tonic-gate 			(void) ioctl(cur_term->Filedes, TCSETSW, &PROGTTYS);
111*7c478bd9Sstevel@tonic-gate #else	/* SYSV */
112*7c478bd9Sstevel@tonic-gate 			(void) ioctl(cur_term->Filedes, TCSETAW, &PROGTTY);
113*7c478bd9Sstevel@tonic-gate #endif	/* SYSV */
114*7c478bd9Sstevel@tonic-gate 		return (OK);
115*7c478bd9Sstevel@tonic-gate 	} else
116*7c478bd9Sstevel@tonic-gate 		return (ERR);
117*7c478bd9Sstevel@tonic-gate #endif	/* TCSETAW */
118*7c478bd9Sstevel@tonic-gate #endif	/* TIOCOUTQ */
119*7c478bd9Sstevel@tonic-gate 
120*7c478bd9Sstevel@tonic-gate #ifndef	_DRAINO
121*7c478bd9Sstevel@tonic-gate 	/*
122*7c478bd9Sstevel@tonic-gate 	 * No way to fake it, so we return failure.
123*7c478bd9Sstevel@tonic-gate 	 * Used #else to avoid warning from compiler about unreached stmt
124*7c478bd9Sstevel@tonic-gate 	 */
125*7c478bd9Sstevel@tonic-gate 	return (ERR);
126*7c478bd9Sstevel@tonic-gate #endif	/* _DRAINO */
127*7c478bd9Sstevel@tonic-gate /*NOTREACHED*/
128*7c478bd9Sstevel@tonic-gate }
129