From 209ca98331dda5d6dc429fc32c57c01b54fb11d9 Mon Sep 17 00:00:00 2001 From: ache Date: Thu, 6 Oct 1994 21:02:21 +0000 Subject: Oops, back out ospeed fix, I forget that flushing can occurse _after_ usleep, too quick commit :-( --- lib/libtermcap/tputs.c | 32 +++++++++++++++++++++++++++----- 1 file changed, 27 insertions(+), 5 deletions(-) (limited to 'lib/libtermcap') diff --git a/lib/libtermcap/tputs.c b/lib/libtermcap/tputs.c index 3d6027f..857147d 100644 --- a/lib/libtermcap/tputs.c +++ b/lib/libtermcap/tputs.c @@ -37,10 +37,19 @@ static char sccsid[] = "@(#)tputs.c 8.1 (Berkeley) 6/4/93"; #include #include -#include -short ospeed; /* not needed, only for compatibility */ -char PC; /* not needed, only for compatibility */ +/* + * The following array gives the number of tens of milliseconds per + * character for each speed as returned by gtty. Thus since 300 + * baud returns a 7, there are 33.3 milliseconds per char at 300 baud. + */ +static +short tmspc10[] = { + 0, 2000, 1333, 909, 743, 666, 500, 333, 166, 83, 55, 41, 20, 10, 5 +}; + +short ospeed; +char PC; /* * Put the character string cp out, with padding. @@ -92,10 +101,23 @@ tputs(cp, affcnt, outc) (*outc)(*cp++); /* - * If no delay needed, then don't try to delay. + * If no delay needed, or output speed is + * not comprehensible, then don't try to delay. */ if (i == 0) return; + if (ospeed <= 0 || ospeed >= (sizeof tmspc10 / sizeof tmspc10[0])) + return; - usleep((u_int) i * 100); /* already * 10 */ + /* + * Round up by a half a character frame, + * and then do the delay. + * Too bad there are no user program accessible programmed delays. + * Transmitting pad characters slows many + * terminals down and also loads the system. + */ + mspc10 = tmspc10[ospeed]; + i += mspc10 / 2; + for (i /= mspc10; i > 0; i--) + (*outc)(PC); } -- cgit v1.1