/* * Copyright (c) 1983 Regents of the University of California. * All rights reserved. * * This code is derived from software contributed to Berkeley by * Edward Wang at The University of California, Berkeley. * * %sccs.include.redist.c% */ #ifndef lint static char sccsid[] = "@(#)ttoutput.c 3.10 (Berkeley) 11/10/92"; #endif /* not lint */ #include "ww.h" #include "tt.h" #include /* * Buffered output package. * We need this because stdio fails on non-blocking writes. */ ttflush() { register char *p; register n = tt_obp - tt_ob; extern errno; if (n == 0) return; if (tt.tt_checksum) (*tt.tt_checksum)(tt_ob, n); if (tt.tt_flush) { (*tt.tt_flush)(); return; } wwnflush++; for (p = tt_ob; p < tt_obp;) { wwnwr++; n = write(1, p, tt_obp - p); if (n < 0) { wwnwre++; if (errno != EWOULDBLOCK) { /* can't deal with this */ p = tt_obp; } } else if (n == 0) { /* what to do? */ wwnwrz++; } else { wwnwrc += n; p += n; } } tt_obp = tt_ob; } ttputs(s) register char *s; { while (*s) ttputc(*s++); } ttwrite(s, n) register char *s; register n; { switch (n) { case 0: break; case 1: ttputc(*s); break; case 2: if (tt_obe - tt_obp < 2) ttflush(); *tt_obp++ = *s++; *tt_obp++ = *s; break; case 3: if (tt_obe - tt_obp < 3) ttflush(); *tt_obp++ = *s++; *tt_obp++ = *s++; *tt_obp++ = *s; break; case 4: if (tt_obe - tt_obp < 4) ttflush(); *tt_obp++ = *s++; *tt_obp++ = *s++; *tt_obp++ = *s++; *tt_obp++ = *s; break; case 5: if (tt_obe - tt_obp < 5) ttflush(); *tt_obp++ = *s++; *tt_obp++ = *s++; *tt_obp++ = *s++; *tt_obp++ = *s++; *tt_obp++ = *s; break; default: while (n > 0) { register m; while ((m = tt_obe - tt_obp) == 0) ttflush(); if ((m = tt_obe - tt_obp) > n) m = n; bcopy(s, tt_obp, m); tt_obp += m; s += m; n -= m; } } }